Ancestry inference from genomic data
- Credit
- Description
- Installation
- Dependencies
- Usage
- Human ancestry predictions
- Demo
- Documentation
- Citing
- License
Written by René L Warren and Lauren Coombe
ntRoot is a framework for ancestry inference from genomic data, offering both Local Ancestry Inference (LAI) and Global Ancestry Inference (GAI). Leveraging integrated variant call sets from the 1000 Genomes Project (1kGP), ntRoot provides accurate predictions(1) of human super-population ancestry with speed and efficiency from Whole Genome Sequencing (WGS) datasets and complete or draft-stage Whole Genome Assemblies (WGA). Through streamlined processing and flexible genomic input, ntRoot holds promises for human ancestry inference of small-to-large patient/individual cohorts, enabling association studies with demographics and facilitating deeper insights into population genetics and disease risk factors.
(1) Tested on base-accurate quality data, including Illumina short read and PacBio CCS HiFi long read datasets, complete reference genomes and polished, Oxford Nanopore Technology long read Flye and Shasta draft genome assemblies
Installing ntRoot using conda (recommended):
conda install -c bioconda -c conda-forge ntroot
Installing ntRoot from the source code:
git clone https://github.com/bcgsc/ntRoot.git
cd ntRoot
No compilation is required for ntRoot (only the dependencies), so simply add the ntRoot repository to your PATH.
- python 3.9+
- perl
- ntEdit 2.0.2+
- snakemake
- samtools
- bedtools
usage: ntroot [-h] [-r REFERENCE] [--reads READS] [--genome GENOME [GENOME ...]] -l L [-k K] [--tile TILE] [--lai] [-t T] [-z Z] [-j J] [-Y Y] [--custom_vcf CUSTOM_VCF]
[--strip_info] [-v] [-V] [-n] [-f]
ntRoot: Ancestry inference from genomic data
optional arguments:
-h, --help show this help message and exit
-r REFERENCE, --reference REFERENCE
Reference genome (FASTA, Multi-FASTA, and/or gzipped compatible)
--reads READS Prefix of input reads file(s) for detecting SNVs. All files in the working directory with the specified prefix will be used. (fastq, fasta, gz, bz, zip)
--genome GENOME [GENOME ...]
Genome assembly file(s) for detecting SNVs compared to --reference
-l L input VCF file with annotated variants (e.g., clinvar.vcf, 1000GP_integrated_snv_v2a_27022019.GRCh38.phased_gt1.vcf.gz)
-k K k-mer size
--tile TILE Tile size for ancestry fraction inference (bp) [default=5000000]
--lai Output ancestry predictons per tile in a separate output file
-t T Number of threads [default=4]
-z Z Minimum contig length [default=100]
-j J controls size of k-mer subset. When checking subset of k-mers, check every jth k-mer [default=3]
-Y Y Ratio of number of k-mers in the k subset that should be present to accept an edit (higher=stringent) [default=0.55]
--custom_vcf CUSTOM_VCF
Input VCF for computing ancestry. When specified, ntRoot will skip the ntEdit step, and predict ancestry from the provided VCF.
--strip_info When using --custom_vcf, strip the existing INFO field from the input VCF.
-v, --verbose Verbose mode [default=False]
-V, --version show program's version number and exit
-n, --dry-run Print out the commands that will be executed
-f, --force Run all ntRoot steps, regardless of existing output files
Note: please specify --reads OR --genome (not both)
If you have any questions about ntRoot, please open an issue at https://github.com/bcgsc/ntRoot
Using the 1kGP integrated variant call set.
Download this archive:
wget https://zenodo.org/records/10976332/files/ntroot_supplementary_zenodo.tar.gz
from:
https://zenodo.org/doi/10.5281/zenodo.10869033
unzip and untar:
tar xvzf ntroot_supplementary_zenodo.tar.gz
access the files:
cd ./ntroot_supplementary_zenodo/data ls 1000GP_integrated_snv_v2a_27022019.GRCh38.phased_gt1.vcf.gz GRCh38.fa.gz readme
Users will specify:
ntroot --reference GRCh38.fa.gz (--reads FILE_PREFIX OR --genome FILE) -l 1000GP_integrated_snv_v2a_27022019.GRCh38.phased_gt1.vcf.gz -k 55
Example command:
ntroot -k 55 --reference GRCh38.fa.gz --reads ERR3242308_ -t 48 -Y 0.55 -l 1000GP_integrated_snv_v2a_27022019.GRCh38.phased_gt1.vcf.gz
If you would like to infer ancestry from a pre-existing VCF file:
ntroot -r GRCh38.fa.gz --custom_vcf third_party.vcf -l 1000GP_integrated_snv_v2a_27022019.GRCh38.phased_gt1.vcf.gz
Note: For more advanced users, and for ancestry predictions on organisms other than human, please contact us.
To test your installation:
cd demo
./run_ntroot_demo.sh
Ensure that the ntRoot installation is available on your PATH.
Refer to the README.md file on how to install and run ntRoot. Our preprint contains information about the software and its performance. This PSB2025 poster, also available on zenodo, contains additional information, benchmarks and results.
Thank you for your and for using and promoting this free software! We hope that ntRoot is useful to you and your research.
If you use ntRoot, please cite:
ntRoot: human ancestry inference at scale, from genomic data
Human ancestry inference at scale, from genomic data Warren RL, Coombe L, Wong J, Kazemi P, Birol I. bioRxiv 2024.03.26.586646; doi: https://doi.org/10.1101/2024.03.26.586646
Citing the poster:
Warren R, Coombe L, Wong J et al. ntRoot: Scalable ancestry predictions from genome sequencing data [version 1]. F1000Research 2024, 13:1021 (poster) (https://doi.org/10.7490/f1000research.1119849.1)
ntRoot Copyright (c) 2024-present British Columbia Cancer Agency Branch. All rights reserved.
ntRoot is released under the GNU General Public License v3
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 3.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.
For commercial licensing options, please contact Patrick Rebstein [email protected]