The popsize
module is an extension of the snpArcher pipeline designed for automated demographic inference, specifically focused on population size change estimation. It streamlines computational tasks, allowing users to concentrate on the biological implications of their analyses and the relevance of the parameters specified using reference tools and methods in this field.
The primary goal of the popsize
module is to facilitate the estimation of population size changes, addressing key assumptions in population genetics. Users can choose from a suite of powerful demographic inference tools tailored for various data scenarios. The modular design allows customization and parameter adjustments based on specific analysis needs.
- Modularity: The
popsize
module integrates a selection of population size inference approaches, offering flexibility and adaptability to different datasets and situations. - Transparency: Parameters used by the integrated tools are transparent, enabling users to understand and control computational aspects.
- Statistical Insights: The module includes essential statistics such as Site Frequency Spectrum (SFS) and Principal Component Analysis (PCA), aiding in population structure evaluation.
-
PSMC (Pairwise Sequentially Markovian Coalescent)
- Description: PSMC infers population size history from diploid sequences using a pairwise sequentially Markovian coalescent model. It explores scaled mutation and recombination rates, providing insights into demographic changes.
- Reference: GitHub - lh3/psmc
- Citation: Li, H., and R. Durbin. 2011. "Inference of human population history from individual whole-genome sequences." Nature 475: 493–496.
-
MSMC2 (Multiple Sequentially Markovian Coalescent 2)
- Description: MSMC2 extends the MSMC model for inferring population size history and separation from whole-genome sequencing data. It provides accurate estimations for a large number of haplotypes.
- Reference: GitHub - stschiff/msmc2
- Citation: Schiffels, S., and K. Wang. 2020. "MSMC and MSMC2: The Multiple Sequentially Markovian Coalescent." In Statistical Population Genomics, edited by J. Y. Dutheil, 147–166. Methods in Molecular Biology, Springer US, New York, NY.
-
Stairway Plot v2
- Description: Stairway Plot v2 infers detailed population demographic history using the site frequency spectrum (SFS) from DNA sequence data. It can use both folded and unfolded SFSs and controls for overfitting.
- Reference: GitHub - xiaoming-liu/stairway-plot-v2
- Citation: Liu, X., and Y.-X. Fu, 2020 Stairway Plot 2: demographic history inference with folded SNP frequency spectra. Genome Biology 21: 280.
-
dadi-cli (Flexible Python Package for Demographic Inference)
- Description: dadi-cli provides a user-friendly command-line interface for dadi, a flexible Python package for inferring demographic history and the distribution of fitness effects from population genomic data.
- Reference: dadi-cli Documentation
- Citation: Gutenkunst, R. N., R. D. Hernandez, S. H. Williamson, and C. D. Bustamante. 2009. "Inferring the Joint Demographic History of Multiple Populations from Multidimensional SNP Frequency Data." PLOS Genetics 5: e1000695.
-
SMC++ (Sequentially Markovian Coalescent++)
- Description: SMC++ is a tool for estimating the size history of populations from whole-genome sequence data. It offers various subcommands for data conversion, estimation, cross-validation, and joint demography analysis.
- Reference: GitHub - popgenmethods/smcpp
- Citation: Terhorst, J., J. A. Kamm, and Y. S. Song. 2017. "Robust and scalable inference of population history from hundreds of unphased whole genomes." Nat Genet 49: 303–309.
- bin: Contains executable files for the demographic inference tools.
- common.smk: Shared Snakemake rules used across the pipeline.
- config: Configuration files for the module, including
config.yaml
for general settings. - envs: Conda environment files (
deminfhelper.yml
,smcpp.yml
) specifying dependencies for each step. - scripts: Python scripts (
deminfhelper.py
,inferences.py
, etc.) for demographic inference and result visualization, includinggenerate_multihetsep.py
from themsmc-tools
repository. - Snakefile: The main Snakemake workflow file orchestrating the module.
-
Installation:
-
Get snpArcher. You can clone the repository straight from Github to get the latest version, however, popsize has been tested for the snapshot of August, 15th, 2024. So we recommend to get this one for running the test dataset:
wget https://github.com/harvardinformatics/snpArcher/archive/8a0921d9dd094a57570c70815453a93da5a2421d.zip # Rename the directory to make it more convenient mv snpArcher-8a0921d9dd094a57570c70815453a93da5a2421d snpArcher
-
Then unzip it and clone the repository of the
popsize
module undersnpArcher/workflow/modules/
:cd snpArcher/workflow/modules/ git clone https://github.com/tforest/popsize.git
-
-
Configuration of the popsize module:
-
Adjust settings in the
snpArcher/workflow/modules/popsize/config/config.yaml
file to fit your needs. -
Important settings to define in
config.yaml
:## Popsize options # popsize modules to use for inference; can be : dadi, swp2, msmc2, psmc, or smcpp. # Specify multiple tools as comma-separated: "dadi, swp2, psmc" for example. popsize_tools: "dadi, swp2, msmc2, psmc, smcpp" # specify generation time for the studied species. gen_time: 5.6 # specify the average per site per generation mutation rate. mut_rate: 5e-9 # specify whether to use folded SFS or not. folded: True # select the number of runs dadi is executing for its optimization phase dadi_optimizations: 1000
-
-
Integration with snpArcher:
-
Add the following lines to the default snpArcher workflow (
snparcher/workflow/Snakefile
):module popsize: snakefile: "modules/popsize/Snakefile" config: config use rule * from popsize as popsize_*
-
-
Configuration of snpArcher:
- Edit the config/config.yaml file on this lines:
samples: "config/samples.csv"
final_prefix: "picus_viridis"
bigtmp: "/path/to/big/tmp/"
# low coverage options (< 10x)
# Comment those lines for the test dataset
#minP: 1
#minD: 1
# high coverage options (> 10x)
# Uncomment those lines for the test dataset
minP: 2
minD: 4
- Create a config/samples.csv file containing information about your samples, for example:
BioSample,LibraryName,Run,refGenome,BioProject,lat,long
SAMN38508702,JF5345,SRR27195338,GCA_033816785.1,PRJNA1027323,45.06017809409504,3.9699892711638065
SAMN38508701,JF5325,SRR27195328,GCA_033816785.1,PRJNA1027323,46.77012124990864,1.5199570846552257
SAMN38508699,JF5258,SRR27195330,GCA_033816785.1,PRJNA1027323,47.53014126080718,7.480021457672387
SAMN38508698,JF5191,SRR27195331,GCA_033816785.1,PRJNA1027323,48.66014527662619,2.649957084655226
SAMN38508697,JF5180,SRR27195332,GCA_033816785.1,PRJNA1027323,48.92013747575708,2.799967813491419
SAMN38508696,MO1993190,SRR27195333,GCA_033816785.1,PRJNA1027323,47.67014088330744,-1.909978542327613
SAMN38508695,MO1991186,SRR27195334,GCA_033816785.1,PRJNA1027323,48.740152121316086,2.1700321865085805
SAMN38508694,MO1991185,SRR27195335,GCA_033816785.1,PRJNA1027323,45.930167901473105,6.930021457672388
SAMN38508693,MO19711091,SRR27195339,GCA_033816785.1,PRJNA1027323,47.5501050000613,-0.1099570846552259
SAMN38508692,MO19711090,SRR27195341,GCA_033816785.1,PRJNA1027323,48.70013808027695,2.130010728836193
This is an example dataset using Picus viridis samples. (Forest et al., 2024)
You can find more information about the sample sheet in snpArcher documentation.
- Edit the profiles/slurm/config.yaml file on this lines:
latency-wait: 300 # Wait N seconds for output files due to latency
retries: 3 # Retry jobs N times.
mem_mb: attempt * 16000
# If your cluster support no wall time, you could just comment the runtime line.
# If not, and you would like to try the test dataset, you should aim to set
# the runtime up to 3 days, or you would encounter a timeout error.
runtime: 720 # In minutes, here 12h
slurm_partition: YOUR_PARTITION
- Execution:
-
Create a conda env with snakemake>=8.20.
-
Once you activated the conda environment, while in snpArcher/ top directory, run snpArcher until the end of the process. (ie. creation of the VCFs):
snakemake --workflow-profile profiles/slurm
-
Once snpArcher executed properly, you can run popsize using snpArcher output:
snakemake --workflow-profile profiles/slurm --forcerun popsize_all
- Snakemake 8.20.x
If you encounter issues or have suggestions, please open an issue on the GitHub repository.
The popsize
module integrates scripts from the deminfhelper project and msmc-tools project. Please visit snpArcher Github repository for more details on the robust framework that forms the basis of this module.
If you use the snpArcher, please consider citing the following publication:
- Mirchandani, C. D., A. J. Shultz, G. W. C. Thomas, S. J. Smith, M. Baylis et al., 2023. "A fast, reproducible, high-throughput variant calling workflow for population genomics." Molecular Biology and Evolution, msad270.
Popsize integrated tools rely on these published works:
- Gutenkunst, R. N., R. D. Hernandez, S. H. Williamson, and C. D. Bustamante. 2009. "Inferring the Joint Demographic History of Multiple Populations from Multidimensional SNP Frequency Data." PLOS Genetics 5: e1000695.
- Li, H., and R. Durbin. 2011. "Inference of human population history from individual whole-genome sequences." Nature 475: 493–496.
- Schiffels, S., and K. Wang. 2020. "MSMC and MSMC2: The Multiple Sequentially Markovian Coalescent." In Statistical Population Genomics, edited by J. Y. Dutheil, 147–166. Methods in Molecular Biology, Springer US, New York, NY.
- Terhorst, J., J. A. Kamm, and Y. S. Song. 2017. "Robust and scalable inference of population history from hundreds of unphased whole genomes." Nat Genet 49: 303–309.
- Liu, X., and Y.-X. Fu, 2020 Stairway Plot 2: demographic history inference with folded SNP frequency spectra. Genome Biology 21: 280.
The example dataset is taken from this study:
- Forest, T., Achaz, G., Marbouty, M., Bignaud, A., Thierry, A., Koszul, R., Milhes, M., Lledo, J., Pons, J.M., & Fuchs, J. (2024). Chromosome-level genome assembly of the European green woodpecker Picus viridis. G3: Genes, Genomes, Genetics, 14(5), jkae042.