Detect CRISPR-Cas genes and arrays, and predict the subtype based on both Cas genes and CRISPR repeat sequence.
CRISPRCasTyper and RepeatType are also available through a webserver
This software finds Cas genes with a large suite of HMMs, then groups these HMMs into operons, and predicts the subtype of the operons based on a scoring scheme. Furthermore, it finds CRISPR arrays with minced and by BLASTing a large suite of known repeats, and using a kmer-based machine learning approach (extreme gradient boosting trees) it predicts the subtype of the CRISPR arrays based on the consensus repeat. It then connects the Cas operons and CRISPR arrays, producing as output:
- CRISPR-Cas loci, with consensus subtype prediction based on both Cas genes (mostly) and CRISPR consensus repeats
- Orphan Cas operons, and their predicted subtype
- Orphan CRISPR arrays, and their predicted associated subtype
It includes the following 50 subtypes/variants (find typing scheme here):
-
I-A, I-B, I-C, I-D, I-E, I-F, I-F (transposon), I-G, II-A, II-B, II-C, II-C2, II-D, III-A, III-B, III-C, III-D, III-E, III-F, IV-A1, IV-A2, IV-A3, IV-B, IV-C, IV-D, IV-E, V-A, V-B1, V-B2, V-C, V-D, V-E, V-F1, V-F2, V-F3, V-F (the rest), V-G, V-H, V-I, V-J, V-K, V-L, V-M, VI-A, VI-B1, VI-B2, VI-C, VI-D, VI-X, VI-Y.
-
All subtypes from the most recent Nature Reviews Microbiology (Makarova et al. 2020): Evolutionary classification of CRISPR–Cas systems: a burst of class 2 and derived variants
-
Updated type IV subtypes and variants based on: Type IV CRISPR–Cas systems are highly diverse and involved in competition between plasmids
-
Type V-K: RNA-guided DNA insertion with CRISPR-associated transposases
-
Transposon associated type I-F: Transposon-encoded CRISPR–Cas systems direct RNA-guided DNA integration
-
New V-A variants: Novel Type V-A CRISPR Effectors Are Active Nucleases with Expanded Targeting Capabilities
-
New Cas13s: Programmable RNA editing with compact CRISPR–Cas13 systems from uncultivated microbes
-
V-L (cas12l): A new family of CRISPR-type V nucleases with C-rich PAM recognition
-
V-M (cas12m): The miniature CRISPR-Cas12m effector binds DNA to block transcription
-
II-D and II-C2: Compact Cas9d and HEARO enzymes for genome editing discovered from uncultivated microbes
Find a free to read version on BioRxiv
- Quick start
- Installation
- CRISPRCasTyper - How to
- RepeatType - How to
- RepeatType - Train
- Troubleshoot
conda create -n cctyper -c conda-forge -c bioconda -c russel88 cctyper
conda activate cctyper
cctyper my.fasta my_output
CRISPRCasTyper can be installed either through conda or pip.
It is advised to use conda, since this installs CRISPRCasTyper and all dependencies, and downloads the database in one go.
Use miniconda or anaconda to install.
Create the environment with CRISPRCasTyper and all dependencies and database
conda create -n cctyper -c conda-forge -c bioconda -c russel88 cctyper
If you have the dependencies (Python >= 3.8, HMMER >= 3.2, Prodigal >= 2.6, minced, grep, sed) in your PATH you can install with pip
Install cctyper python module
python -m pip install cctyper
Upgrade cctyper python module to the latest version
python -m pip install cctyper --upgrade
# Download and unpack
svn checkout https://github.com/Russel88/CRISPRCasTyper/trunk/data
tar -xvzf data/Profiles.tar.gz
mv Profiles/ data/
rm data/Profiles.tar.gz
# Tell CRISPRCasTyper where the data is:
# either by setting an environment variable (has to be done for each terminal session, or added to .bashrc):
export CCTYPER_DB="/path/to/data/"
# or by using the --db argument each time you run CRISPRCasTyper:
cctyper input.fa output --db /path/to/data/
CRISPRCasTyper takes as input a nucleotide fasta, and produces outputs with CRISPR-Cas predictions
conda activate cctyper
cctyper genome.fa my_output
If you have a complete circular genome (each entry in the fasta will be treated as having circular topology)
cctyper genome.fa my_output --circular
The default prodigal mode expects the input to be a single draft or complete genome
cctyper assembly.fa my_output --prodigal meta
cctyper -h
- CRISPR_Cas.tab: CRISPR_Cas loci, with consensus subtype prediction
- Contig: Sequence accession
- Operon: Operon ID (Sequence accession @ NUMBER)
- Operon_Pos: [Start, End] of operon
- Prediction: Consenus prediction based on both Cas operon and CRISPR arrays
- CRISPRs: CRISPRs adjacent to Cas operon
- Distances: Distances to CRISPRs from Cas operon
- Prediction_Cas: Subtype prediction based on Cas operon
- Prediction_CRISPRs: Subtype prediction of CRISPRs based on CRISPR repeat sequences
- cas_operons.tab: All certain Cas operons
- Contig: Sequence accession
- Operon: Operon ID (Sequence accession @ NUMBER)
- Start: Start of operon
- End: End of operon
- Prediction: Subtype prediction
- Complete_Interference: Percent completion of the interference module(s). Can be a list if best_type is a list (Hybrid and Ambiguous)
- Complete_Adaptation: Percent completion of the adaptation module(s). Can be a list if best_type is a list (Hybrid and Ambiguous)
- Best_type: Subtype with the highest score. If the score is high then Prediction = Best_type
- Best_score: Score of the highest scoring subtype
- Genes: List of Cas genes
- Positions: List of Gene IDs for the genes
- E-values: List of E-values for the genes
- CoverageSeq: List of sequence coverages for the genes
- CoverageHMM: List of HMM coverages for the genes
- Strand_Interference: Strand of interference module. 1 is positive strand, -1 is negative strand, 0 is mixed, NA if no interference gene found
- Strand_Adaptation: Strand of adaptation module. 1 is positive strand, -1 is negative strand, 0 is mixed, NA if no adaptation gene found
- crisprs_all.tab: All CRISPR arrays, also false positives
- Contig: Sequence accession
- CRISPR: CRISPR ID (minced: Sequence accession _ NUMBER; repeatBLAST: Sequence accession - NUMBER _ NUMBER)
- Start: Start of CRISPR
- End: End of CRISPR
- Consensus_repeat: Consensus repeat sequence
- N_repeats: Number of repeats
- Repeat_len: Length of repeat sequences
- Spacer_len_avg: Average spacer length
- Repeat_identity: Average identity of repeat sequences
- Spacer_identity: Average identity of spacer sequences
- Spacer_len_sem: Standard error of the mean of spacer lenghts
- Trusted: TRUE/FALSE, is the array trusted. Based on repeat/spacer identity, spacer sem, prediction probability and adjacency to a cas operon
- Prediction: Prediction of the associated subtype based on the repeat sequence
- Subtype: Subtype with highest prediction probability. Prediction = Subtype if Subtype_probability is high
- Subtype_probability: Probability of subtype prediction
- crisprs_near_cas.tab: CRISPRs part of CRISPR-Cas loci
- Same columns as crisprs_all.tab
- crisprs_orphan.tab: Orphan CRISPRs (those not in CRISPR_Cas.tab)
- Same columns as crisprs_all.tab
- crisprs_putative.tab: Low quality CRISPRs. Most likely false positives
- Same columns as crisprs_all.tab
- cas_operons_orphan.tab: Orphan Cas operons (those not in CRISPR_Cas.tab)
- Same columns as cas_operons.tab
- CRISPR_Cas_putative.tab: Putative CRISPR_Cas loci, often lonely Cas genes next to a CRISPR array
- Same columns as CRISPR_Cas.tab
- cas_operons_putative.tab: Putative Cas operons, mostly false positives, but also some ambiguous and partial systems
- Same columns as cas_operons.tab
- spacers/*.fa: Fasta files with all spacer sequences
- hmmer.tab: All HMM vs. ORF matches, unfiltered results
- Hmm: HMM name
- ORF: ORF name (Sequence accession _ Gene ID)
- tlen: ORF length
- qlen: HMM length
- Eval: E-value of alignment
- score: Alignment score
- start: ORF start
- end: ORF end
- Acc: Sequence accession
- Pos: Gene ID
- Cov_seq: Sequence coverage
- Cov_hmm: HMM coverage
- strand: Coding strand is like input (1) or reverse complement (-1)
- genes.tab All genes and their positions
- Contig: Sequence accession
- Start: Start of ORF
- End: End of ORF
- Strand: Coding strand is like input (1) or reverse complement (-1)
- Pos: Gene ID
- arguments.tab: File with arguments given to CRISPRCasTyper
- hmmer.log Error messages from HMMER (only produced if any errors were encountered)
- prodigal.log Log from prodigal
- proteins.faa Protein sequences
- hmmer/*.tab Alignment output from HMMER for each Cas HMM
- minced.out: CRISPR array output from minced
- blast.tab: BLAST output from repeat alignment against flanking regions of cas operons
- Flank....: Fasta of flanking regions near cas operons and BLAST database of this
Files are only created if there is any data. For example, the CRISPR_Cas.tab file is only created if there are any CRISPR-Cas loci.
CRISPRCasTyper will automatically plot a map of the CRISPR-Cas loci, orphan Cas operons, and orphan CRISPR arrays.
These maps can be expanded (--expand N
) by adding unknown genes and genes with alignment scores below the thresholds. This can help in identify potentially un-annotated genes in operons. You can generate new plots without having to re-run the entire pipeline by adding --redo_typing
to the command. This will re-use the mappings and re-type the operons and re-make the plot, based on new thresholds and plot parameters.
The plot below is run with --expand 5000
- Arrays are in alternating black/white displaying the actual number of repeats/spacers, and with their predicted subtype association based on the consensus repeat sequence.
- The interference module is in yellow.
- The adaptation module is in blue.
- Cas6 is in red.
- Accessory genes are in purple
- Genes with alignment scores below the thresholds are lighter and with parentheses around names.
- Unknown genes are in gray (the number matches the genes.tab file)
With an input of CRISPR repeats (one per line, in a simple textfile) RepeatTyper will predict the subtype, based on the kmer composition of the repeat
conda activate cctyper
Run with a simple textfile, containing only CRISPR repeats (in capital letters), one repeat per line.
repeatType repeats.txt
The script prints:
- Repeat sequence
- Predicted subtype
- Probability of prediction
- Predictions with probabilities below 0.75 are uncertain, and should be taken with a grain of salt.
- Prior to version 1.4.0 the curated repeatTyper model was included in CCTyper
- From version 1.4.0 and onwards updated repeatTyper models are included in CCTyper (see more information in the section below)
- The followinig subtypes are included in the updated model as per December 2022:
- I-A, I-B, I-C, I-D, I-E, I-F, I-F (Transposon), I-G
- II-A, II-B, II-C
- III-A, III-B, III-C, III-D, III-E, III-F
- IV-A1, IV-A2, IV-A3, IV-D, IV-E
- V-A, V-B1, V-E, V-F1, V-F2, V-F3, V-F (the rest), V-G, V-I, V-J, V-K
- VI-A, VI-B1, VI-B2, VI-C, VI-D
- This is the accuracy per subtype (on an unseen test dataset):
- I-A 0.76
- I-B 0.81
- I-C 0.97
- I-D 0.86
- I-E 0.95
- I-F 0.96
- I-F_T 0.99
- I-G 0.89
- II-A 0.92
- II-B 0.97
- II-C 0.90
- III-A 0.82
- III-B 0.68
- III-C 0.60
- III-D 0.59
- III-E 1.00
- III-F 0.25
- IV-A1 0.85
- IV-A2 0.68
- IV-A3 0.96
- IV-D 0.85
- IV-E 0.92
- V-A 1.00
- V-B1 0.90
- V-E 0.30
- V-F 0.87
- V-F1 0.87
- V-F2 0.90
- V-F3 0.90
- V-G 0.67
- V-I 0.80
- V-J 0.63
- V-K 0.99
- VI-A 0.96
- VI-B1 0.96
- VI-B2 1.00
- VI-C 0.67
- VI-D 0.97
The CCTyper webserver is crowdsourcing subtyped repeats and includes an updated RepeatTyper model based on a much larger set of repeats and contains additional subtypes compared to the curated RepeatTyper model. This updated model is automatically retrained each month and the models can be downloaded here.
From version 1.4.0 and onwards of CCTyper the newest repeatTyper model is included upon release of the version.
Each model contains a training report (xgb_report), where you can find the training log, and in the bottom the accuracy, both overall and per subtype.
Save the original database files:
mv ${CCTYPER_DB}/type_dict.tab ${CCTYPER_DB}/type_dict_orig.tab
mv ${CCTYPER_DB}/xgb_repeats.model ${CCTYPER_DB}/xgb_repeats_orig.model
Move the new model into the database folder
mv repeat_model/* ${CCTYPER_DB}/
You can train the repeat classifier with your own set of subtyped repeats. With a tab-delimeted input where 1. column contains the subtypes and 2. column contains the CRISPR repeat sequences, RepeatTrain will train a CRISPR repeat classifier that is directly usable for both RepeatTyper and CRISPRCasTyper.
repeatTrain typed_repeats.tab my_classifier
repeatType repeats.txt --db my_classifier
Save the original database files:
mv ${CCTYPER_DB}/type_dict.tab ${CCTYPER_DB}/type_dict_orig.tab
mv ${CCTYPER_DB}/xgb_repeats.model ${CCTYPER_DB}/xgb_repeats_orig.model
Move the new model into the database folder
mv my_classifier/* ${CCTYPER_DB}/
Large metagenomic assemblies with many small contigs can exhaust the RAM on your laptop. Fortunately, as metagenomic contigs are analysed separately (when run with --prodigal meta
) a simple solution is to split the input into smaller chunks (e.g. with pyfasta)