Skip to content

mixcr assembleContigs

Assembles longest possible TCR/Ig receptor contig sequences.

img.png img.png

This step may be used in the following cases:

  • for non-enriched RNA-Seq (shotgun) data in order to reconstruct the longest possible VDJ contigs
  • for single cell fragmented libraries (like 10x Genomics) to assemble full V-D-J consensus sequences in each cell
  • for poor quality targeted amplicon data with no UMI barcodes and with a high rates of sequencing and PCR errors in order to build full-length (or as long as possible) V-D-J contigs using consensus algorithms

In the first two cases the data is fragmented, reads do not have a fixed position on the reference, so it's not possible to specify a fixed assemblingFeature. MiXCR uses alignment-guided assembly algorithms to build the full-length consensus V-D-J sequence.

For single cell data MiXCR utilizes all alignments with the corresponding cell barcodes, even if they do not cover CDR3 region:

img.png img.png

In the last case of poor quality targeted libraries, though the exact assembling feature may be known in advance, high mutation rate may lead to the situation when there aren't any true (error-free) full-length V-D-J sequences in the data. Error correction algorithms used in clonotype assembly will not have any "anchor" sequence to determine the original clone. In this case we might benefit from assembling clonotypes by CDR3 region at first and then use a consensus algorithm to determine true clones and distinguish errors from hypermutations.

The algorithm iterates through alignments that were used to build a particular clonotype, and aggregates information per each position in V-D-J reference. It takes into account cell barcodes (if present) to assembly full-length contigs inside cells. It also takes care of hypermutations and splits clonotypes into hypermutated variants (see -OsubCloningRegion option).

Note that since assembleContigs uses original alignments, it takes .clna (clones & alignments) file as input, produced by assemble command with option --write-alignments.

Command line options

mixcr assembleContigs 
    [--ignore-tags] 
    [--assemble-contigs-by <gene_features>] 
    [-O <key=value>]... 
    [--report <path>] 
    [--json-report <path>] 
    [--threads <n>] 
    [--force-overwrite] 
    [--no-warnings] 
    [--verbose] 
    [--help]
    clones.clna clones.clns

The command returns a highly-compressed, memory- and CPU-efficient binary .clns file that holds exhaustive information on consensus clonotype contigs. Clonotype table may be further extracted in a human-readable form using exportClonesPretty or in a tabular form using exportClones. It is also possible to impute uncovered V-D-J contig parts from germline (marking such nucleotides lowercase). Additionally, MiXCR produces a comprehensive report.

Basic command line options are:

clones.clna
Path to input clna file
clones.clns
Path where to write assembled clones.
--ignore-tags
Ignore tags (UMIs, cell-barcodes). Default value determined by the preset.
--assemble-contigs-by <gene_features>
Selects the region of interest for the action. Clones will be separated if inconsistent nucleotides will be detected in the region, assembling procedure will be limited to the region, and only clonotypes that fully cover the region will be outputted, others will be filtered out.
-O <key=value>
Overrides for the assembler parameters.
-r, --report <path>
Report file (human readable version, see -j / --json-report for machine readable report).
-j, --json-report <path>
JSON formatted report file.
-t, --threads <n>
Processing threads
-f, --force-overwrite
Force overwrite of output file(s).
-nw, --no-warnings
Suppress all warning messages.
--verbose
Verbose messages.
-h, --help
Show this help message and exit.

Example

Here is the typical workflow for full receptor assembly of e.g. mouse B-cells.

Align raw sequences using kAligner2 specifically designed to work with highly mutated data:

> mixcr align \
    --species mmu \
    -p kAligner2 \
    --report report.txt \
    input_R1.fq \
    input_R2.fq \
    alignments.vdjca

Assemble default CDR3 clonotypes (note: --write-alignments is required for further contig assembly):

> mixcr assemble \
    -OassemblingFeatures=CDR3 \
    --write-alignments \
    --report report.txt \
    alignments.vdjca \
    clones.clna

Assembly full BCR receptor consensus sequences and clonotype into hypermutated variants:

> mixcr assembleContigs \
    --report report.txt \
    -OsubCloningRegion=VDJRegion \
    clones.clna \
    contigs.clns

Export full BCR receptors sequences and impute uncovered regions from germline (marked lowercase):

mixcr exportClones \
    --chains IG \
    --preset fullImputed \
    contigs.clns \
    contigs.tsv

Full sequence assembler parameters

Full sequence assembler parameters that may be tuned:

-OsubCloningRegion=null
Region where clonotype variants are allowed (typically that are hypermutated variants); null stands for no variants allowed (one consensus per one clone)
-(minimalContigLength=20
Minimal contiguous sequence length
-OalignedRegionsOnly=false
Assemble only parts of sequences covered by alignments
-ObranchingMinimalQualityShare=0.1
Minimal quality fraction (variant may be marked significant if variantQuality > totalSumQuality * branchingMinimalQualityShare
-ObranchingMinimalSumQuality=80
Minimal variant quality threshold (variant may be marked significant if variantQuality > branchingMinimalSumQuality
-OdecisiveBranchingSumQualityThreshold=120
Variant quality that guaranties that variant will be marked significant (even if other criteria are not satisfied)
-OoutputMinimalQualityShare=0.5
Positions having quality share less then this value, will not be represented in the output
-OoutputMinimalSumQuality=50
Positions having sum quality less then this value, will not be represented in the output
-OalignedSequenceEdgeDelta=3
Maximal number of not aligned nucleotides at the edge of sequence so that sequence is still considered aligned “to the end”
-OalignmentEdgeRegionSize=7
Number of nucleotides at the edges of alignments (with almost fully aligned seq2) that are “not trusted”
-OminimalNonEdgePointsFraction=0.25
Minimal fraction of non-edge points in variant that must be reached to consider the variant significant
-OsubCloningRegions=null
Gene feature limiting the set of positions where sufficient number of different nucleotides may split input into several clonotypes. If position is not covered by the region, and significant disagreement between nucleotides is observed, algorithm will produce "N" letter in the corresponding contig position to indicate the ambiguity. Null - means no subcloning region, and guarantees one to one input to output clonotype correspondence. Default - null
-OassemblingRegions=null
Limits the region of the sequence to assemble during the procedure, no nucleotides will be assembled outside it. Null will result in assembly of the longest possible contig sequence. Default - null
-OpostFiltering.type=NoFiltering
Used only if assemblingRegions is not null. Sets filtering criteria to apply before outputting the resulting clonotypes. NoFiltering - don't filter output clonotypes. OnlyFullyAssembled - only clonotypes completely covering assemblingRegions will be retained. OnlyFullyDefined - only clonotypes completely covering assemblingRegions and having no "N" letters will be retained. Default - NoFiltering
-OdiscardAmbiguousNucleotideCalls
Discard ambiguous calls (no use of 'N's).