..
This file was automatically generated by docs/create.py.
README
******
.. image:: https://badge.fury.io/py/pypgx.svg
:target: https://badge.fury.io/py/pypgx
.. image:: https://readthedocs.org/projects/pypgx/badge/?version=latest
:target: https://pypgx.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Status
.. image:: https://anaconda.org/bioconda/pypgx/badges/version.svg
:target: https://anaconda.org/bioconda/pypgx
.. image:: https://anaconda.org/bioconda/pypgx/badges/license.svg
:target: https://github.com/sbslee/pypgx/blob/master/LICENSE
.. image:: https://anaconda.org/bioconda/pypgx/badges/downloads.svg
:target: https://anaconda.org/bioconda/pypgx/files
Introduction
============
The main purpose of the PyPGx package is to provide a unified platform for
pharmacogenomics (PGx) research. PyPGx is and always will be completely free
and open source.
The package is written in Python, and supports both command line interface
(CLI) and application programming interface (API) whose documentations are
available at the `Read the Docs <https://pypgx.readthedocs.io/en/latest/>`_.
Quick links:
- `README <https://pypgx.readthedocs.io/en/latest/readme.html>`__
- `Genes <https://pypgx.readthedocs.io/en/latest/genes.html>`__
- `Glossary <https://pypgx.readthedocs.io/en/latest/glossary.html>`__
- `Tutorials <https://pypgx.readthedocs.io/en/latest/tutorials.html>`__
- `CLI <https://pypgx.readthedocs.io/en/latest/cli.html>`__
- `API <https://pypgx.readthedocs.io/en/latest/api.html>`__
- `SDK <https://pypgx.readthedocs.io/en/latest/sdk.html>`__
- `FAQ <https://pypgx.readthedocs.io/en/latest/faq.html>`__
- `Changelog <https://pypgx.readthedocs.io/en/latest/changelog.html>`__
PyPGx can predict PGx genotypes (e.g. ``*4/*5``) and phenotypes (e.g.
``Poor Metabolizer``) using various genomic data, including data from
next-generation sequencing (NGS), single nucleotide polymorphism (SNP) array,
and long-read sequencing. Importantly, for NGS data the package can detect
`structural variation (SV) <https://pypgx.readthedocs.io/en/latest/
glossary.html#structural-variation-sv>`__ using a machine learning-based
approach. Finally, note that PyPGx is compatible with both of the Genome
Reference Consortium Human (GRCh) builds, GRCh37 (hg19) and GRCh38 (hg38).
There are currently 87 pharmacogenes in PyPGx:
.. list-table::
* - ABCB1
- ABCG2
- ACYP2
- ADRA2A
- ADRB2
* - ANKK1
- APOE
- ATM
- BCHE
- BDNF
* - CACNA1S
- CFTR
- COMT
- CYP1A1
- CYP1A2
* - CYP1B1
- CYP2A6/CYP2A7
- CYP2A13
- CYP2B6/CYP2B7
- CYP2C8
* - CYP2C9
- CYP2C19
- CYP2D6/CYP2D7
- CYP2E1
- CYP2F1
* - CYP2J2
- CYP2R1
- CYP2S1
- CYP2W1
- CYP3A4
* - CYP3A5
- CYP3A7
- CYP3A43
- CYP4A11
- CYP4A22
* - CYP4B1
- CYP4F2
- CYP17A1
- CYP19A1
- CYP26A1
* - DBH
- DPYD
- DRD2
- F2
- F5
* - G6PD
- GRIK1
- GRIK4
- GRIN2B
- GSTM1
* - GSTP1
- GSTT1
- HTR1A
- HTR2A
- IFNL3
* - IFNL3
- ITGB3
- ITPA
- MTHFR
- NAT1
* - NAT2
- NUDT15
- OPRK1
- OPRM1
- POR
* - PTGIS
- RARG
- RYR1
- SLC6A4
- SLC15A2
* - SLC22A2
- SLC28A3
- SLC47A2
- SLCO1B1
- SLCO1B3
* - SLCO2B1
- SULT1A1
- TBXAS1
- TPMT
- UGT1A1
* - UGT1A4
- UGT1A6
- UGT2B7
- UGT2B15
- UGT2B17
* - VKORC1
- XPC
-
-
-
Your contributions (e.g. feature ideas, pull requests) are most welcome.
| Author: Seung-been "Steven" Lee
| Email: sbstevenlee@gmail.com
| License: MIT License
Citation
========
If you use PyPGx in a published analysis, please report the program version
and cite the following article:
- Lee et al., 2022. `ClinPharmSeq: A targeted sequencing panel for clinical pharmacogenetics implementation <https://doi.org/10.1371/journal.pone.0272129>`__. PLOS ONE.
In this article, PyPGx was used to call star alleles for genomic DNA
reference materials from the Centers for Disease Control and Prevention–based
`Genetic Testing Reference Materials Coordination Program (GeT-RM)
<https://pypgx.readthedocs.io/en/latest/glossary.html#
genetic-testing-reference-materials-coordination-program-get-rm>`__, where it
showed almost 100% concordance with genotype results from previous works.
The development of PyPGx was heavily inspired by `Stargazer <https://
stargazer.gs.washington.edu/stargazerweb/>`__, another star-allele calling
tool developed by Steven when he was in his PhD program at the University of
Washington. Therefore, please also cite the following articles:
- Lee et al., 2019. `Calling star alleles with Stargazer in 28 pharmacogenes with whole genome sequences <https://doi.org/10.1002/cpt.1552>`__. Clinical Pharmacology & Therapeutics.
- Lee et al., 2018. `Stargazer: a software tool for calling star alleles from next-generation sequencing data using CYP2D6 as a model <https://doi.org/10.1038/s41436-018-0054-0>`__. Genetics in Medicine.
Below is an incomplete list of publications which have used PyPGx:
- Wroblewski et al., 2022. `Pharmacogenetic variation in Neanderthals and Denisovans and implications for human health and response to medications <https://doi.org/10.1101/2021.11.27.470071>`__. bioRxiv.
- Botton et al., 2020. `Phased Haplotype Resolution of the SLC6A4 Promoter Using Long-Read Single Molecule Real-Time (SMRT) Sequencing <https://doi.org/10.3390/genes11111333>`__. Genes.
Support PyPGx
=============
If you find my work useful, please consider becoming a `sponsor <https://github.com/sponsors/sbslee>`__.
Installation
============
Following packages are required to run PyPGx:
.. list-table::
:header-rows: 1
* - Package
- Anaconda
- PyPI
* - ``fuc``
- ✅
- ✅
* - ``scikit-learn``
- ✅
- ✅
* - ``openjdk``
- ✅
- ❌
There are various ways you can install PyPGx. The recommended way is via
conda (`Anaconda <https://www.anaconda.com/>`__):
.. code-block:: text
$ conda install -c bioconda pypgx
Above will automatically download and install all the dependencies as well.
Alternatively, you can use pip (`PyPI <https://pypi.org/>`__) to install
PyPGx and all of its dependencies except ``openjdk`` (i.e. Java JDK must be
installed separately):
.. code-block:: text
$ pip install pypgx
Finally, you can clone the GitHub repository and then install PyPGx locally:
.. code-block:: text
$ git clone https://github.com/sbslee/pypgx
$ cd pypgx
$ pip install .
The nice thing about this approach is that you will have access to
development versions that are not available in Anaconda or PyPI. For example,
you can access a development branch with the ``git checkout`` command. When
you do this, please make sure your environment already has all the
dependencies installed.
.. note::
`Beagle <https://faculty.washington.edu/browning/beagle/beagle.html>`__
is one of the default software tools used by PyPGx for haplotype phasing
SNVs and indels. The program is freely available and published under the
`GNU General Public License <https://faculty.washington.edu/browning/
beagle/gpl_license>`__. Users do not need to download Beagle separately
because a copy of the software (``beagle.22Jul22.46e.jar``) is already
included in PyPGx.
.. warning::
You're not done yet! Keep scrolling down to obtain the resource bundle
for PyPGx, which is essential for running the package.
Resource bundle
===============
Starting with the 0.12.0 version, reference haplotype panel files and
structural variant classifier files in PyPGx are moved to the
``pypgx-bundle`` `repository <https://github.com/sbslee/pypgx-bundle>`__
(only those files are moved; other files such as ``allele-table.csv`` and
``variant-table.csv`` are intact). Therefore, the user must clone the
``pypgx-bundle`` repository with matching PyPGx version to their home
directory in order for PyPGx to correctly access the moved files (i.e. replace
``x.x.x`` with the version number of PyPGx you're using, such as ``0.18.0``):
.. code-block:: text
$ cd ~
$ git clone --branch x.x.x --depth 1 https://github.com/sbslee/pypgx-bundle
This is undoubtedly annoying, but absolutely necessary for portability
reasons because PyPGx has been growing exponentially in file size due to the
increasing number of genes supported and their variation complexity, to the
point where it now exceeds upload size limit for PyPI (100 Mb). After removal
of those files, the size of PyPGx has reduced from >100 Mb to <1 Mb.
Starting with version 0.22.0, you can now specify a custom location for the
``pypgx-bundle`` directory instead of using the home directory. This can be
achieved by setting the bundle location using the ``PYPGX_BUNDLE`` environment
variable:
.. code-block:: text
$ export PYPGX_BUNDLE=/path/to/pypgx-bundle
Structural variation detection
==============================
Many pharmacogenes are known to have `structural variation (SV)
<https://pypgx.readthedocs.io/en/latest/glossary.html#structural-variation-
sv>`__ such as gene deletions, duplications, and hybrids. You can visit the
`Genes <https://pypgx.readthedocs.io/en/latest/genes.html>`__ page to see the
list of genes with SV.
Some of the SV events can be quite challenging to detect accurately with NGS
data due to misalignment of sequence reads caused by sequence homology with
other gene family members (e.g. CYP2D6 and CYP2D7). PyPGx attempts to address
this issue by training a `support vector machine (SVM) <https://scikit-
learn.org/stable/modules/generated/sklearn.svm.SVC.html>`__-based multiclass
classifier using the `one-vs-rest strategy <https://scikit-learn.org/stable
/modules/generated/sklearn.multiclass.OneVsRestClassifier.html>`__ for each
gene for each GRCh build. Each classifier is trained using copy number
profiles of real NGS samples as well as simulated ones, including those from
`1KGP <https://pypgx.readthedocs.io/en/latest/glossary.html#genomes-project-
1kgp>`__ and `GeT-RM <https://pypgx.readthedocs.io/en/latest/
glossary.html#genetic-testing-reference-materials-coordination-program-get-rm>`__.
You can plot copy number profile and allele fraction profile with PyPGx to
visually inspect SV calls. Below are CYP2D6 examples:
.. list-table::
:header-rows: 1
:widths: 10 30 60
* - SV Name
- Gene Model
- Profile
* - Normal
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-1.png
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-8.png
* - WholeDel1
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-2.png
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-1.png
* - WholeDel1Hom
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-3.png
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-6.png
* - WholeDup1
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-4.png
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-2.png
* - Tandem3
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-11.png
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-9.png
* - Tandem2C
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-10.png
- .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-7.png
PyPGx was recently applied to the entire high-coverage WGS dataset from 1KGP
(N=2,504). Click `here <https://github.com/sbslee/1kgp-pgx-paper/tree/main/
sv-tables>`__ to see individual SV calls, and corresponding copy number
profiles and allele fraction profiles.
GRCh37 vs. GRCh38
=================
When working with PGx data, it's not uncommon to encounter a situation
where you are handling GRCh37 data in one project but GRCh38 in another. You
may be tempted to use tools like ``LiftOver`` to convert GRCh37 to GRCh38, or
vice versa, but deep down you know it's going to be a mess (and please don't
do this). The good news is, PyPGx supports both of the builds!
In many PyPGx actions, you can simply indicate which genome build to use. For
example, for GRCh38 data you can use ``--assembly GRCh38`` in CLI and
``assembly='GRCh38'`` in API. **Note that GRCh37 will always be the
default.** Below is an example of using the API:
.. code:: python3
>>> import pypgx
>>> pypgx.list_variants('CYP2D6', alleles=['*4'], assembly='GRCh37')
['22-42524947-C-T']
>>> pypgx.list_variants('CYP2D6', alleles=['*4'], assembly='GRCh38')
['22-42128945-C-T']
However, there is one important caveat to consider if your sequencing data is
GRCh38. That is, sequence reads must be aligned only to the main contigs
(i.e. ``chr1``, ``chr2``, ..., ``chrX``, ``chrY``), and not to the
alternative (ALT) contigs such as ``chr1_KI270762v1_alt``. This is because
the presence of ALT contigs reduces the sensitivity of variant calling
and many other analyses including SV detection. Therefore, if you have
sequencing data in GRCh38, make sure it's aligned to the main contigs only.
The only exception to above rule is the GSTT1 gene, which is located on
``chr22`` for GRCh37 but on ``chr22_KI270879v1_alt`` for GRCh38. This gene is
known to have an extremely high rate of gene deletion polymorphism in the
population and thus requires SV analysis. Therefore, if you are interested in
genotyping this gene with GRCh38 data, then you must include that contig
when performing read alignment. To this end, you can easily filter your
reference FASTA file before read alignment so that it only contains the main
contigs plus the ALT contig. If you don't know how to do this, here's one way
using the ``fuc`` program (which should have already been installed along
with PyPGx):
.. code-block:: text
$ cat contigs.list
chr1
chr2
...
chrX
chrY
chr22_KI270879v1_alt
$ fuc fa-filter in.fa --contigs contigs.list > out.fa
Archive file, semantic type, and metadata
=========================================
In order to efficiently store and transfer data, PyPGx uses the ZIP archive
file format (``.zip``) which supports lossless data compression. Each archive
file created by PyPGx has a metadata file (``metadata.txt``) and a data file
(e.g. ``data.tsv``, ``data.vcf``). A metadata file contains important
information about the data file within the same archive, which is expressed
as pairs of ``=``-separated keys and values (e.g. ``Assembly=GRCh37``):
.. list-table::
:widths: 20 40 40
:header-rows: 1
* - Metadata
- Description
- Examples
* - ``Assembly``
- Reference genome assembly.
- ``GRCh37``, ``GRCh38``
* - ``Control``
- Control gene.
- ``VDR``, ``chr1:10000-20000``
* - ``Gene``
- Target gene.
- ``CYP2D6``, ``GSTT1``
* - ``Platform``
- Genotyping platform.
- ``WGS``, ``Targeted``, ``Chip``, ``LongRead``
* - ``Program``
- Name of the phasing program.
- ``Beagle``, ``SHAPEIT``
* - ``Samples``
- Samples used for inter-sample normalization.
- ``NA07000,NA10854,NA11993``
* - ``SemanticType``
- Semantic type of the archive.
- ``CovFrame[CopyNumber]``, ``Model[CNV]``
Semantic types
--------------
Notably, all archive files have defined semantic types, which allows us to
ensure that the data that is passed to a PyPGx command (CLI) or method (API)
is meaningful for the operation that will be performed. Below is a list of
currently defined semantic types:
- ``CovFrame[CopyNumber]``
* CovFrame for storing target gene's per-base copy number which is computed from read depth with control statistics.
* Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Platform``, ``Control``, ``Samples``.
- ``CovFrame[DepthOfCoverage]``
* CovFrame for storing read depth for all target genes with SV.
* Requires following metadata: ``Assembly``, ``SemanticType``, ``Platform``.
- ``CovFrame[ReadDepth]``
* CovFrame for storing read depth for single target gene.
* Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Platform``.
- ``Model[CNV]``
* Model for calling CNV in target gene.
* Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Control``.
- ``SampleTable[Alleles]``
* TSV file for storing target gene's candidate star alleles for each sample.
* Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``, ``Program``.
- ``SampleTable[CNVCalls]``
* TSV file for storing target gene's CNV call for each sample.
* Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Control``.
- ``SampleTable[Genotypes]``
* TSV file for storing target gene's genotype call for each sample.
* Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``.
- ``SampleTable[Phenotypes]``
* TSV file for storing target gene's phenotype call for each sample.
* Requires following metadata: ``Gene``, ``SemanticType``.
- ``SampleTable[Results]``
* TSV file for storing various results for each sample.
* Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``.
- ``SampleTable[Statistics]``
* TSV file for storing control gene's various statistics on read depth for each sample. Used for converting target gene's read depth to copy number.
* Requires following metadata: ``Control``, ``Assembly``, ``SemanticType``, ``Platform``.
- ``VcfFrame[Consolidated]``
* VcfFrame for storing target gene's consolidated variant data.
* Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``, ``Program``.
- ``VcfFrame[Imported]``
* VcfFrame for storing target gene's raw variant data.
* Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``.
- ``VcfFrame[Phased]``
* VcfFrame for storing target gene's phased variant data.
* Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``, ``Program``.
Working with archive files
--------------------------
To demonstrate how easy it is to work with PyPGx archive files, below we will
show some examples. First, download an archive to play with, which has
``SampleTable[Results]`` as semantic type:
.. code-block:: text
$ wget https://raw.githubusercontent.com/sbslee/pypgx-data/main/getrm-wgs-tutorial/grch37-CYP2D6-results.zip
Let's print its metadata:
.. code-block:: text
$ pypgx print-metadata grch37-CYP2D6-results.zip
Gene=CYP2D6
Assembly=GRCh37
SemanticType=SampleTable[Results]
Now print its main data (but display first sample only):
.. code-block:: text
$ pypgx print-data grch37-CYP2D6-results.zip | head -n 2
Genotype Phenotype Haplotype1 Haplotype2 AlternativePhase VariantData CNV
HG00276_PyPGx *4/*5 Poor Metabolizer *4;*10;*74;*2; *10;*74;*2; ; *4:22-42524947-C-T:0.913;*10:22-42526694-G-A,22-42523943-A-G:1.0,1.0;*74:22-42525821-G-T:1.0;*2:default; DeletionHet
We can unzip it to extract files inside (note that ``tmpcty4c_cr`` is the
original folder name):
.. code-block:: text
$ unzip grch37-CYP2D6-results.zip
Archive: grch37-CYP2D6-results.zip
inflating: tmpcty4c_cr/metadata.txt
inflating: tmpcty4c_cr/data.tsv
We can now directly interact with the files:
.. code-block:: text
$ cat tmpcty4c_cr/metadata.txt
Gene=CYP2D6
Assembly=GRCh37
SemanticType=SampleTable[Results]
$ head -n 2 tmpcty4c_cr/data.tsv
Genotype Phenotype Haplotype1 Haplotype2 AlternativePhase VariantData CNV
HG00276_PyPGx *4/*5 Poor Metabolizer *4;*10;*74;*2; *10;*74;*2; ; *4:22-42524947-C-T:0.913;*10:22-42526694-G-A,22-42523943-A-G:1.0,1.0;*74:22-42525821-G-T:1.0;*2:default; DeletionHet
We can easily create a new archive:
.. code-block:: text
$ zip -r grch37-CYP2D6-results-new.zip tmpcty4c_cr
adding: tmpcty4c_cr/ (stored 0%)
adding: tmpcty4c_cr/metadata.txt (stored 0%)
adding: tmpcty4c_cr/data.tsv (deflated 84%)
$ pypgx print-metadata grch37-CYP2D6-results-new.zip
Gene=CYP2D6
Assembly=GRCh37
SemanticType=SampleTable[Results]
Phenotype prediction
====================
Many genes in PyPGx have a genotype-phenotype table available from the
Clinical Pharmacogenetics Implementation Consortium (CPIC) or
the Pharmacogenomics Knowledge Base (PharmGKB). PyPGx uses these tables to
perform phenotype prediction with one of the two methods:
- Method 1. Simple diplotype-phenotype mapping: This method directly uses the
diplotype-phenotype mapping as defined by CPIC or PharmGKB. Using the
CYP2B6 gene as an example, the diplotypes \*6/\*6, \*1/\*29, \*1/\*2,
\*1/\*4, and \*4/\*4 correspond to Poor Metabolizer, Intermediate
Metabolizer, Normal Metabolizer, Rapid Metabolizer, and Ultrarapid
Metabolizer.
- Method 2. Summation of haplotype activity scores: This method uses a
standard unit of enzyme activity known as an activity score. Using the
CYP2D6 gene as an example, the fully functional reference \*1 allele is
assigned a value of 1, decreased-function alleles such as \*9 and \*17
receive a value of 0.5, and nonfunctional alleles including \*4 and \*5
have a value of 0. The sum of values assigned to both alleles constitutes
the activity score of a diplotype. Consequently, subjects with \*1/\*1,
\*1/\*4, and \*4/\*5 diplotypes have an activity score of 2 (Normal
Metabolizer), 1 (Intermediate Metabolizer), and 0 (Poor Metabolizer),
respectively.
Please visit the `Genes <https://pypgx.readthedocs.io/en/latest/
genes.html>`__ page to see the list of genes with a genotype-phenotype
table and each of their prediction method.
To perform phenotype prediction with the API, you can use the
``pypgx.predict_phenotype`` method:
.. code:: python3
>>> import pypgx
>>> pypgx.predict_phenotype('CYP2D6', '*4', '*5') # Both alleles have no function
'Poor Metabolizer'
>>> pypgx.predict_phenotype('CYP2D6', '*5', '*4') # The order of alleles does not matter
'Poor Metabolizer'
>>> pypgx.predict_phenotype('CYP2D6', '*1', '*22') # *22 has uncertain function
'Indeterminate'
>>> pypgx.predict_phenotype('CYP2D6', '*1', '*1x2') # Gene duplication
'Ultrarapid Metabolizer'
To perform phenotype prediction with the CLI, you can use the
``call-phenotypes`` command. It takes a ``SampleTable[Genotypes]`` file as
input and outputs a ``SampleTable[Phenotypes]`` file:
.. code-block:: text
$ pypgx call-phenotypes genotypes.zip phenotypes.zip
Pipelines
=========
PyPGx currently provides three pipelines for performing PGx genotype analysis
of single gene for one or multiple samples: NGS pipeline, chip pipeline, and
long-read pipeline. In additional to genotyping, each pipeline will perform
phenotype prediction based on genotype results. All pipelines are compatible
with both GRCh37 and GRCh38 (e.g. for GRCh38 use ``--assembly GRCh38`` in CLI
and ``assembly='GRCh38'`` in API).
NGS pipeline
------------
.. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/flowchart-ngs-pipeline.png
Implemented as ``pypgx run-ngs-pipeline`` in CLI and
``pypgx.pipeline.run_ngs_pipeline`` in API, this pipeline is designed for
processing short-read data (e.g. Illumina). Users must specify whether the
input data is from whole genome sequencing (WGS) or targeted sequencing
(custom targeted panel sequencing or whole exome sequencing).
This pipeline supports SV detection based on copy number analysis for genes
that are known to have SV. Therefore, if the target gene is associated with
SV (e.g. CYP2D6) it's strongly recommended to provide a
``CovFrame[DepthOfCoverage]`` file and a ``SampleTable[Statistics]`` file in
addtion to a VCF file containing SNVs/indels. If the target gene is not
associated with SV (e.g. CYP3A5) providing a VCF file alone is enough. You can
visit the `Genes <https://pypgx.readthedocs.io/en/latest/genes.html>`__ page
to see the full list of genes with SV. For details on SV detection algorithm,
please see the `Structural variation detection <https://pypgx.readthedocs.io/
en/latest/readme.html#structural-variation-detection>`__ section.
When creating a VCF file (containing SNVs/indels) from BAM files, users have
a choice to either use the ``pypgx create-input-vcf`` command (strongly
recommended) or a variant caller of their choice (e.g. GATK4
HaplotypeCaller). See the `Variant caller choice <https://pypgx.readthedocs.
io/en/latest/faq.html#variant-caller-choice>`__ section for detailed
discussion on when to use either option.
Check out the `GeT-RM WGS tutorial <https://pypgx.readthedocs.io/en/latest/
tutorials.html#get-rm-wgs-tutorial>`__ to see this pipeline in action.
Chip pipeline
-------------
.. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/flowchart-chip-pipeline.png
Implemented as ``pypgx run-chip-pipeline`` in CLI and
``pypgx.pipeline.run_chip_pipeline`` in API, this pipeline is designed for
DNA chip data (e.g. Global Screening Array from Illumina). It's recommended
to perform variant imputation on the input VCF prior to feeding it to the
pipeline using a large reference haplotype panel (e.g. `TOPMed Imputation
Server <https://imputation.biodatacatalyst.nhlbi.nih.gov/>`__).
Alternatively, it's possible to perform variant imputation with the 1000
Genomes Project (1KGP) data as reference within PyPGx using ``--impute`` in
CLI and ``impute=True`` in API.
The pipeline currently does not support SV detection. Please post a GitHub
issue if you want to contribute your development skills and/or data for
devising an SV detection algorithm.
Check out the `Coriell Affy tutorial <https://pypgx.readthedocs.io/en/latest/
tutorials.html#coriell-affy-tutorial>`__ to see this pipeline in action.
Long-read pipeline
------------------
.. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/flowchart-long-read-pipeline.png
Implemented as ``pypgx run-long-read-pipeline`` in CLI and
``pypgx.pipeline.run_long_read_pipeline`` in API, this pipeline is designed
for long-read data (e.g. Pacific Biosciences and Oxford Nanopore
Technologies). The input VCF must be phased using a read-backed haplotype
phasing tool such as `WhatsHap <https://github.com/whatshap/whatshap>`__.
The pipeline currently does not support SV detection. Please post a GitHub
issue if you want to contribute your development skills and/or data for
devising an SV detection algorithm.
Results interpretation
======================
PyPGx outputs per-sample genotype results in a table, which is stored in an
archive file with the semantic type ``SampleTable[Results]``. Below, we will
use the CYP2D6 gene with GRCh37 as an example to illustrate how to interpret
genotype results from PyPGx.
.. list-table::
:header-rows: 1
* -
- Genotype
- Phenotype
- Haplotype1
- Haplotype2
- AlternativePhase
- VariantData
- CNV
* - NA11839
- \*1/\*2
- Normal Metabolizer
- \*1;
- \*2;
- ;
- \*1:22-42522613-G-C,22-42523943-A-G:0.5,0.488;\*2:default
- Normal
* - NA12006
- \*4/\*41
- Intermediate Metabolizer
- \*41;\*2;
- \*4;\*10;\*2;
- \*69;
- \*69:22-42526694-G-A,22-42523805-C-T:0.5,0.551;\*4:22-42524947-C-T:0.444;\*10:22-42523943-A-G,22-42526694-G-A:0.55,0.5;\*41:22-42523805-C-T:0.551;\*2:default;
- Normal
* - HG00276
- \*4/\*5
- Poor Metabolizer
- \*4;\*10;\*74;\*2;
- \*10;\*74;\*2;
- ;
- \*4:22-42524947-C-T:0.913;\*10:22-42523943-A-G,22-42526694-G-A:1.0,1.0;\*74:22-42525821-G-T:1.0;\*2:default;
- WholeDel1
* - NA19207
- \*2x2/\*10
- Normal Metabolizer
- \*10;\*2;
- \*2;
- ;
- \*10:22-42523943-A-G,22-42526694-G-A:0.361,0.25;\*2:default;
- WholeDup1
This list explains each of the columns in the example results.
- **Genotype**: Diplotype call. When there is no SV this simply combines the two top-ranked star alleles from **Haplotype1** and **Haplotype2** with the delimiter '/'. In the presence of SV the final diplotype is determined using one of the genotypers in the ``pypgx.api.genotype`` module (e.g. `CYP2D6Genotyper <https://pypgx.readthedocs.io/en/latest/api.html#pypgx.api.genotype.CYP2D6Genotyper>`__).
- **Phenotype**: Phenotype call.
- **Haplotype1**, **Haplotype2**: List of candidate star alleles for each haplotype. For example, if a given haplotype contains three variants ``22-42523943-A-G``, ``22-42524947-C-T``, and ``22-42526694-G-A``, then it will get assigned ``*4;*10;`` because the haplotype pattern can fit both \*4 (``22-42524947-C-T``) and \*10 (``22-42523943-A-G`` and ``22-42526694-G-A``). Note that \*4 comes first before \*10 because it has higher priority for reporting purposes (see the ``pypgx.sort_alleles`` `method <https://pypgx.readthedocs.io/en/latest/api.html#pypgx.api.core.sort_alleles>`__ for detailed implementation).
- **AlternativePhase**: List of star alleles that could be missed due to potentially incorrect statistical phasing. For example, let's assume that statistical phasing has put ``22-42526694-G-A`` for **Haplotype1** and ``22-42523805-C-T`` for **Haplotype2**. Even though the two variants are in trans orientation, PyPGx will also consider alternative phase in case the two variants are actually in cis orientation, resulting in ``*69;`` as **AlternativePhase** because \*69 is defined by ``22-42526694-G-A`` and ``22-42523805-C-T``.
- **VariantData**: Information for SNVs/indels used to define observed star alleles, including allele fraction which is important for allelic decomposition after identifying CNV (e.g. the sample NA19207). In some situations, there will not be any variants for a given star allele because the allele itself is "default" allele for the selected reference assembly (e.g. GRCh37 has \*2 as default while GRCh38 has \*1).
- **CNV**: Structural variation call. See the `Structural variation detection <https://pypgx.readthedocs.io/en/latest/readme.html#structural-variation-detection>`__ section for more details.
Getting help
============
For detailed documentations on the CLI and API, please refer to the
`Read the Docs <https://pypgx.readthedocs.io/en/latest/>`_.
For getting help on the CLI:
.. code-block:: text
$ pypgx -h
usage: pypgx [-h] [-v] COMMAND ...
positional arguments:
COMMAND
call-genotypes Call genotypes for target gene.
call-phenotypes Call phenotypes for target gene.
combine-results Combine various results for target gene.
compare-genotypes Calculate concordance between two genotype results.
compute-control-statistics
Compute summary statistics for control gene from BAM
files.
compute-copy-number
Compute copy number from read depth for target gene.
compute-target-depth
Compute read depth for target gene from BAM files.
create-consolidated-vcf
Create a consolidated VCF file.
create-input-vcf Call SNVs/indels from BAM files for all target genes.
create-regions-bed Create a BED file which contains all regions used by
PyPGx.
estimate-phase-beagle
Estimate haplotype phase of observed variants with
the Beagle program.
filter-samples Filter Archive file for specified samples.
import-read-depth Import read depth data for target gene.
import-variants Import SNV/indel data for target gene.
plot-bam-copy-number
Plot copy number profile from CovFrame[CopyNumber].
plot-bam-read-depth
Plot read depth profile with BAM data.
plot-cn-af Plot both copy number profile and allele fraction
profile in one figure.
plot-vcf-allele-fraction
Plot allele fraction profile with VCF data.
plot-vcf-read-depth
Plot read depth profile with VCF data.
predict-alleles Predict candidate star alleles based on observed
variants.
predict-cnv Predict CNV from copy number data for target gene.
prepare-depth-of-coverage
Prepare a depth of coverage file for all target
genes with SV from BAM files.
print-data Print the main data of specified archive.
print-metadata Print the metadata of specified archive.
run-chip-pipeline Run genotyping pipeline for chip data.
run-long-read-pipeline
Run genotyping pipeline for long-read sequencing data.
run-ngs-pipeline Run genotyping pipeline for NGS data.
slice-bam Slice BAM file for all genes used by PyPGx.
test-cnv-caller Test CNV caller for target gene.
train-cnv-caller Train CNV caller for target gene.
options:
-h, --help Show this help message and exit.
-v, --version Show the version number and exit.
For getting help on a specific command (e.g. call-genotypes):
.. code-block:: text
$ pypgx call-genotypes -h
Below is the list of submodules available in the API:
- **core** : The core submodule is the main suite of tools for PGx research.
- **genotype** : The genotype submodule is primarily used to make final diplotype calls by interpreting candidate star alleles and/or detected structural variants.
- **pipeline** : The pipeline submodule is used to provide convenient methods that combine multiple PyPGx actions and automatically handle semantic types.
- **plot** : The plot submodule is used to plot various kinds of profiles such as read depth, copy number, and allele fraction.
- **utils** : The utils submodule contains main actions of PyPGx.
For getting help on a specific submodule (e.g. ``utils``):
.. code:: python3
>>> from pypgx.api import utils
>>> help(utils)
For getting help on a specific method (e.g. ``pypgx.predict_phenotype``):
.. code:: python3
>>> import pypgx
>>> help(pypgx.predict_phenotype)
In Jupyter Notebook and Lab, you can see the documentation for a python
function by hitting ``SHIFT + TAB``. Hit it twice to expand the view.
CLI examples
============
We can print the metadata of an archive file:
.. code-block:: text
$ pypgx print-metadata grch37-depth-of-coverage.zip
Above will print:
.. code-block:: text
Assembly=GRCh37
SemanticType=CovFrame[DepthOfCoverage]
Platform=WGS
We can run the NGS pipeline for the CYP2D6 gene:
.. code-block:: text
$ pypgx run-ngs-pipeline \
CYP2D6 \
grch37-CYP2D6-pipeline \
--variants grch37-variants.vcf.gz \
--depth-of-coverage grch37-depth-of-coverage.zip \
--control-statistics grch37-control-statistics-VDR.zip
Above will create a number of archive files:
.. code-block:: text
Saved VcfFrame[Imported] to: grch37-CYP2D6-pipeline/imported-variants.zip
Saved VcfFrame[Phased] to: grch37-CYP2D6-pipeline/phased-variants.zip
Saved VcfFrame[Consolidated] to: grch37-CYP2D6-pipeline/consolidated-variants.zip
Saved SampleTable[Alleles] to: grch37-CYP2D6-pipeline/alleles.zip
Saved CovFrame[ReadDepth] to: grch37-CYP2D6-pipeline/read-depth.zip
Saved CovFrame[CopyNumber] to: grch37-CYP2D6-pipeline/copy-number.zip
Saved SampleTable[CNVCalls] to: grch37-CYP2D6-pipeline/cnv-calls.zip
Saved SampleTable[Genotypes] to: grch37-CYP2D6-pipeline/genotypes.zip
Saved SampleTable[Phenotypes] to: grch37-CYP2D6-pipeline/phenotypes.zip
Saved SampleTable[Results] to: grch37-CYP2D6-pipeline/results.zip
API examples
============
We can obtain allele function for the CYP2D6 gene:
.. code:: python3
>>> import pypgx
>>> pypgx.get_function('CYP2D6', '*1')
'Normal Function'
>>> pypgx.get_function('CYP2D6', '*4')
'No Function'
>>> pypgx.get_function('CYP2D6', '*22')
'Uncertain Function'
>>> pypgx.get_function('CYP2D6', '*140')
'Unknown Function'
We can predict phenotype for CYP2D6 based on two haplotype calls:
.. code:: python3
>>> import pypgx
>>> pypgx.predict_phenotype('CYP2D6', '*4', '*5') # Both alleles have no function
'Poor Metabolizer'
>>> pypgx.predict_phenotype('CYP2D6', '*5', '*4') # The order of alleles does not matter
'Poor Metabolizer'
>>> pypgx.predict_phenotype('CYP2D6', '*1', '*22') # *22 has uncertain function
'Indeterminate'
>>> pypgx.predict_phenotype('CYP2D6', '*1', '*1x2') # Gene duplication
'Ultrarapid Metabolizer'
We can also obtain recommendation (e.g. CPIC) for certain drug-phenotype combination:
.. code:: python3
>>> import pypgx
>>> # Codeine, an opiate and prodrug of morphine, is metabolized by CYP2D6
>>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Normal Metabolizer')
'Use codeine label recommended age- or weight-specific dosing.'
>>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Ultrarapid Metabolizer')
'Avoid codeine use because of potential for serious toxicity. If opioid use is warranted, consider a non-tramadol opioid.'
>>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Poor Metabolizer')
'Avoid codeine use because of possibility of diminished analgesia. If opioid use is warranted, consider a non-tramadol opioid.'
>>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Indeterminate')
'None'
Raw data
{
"_id": null,
"home_page": "https://github.com/sbslee/pypgx",
"name": "pypgx",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": null,
"author": "Seung-been \"Steven\" Lee",
"author_email": "sbstevenlee@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/08/d5/407fa3e8c151f3b2c548b7567e3bf0cee0500e120146b0440d622abe3d1b/pypgx-0.25.0.tar.gz",
"platform": null,
"description": "..\n This file was automatically generated by docs/create.py.\n\nREADME\n******\n\n.. image:: https://badge.fury.io/py/pypgx.svg\n :target: https://badge.fury.io/py/pypgx\n\n.. image:: https://readthedocs.org/projects/pypgx/badge/?version=latest\n :target: https://pypgx.readthedocs.io/en/latest/?badge=latest\n :alt: Documentation Status\n\n.. image:: https://anaconda.org/bioconda/pypgx/badges/version.svg\n :target: https://anaconda.org/bioconda/pypgx\n\n.. image:: https://anaconda.org/bioconda/pypgx/badges/license.svg\n :target: https://github.com/sbslee/pypgx/blob/master/LICENSE\n\n.. image:: https://anaconda.org/bioconda/pypgx/badges/downloads.svg\n :target: https://anaconda.org/bioconda/pypgx/files\n\nIntroduction\n============\n\nThe main purpose of the PyPGx package is to provide a unified platform for\npharmacogenomics (PGx) research. PyPGx is and always will be completely free\nand open source.\n\nThe package is written in Python, and supports both command line interface\n(CLI) and application programming interface (API) whose documentations are\navailable at the `Read the Docs <https://pypgx.readthedocs.io/en/latest/>`_.\n\nQuick links:\n\n- `README <https://pypgx.readthedocs.io/en/latest/readme.html>`__\n- `Genes <https://pypgx.readthedocs.io/en/latest/genes.html>`__\n- `Glossary <https://pypgx.readthedocs.io/en/latest/glossary.html>`__\n- `Tutorials <https://pypgx.readthedocs.io/en/latest/tutorials.html>`__\n- `CLI <https://pypgx.readthedocs.io/en/latest/cli.html>`__\n- `API <https://pypgx.readthedocs.io/en/latest/api.html>`__\n- `SDK <https://pypgx.readthedocs.io/en/latest/sdk.html>`__\n- `FAQ <https://pypgx.readthedocs.io/en/latest/faq.html>`__\n- `Changelog <https://pypgx.readthedocs.io/en/latest/changelog.html>`__\n\nPyPGx can predict PGx genotypes (e.g. ``*4/*5``) and phenotypes (e.g.\n``Poor Metabolizer``) using various genomic data, including data from\nnext-generation sequencing (NGS), single nucleotide polymorphism (SNP) array,\nand long-read sequencing. Importantly, for NGS data the package can detect\n`structural variation (SV) <https://pypgx.readthedocs.io/en/latest/\nglossary.html#structural-variation-sv>`__ using a machine learning-based\napproach. Finally, note that PyPGx is compatible with both of the Genome\nReference Consortium Human (GRCh) builds, GRCh37 (hg19) and GRCh38 (hg38).\n\nThere are currently 87 pharmacogenes in PyPGx:\n\n.. list-table::\n\n * - ABCB1\n - ABCG2\n - ACYP2\n - ADRA2A\n - ADRB2\n * - ANKK1\n - APOE\n - ATM\n - BCHE\n - BDNF\n * - CACNA1S\n - CFTR\n - COMT\n - CYP1A1\n - CYP1A2\n * - CYP1B1\n - CYP2A6/CYP2A7\n - CYP2A13\n - CYP2B6/CYP2B7\n - CYP2C8\n * - CYP2C9\n - CYP2C19\n - CYP2D6/CYP2D7\n - CYP2E1\n - CYP2F1\n * - CYP2J2\n - CYP2R1\n - CYP2S1\n - CYP2W1\n - CYP3A4\n * - CYP3A5\n - CYP3A7\n - CYP3A43\n - CYP4A11\n - CYP4A22\n * - CYP4B1\n - CYP4F2\n - CYP17A1\n - CYP19A1\n - CYP26A1\n * - DBH\n - DPYD\n - DRD2\n - F2\n - F5\n * - G6PD\n - GRIK1\n - GRIK4\n - GRIN2B\n - GSTM1\n * - GSTP1\n - GSTT1\n - HTR1A\n - HTR2A\n - IFNL3\n * - IFNL3\n - ITGB3\n - ITPA\n - MTHFR\n - NAT1\n * - NAT2\n - NUDT15\n - OPRK1\n - OPRM1\n - POR\n * - PTGIS\n - RARG\n - RYR1\n - SLC6A4\n - SLC15A2\n * - SLC22A2\n - SLC28A3\n - SLC47A2\n - SLCO1B1\n - SLCO1B3\n * - SLCO2B1\n - SULT1A1\n - TBXAS1\n - TPMT\n - UGT1A1\n * - UGT1A4\n - UGT1A6\n - UGT2B7\n - UGT2B15\n - UGT2B17\n * - VKORC1\n - XPC\n -\n -\n -\n\nYour contributions (e.g. feature ideas, pull requests) are most welcome.\n\n| Author: Seung-been \"Steven\" Lee\n| Email: sbstevenlee@gmail.com\n| License: MIT License\n\nCitation\n========\n\nIf you use PyPGx in a published analysis, please report the program version\nand cite the following article:\n\n- Lee et al., 2022. `ClinPharmSeq: A targeted sequencing panel for clinical pharmacogenetics implementation <https://doi.org/10.1371/journal.pone.0272129>`__. PLOS ONE.\n\nIn this article, PyPGx was used to call star alleles for genomic DNA\nreference materials from the Centers for Disease Control and Prevention\u2013based\n`Genetic Testing Reference Materials Coordination Program (GeT-RM)\n<https://pypgx.readthedocs.io/en/latest/glossary.html#\ngenetic-testing-reference-materials-coordination-program-get-rm>`__, where it\nshowed almost 100% concordance with genotype results from previous works.\n\nThe development of PyPGx was heavily inspired by `Stargazer <https://\nstargazer.gs.washington.edu/stargazerweb/>`__, another star-allele calling\ntool developed by Steven when he was in his PhD program at the University of\nWashington. Therefore, please also cite the following articles:\n\n- Lee et al., 2019. `Calling star alleles with Stargazer in 28 pharmacogenes with whole genome sequences <https://doi.org/10.1002/cpt.1552>`__. Clinical Pharmacology & Therapeutics.\n- Lee et al., 2018. `Stargazer: a software tool for calling star alleles from next-generation sequencing data using CYP2D6 as a model <https://doi.org/10.1038/s41436-018-0054-0>`__. Genetics in Medicine.\n\nBelow is an incomplete list of publications which have used PyPGx:\n\n- Wroblewski et al., 2022. `Pharmacogenetic variation in Neanderthals and Denisovans and implications for human health and response to medications <https://doi.org/10.1101/2021.11.27.470071>`__. bioRxiv.\n- Botton et al., 2020. `Phased Haplotype Resolution of the SLC6A4 Promoter Using Long-Read Single Molecule Real-Time (SMRT) Sequencing <https://doi.org/10.3390/genes11111333>`__. Genes.\n\nSupport PyPGx\n=============\n\nIf you find my work useful, please consider becoming a `sponsor <https://github.com/sponsors/sbslee>`__.\n\nInstallation\n============\n\nFollowing packages are required to run PyPGx:\n\n.. list-table::\n :header-rows: 1\n\n * - Package\n - Anaconda\n - PyPI\n * - ``fuc``\n - \u2705\n - \u2705\n * - ``scikit-learn``\n - \u2705\n - \u2705\n * - ``openjdk``\n - \u2705\n - \u274c\n\nThere are various ways you can install PyPGx. The recommended way is via\nconda (`Anaconda <https://www.anaconda.com/>`__):\n\n.. code-block:: text\n\n $ conda install -c bioconda pypgx\n\nAbove will automatically download and install all the dependencies as well.\nAlternatively, you can use pip (`PyPI <https://pypi.org/>`__) to install\nPyPGx and all of its dependencies except ``openjdk`` (i.e. Java JDK must be\ninstalled separately):\n\n.. code-block:: text\n\n $ pip install pypgx\n\nFinally, you can clone the GitHub repository and then install PyPGx locally:\n\n.. code-block:: text\n\n $ git clone https://github.com/sbslee/pypgx\n $ cd pypgx\n $ pip install .\n\nThe nice thing about this approach is that you will have access to\ndevelopment versions that are not available in Anaconda or PyPI. For example,\nyou can access a development branch with the ``git checkout`` command. When\nyou do this, please make sure your environment already has all the\ndependencies installed.\n\n.. note::\n `Beagle <https://faculty.washington.edu/browning/beagle/beagle.html>`__\n is one of the default software tools used by PyPGx for haplotype phasing\n SNVs and indels. The program is freely available and published under the\n `GNU General Public License <https://faculty.washington.edu/browning/\n beagle/gpl_license>`__. Users do not need to download Beagle separately\n because a copy of the software (``beagle.22Jul22.46e.jar``) is already\n included in PyPGx.\n\n.. warning::\n You're not done yet! Keep scrolling down to obtain the resource bundle\n for PyPGx, which is essential for running the package.\n\nResource bundle\n===============\n\nStarting with the 0.12.0 version, reference haplotype panel files and\nstructural variant classifier files in PyPGx are moved to the\n``pypgx-bundle`` `repository <https://github.com/sbslee/pypgx-bundle>`__\n(only those files are moved; other files such as ``allele-table.csv`` and\n``variant-table.csv`` are intact). Therefore, the user must clone the\n``pypgx-bundle`` repository with matching PyPGx version to their home\ndirectory in order for PyPGx to correctly access the moved files (i.e. replace \n``x.x.x`` with the version number of PyPGx you're using, such as ``0.18.0``):\n\n.. code-block:: text\n\n $ cd ~\n $ git clone --branch x.x.x --depth 1 https://github.com/sbslee/pypgx-bundle\n\nThis is undoubtedly annoying, but absolutely necessary for portability\nreasons because PyPGx has been growing exponentially in file size due to the\nincreasing number of genes supported and their variation complexity, to the\npoint where it now exceeds upload size limit for PyPI (100 Mb). After removal\nof those files, the size of PyPGx has reduced from >100 Mb to <1 Mb.\n\nStarting with version 0.22.0, you can now specify a custom location for the \n``pypgx-bundle`` directory instead of using the home directory. This can be \nachieved by setting the bundle location using the ``PYPGX_BUNDLE`` environment \nvariable:\n\n.. code-block:: text\n\n $ export PYPGX_BUNDLE=/path/to/pypgx-bundle\n\nStructural variation detection\n==============================\n\nMany pharmacogenes are known to have `structural variation (SV)\n<https://pypgx.readthedocs.io/en/latest/glossary.html#structural-variation-\nsv>`__ such as gene deletions, duplications, and hybrids. You can visit the\n`Genes <https://pypgx.readthedocs.io/en/latest/genes.html>`__ page to see the\nlist of genes with SV.\n\nSome of the SV events can be quite challenging to detect accurately with NGS\ndata due to misalignment of sequence reads caused by sequence homology with\nother gene family members (e.g. CYP2D6 and CYP2D7). PyPGx attempts to address\nthis issue by training a `support vector machine (SVM) <https://scikit-\nlearn.org/stable/modules/generated/sklearn.svm.SVC.html>`__-based multiclass\nclassifier using the `one-vs-rest strategy <https://scikit-learn.org/stable\n/modules/generated/sklearn.multiclass.OneVsRestClassifier.html>`__ for each\ngene for each GRCh build. Each classifier is trained using copy number\nprofiles of real NGS samples as well as simulated ones, including those from\n`1KGP <https://pypgx.readthedocs.io/en/latest/glossary.html#genomes-project-\n1kgp>`__ and `GeT-RM <https://pypgx.readthedocs.io/en/latest/\nglossary.html#genetic-testing-reference-materials-coordination-program-get-rm>`__.\n\nYou can plot copy number profile and allele fraction profile with PyPGx to\nvisually inspect SV calls. Below are CYP2D6 examples:\n\n.. list-table::\n :header-rows: 1\n :widths: 10 30 60\n\n * - SV Name\n - Gene Model\n - Profile\n * - Normal\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-1.png\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-8.png\n * - WholeDel1\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-2.png\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-1.png\n * - WholeDel1Hom\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-3.png\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-6.png\n * - WholeDup1\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-4.png\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-2.png\n * - Tandem3\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-11.png\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-9.png\n * - Tandem2C\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/gene-model-CYP2D6-10.png\n - .. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/dpsv/GRCh37-CYP2D6-7.png\n\nPyPGx was recently applied to the entire high-coverage WGS dataset from 1KGP\n(N=2,504). Click `here <https://github.com/sbslee/1kgp-pgx-paper/tree/main/\nsv-tables>`__ to see individual SV calls, and corresponding copy number\nprofiles and allele fraction profiles.\n\nGRCh37 vs. GRCh38\n=================\n\nWhen working with PGx data, it's not uncommon to encounter a situation\nwhere you are handling GRCh37 data in one project but GRCh38 in another. You\nmay be tempted to use tools like ``LiftOver`` to convert GRCh37 to GRCh38, or\nvice versa, but deep down you know it's going to be a mess (and please don't\ndo this). The good news is, PyPGx supports both of the builds!\n\nIn many PyPGx actions, you can simply indicate which genome build to use. For\nexample, for GRCh38 data you can use ``--assembly GRCh38`` in CLI and\n``assembly='GRCh38'`` in API. **Note that GRCh37 will always be the\ndefault.** Below is an example of using the API:\n\n.. code:: python3\n\n >>> import pypgx\n >>> pypgx.list_variants('CYP2D6', alleles=['*4'], assembly='GRCh37')\n ['22-42524947-C-T']\n >>> pypgx.list_variants('CYP2D6', alleles=['*4'], assembly='GRCh38')\n ['22-42128945-C-T']\n\nHowever, there is one important caveat to consider if your sequencing data is\nGRCh38. That is, sequence reads must be aligned only to the main contigs\n(i.e. ``chr1``, ``chr2``, ..., ``chrX``, ``chrY``), and not to the\nalternative (ALT) contigs such as ``chr1_KI270762v1_alt``. This is because\nthe presence of ALT contigs reduces the sensitivity of variant calling\nand many other analyses including SV detection. Therefore, if you have\nsequencing data in GRCh38, make sure it's aligned to the main contigs only.\n\nThe only exception to above rule is the GSTT1 gene, which is located on\n``chr22`` for GRCh37 but on ``chr22_KI270879v1_alt`` for GRCh38. This gene is\nknown to have an extremely high rate of gene deletion polymorphism in the\npopulation and thus requires SV analysis. Therefore, if you are interested in\ngenotyping this gene with GRCh38 data, then you must include that contig\nwhen performing read alignment. To this end, you can easily filter your\nreference FASTA file before read alignment so that it only contains the main\ncontigs plus the ALT contig. If you don't know how to do this, here's one way\nusing the ``fuc`` program (which should have already been installed along\nwith PyPGx):\n\n.. code-block:: text\n\n $ cat contigs.list\n chr1\n chr2\n ...\n chrX\n chrY\n chr22_KI270879v1_alt\n $ fuc fa-filter in.fa --contigs contigs.list > out.fa\n\nArchive file, semantic type, and metadata\n=========================================\n\nIn order to efficiently store and transfer data, PyPGx uses the ZIP archive\nfile format (``.zip``) which supports lossless data compression. Each archive\nfile created by PyPGx has a metadata file (``metadata.txt``) and a data file\n(e.g. ``data.tsv``, ``data.vcf``). A metadata file contains important\ninformation about the data file within the same archive, which is expressed\nas pairs of ``=``-separated keys and values (e.g. ``Assembly=GRCh37``):\n\n.. list-table::\n :widths: 20 40 40\n :header-rows: 1\n\n * - Metadata\n - Description\n - Examples\n * - ``Assembly``\n - Reference genome assembly.\n - ``GRCh37``, ``GRCh38``\n * - ``Control``\n - Control gene.\n - ``VDR``, ``chr1:10000-20000``\n * - ``Gene``\n - Target gene.\n - ``CYP2D6``, ``GSTT1``\n * - ``Platform``\n - Genotyping platform.\n - ``WGS``, ``Targeted``, ``Chip``, ``LongRead``\n * - ``Program``\n - Name of the phasing program.\n - ``Beagle``, ``SHAPEIT``\n * - ``Samples``\n - Samples used for inter-sample normalization.\n - ``NA07000,NA10854,NA11993``\n * - ``SemanticType``\n - Semantic type of the archive.\n - ``CovFrame[CopyNumber]``, ``Model[CNV]``\n\nSemantic types\n--------------\n\nNotably, all archive files have defined semantic types, which allows us to\nensure that the data that is passed to a PyPGx command (CLI) or method (API)\nis meaningful for the operation that will be performed. Below is a list of\ncurrently defined semantic types:\n\n- ``CovFrame[CopyNumber]``\n * CovFrame for storing target gene's per-base copy number which is computed from read depth with control statistics.\n * Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Platform``, ``Control``, ``Samples``.\n- ``CovFrame[DepthOfCoverage]``\n * CovFrame for storing read depth for all target genes with SV.\n * Requires following metadata: ``Assembly``, ``SemanticType``, ``Platform``.\n- ``CovFrame[ReadDepth]``\n * CovFrame for storing read depth for single target gene.\n * Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Platform``.\n- ``Model[CNV]``\n * Model for calling CNV in target gene.\n * Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Control``.\n- ``SampleTable[Alleles]``\n * TSV file for storing target gene's candidate star alleles for each sample.\n * Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``, ``Program``.\n- ``SampleTable[CNVCalls]``\n * TSV file for storing target gene's CNV call for each sample.\n * Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``, ``Control``.\n- ``SampleTable[Genotypes]``\n * TSV file for storing target gene's genotype call for each sample.\n * Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``.\n- ``SampleTable[Phenotypes]``\n * TSV file for storing target gene's phenotype call for each sample.\n * Requires following metadata: ``Gene``, ``SemanticType``.\n- ``SampleTable[Results]``\n * TSV file for storing various results for each sample.\n * Requires following metadata: ``Gene``, ``Assembly``, ``SemanticType``.\n- ``SampleTable[Statistics]``\n * TSV file for storing control gene's various statistics on read depth for each sample. Used for converting target gene's read depth to copy number.\n * Requires following metadata: ``Control``, ``Assembly``, ``SemanticType``, ``Platform``.\n- ``VcfFrame[Consolidated]``\n * VcfFrame for storing target gene's consolidated variant data.\n * Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``, ``Program``.\n- ``VcfFrame[Imported]``\n * VcfFrame for storing target gene's raw variant data.\n * Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``.\n- ``VcfFrame[Phased]``\n * VcfFrame for storing target gene's phased variant data.\n * Requires following metadata: ``Platform``, ``Gene``, ``Assembly``, ``SemanticType``, ``Program``.\n\nWorking with archive files\n--------------------------\n\nTo demonstrate how easy it is to work with PyPGx archive files, below we will\nshow some examples. First, download an archive to play with, which has\n``SampleTable[Results]`` as semantic type:\n\n.. code-block:: text\n\n $ wget https://raw.githubusercontent.com/sbslee/pypgx-data/main/getrm-wgs-tutorial/grch37-CYP2D6-results.zip\n\nLet's print its metadata:\n\n.. code-block:: text\n\n $ pypgx print-metadata grch37-CYP2D6-results.zip\n Gene=CYP2D6\n Assembly=GRCh37\n SemanticType=SampleTable[Results]\n\nNow print its main data (but display first sample only):\n\n.. code-block:: text\n\n $ pypgx print-data grch37-CYP2D6-results.zip | head -n 2\n \tGenotype\tPhenotype\tHaplotype1\tHaplotype2\tAlternativePhase\tVariantData\tCNV\n HG00276_PyPGx\t*4/*5\tPoor Metabolizer\t*4;*10;*74;*2;\t*10;*74;*2;\t;\t*4:22-42524947-C-T:0.913;*10:22-42526694-G-A,22-42523943-A-G:1.0,1.0;*74:22-42525821-G-T:1.0;*2:default;\tDeletionHet\n\nWe can unzip it to extract files inside (note that ``tmpcty4c_cr`` is the\noriginal folder name):\n\n.. code-block:: text\n\n $ unzip grch37-CYP2D6-results.zip\n Archive: grch37-CYP2D6-results.zip\n inflating: tmpcty4c_cr/metadata.txt\n inflating: tmpcty4c_cr/data.tsv\n\nWe can now directly interact with the files:\n\n.. code-block:: text\n\n $ cat tmpcty4c_cr/metadata.txt\n Gene=CYP2D6\n Assembly=GRCh37\n SemanticType=SampleTable[Results]\n $ head -n 2 tmpcty4c_cr/data.tsv\n \tGenotype\tPhenotype\tHaplotype1\tHaplotype2\tAlternativePhase\tVariantData\tCNV\n HG00276_PyPGx\t*4/*5\tPoor Metabolizer\t*4;*10;*74;*2;\t*10;*74;*2;\t;\t*4:22-42524947-C-T:0.913;*10:22-42526694-G-A,22-42523943-A-G:1.0,1.0;*74:22-42525821-G-T:1.0;*2:default;\tDeletionHet\n\nWe can easily create a new archive:\n\n.. code-block:: text\n\n $ zip -r grch37-CYP2D6-results-new.zip tmpcty4c_cr\n adding: tmpcty4c_cr/ (stored 0%)\n adding: tmpcty4c_cr/metadata.txt (stored 0%)\n adding: tmpcty4c_cr/data.tsv (deflated 84%)\n $ pypgx print-metadata grch37-CYP2D6-results-new.zip\n Gene=CYP2D6\n Assembly=GRCh37\n SemanticType=SampleTable[Results]\n\nPhenotype prediction\n====================\n\nMany genes in PyPGx have a genotype-phenotype table available from the\nClinical Pharmacogenetics Implementation Consortium (CPIC) or\nthe Pharmacogenomics Knowledge Base (PharmGKB). PyPGx uses these tables to\nperform phenotype prediction with one of the two methods:\n\n- Method 1. Simple diplotype-phenotype mapping: This method directly uses the\n diplotype-phenotype mapping as defined by CPIC or PharmGKB. Using the\n CYP2B6 gene as an example, the diplotypes \\*6/\\*6, \\*1/\\*29, \\*1/\\*2,\n \\*1/\\*4, and \\*4/\\*4 correspond to Poor Metabolizer, Intermediate\n Metabolizer, Normal Metabolizer, Rapid Metabolizer, and Ultrarapid\n Metabolizer.\n- Method 2. Summation of haplotype activity scores: This method uses a\n standard unit of enzyme activity known as an activity score. Using the\n CYP2D6 gene as an example, the fully functional reference \\*1 allele is\n assigned a value of 1, decreased-function alleles such as \\*9 and \\*17\n receive a value of 0.5, and nonfunctional alleles including \\*4 and \\*5\n have a value of 0. The sum of values assigned to both alleles constitutes\n the activity score of a diplotype. Consequently, subjects with \\*1/\\*1,\n \\*1/\\*4, and \\*4/\\*5 diplotypes have an activity score of 2 (Normal\n Metabolizer), 1 (Intermediate Metabolizer), and 0 (Poor Metabolizer),\n respectively.\n\nPlease visit the `Genes <https://pypgx.readthedocs.io/en/latest/\ngenes.html>`__ page to see the list of genes with a genotype-phenotype\ntable and each of their prediction method.\n\nTo perform phenotype prediction with the API, you can use the\n``pypgx.predict_phenotype`` method:\n\n.. code:: python3\n\n >>> import pypgx\n >>> pypgx.predict_phenotype('CYP2D6', '*4', '*5') # Both alleles have no function\n 'Poor Metabolizer'\n >>> pypgx.predict_phenotype('CYP2D6', '*5', '*4') # The order of alleles does not matter\n 'Poor Metabolizer'\n >>> pypgx.predict_phenotype('CYP2D6', '*1', '*22') # *22 has uncertain function\n 'Indeterminate'\n >>> pypgx.predict_phenotype('CYP2D6', '*1', '*1x2') # Gene duplication\n 'Ultrarapid Metabolizer'\n\nTo perform phenotype prediction with the CLI, you can use the\n``call-phenotypes`` command. It takes a ``SampleTable[Genotypes]`` file as\ninput and outputs a ``SampleTable[Phenotypes]`` file:\n\n.. code-block:: text\n\n $ pypgx call-phenotypes genotypes.zip phenotypes.zip\n\nPipelines\n=========\n\nPyPGx currently provides three pipelines for performing PGx genotype analysis\nof single gene for one or multiple samples: NGS pipeline, chip pipeline, and\nlong-read pipeline. In additional to genotyping, each pipeline will perform\nphenotype prediction based on genotype results. All pipelines are compatible\nwith both GRCh37 and GRCh38 (e.g. for GRCh38 use ``--assembly GRCh38`` in CLI\nand ``assembly='GRCh38'`` in API).\n\nNGS pipeline\n------------\n\n.. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/flowchart-ngs-pipeline.png\n\nImplemented as ``pypgx run-ngs-pipeline`` in CLI and\n``pypgx.pipeline.run_ngs_pipeline`` in API, this pipeline is designed for\nprocessing short-read data (e.g. Illumina). Users must specify whether the\ninput data is from whole genome sequencing (WGS) or targeted sequencing\n(custom targeted panel sequencing or whole exome sequencing).\n\nThis pipeline supports SV detection based on copy number analysis for genes\nthat are known to have SV. Therefore, if the target gene is associated with\nSV (e.g. CYP2D6) it's strongly recommended to provide a\n``CovFrame[DepthOfCoverage]`` file and a ``SampleTable[Statistics]`` file in\naddtion to a VCF file containing SNVs/indels. If the target gene is not\nassociated with SV (e.g. CYP3A5) providing a VCF file alone is enough. You can\nvisit the `Genes <https://pypgx.readthedocs.io/en/latest/genes.html>`__ page\nto see the full list of genes with SV. For details on SV detection algorithm,\nplease see the `Structural variation detection <https://pypgx.readthedocs.io/\nen/latest/readme.html#structural-variation-detection>`__ section.\n\nWhen creating a VCF file (containing SNVs/indels) from BAM files, users have\na choice to either use the ``pypgx create-input-vcf`` command (strongly\nrecommended) or a variant caller of their choice (e.g. GATK4\nHaplotypeCaller). See the `Variant caller choice <https://pypgx.readthedocs.\nio/en/latest/faq.html#variant-caller-choice>`__ section for detailed\ndiscussion on when to use either option.\n\nCheck out the `GeT-RM WGS tutorial <https://pypgx.readthedocs.io/en/latest/\ntutorials.html#get-rm-wgs-tutorial>`__ to see this pipeline in action.\n\nChip pipeline\n-------------\n\n.. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/flowchart-chip-pipeline.png\n\nImplemented as ``pypgx run-chip-pipeline`` in CLI and\n``pypgx.pipeline.run_chip_pipeline`` in API, this pipeline is designed for\nDNA chip data (e.g. Global Screening Array from Illumina). It's recommended\nto perform variant imputation on the input VCF prior to feeding it to the\npipeline using a large reference haplotype panel (e.g. `TOPMed Imputation\nServer <https://imputation.biodatacatalyst.nhlbi.nih.gov/>`__).\nAlternatively, it's possible to perform variant imputation with the 1000\nGenomes Project (1KGP) data as reference within PyPGx using ``--impute`` in\nCLI and ``impute=True`` in API.\n\nThe pipeline currently does not support SV detection. Please post a GitHub\nissue if you want to contribute your development skills and/or data for\ndevising an SV detection algorithm.\n\nCheck out the `Coriell Affy tutorial <https://pypgx.readthedocs.io/en/latest/\ntutorials.html#coriell-affy-tutorial>`__ to see this pipeline in action.\n\nLong-read pipeline\n------------------\n\n.. image:: https://raw.githubusercontent.com/sbslee/pypgx-data/main/flowchart-long-read-pipeline.png\n\nImplemented as ``pypgx run-long-read-pipeline`` in CLI and\n``pypgx.pipeline.run_long_read_pipeline`` in API, this pipeline is designed\nfor long-read data (e.g. Pacific Biosciences and Oxford Nanopore\nTechnologies). The input VCF must be phased using a read-backed haplotype\nphasing tool such as `WhatsHap <https://github.com/whatshap/whatshap>`__.\n\nThe pipeline currently does not support SV detection. Please post a GitHub\nissue if you want to contribute your development skills and/or data for\ndevising an SV detection algorithm.\n\nResults interpretation\n======================\n\nPyPGx outputs per-sample genotype results in a table, which is stored in an\narchive file with the semantic type ``SampleTable[Results]``. Below, we will\nuse the CYP2D6 gene with GRCh37 as an example to illustrate how to interpret\ngenotype results from PyPGx.\n\n.. list-table::\n :header-rows: 1\n\n * -\n - Genotype\n - Phenotype\n - Haplotype1\n - Haplotype2\n - AlternativePhase\n - VariantData\n - CNV\n * - NA11839\n - \\*1/\\*2\n - Normal Metabolizer\n - \\*1;\n - \\*2;\n - ;\n - \\*1:22-42522613-G-C,22-42523943-A-G:0.5,0.488;\\*2:default\n - Normal\n * - NA12006\n - \\*4/\\*41\n - Intermediate Metabolizer\n - \\*41;\\*2;\n - \\*4;\\*10;\\*2;\n - \\*69;\n - \\*69:22-42526694-G-A,22-42523805-C-T:0.5,0.551;\\*4:22-42524947-C-T:0.444;\\*10:22-42523943-A-G,22-42526694-G-A:0.55,0.5;\\*41:22-42523805-C-T:0.551;\\*2:default;\n - Normal\n * - HG00276\n - \\*4/\\*5\n - Poor Metabolizer\n - \\*4;\\*10;\\*74;\\*2;\n - \\*10;\\*74;\\*2;\n - ;\n - \\*4:22-42524947-C-T:0.913;\\*10:22-42523943-A-G,22-42526694-G-A:1.0,1.0;\\*74:22-42525821-G-T:1.0;\\*2:default;\n - WholeDel1\n * - NA19207\n - \\*2x2/\\*10\n - Normal Metabolizer\n - \\*10;\\*2;\n - \\*2;\n - ;\n - \\*10:22-42523943-A-G,22-42526694-G-A:0.361,0.25;\\*2:default;\n - WholeDup1\n\nThis list explains each of the columns in the example results.\n\n- **Genotype**: Diplotype call. When there is no SV this simply combines the two top-ranked star alleles from **Haplotype1** and **Haplotype2** with the delimiter '/'. In the presence of SV the final diplotype is determined using one of the genotypers in the ``pypgx.api.genotype`` module (e.g. `CYP2D6Genotyper <https://pypgx.readthedocs.io/en/latest/api.html#pypgx.api.genotype.CYP2D6Genotyper>`__).\n- **Phenotype**: Phenotype call.\n- **Haplotype1**, **Haplotype2**: List of candidate star alleles for each haplotype. For example, if a given haplotype contains three variants ``22-42523943-A-G``, ``22-42524947-C-T``, and ``22-42526694-G-A``, then it will get assigned ``*4;*10;`` because the haplotype pattern can fit both \\*4 (``22-42524947-C-T``) and \\*10 (``22-42523943-A-G`` and ``22-42526694-G-A``). Note that \\*4 comes first before \\*10 because it has higher priority for reporting purposes (see the ``pypgx.sort_alleles`` `method <https://pypgx.readthedocs.io/en/latest/api.html#pypgx.api.core.sort_alleles>`__ for detailed implementation).\n- **AlternativePhase**: List of star alleles that could be missed due to potentially incorrect statistical phasing. For example, let's assume that statistical phasing has put ``22-42526694-G-A`` for **Haplotype1** and ``22-42523805-C-T`` for **Haplotype2**. Even though the two variants are in trans orientation, PyPGx will also consider alternative phase in case the two variants are actually in cis orientation, resulting in ``*69;`` as **AlternativePhase** because \\*69 is defined by ``22-42526694-G-A`` and ``22-42523805-C-T``.\n- **VariantData**: Information for SNVs/indels used to define observed star alleles, including allele fraction which is important for allelic decomposition after identifying CNV (e.g. the sample NA19207). In some situations, there will not be any variants for a given star allele because the allele itself is \"default\" allele for the selected reference assembly (e.g. GRCh37 has \\*2 as default while GRCh38 has \\*1).\n- **CNV**: Structural variation call. See the `Structural variation detection <https://pypgx.readthedocs.io/en/latest/readme.html#structural-variation-detection>`__ section for more details.\n\nGetting help\n============\n\nFor detailed documentations on the CLI and API, please refer to the\n`Read the Docs <https://pypgx.readthedocs.io/en/latest/>`_.\n\nFor getting help on the CLI:\n\n.. code-block:: text\n\n $ pypgx -h\n\n usage: pypgx [-h] [-v] COMMAND ...\n \n positional arguments:\n COMMAND\n call-genotypes Call genotypes for target gene.\n call-phenotypes Call phenotypes for target gene.\n combine-results Combine various results for target gene.\n compare-genotypes Calculate concordance between two genotype results.\n compute-control-statistics\n Compute summary statistics for control gene from BAM\n files.\n compute-copy-number\n Compute copy number from read depth for target gene.\n compute-target-depth\n Compute read depth for target gene from BAM files.\n create-consolidated-vcf\n Create a consolidated VCF file.\n create-input-vcf Call SNVs/indels from BAM files for all target genes.\n create-regions-bed Create a BED file which contains all regions used by\n PyPGx.\n estimate-phase-beagle\n Estimate haplotype phase of observed variants with\n the Beagle program.\n filter-samples Filter Archive file for specified samples.\n import-read-depth Import read depth data for target gene.\n import-variants Import SNV/indel data for target gene.\n plot-bam-copy-number\n Plot copy number profile from CovFrame[CopyNumber].\n plot-bam-read-depth\n Plot read depth profile with BAM data.\n plot-cn-af Plot both copy number profile and allele fraction\n profile in one figure.\n plot-vcf-allele-fraction\n Plot allele fraction profile with VCF data.\n plot-vcf-read-depth\n Plot read depth profile with VCF data.\n predict-alleles Predict candidate star alleles based on observed\n variants.\n predict-cnv Predict CNV from copy number data for target gene.\n prepare-depth-of-coverage\n Prepare a depth of coverage file for all target\n genes with SV from BAM files.\n print-data Print the main data of specified archive.\n print-metadata Print the metadata of specified archive.\n run-chip-pipeline Run genotyping pipeline for chip data.\n run-long-read-pipeline\n Run genotyping pipeline for long-read sequencing data.\n run-ngs-pipeline Run genotyping pipeline for NGS data.\n slice-bam Slice BAM file for all genes used by PyPGx.\n test-cnv-caller Test CNV caller for target gene.\n train-cnv-caller Train CNV caller for target gene.\n \n options:\n -h, --help Show this help message and exit.\n -v, --version Show the version number and exit.\n\nFor getting help on a specific command (e.g. call-genotypes):\n\n.. code-block:: text\n\n $ pypgx call-genotypes -h\n\nBelow is the list of submodules available in the API:\n\n- **core** : The core submodule is the main suite of tools for PGx research.\n- **genotype** : The genotype submodule is primarily used to make final diplotype calls by interpreting candidate star alleles and/or detected structural variants.\n- **pipeline** : The pipeline submodule is used to provide convenient methods that combine multiple PyPGx actions and automatically handle semantic types.\n- **plot** : The plot submodule is used to plot various kinds of profiles such as read depth, copy number, and allele fraction.\n- **utils** : The utils submodule contains main actions of PyPGx.\n\nFor getting help on a specific submodule (e.g. ``utils``):\n\n.. code:: python3\n\n >>> from pypgx.api import utils\n >>> help(utils)\n\nFor getting help on a specific method (e.g. ``pypgx.predict_phenotype``):\n\n.. code:: python3\n\n >>> import pypgx\n >>> help(pypgx.predict_phenotype)\n\nIn Jupyter Notebook and Lab, you can see the documentation for a python\nfunction by hitting ``SHIFT + TAB``. Hit it twice to expand the view.\n\nCLI examples\n============\n\nWe can print the metadata of an archive file:\n\n.. code-block:: text\n\n $ pypgx print-metadata grch37-depth-of-coverage.zip\n\nAbove will print:\n\n.. code-block:: text\n\n Assembly=GRCh37\n SemanticType=CovFrame[DepthOfCoverage]\n Platform=WGS\n\nWe can run the NGS pipeline for the CYP2D6 gene:\n\n.. code-block:: text\n\n $ pypgx run-ngs-pipeline \\\n CYP2D6 \\\n grch37-CYP2D6-pipeline \\\n --variants grch37-variants.vcf.gz \\\n --depth-of-coverage grch37-depth-of-coverage.zip \\\n --control-statistics grch37-control-statistics-VDR.zip\n\nAbove will create a number of archive files:\n\n.. code-block:: text\n\n Saved VcfFrame[Imported] to: grch37-CYP2D6-pipeline/imported-variants.zip\n Saved VcfFrame[Phased] to: grch37-CYP2D6-pipeline/phased-variants.zip\n Saved VcfFrame[Consolidated] to: grch37-CYP2D6-pipeline/consolidated-variants.zip\n Saved SampleTable[Alleles] to: grch37-CYP2D6-pipeline/alleles.zip\n Saved CovFrame[ReadDepth] to: grch37-CYP2D6-pipeline/read-depth.zip\n Saved CovFrame[CopyNumber] to: grch37-CYP2D6-pipeline/copy-number.zip\n Saved SampleTable[CNVCalls] to: grch37-CYP2D6-pipeline/cnv-calls.zip\n Saved SampleTable[Genotypes] to: grch37-CYP2D6-pipeline/genotypes.zip\n Saved SampleTable[Phenotypes] to: grch37-CYP2D6-pipeline/phenotypes.zip\n Saved SampleTable[Results] to: grch37-CYP2D6-pipeline/results.zip\n\nAPI examples\n============\n\nWe can obtain allele function for the CYP2D6 gene:\n\n.. code:: python3\n\n >>> import pypgx\n >>> pypgx.get_function('CYP2D6', '*1')\n 'Normal Function'\n >>> pypgx.get_function('CYP2D6', '*4')\n 'No Function'\n >>> pypgx.get_function('CYP2D6', '*22')\n 'Uncertain Function'\n >>> pypgx.get_function('CYP2D6', '*140')\n 'Unknown Function'\n\nWe can predict phenotype for CYP2D6 based on two haplotype calls:\n\n.. code:: python3\n\n >>> import pypgx\n >>> pypgx.predict_phenotype('CYP2D6', '*4', '*5') # Both alleles have no function\n 'Poor Metabolizer'\n >>> pypgx.predict_phenotype('CYP2D6', '*5', '*4') # The order of alleles does not matter\n 'Poor Metabolizer'\n >>> pypgx.predict_phenotype('CYP2D6', '*1', '*22') # *22 has uncertain function\n 'Indeterminate'\n >>> pypgx.predict_phenotype('CYP2D6', '*1', '*1x2') # Gene duplication\n 'Ultrarapid Metabolizer'\n\nWe can also obtain recommendation (e.g. CPIC) for certain drug-phenotype combination:\n\n.. code:: python3\n\n >>> import pypgx\n >>> # Codeine, an opiate and prodrug of morphine, is metabolized by CYP2D6\n >>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Normal Metabolizer')\n 'Use codeine label recommended age- or weight-specific dosing.'\n >>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Ultrarapid Metabolizer')\n 'Avoid codeine use because of potential for serious toxicity. If opioid use is warranted, consider a non-tramadol opioid.'\n >>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Poor Metabolizer')\n 'Avoid codeine use because of possibility of diminished analgesia. If opioid use is warranted, consider a non-tramadol opioid.'\n >>> pypgx.get_recommendation('codeine', 'CYP2D6', 'Indeterminate')\n 'None'\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "A Python package for pharmacogenomics (PGx) research",
"version": "0.25.0",
"project_urls": {
"Homepage": "https://github.com/sbslee/pypgx"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "fc89efd031d45f55e046190b9a20bc3f8bea3480997a11dcdd66c143b0138169",
"md5": "37642e021c5f4ced41918e888d82d77e",
"sha256": "71c3656e67c15c6c04752455ecf7478d9f3f7fa2707e95ee1d7289aaf0824c50"
},
"downloads": -1,
"filename": "pypgx-0.25.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "37642e021c5f4ced41918e888d82d77e",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 554743,
"upload_time": "2024-06-16T01:00:20",
"upload_time_iso_8601": "2024-06-16T01:00:20.492631Z",
"url": "https://files.pythonhosted.org/packages/fc/89/efd031d45f55e046190b9a20bc3f8bea3480997a11dcdd66c143b0138169/pypgx-0.25.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "08d5407fa3e8c151f3b2c548b7567e3bf0cee0500e120146b0440d622abe3d1b",
"md5": "6cc2449d5e1bd608b071719b486e0753",
"sha256": "4395ffdd7e9a30033b76eb6e0afe98e4c2fd2b131eab1a0de47cc404b5122fd2"
},
"downloads": -1,
"filename": "pypgx-0.25.0.tar.gz",
"has_sig": false,
"md5_digest": "6cc2449d5e1bd608b071719b486e0753",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 558087,
"upload_time": "2024-06-16T01:00:23",
"upload_time_iso_8601": "2024-06-16T01:00:23.867049Z",
"url": "https://files.pythonhosted.org/packages/08/d5/407fa3e8c151f3b2c548b7567e3bf0cee0500e120146b0440d622abe3d1b/pypgx-0.25.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-16 01:00:23",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "sbslee",
"github_project": "pypgx",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "pypgx"
}