Esvee is a structural variant caller optimised for short read sequencing that identifies somatic and germline somatic rearrangements.
Esvee runs is run in 4 steps
- ESVEE Prep
- Assembly & Alignment
- Reference Depth Annotation
- Variant Calling & Filtering
The full algorithm for each step is described in the algorithm section below.
Prep generates a maximally filtered SV BAM file by identifying candidate SV junctions and extracting all reads that may provide support to that junction.
java -cp esvee.jar com.hartwig.hmftools.esvee.prep.PrepApplication
-sample 'TUMOR_SAMPLE_ID,REF_SAMPLE_ID'
-bam_file '/sample_data/TUMOR_SAMPLE_ID.bam,/sample_data/REF_SAMPLE_ID.bam'
-ref_genome /path_to_ref_genome_fasta/
-ref_genome_version 38
-known_fusion_bed /ref_data/known_fusions.38.bedpe
-bamtool /tools/sambamba/sambamba
-output_dir /sample_data/output/
-threads 16
Argument | Description |
---|---|
sample | Sample IDs separated by ',' |
bam_file | BAM file paths separated by ',' |
ref_genome | Reference genome fasta file |
ref_genome_version | 37 (default) or 38 |
bamtool | Sambamba or Samtools, required to sort and index the output BAMs |
output_dir | Output directory |
threads | Thread count |
Argument | Description |
---|---|
known_fusion_bed | BED file with known fusion pair coordinates, require only 1 fragment for junctions |
blacklist_bed | See below for explanation |
java -cp esvee.jar com.hartwig.hmftools.esvee.assembly.AssemblyApplication
-tumor TUMOR_SAMPLE_ID
-reference REF_SAMPLE_ID
-tumor_bam /sample_data/TUMOR_SAMPLE_ID.bam
-reference_bam /sample_data/REF_SAMPLE_ID.bam
-junction_file /sample_data/output/TUMOR_SAMPLE_ID.esvee.prep.junction.tsv
-ref_genome /path_to_ref_genome_fasta/
-ref_genome_version 38
-write_types 'JUNC_ASSEMBLY;PHASED_ASSEMBLY;ALIGNMENTS;BREAKEND;VCF'
-output_dir /sample_data/output/
-threads 16
Argument | Description |
---|---|
tumor | Tumor sample ID |
tumor_bam | Path to Prep tumor BAM file |
reference | Tumor sample ID (can be omitted in tumo-only mode) |
reference_bam | Path to Prep reference BAM file |
junction_file | Path to Prep junction TSV file, assumes named as 'TUMOR_SAMPLE_ID.esvee.prep.junction.tsv' |
ref_genome | Reference genome fasta file |
ref_genome_version | 37 (default) or 38 |
write_types | Minimum required is VCF for latter steps |
output_dir | Output directory |
threads | Thread count |
Argument | Description |
---|---|
decoy_genome | Decoy fastq sequences file, eg use HG38 decoys for a GRCH37 run |
Once unfiltered variants have been identified, they are annotated with the depth matching the reference genome in each input BAM. This feeds into the VAF calculations in the caller routine below.
java -cp esvee.jar com.hartwig.hmftools.esvee.depth.DepthAnnotator \
-sample 'TUMOR_SAMPLE_ID,REF_SAMPLE_ID'
-bam_file '/sample_data/TUMOR_SAMPLE_ID.bam,/sample_data/REF_SAMPLE_ID.bam'
-input_vcf TUMOR_SAMPLE_ID.esee.raw.vcf.gz
-output_vcf TUMOR_SAMPLE_ID.esee.ref_depth.vcf.gz
-ref_genome /path_to_ref_genome_fasta/
-ref_genome_version 38
-threads 16
Argument | Description |
---|---|
sample | Sample IDs separated by ',' |
bam_file | BAM file paths separated by ',' |
ref_genome | Reference genome fasta file |
ref_genome_version | 37 (default) or 38 |
input_vcf | Input VCF from assembly, assumes named as 'TUMOR_SAMPLE_ID.esvee.raw.vcf.gz' |
output_vcf | Output VCF, default is TUMOR_SAMPLE_ID.esvee.ref_depth.vcf.gz |
threads | Thread count |
The final step is to filter and annotate all variants, and then to write out 3 VCFs:
- somatic VCF - SAMPLE_ID.esvee.somatic.vcf.gz
- germline VCF - SAMPLE_ID.esvee.germline.vcf.gz
- unfiltered VCF - SAMPLE_ID.esvee.unfiltered.vcf.gz
java -cp esvee.jar com.hartwig.hmftools.esvee.caller.CallerApplication
-sample TUMOR_SAMPLE_ID
-reference REF_SAMPLE_ID
-input_vcf /sample_data/output/TUMOR_SAMPLE_ID.esvee.ref_depth.vcf.gz
-ref_genome_version 38
-pon_sgl_file /ref_data/sgl_pon.38.bed.gz
-pon_sv_file /ref_data/sv_pon.38.bedpe.gz
-known_hotspot_file /ref_data/known_fusions.38.bedpe
-repeat_mask_file /ref_data/repeat_mask_data.37.fa.gz
-output_dir /sample_data/output/
Argument | Description |
---|---|
sample | Tumor sample ID |
reference | Reference sample ID |
ref_genome_version | 37 (default) or 38 |
output_dir | Output directory |
Argument | Description |
---|---|
input_vcf | VCF from reference depth routine above, assumed named as 'TUMOR_SAMPLE_ID.esvee.ref_depth.vcf.gz' |
pon_sgl_file | PON for SGL breakends |
pon_sv_file | PON for SVs |
known_hotspot_file | Known hotspot SVs, matches known-pair fusions as used by Linx |
repeat_mask_file | Repeat mask file |
ESVEE is a structural variant caller that evaluates evidence for candidate breakends in a BAM and outputs forms fully assembled, aligned junctions, fully annotated and filtered based on read support.
Some key terms and concepts in ESVEE are set out below:
Term | Definition |
---|---|
Breakend | A candidate position and orientation for a structural variant |
Split read | A read which directly overlaps a breakend and is normally soft clipped at or near the breakend (depending on homology) |
Discordant read | A read with mate which is unmapped OR on different chromosome OR Fragment Length > 99.75%or < 0.25%. Discordant reads <1kb from and facing a junction are kept by SV_PREP and considered in assembly extension. |
INDEL read | A read with an INDEL that exceeds the minLength threshold of SV (32 bases). These are used to form and support junctions. Shorter INDELS are converted to soft clips in read processing step |
Junction | A linked pair of breakends that together form a structural variant |
Chained breakends | A pair of breakends that face each other and are explicitly cis-phased by fragments. This normally represents a short-templated piece of DNA which may be inserted into another location. |
Phase group | Maximal set of breakends that share at least 1 fragment with another breakend in the group. Breakends which may imply short DEL/DUP/INS may also be added to the same phase group, even without shared fragment evidence. Phase groups are created to limit complexity of assembly: all assembly merging and extension is done within phase groups only. |
Remote region | Co-ordinates and orientation of a set of overlapping (or near for gaps) reads that are paired with assembled or discordant reads. Breakends may have one or many remote regions. |
LINE insertion site | A site where a LINE element has been inserted characterised by 2 opposite orientation breakends either facing each other with less than 10 bases gap or overlapping with less than 30 bases and with either a long PolyA insertion sequence on the negatively oriented breakend or a long polyT insertion sequence on the positively oriented breakend. The insertion sequence size may vary from just a few bases to a long sequence and is often unmappable due to the repetitive LINE elements in the human genome. LINE insertion sites have special logic throughout each of the ESVEE steps to maximise sensitivity. |
SV Length | For INV, DEL, DUP and INS, the SV length is defined as the position difference between the 2 locations (excluding the last mapped base) + length of any insert sequence. |
Much of the logic depends in ESVEE depends on assembling reads into contiguous sequence, first locally and then merging assemblies and remote regions within phase groups. The algorithms use the following tolerances throughout ESVEE:
- Minimum length: We require 32 bases to call a variant. At the ESVEE-PREP and local breakend assembly stage we also require a soft clip of at least 32 bases to retain a junction (an exception is made for regions with high discordant fragment support)
- Low Quality SNV errors: Low quality mismatches (rawBQ<26) are ignored and deemed to always match an existing assembly
- Minimum assembly overlap: We require 50 bases of overlap to merge and extend assemblies OR 20 bases to merge and extend reference bases
- Mismatch tolerance: When comparing reads and assemblies with allow 0 high quality mismatches for sequences of < 15 bases, 1 high quality mismatches for sequences of 15 to 100 bases, and then 1 additional high mismatches for each additional 200 bases of sequence overlap more than 100 bases. Note that a 1 or 2 base mismatch or a longer mismatch in microsatellite counts as 1 mismatch
ESVEE also employees concepts of a modified alignment scores and MAPQs to try to represent absolute versus relative likelihood of mismatch. THese are defined as follows:
Modified length of an alignment after allowing for inexact homology, repeats and mismatches. Defined as:
adjAS = AS - inexact homology length – repeatBases[repeatCount>2]
Note that the alignment score incorporates both length and number of mismatches and that the repeats are only evaluated for the bases outside of the homology region (so that this is not double counted)
The modified MAPQ is intended to convert the MAPQ which is a relative MAPQ into something more akin to an ‘absolute’ MAPQ. The MAPQ is penalised if the length is short or the alignmnet score is low relative to the length.
modMAPQ = MAPQ * min [1, adjAS/max(100,alignLength)]^2
ESVEE-PREP generates a set of maximally filtered SV BAM files and an initial set of candidate SV junctions from input tumor/normal BAM files. The SV BAM files includes all candidate split and discordant reads that are proximate to candidate junctions that may provide support to that junction.
Ignoring reads that are duplicate (or where the primary is a duplicate), secondary or contain soft clipping with more than 16 consecutive bases of PolyG/C), and excluding sites in blacklisted regions, ESVEE-PREP parses through the BAMS end to end to identify breakend sites with CREDIBLE soft clipping:
- At least 1 read with AdjAlignmentScore > 40 and abs(Insert size - M length) > 5 bases (ie test for short fragments with adapter) AND a soft clip length of >32 with >=75% of soft clip bases with qual > 25.
- Soft clip length of <32 is allowed where the soft clip meet the polyA LINE criteria (ie 16 of first 18 soft clip bases must be A/T).
- The read must also not be a simple repeat expansion. ie the first 9 bases of soft clip and the last 9 bases of aligned read are not matching 1,2 or 3 nucleotide repeats.
- At least 1 additional read which have soft clipping of any length at the same base OR within 50 bases with <=1 high quality mismatch between the soft clip locations (not required for HOTSPOT regions)
Sites with aligned INDELs of >= 32 bases are also treated as candidate sites.
Additionally, to ensure we capture SV with long (inexact) homology we also identify sites where there are >=5 reads within a 500 base region with insert size outside the max(1000,99.75%) insert size (or >=3 reads if insert size is more than twice that length) with their mates also starting within a 1000 base region of each other. The sites must also be on the same chromosome within +/1MB with a DEL or DUP orientation or create a link between a known hotspot region. At least one read must have MAPQ>=40 and adjAS>75. The range can be further extended to the inner side of the fragment up to the 99.75% fragment size if more reads can be found in that region with long insert sizes and mates within 1kb of each other. If such a candidate region is found and the reads do not support a site of credible soft clipping, then create a breakend regardless on the innermost base of the reads supporting the potential breakend.
For each site we also obtain the following reads (excluding reads with alignments that overlap blacklist regions) and their mates
- All reads with soft clipping that matches the orientation and position of the variant (+/-50 bases)
- All reads within 99.75% range fragment length of the site on the correct side of the breakend with read facing the breakend and mate is unmapped, inter-chromosomal, has the same orientation or has an insert size outside the percentile range [0.25,99.75]
- All reads that overlap the breakend and contain an INDEL of 3+ bases For the last 2 categories (discordant & indel containing reads), we filter if they have more than max(5,25% of soft clip length) soft clip bases with base qual <=25, since these frequently cause FP calls in GRIDSS.
A BAM is written for each input sample which contains the reads described above and their mates.
ESVEE also counts discordant fragments genome wide in 3 buckets (translocations, shortInversions (<5kb) and other) and writes to a separate counts file.
The candidate breakends generated by ESVEE prep are organised into breakend groups, covering a set of breakends within 1kb of each other. All reads from the ESVEE-PREP BAMs are retrieved for each breakend group.
Each read has the following adjustments made to it prior to assembly:
- Drop low qual reads - any reads with >50% of low qual bases are dropped altogether
- PolyG trimming – any continuous stretch of 4 or more Gs (Cs on reverse-strand reads) are trimmed from the read. These bases and quals are entirely truncated from the read.
- Quality trimming – Trim up to the last soft clipped 3' base that satisfies proportion of lowQual bases > 35%. To maximise LINE insertion sensitivity, the first 18 bases of the SC are NOT trimmed regardless of QUAL IF at least 16 of them are either A or T AND the bases are not an extension of an aligned PolyA/T sequence of at least 8 bases in the reference.
- Indel to soft-clips – any INDEL of length >= 10 and < minBases [32] is converted into a soft-clip on the side closer to the edge of the read. Only the cigar of the read is affected.
Discordant fragments with unmapped mates are ignored in subsequent steps if unmapped trimmed read length < 50 or if MAPQ = 0.
Breakend supporting reads identified by EVEE-PREP are used to build initial breakend assemblies. These must either be soft clipped on the junction side and cross the breakend or indel containing reads with indels >= min. length bases (currently 32). Discordant reads are not included at this stage as we have not yet confirmed their mates are part of the same assembly.
In the first step the ‘extension’ sequence is built from the breakend outwards using the consensus of soft-clipped bases. If 2 or more reads differ from the consensus with high qual mismatches exceeding the mismatch tolerance the extension is split into multiple alignments. Each of the candidate overlapping breakend supporting reads that overlaps the candidate junction site (including any indel containing reads or reads with an SNV and the soft clip junction is within 2 bases) is tested against these unique breakend-extension assemblies. These initial assemblies are filtered unless at least 1 read has a soft clip > 32 bases and at least one other read has a soft clip >= 16 bases OR the sequence contains a PolyA/PolyT LINE sequence of 16 bases and a 2nd read with supporting soft clip > = 8 bases with an insertion site orientation. However, note that candidate junctions with LINE source insertion orientations are filtered as they may be promiscuous causing issues downstream These are always assembled from the LINE insertion site end.
To allow calling of variants with long homology which may not have soft clipping, if no assembly can be created with sufficiently long soft clip, but there exists a remote region with more than 3 discordant fragments supporting the link then an assembly is made using only the fragments associated with that specific remote region. Only reads that support the specific remote location are allowed to form the assembly The breakend is arbitarily initially placed 32 bases from the innermost base of the assembly. Only reads with MAPQ>20 are considered in the assembly construction.
All remaining breakend assemblies are then extended into the reference base direction from their supporting reads. Only junction split reads with 10+ soft-clipped bases and at least 2 high quality soft clipped bases matching the consensus, can be used to build the initial assembly ref base sequence.
Duplicate assemblies may exist at either the same breakend or within +/-50 bases with the same orientation. Assemblies are deduped (the assembly with the higher initial read support is retained) if they satisfy an assembly comparison within mismatch tolerances (see above)
Any local breakend which fully aligns to a decoy or ALT (excluding HLA ALTs) sequence (top alignment with <=3 mismatches and AS/length > 0.9) in the hg38 genome are filtered at this stage and not processed further.
For any junction with average of support reads less than MAPQ < 10, the reference base sequence is aligned. If the aligner returns MAPQ < 10 and no XA tag we filter the assembly as it cannot lead to a breakend with our later alignment rules
If more than one assembly shares the same breakend after deduplication then secondary assemblies are only kept if supported by at least 5 fragments and by at least 20% of the primary assembly count.
Phase groups are created by maximally linking any breakends which share at least 1 fragment. Since short DEL, DUP and INS will not share discordant reads on either side of the junction, if there are no supplementary reads that directly support the junction, they will not share any reads. Hence, we also merge any 2 proximate breakends into the same phase group if:
- they form a DUP orientation <500b OR DEL orientation < 1kb AND
- both breakends have at least 1 split read with concordant mate on the soft clipped side OR at least one side has a PolyA / PolyT tail sequence with insertino site orientation.
During phasing, all candidate remote linking sites are collected for each breakend. These are taken from discordant reads, breakend assembly read mates and breakend read supplementaries, and are established from the remote read or supplementaries coordinates (ie its chromosome and read start and end alignments). Remote reads with overlapping alignments are merged into sets of remote regions, and then cached against each assembly and are used later in phasing and assembly merging.
At this stage each phase group consists of multiple breakends:
- Sharing fragment support (=1) or
- Are proximate to each other (for short DEL, DUP, INS)
- These breakends may be single breakends, breakend pairs, or represent chained/complex structural variants.
Each breakend consists of:
- A local assembly and the reads that make up that assembly
- A set of local discordant reads proximate to that breakend which may support the breakend
- A set of remote regions consisting of the mates of the assembled and local discordant reads
- A set of unmapped mates of the assembled reads and local discordant reads.
- A phase group which contains any breakends which are proximate or with shared fragment support
Breakend assemblies are merged and extended to form junctions. There are 6 sub-steps:
In each step, ESVEE attempts to merge existing assemblies with other assemblies, remote regions and/or mates of assembled reads. Assemblies are merged if a 10 base exact seed within a range of +/- 100 bases of each breakend can be matched, and the seed can be extended to the end of each assembly sequence with the minimium require overlap aand up to the prescribed number of high- quality mismatches (see above). When 2 breakends are assembled, if there is a gap between the reference sequences, an insert sequence is recorded. If there is an overlap of reference sequences, the reference bases are also extended. Assemblies are branched into multiple assemblies if there is at least 5 reads and 20% maximum support supporting an alternative alignment. This may occur in the case of foldback inversions.
Since short DEL & DUP are the most common variant types, ESVEE first tries to merge proximate breakends (within 500 bases for DUP or 1000 bases for DEL) with consistent orientations that may be a DEL or DUP, prioritising pairs that share indel containing reads or supplementary alignments. Breakends supported by indel containing reads are also examined to see if the INDEL cigar can fully explain the soft clipping.
Each unlinked breakend is next checked if it can be resolved by local alignment. The same merge criteria applied, but instead of aligning between 2 local assemblies, ESVEE instead aligns the breakend assembly to the local reference genome within +/- 500 bases. If an alignment is made and the variant length > minLength a new breakend is created at the alignment location. If an alignment is made and the variant length < minLength, the candidate breakend is filtered as SHORT_INDEL.
Within a phase group, ESVEE next attempts to merge any pair of unlinked distal breakend assemblies OR individual breakends with discordant and unmapped mates, that may form a paired junction assembly and are directly linked by same fragment support. The breakend pairs are prioritised by the total shared fragment support and the breakends are merged based on matching the sequence assembly. For remote and unmapped regions, EEVEE tests iteratively to see if they can be merged into the extended assembly until no further extensions may be made. When 2 breakend assemblies are merged, the assembly is also maximally extended on both ends from the junction outwards, using discordant read mates and incorporating also any discordant pairs which link the 2 regions. Assemblies are also extended in the reference sequence with local junction mates if the the required overlap. After all distal mergers are made, remaining candidate breakends are tested to see if they can be merged into and extend the existing merged assemblies. Breakends which are merged into already formed junctions are marked as ‘SECONDARY’
For LINE insertions sites with 2 breakends, both breakends are assembled simultaneously
ESVEE next merges chained or facing breakends that share fragments and are at least 30 bases apart and less than 1kb. To merge, any overlapping reference bases must agree with each other and soft clipping in the reference base must match the facing breakend.
If any unassembled mates remain which are within 200 bases of an assembly on the 3’ side of the read and neither the assembly sequencing or the reads are soft clipped on the facing breakend, then extend the assembly to include the read sequence and assume the bases in between match the reference sequence
Finally each assembly within the phase group are compared to each other. If they overlap and mismatches are within tolerances they are merged into a single assembly. Phased assemblies should only be collapsed if either:
- The matching sequence overlaps at least 1 junction on either assembly OR
- The 2 sequences are either end of the same LINE insertion site
ESVEE now has a set of unique assemblies which may relate to a single candidate breakend, a junction pair or a complex set of chained breakends. Each unique assembly is aligned using BWA-mem with '-w 32' parameter whichhas the effect of splitting gaps of more than 32 bases into supplementary alignments (default = 100)
BWA may return one primary alignment as well as one or more supplementary alignments. Since BWA can assign an unreliable MAPQ to supplementary alignments, any supplementary alignments are realigned again using BWA with the primary alignment of the re-query kept and any further supplementaries dropped
At this stage a modified MAPQ is calculated for each alignment
modMAPQ = MAPQ * min [1, AdjustedAlignmentScore/max(100,alignLength - IHOM length)]^2
where:
AdjustedAlignmentScore = Alignment score – IHOM length – repeatBases[repeatCount>2]
Note that if (alignmentScore + 15 < 0.85 * (length – inexact homology length)) the modMAPQ is set to 0. This helps to filter long but biologically implausible alignments.
The interpretation of the alignment depends on both the modified map quality and the XA tag which will display the alternative alignments if there are a small number of alternatives. Assemblies with no alignments or with all alignments with modMAPQ < 10 and NULL XA tags are ignored.
For assemblies with a single alignment, a junction is inferred from CIGAR and added to the VCF if the alignment has modMAPQ>=10 and the alignment has an ‘I’ or ‘D’ CIGAR element of 32+ bases with at least 50 bases of matched bases (M cigar) on either side after trimming. Note that if an assembly already resolved as a local indel is aligned as a SGL again (due to one side being unmappable) it is converted back to an INDEL alignment. A single breakend is created in the VCF if there is either a soft clip length of at least 32 bases or a PolyA/PolyT INS sequence of at least 1.5x length of PolyA in the adjacent reference bases), and either the modMAPQ>=10 OR the alignment has a non NULL XA tag .
For assemblies with 2+ alignments, for each pair of consecutive alignments in the assembly with modMAPQ >=10, ESVEE writes a pair of breakends representing a junction to a VCF. For alignments with modMAPQ < 10 AND XA!=NULL, the default and alternative alignments are checked to see if they can make a short variant (length < 100kb) with adjacent alignments, and if so the alignment which makes the shortest variant is chosen. If there are consecutive alignments with ModMAPQ<10 and XA!=NULL, adjacent alignments with modMAPQ >=10 are checked first, followed by any remaining consecutive alignments with XA!=NULL. If 2 identical length variants are possible between consecutive alignments with modMAPQ < 10 and XA!=NULL, then prefer the default alignment. If no short variant can be made but either the XA!=NULL or MAPQ>=5 then use the default alignment. Otherwise, the alignment is converted to insert sequence. A summary of the behaviour is shown in the below table:
Case | Alignment behaviour |
---|---|
Has XATag with <100kb alignment | Use shortest (or default if equal). Add 15 to QUAL |
Has XATag and MAPQ > 0 No short alignment | Use default alignment |
No XA Tag. modMAPQ>=5 | Use default alignment |
Other | No alignment (convert to insert sequence) |
For each alignment with modMAPQ<10 and either (XATag!=NULL OR alignment is in DUX4 region) regardless of whether the alignment was inferred or was converted to an insert sequence, then all the alternatives are recorded in the INSALN field for any adjacent breakends or the ALTALN field if an alignment.
Note that 2 special exceptions are made for clinically relevant fusions in low mappabilitiy:
- SSX2: SS18 Exon 10 to SSX2 Exon 6 mutations are common pathogenic fusions in Synovial Sarcomas, but may be confused with the homolog SSX2B. Therefore, for any alignment which falls in the range of intron 5 of SSX2 (hg19: X:52,729,628-52,731,680; hg38 chrX: 52,700,578-52,702,630) and SSX2B (hg19: X: 52,784,877-52,786,929; hg38 chrX:52,755,800-52,757,852) with a downstream genic orientation with MAPQ < 20 and the assembly has a breakend mapped to another chromosome is assumed to have the SSX2 alignment.
- DUX4: DUX4 is a special case as it has known clinically relevant fusions but many identical copies in the reference genome. DUX4 regions are defined as {GL000228.1:20000-125000, 4:190930000-191030000, 10:135420000-135520000} on hg19 and {chr4:190060000-190190000, chr10:133660000-133770000} in hg38. If there are 2 or more consecutive modMAPQ<3 alignments, then the INSALN is merged for those cases.
Where alignments are overlapping, the junction is aligned to the midpoint of the subset of overlapping bases that require that lead to the least total number of mismatches to the reference genome across both breakends. If there are multiple non-contiguous regions with identical number of mismatches, then the longest is selected. The confidence interval CIPOS is set to the bounds of the lowest mismatch region and the bases in this region are set to the homology sequence (HOMSEQ). The bounds of the overlap relative to the aligned breakpoint is set to be the inexact homology confidence interval (IHOMPOS).
The QUAL is set to the SUM of the alignment qualities at either end, with an adjustment to penalise alignments with low read count support:
QUAL = [modMAPQ(localBE) + modMAPQ(remoteBE)]*[readSupport / (readSupport + halfQualSupport)]
HalfQualSupport is set to 4 by default.
If a breakend is in multiple assemblies, the qual is calculated across each of the assemblies and the highest QUAL is used.
For each breakend the total variant fragments (VF) that overlap the breakend across all assemblies is recorded. This is also broken down into fragments with reads that directly overlap the breakend (SR) and discordant fragments that span but do not overlap the breakend. Note that spanning fragments are NOT included in counts for INS or DEL and DUP < 1000 bases in length as we cannot uniquely determine if they are discordant.
For each breakend, ESVEE queries the full BAM files and annotates the fragments with a read that directly overlaps the breakpoint (REFSR) and spans the breakpoint (REFRP). These are also used to calculate a variant allele frequency (AF) for the variant. To be consistent, for INS or DEL and DUP < 1000 bases in length, the REFRP is also ignored from the denominator of the AF calculation. If the VAF is > 90% and the variant falls into an ‘unmapped region’ as defined in REDUX, then the REF_DEPTH is assumed to be the sample median.
The following filters are applied to the variant with a context of ‘any sample’ (ie PASS if any sample meets the criteria) or ‘all samples’ (pass if the criteria is met across all sampes for the variant:
Filter Name | Samples | Definition | Junction | LINE Site | Single | Hotspot |
---|---|---|---|---|---|---|
minQual | Any | QUAL | 30 (WGS) / 60 (PANEL) | 30 (WGS) / 60 (PANEL) 1 | 30 (WGS) / 60 (PANEL) | 30 |
minSupport | Any | VF | 4 | 41 | 6 | 2 |
minAF | Any | min(AF[BE1],AF[BE2]) | 0.001 | 0.001 | 0.05 | 0.001 |
minLength2 | All | EndPos-StartPos+InsSeqLength | 32 | NA | NA | 32 |
shortFrags | All | Lengthmedian - NumSD * LengthstdDev/sqrt(VF)3 | 3 | NA | NA | 3 |
minAnchorLength | All | AlignLength – repeatLength – Homology | 50 | NA | 504 | 50 |
shortLowVafInv | All | min(AF[BE1],AF[BE2]) | 3<=IHOMLEN<6: min(0.1,200 * shortINVRate); IHOMLEN>=6 min(0.2,400 * shortINVRate) 5 | NA | NA | NA |
sbArtefact6 | All | SB | NA | NA | 1.0 | NA |
1. For pairs of SGL breakends which resemble a likely LINE insertion site (see above) the SUM(Qual) is used for both breakends.
2. Same chromosome junctions only.
3. implies the sampled average fragment length should be within 3 standard deviations of the sample median length (note the cutoff is also capped at 0.6*SD below median length). Standard deviation is estimated as Lengthmedian-length16th percentile
4. The inserted sequence length must also meet these requirements
5. Only applied to variants with type=INV and LEN<3kb. ShortINVRate = proportion of fragments genome wide that support a short INV
6. Only for SGL 5' end contains GTGTAGATCTCGGTGGTCGCCGTATCATTAAAAA or reverse complement TTTTTAATGATACGGCGACCACCGAGATCTACAC
Note that for pairs of breakends at LINE insertion sites, if one has a PASS filter we should always PASS the other side.
In targeted mode, SGL breakends are only retained if in a targeted region.
If the same precise breakend is found to PASS multiple times in the VCF then retain the variant with the highest QUAL only
A consolidated VCF is produced showing all soft filters. If a germline sample is present and BOTH max(germline AF/TumorAF) > 0.1 AND germlineAD / tumorAD > 0.01 the variant is deemed to be germline, else somatic. Separate vcfs are written for PASS and PON somatic and germline variants only (in tumor only mode just a somatic vcf filter is written). A PON filter is also applied to the somatic variant vcf based on both a SGL BE PON (for SGL breakends) and a paired BE PON (for junctions). SGL breakends with candidate alignments that fall in the SSX2, SSX2B or DUX4 regions are never PON filtered. For pairs of breakends at LINE insertion sites, if one variant is marked as germline, then both should be considered as germline.
Stage | Special rules |
---|---|
Esvee Prep | min 32 base length is not required |
Trimming | Don’t trim the first 18 bases if at least 16 of them are PolyA or T |
Local assembly | Prioritse reads with the 5’ in the softclip and which reach beyond the PolyA for extension; Allow any length of PolyA to match. Set the length in the assembly to be the median of lengths with additional bases beyond the PolyA or else just the longest PolyA sequence if none exist; Require only 16 bases longest and 8 bases 2nd longest to retain soft clip |
Phasing | Phase breakends even if neither has a locally concordant mate |
Assembly extension | Allow remote regions and unmapped mates of both sides to extend the assembly |
Alignment | Secondary links are still aligned for LINE insertion sites; Call single breakend if PolyA length exceeds 1.5x reference PolyA length (no 50 base minimumum); Secondary links are still aligned for LINE insertion sites |
Filters | MinLength, ShortFrags, minAnchorLength filters not applied; PASS if either side PASES ; MinSupport & MinQual uses qual of both sides |
Germline vs Somatic | Mark as germline if either side meets germline filters |
Field | Description |
---|---|
ALTALN | Potential alternative alignments of segment in the format chr:start |
ASMID | Unique id(s) of assembly(s) containing the breakend |
ASMLEN | Total length(s) of assembly(s) containing the breakend |
ASMLNKS | Breakend id of breakends linked by assembly |
ASMSEG | #(s) of segments in assembly(s) containing the breakend |
AVGLEN | Average implied length of fragments supporting the junction |
BEAOR | Breakend orientation(s) in assembly(s) |
BEAPOS | Breakend position(s) in assembly(s) |
BEOR | Breakend orientation(s) in reference genome |
CIPOS | Confidence interval around breakend position (for homlogy) |
HOMSEQ | Homology sequence at junction |
HOTSPOT | Is Known fusion hotpsot |
IHOMPOS | Offset positions of inexact homology |
INSALN | Potential alignment locations of insert sequence in the format chr:start |
INSRMP | Portion of inserted sequence whose alignment overlaps the repeatmasker repeat |
INSRMRC | IInserted sequence repeatmasker repeat class |
INSRMRT | Inserted sequence repeatmasker repeat type |
LINE | LINE Insertion Site |
MATEID | Id of other breakend in junction |
PON_COUNT | PON count if in PON |
SEGALEN | Aligned length of segment(s) in reference genome |
SEGID | Unique id(s) of segment(s) containing the breakend |
SEGMAPQ | MAPQ of segment containing the breakend with highest QUAL contribution |
SEGRL | Repeat length of segment with highest QUAL contribution |
SEGSCO | Alignment score of segments containing the breakend with highest QUAL contribution |
SVID | ID shared by both breakends in the variant |
SVTYPE | Type of structural variant |
Field | Description |
---|---|
AD | Allelic depths for the ref and alt alleles in the order listed |
AF | Allele frequency of the breakend |
DF | Count of discordant fragments with a read either side of the breakend |
DP | Approximate read depth |
GT | Genotype |
REF | Count of fragments supporting the reference with a read overlapping the breakend |
REFPAIR | Count of paired fragments supporting the ref with a read either side of the breakend |
SB | Proportion of split reads with 3' end facing the breakend. Fragments with both reads split are counted in both directions |
SF | Count of fragments supporting the breakend with a read overlapping the breakend |
VF | Total variant fragments supporting the breakend |
Know sources of errors
- Poor extension from a single mispleced read => can lead to either a FP or prevent further assembly extension
- Assembly merging requirements are quite strict and sometimes we can miss read support. If missed in the germline, this may cause germline leakage
- Misintepretation of INDELs in long repeats can sometimes cause poor quality consensus sequences in assembly extension.
- MSI Jitter of germline INDELS just under 32 bases in length may be intepreted as a somatic SV of 32+ bases
- Long dinucleotide MS expansions can fail minAnchorfilter
- SGL AF will be systematically underestimated if we cannot extend the assembly.
- Somatically activated LINE insertion sites - Some insertion sites of LINE elments may become active LINE source elements themselves. These may appear to be BOTH insertion and source sites for LINE elements and may lead to overcounting of support at insertion sites.
Alignment
- We should analyse additional supplemementary alignments arising from re-query of initial supplementary alignments (currently dropping)
- We should requery long softclips to see if additional alignments can be found.
ESVEE has some implicit and explicit assumptions on reads, qualities and alignments:
- AS field - AS is currently required
- Low qual masking - assumes a high proportion of bases have qual > 30
- Read lengths - Soft clip & alignment score assumptions require read lengths > 80 bases
- Fragment lengts - We use 1000,500 to refer to short DEL, DUP respectively. Ideally this should depend on fragment lengths.
- Low Qual INDELS - Technologies with many low quality indel errors (eg Ultima) may have assembly impacted. These should be masked from assembly
- Hard clipping - ESVEE prep may not retain reads with hard clipping at or near junctions
Other planned improvements
- Variant visualisations
- Multi tumor and reference sample support including donor support
- Append mode
- Develop an ESVEE specific PON (currently using GRIDSS)
- Investigate region specific filtering for IG,TCR & HLA regions
- Switch minSupport from MAX to SUM of samples & lower minSupport to 3. Depends on duplicate collapsing improvements in REDUX to allow supplementary and primary read are reverse