pangrowth is an efficient tool designed for genomic researchers to predict the openness of a pangenome and
estimate the core genome size. This tool is capable of analyzing fasta
sequences using k-mers, as well as other genomic elements such as genes, CDS,
ORFs, provided as either a frequency histogram or a pan-matrix (with columns
representing genomes and rows representing items; see panmatrix_ecoli_n50.txt
for an example).
- k-mer counting: utilizes a modified version of yak to count k-mers
- growth/core calculation: computes the exact expected genomic growth/core size quadratically in the number of genomes
Parmigiani, L., Wittler, R., Stoye, J.,: Revisiting pangenome openness with k-mers. PCI Comp & Biol. (2024).
git clone https://github.com/gi-bielefeld/pangrowth
cd pangrowth
make To plot the results we need the following python libraries: numpy, pandas, matplotlib, scipy and searbon. You can install them with:
pip install -r requirements.txt
./pangrowth hist -k 17 -t 12 data/fa/*.fna.gz > hist.txtpangrowthalso accepts a file containing a list of fasta files (each one on a single line) passed with the paremeter-i fasta_list.txt
To visualize the histogram:
python scripts/plot_hist.py hist.txt hist.pdfIf you have multiple histograms that you want to compare with different number of genomes you can use:
python scripts/plot_hist.py --norm_x --norm_y=both hist.txt data/hist_ecoli_n50.txt data/hist_ecoli_n200.txt hist_multiple.pdf- The flag
--norm_xnormalize the x-axis to be between (0,1]. - The flag
--norm_yallows two types of normalization:multiplicitywhich adjusts each histogram value h[i] multiplying it by its index i (i.e., h[i] * i, this means that values appearing once remain the same, values appearing twice are doubled, and so on)percentagewhich divides the values of h[i] by the total sum of h (its total sum equals 1) The--norm_y=bothapplies both in series.
./pangrowth growth -h data/hist_ecoli_n50.txt > growth.txt
#./pangrowth growth -p data/panmatrix_ecoli_n50.txt > growth.txtTo fit the openness and visualize the growth:
python scripts/plot_growth.py growth.txt growth.pdfWe can again pass multiple growth files to scripts/plot_growth.py to
compare with other species.
python scripts/plot_growth.py growth.txt data/growth_ecoli_n200.txt growth_multiple.pdf./pangrowth core -h data/hist_ecoli_n50.txt > core.txt
#./pangrowth core -p data/panmatrix_ecoli_n50.txt > core.txt
./pangrowth core -h data/hist_ecoli_n50.txt -q 0.9 > core_q90.txt- The
-qtakes a quorum to considered the item in the core (default 1.0).
To fit the core genome and report the percentage of core item over the expected genome size:
python scripts/plot_core.py core_q90.txt data/core_q90_ecoli_n200.txt core.pdfThe expected genome size is calculated as the total sum of the histogram divided by the number of genomes.
For any question, feedback or problem, please feel free to file an issue on Github or contact me here and I will get back to you as soon as possible.
Pangrowth is provided as a service of the German Network for Bioinformatics Infrastructure (de.NBI). We would appriciate if you would participate in the evaluation of Pangrwoth by completing this very short survey.