Skip to content

Latest commit

 

History

History
488 lines (378 loc) · 38.9 KB

README.md

File metadata and controls

488 lines (378 loc) · 38.9 KB

Esvee - Structural Variant Calling

Overview

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.

STEP 1: ESVEE Prep

Prep generates a maximally filtered SV BAM file by identifying candidate SV junctions and extracting all reads that may provide support to that junction.

Command

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

Mandatory Arguments

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

Optional Arguments

Argument Description
known_fusion_bed BED file with known fusion pair coordinates, require only 1 fragment for junctions
blacklist_bed See below for explanation

STEP 2: Assembly & Alignment

Command

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

Mandatory Arguments

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

Optional Arguments

Argument Description
decoy_genome Decoy fastq sequences file, eg use HG38 decoys for a GRCH37 run

STEP 3: Reference Depth Annotation

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

Arguments

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

STEP4: Variant Calling and Filtering

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

Command

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/ 

Mandatory Arguments

Argument Description
sample Tumor sample ID
reference Reference sample ID
ref_genome_version 37 (default) or 38
output_dir Output directory

Optional Arguments

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

Algorithm

Key concepts

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:

Adjust alignment score (AdjAS)

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)

Modified MAPQ (modMAPQ)

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 

STEP 1: ESVEE PREP

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.

STEP 2A: Local breakend assembly

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.

Assembly

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.

Assembly deduplication

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)

Local assembly filtering

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.

STEP 2B: Phasing

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

STEP 2C: Merge & extend assemblies

Breakend assemblies are merged and extended to form junctions. There are 6 sub-steps: image

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.

1. Assemble local pairs

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.

2. Local alignments

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.

3. Assemble distal junctions

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

4. Chained assemblies

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.

5. Infer local gaps

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

6. Collapse duplicates

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

STEP 2D: Alignment & variant calling

Alignment

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.

Homology annotation and precise breakend alignment

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).

QUAL Annotation

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.

Read count annotations

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.

STEP 3: Reference counts & filtering

Reference count annotations

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.

STEP 4: Filtering

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.

Variant Deduplication

If the same precise breakend is found to PASS multiple times in the VCF then retain the variant with the highest QUAL only

Germline or Somatic determination

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.

Summary of LINE insertion site behaviour

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

Output

VCF INFO fields

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

VCF sample specific fields

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

Known issues and future improvements

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

GRIDSS and GRIPSS SV filtering

Version History and Download Links