This tool classifies the outputs of AmpliconArchitect.
If using AmpliconClassifier, please cite the following publication which describes the AmpliconClassifier methodology in the Supplementary Information section:
Luebeck J, et al. Extrachromosomal DNA in the cancerous transformation of Barrett’s oesophagus. Nature. 2023. PMID: 37046089
See the section at the end of the README for information about the legacy version.
AmpliconClassifier is included with AmpliconSuite-pipeline, but for re-classification, you may wish to keep a standalone installation of this module, using the instructions below.
intervaltree
and scipy
python libraries:
conda install intervaltree scipy
# orpip install intervaltree scipy
$AA_DATA_REPO
environment variable and data repo files. See instructions here. matplotlib
: conda install matplotlib-base
or pip install matplotlib
Mac users will need to perform one additional installation step:
brew install coreutils
git clone https://github.com/jluebeck/AmpliconClassifier.git
cd AmpliconClassifier
echo export AC_SRC=$PWD >> ~/.bashrc
source ~/.bashrc
amplicon_classifier.py
takes a collection of (or single) AA graph files and corresponding AA cycles file as inputs.
To classify a single amplicon:
python amplicon_classifier.py --ref GRCh38 --cycles sample_amplicon1_cycles.txt --graph sample_amplicon1_graph.txt > classifier_stdout.log
Most common - classifying multiple amplicons: You can provide the directory containing multiple AA amplicons or multiple uniquely named samples
python amplicon_classifier.py --ref GRCh38 --AA_results /path/to/AA/output/directories/ > classifier_stdout.log
AC will crawl the given location and find all relevant AA files and perform classification on them.
Less common - separate usage of make_input.sh
:
Alternatively, you can use the make_input.sh
script to gather the necessary input files outside of AC:
make_input.sh
takes a path and an output prefix. e.g:
make_input.sh /path/to/AA/output/directories/ example_collection
This will create a file called example_collection.input
which can be given as the --input
argument for AC.
If combining data from both GRCh37 and hg19 in the same classification run, you can set the flag --add_chr_tag
to add the "chr" prefix to each chromosome name and effectively unify everything as hg19-based.
[prefix]_amplicon_classification_profiles.tsv
Contains an abstract classification of the amplicon, and also indicates in separate columns "BFB+" and "ecDNA+" status. Note that amplicons receiving a "Cyclic" classification may be ecDNA+, BFB+ or both.
Column name | Contents |
---|---|
sample_name |
Sample name prefix |
amplicon_number |
AA amplicon index, e.g. amplicon2 |
amplicon_decomposition_class |
Abstract description of the AA amplicon type. Note that Cyclic can refer to either BFB or ecDNA. Please see the following columns for that distinction. |
ecDNA+ |
Prediction about whether the AA amplicon contains ecDNA. Note, an AA amplicon may contain regions surrounding the ecDNA, or multiple linked ecDNA. Either Positive or None detected |
BFB+ |
Prediction about whether the AA amplicon is the result of a BFB. Either Positive or None detected |
ecDNA_amplicons |
Predicted number of distinct (non-overlapping) ecDNA which are represented in a single AA amplicon. This estimate is highly experimental. |
Because an ecDNA may overlap with a BFB, they are reported separately.
[prefix]_gene_list.tsv
Reports the genes present on amplicons with each classification, and which genomic feature (e.g. ecDNA_1, BFB_1, etc), it is located on, along with the copy number and which end(s) of the gene have been lost ("truncated"), will be one of None
, 5p
(5-prime end), 3p
(3-prime end) or 5p_3p
if both. Genes are sourced from RefGene and most lncRNAs and micro-RNAs are excluded from the report.
Column name | Contents |
---|---|
sample_name |
Sample name prefix |
amplicon_number |
AA amplicon index, e.g. amplicon2 |
feature |
Which feature inside the amplicon the gene is present on. May be unknown if cannot be confidently assigned to a feature. |
gene |
Gene name (RefGene) |
gene_cn |
Maximum copy number of genomic segments (larger than 1kbp) overlapping the gene, as reported by AA |
truncated |
Which end(s) of the gene have been lost ("truncated"), will be one of None , 5p (5-prime end), 3p (3-prime end) or 5p_3p if both |
is_canonical_oncogene |
Reports if gene is present in COSMIC, ONGene. |
ncbi_id |
Reports the NCBI Accession ID of the gene |
[prefix]_feature_basic_properties.tsv
Reports a table of basic properties such as size of captured regions, median and max CN, and a flag field to report if the call is "borderline" (ecDNA with CN < 8, other classes with CN < 5).
[prefix]_feature_entropy.tsv
Reports amplicon complexity scores as measured by the number of genomic segments and the diversity of copy number among all the amplicon decompositions performed by AA. For more information please see the Supplementary Information file of this study.
Column name | Contents |
---|---|
sample_name |
Sample name prefix |
amplicon_number |
AA amplicon index, e.g. amplicon2 |
feature |
Which feature inside the amplicon the gene is present on. May be unknown if cannot be confidently assigned to a feature. |
total_feature_entropy |
This is the amplicon complexity score. |
decomp_entropy |
Amount of entropy or diversity captured in the AA decompositions overlapping this feature. |
Amp_nseg_entropy |
Amount of entropy or diversity captured by the number of genomic segments overlapping this feature. |
[output_prefix]_ecDNA_counts.tsv
This two-column file reports the sample_name
and the number of ecDNA identified in the samples.
[output_prefix]_ecDNA_context_calls.tsv
This two column file reports the ecDNA feature name (sample_amplicon_ecDNA_number), and a classification of the ecDNA focal amplification genome context. The possibilities for ecDNA context classification are
ecDNA context class | Description |
---|---|
Simple circular simple background | A simple ecDNA cycle with minimal rearrangements in the surrounding genome. Likely not derived from chromothripsis. |
Simple circular complex background | A simple ecDNA cycle however there are genomic rearrangements in the vicinity outside the ecDNA region. |
BFB-like | ecDNA possibly derived from a BFB. |
Two-foldback | ecDNA being flanked by two foldback-like SVs. Likely not derived from chromothripsis, but possibly from ODIRA. |
Heavily rearranged unichromosomal | ecDNA from a heavily rearranged genome on one chromosome. Possibly due to chromothripsis. |
Heavily rearranged multichromosomal | ecDNA from a heavily rearranged genome involving multiple chromosomes. Possibly due to chromothripsis and chromoplexy. |
Unknown | Does not match any of the classes above. |
Additionally, there are three directories created by amplicon_classifier.py
. They are
[prefix]_classification_bed_files/
, which contains bed files of the regions classified into each feature. May contain bed files marked unknown
if the region could not be confidently assigned.
[prefix]_SV_summaries/
, which contains tab-separated files summarizing the SVs detected by AA and what features the overlap in the amplicon.
[prefix]_annotated_cycles_files/
, which contains AA cycles files with additional annotations about length of discovered paths/cycles and their classification status. Using these annotated cycles files is preferred over the unannotated cycles file produced by AA. These cycles are filtered to remove cycles overlapping low-complexity regions of the genome, patches reference genome issues, and filters duplicate cycle entries erroneously output by AA (uncommon).
If running AC only on a single AA amplicon, use arguments:
-c/--cycles
: AA cycles file-g/--graph
: AA graph fileElse if running on multiple amplicons, use argument
--AA_results
: Path to a directory containing one or more AA results. AC will search this directory recursively and index all the AA results it finds for classification.Column name | Contents |
---|---|
--ref [hg19, GRCh37, GRCh38, mm10, or GRCm38] |
(Required) Choose reference genome version used in generating AA output. |
-v/--version |
Print version and exit. |
-o |
Output filename prefix. Default is prefix of -i or -c . |
--add_chr_tag |
Adds back missing "chr" prefix to chromosome names. If you have a mix of hg19 and GRCh37 amplicons, set --ref hg19 and --add_chr_tag to classify them all together. |
--min_flow |
Minumum cycle CN flow to consider among decomposed paths (default=1). |
--min_size |
Minimum cycle size (in bp) to consider as valid amplicon (default=5000). |
--verbose_classification |
Output verbose information in the amplicon_classification_profiles.tsv file, and create edge_classification_profiles.tsv . Useful for debugging. |
--force |
Disable No amp/Invalid class, if possible. Use only when extremely large CN seeds were used in AA amplicon generation (>10 Mbp intervals) or if debugging. |
--plotstyle [noplot, individual] |
[experimental] Produce a radar-style plot of classification strengths. Default noplot . |
--decomposition_strictness |
Value between 0 and 1 reflecting how strictly to filter low CN decompositions (default = 0.1). Higher values filter more of the low-weight decompositions. |
--exclude_bed |
Provide a bed file of regions to ignore during classification. Useful for separating linked amplicons or augmenting existing low-complexity annotations. |
--no_LC_filter |
Set this to turn off filtering low-complexity & poor mappability genome region paths & cycles based on the regions in the AA data repo. |
--filter_similar |
Permits filtering of false-positive amps arising in multiple independent samples based on similarity calculation. Only use if all samples are of independent origins (not replicates and not multi-region biopsies). |
-i/--input |
If you have already run make_input.sh , you can give the resulting .input file instead of setting --AA_results |
One may wish to compare two overlapping focal amplifications and quantify their similarity - particularly when they are derived from multi-region
or longitudinal sampling. We provide a script which a) identifies overlap between pairs of amplicons (using the same input file as amplicon_classifier.py
),
b) computes measurements of the similarity of the two overlapping amplicons based on shared breakpoints and shared genomic content -
using both a Jaccard index approach and also our own Symmetric Similarity Score and Asymmetric Similarity Score approaches, and c) compares the scores against
the similarity scores for overlapping amplicons derived from unrelated origins (data derived from Turner et al. Nature 2017 and deCarvalho et al. Nature Genetics 2018, Bergstrom et al. Nature 2020 and Paulson et al. Nature Communications 2022).
The output file *_similarity_scores.tsv
reports the following columns:
GenomicSegmentScore1
& GenomicSegmentScore2
based on the directional similarity of genomic segment overlap (Amp1 and Amp2)/(Amp1) or (Amp1 and Amp2)/(Amp2), respectively.BreakpointScore1
& BreakpointScore2
based on the directional similarity of breakpoint matching (Amp1 and Amp2)/(Amp1) or (Amp1 and Amp2)/(Amp2), respectively.JaccardGenomicSegment
, based on overlap of genomic segments (based on overlap of genomic coordinates)JaccardBreakpoint
, based on overlap from matching of breakpoints.The primary difference between amplicon_similarity.py
and feature_similarity.py
is that the latter only considers regions annotated as specific classification features (e.g. ecDNA, BFB) when computing similarity scores.
Example command for feature_similarity.py
$AC_SRC/feature_similarity.py --ref hg38 -f [sample]_features_to_graph.txt --required_classifications [default "any", but can be "ecDNA", "BFB", "CNC", "linear" or any combination of those]
Where "[sample]_features_to_graph.txt" is one of the output files generated by amplicon_classifier.py
. --include_path_in_features
is useful for comparing two runs with the same sample names
(after combining both _features_to_graph.txt
files from each run into one file).
How do I use this to perform similarity score-based filtering on my samples?
To remove potential false-positive focal amplificaiton calls from a collection of samples, we can use the similarity scores and p-value reported by AC. The motivating idea is that in unrelated samples, precisely conserved CN boundaries and SVs should be exceptionally rare unless they are derived from issues with the reference genome. If all samples in the collection are from unrelated sources (no replicates, no multi-region or longitudinal samples, etc.) users can simply run AC on the batch of samples setting the --filter_similar
flag. However, if the collection contains a mixture of samples from related and unrelated sources, then some samples will likely have focal amplifications having a high degree of similarity due to being from related origins. In this case, users can run the feature_similarity.py
script described above on the samples to produce a table of similarity scores and p-values. Users can then filter highly similar focal amplifications from unrelated samples using the p-value in the table. Since this involves multiple hypothesis testing, to control false positive rate, users can mirror what is done by internally by AC and apply a slightly modified Bonferroni correction of alpha/(n-1)
where alpha by default is 0.05 and n
is the number of samples in the collection having a focal amplification.
Info about accessing the legacy version of AmpliconClassifier:
For the legacy version used in Kim et al., Nature Genetics, 2020 please see the scripts and README in the "legacy_natgen_2020" folder of this repo. The legacy version is only recommended for reproducing the paper results, and not for state-of-the-art amplicon classification. The legacy version was developed by Nam Nguyen, Jens Luebeck, and Hoon Kim. The current version was developed by Jens Luebeck and Bhargavi Dameracharla.