Check our paper: Puente-Sánchez F, Hoetzinger M, Buck M and Bertilsson S. Exploring intra-species diversity through non-redundant pangenome assemblies Molecular Ecology Resources (2023) DOI: 10.1111/1755-0998.13826
... but note that performance is now better (3x less memory usage, 20% faster execution time) than when we first benchmarked Superpang.
Requires graph-tool, speedict, mOTUlizer v0.2.4, minimap2 2.28 or higher and mappy. The easiest way to get it running is using conda.
# Install into a new conda environment
conda create -n SuperPang -c conda-forge -c bioconda -c fpusan superpang
# Check that it works for you!
conda activate SuperPang
test-SuperPang.py
SuperPang.py --fasta <genome1.fasta> <genome2.fasta> <genomeN.fasta> --checkm <check_results> --output-dir <output_directory>
- The input genomes can be genomes from isolates, MAGs (Metagenome-Assembled Genomes) or SAGs (Single-cell Assembled Genomes).
- The input genomes can have different qualities, for normal usage we recommend that you provide completeness estimates for each input genome through the
-q/--checkm
parameter. - If you are certain that all your input genomes are complete, you can use the
--assume-complete
flag or manually tweak the-a/--genome-assignment-threshold
and-x/--default-completeness
parameters instead of providing a file with completeness estimates. - The default parameter values in SuperPang assume that all of the input genomes come from the same species (ANI>=0.95). This can be controlled by changing the values of the
-i/--identity_threshold
and-b/--bubble-identity-threshold
to the expected ANI. However SuperPang has currently only been tested in species-level clusters.
- -f/--fasta: Input fasta files with the sequences for each bin/genome, or a single file containing the path to one input fasta file per line.
- -q/--checkm: CheckM output for the bins. This can be the STDOUT of running checkm on all the fasta files passed in --fasta, or a tab-delimited file ended with a
.tsv
extension, in the formgenome1 percent_completeness
. Genome names should not contain the file extension (e.g..fna
). If empty, completeness will be estimated by mOTUpan but this may lead to wrong estimations for very incomplete genomes. - -i/--identity_threshold: Identity threshold (fraction) to initiate correction with minimap2. Values of 1 or higher will skip the correction step entirely. Default
0.95
. - -m/--mismatch-size-threshold: Maximum contiguous mismatch size that will be corrected. Default
100
. - -g/--indel-size-threshold: Maximum contiguous indel size that will be corrected. Default
100
. - -r/--correction-repeats: Maximum iterations for sequence correction. Default
20
. - -n/--correction-repeats-min: Minimum iterations for sequence correction. Default
5
. - -k/--ksize: Kmer-size. Default
301
. - -l/--minlen: Scaffold length cutoff. Default
0
(no cutoff). - -c/--mincov: Scaffold coverage cutoff. Default
0
(no cutoff). - -b/--bubble-identity-threshold: Minimum identity (matches / length) required to remove a bubble in the sequence graph. Default
0.95
. - -a/--genome-assignment-threshold. Fraction of shared kmers required to assign a contig to an input genome (0 means a single shared kmer is enough) (DEPRECATED).
- -x/--default-completeness: Default genome completeness to assume if a CheckM output is not provided with --checkm. Default
70
. - -t/--threads: Number of processors to use. Default
1
. - -o/--output: Output directory. Default
output
. - -d/--temp-dir: Directory for temp files. Default
tmp
. - -u/--header-prefix: Prefix to be added to output sequence names. No prefix is added by default.
- --assume-complete: Assume that the input genomes are complete (--default-completeness 99).
- --lowmem: Use disk storages instead of memory when possible, reduces memory usage at the cost of execution time.
- --minimap2-path: Path to the minimap2 executable. Default
minimap2
. - --keep-intermediate: Keep intermediate files.
- --keep-temporary: Keep temporary files.
- --verbose-mOTUpan: Print out mOTUpan logs.
- --nice-headers: Removes semicolons from non-branching-path names.
- --output-as-file-prefix: Use the output dir name also as a prefix for output file names.
- --force-overwrite: Write results even if the output directory already exists.
- --debug: Run additional sanity checks (increases execution time).
assembly.fasta
: contigs.assembly.info
: core/auxiliary and path information for each contig.NBPs.fasta
: non-branching paths.NBPs.core.fasta
: non-branching paths deemed to belong to the core genome of the species by mOTUpan.NBPs.accessory.fasta
: non-branching paths deemed to belong to the accessory genome of the species.NBP2origins.tsv
: tab-separated file with the non-branching path IDs, a comma-separated list of the input sequences in which that NBP was deemed present, a comma-separated list of the input genomes in which that NBP was deemed present, and the number of input genomes in which that NBP was deemed present.graph.fastg
: assembly graph in a format compatible with bandage.graph.NBP2origins.csv
: file with similar structure as NBP2origins.tsv, formatted for use together with the "Load CSV file" option in Bandage. This allows using the information in the file as node labels in Bandage.params.tsv
: parameters used in the run.
SuperPang is developed by Fernando Puente-Sánchez (Sveriges lantbruksuniversitet). Feel free to open an issue or reach out for support fernando.puente.sanchez@slu.se.