Skip to content

Latest commit

 

History

History
605 lines (413 loc) · 24.8 KB

README.md

File metadata and controls

605 lines (413 loc) · 24.8 KB

A Tutorial for Pharmacogenomics Clinical Annotation Tool (PharmCAT)

PharmCAT logo

By the end of this tutorial, you will know how to use PharmCAT for data analysis and annotation.

This repository provides genetic data and other materials that you need to familiarize yourself with PharmCAT v2.0.

Note: parallel computing feature will be added in the near future to the PharmCAT VCF Preprocessor and PharmCAT!

Citing PharmCAT:

  1. Klein, T. E. & Ritchie, M. D. PharmCAT: A Pharmacogenomics Clinical Annotation Tool. Clin Pharmacol Ther 104, 19–22 (2018).
  2. Sangkuhl, K. et al. Pharmacogenomics Clinical Annotation Tool (PharmCAT). Clin Pharmacol Ther 107, 203–210 (2020).
  3. Li, B., Sangkuhl, K. et al. How to Run the Pharmacogenomics Clinical Annotation Tool (PharmCAT). Clinical Pharmacology & Therapeutics (2022).
  4. Li, B., Sangkuhl, K., Whaley, R., Woon, M., Keat, K., Whirl-Carrillo, M., Ritchie, M. D. & Klein, T. E. (2023). Frequencies of pharmacogenomic alleles across biogeographic groups in a large-scale biobank. Am J Hum Genet 110, 1628–1647.

Table of contents

  1. Intro to PharmCAT
  2. Why use PharmCAT
  3. Set up for the tutorial
  4. Run the PharmCAT VCF Preprocessor (strongly recommended)
  5. Run PharmCAT
    1. Run the whole PharmCAT
    2. Incorporate outside PGx calls
    3. Batch-annotation on multiple samples
  6. Extracting the PharmCAT JSON data into a TSV file
  7. Advanced uses
    1. Individual PharmCAT modules
    2. PharmCAT Research mode
      1. Calling combination or partial alleles
      2. Inferring CYP2D6 based on SNPs and INDELs
    3. Multiprocessing support for the PharmCAT VCF Preprocessor
    4. Multiprocessing support for JSON-to-TSV
  8. Transfer files and stop the Docker container
  9. [Advanced uses]

1. Intro to PharmCAT

Pharmacogenomics Clinical Annotation Tool (PharmCAT) is a software tool that serves the global pharmacogenomics (PGx) and clinical communities and promotes clinical implementation of PGx. PharmCAT digests an individual's genetic data in a VCF file (a common genetic data file format), infers PGx information (PGx alleles, diplotypes, and phenotypes), and generates a drug prescribing recommendation report for the individual.

You can find more information about the PharmCAT project and tool on pharmcat.org.

This figure explains the workflow of PharmCAT. We will explore every part of PharmCAT that is represented in this figure. You will have a better understanding about each part at the end of this tutorial. PharmCAT workflow

Back to Top

2. Why use PharmCAT

PGx is the low-hanging fruit of precision medicine and a research field that we are likely to witness near-term success of individualized clinical care.

PharmCAT has the following features that make it a desired tool for PGx implementation in clinical care.

(1) Scalability as an automated end-to-end annotation tool.

(2) Standardization in end-to-end PGx annotation from genotypes to drug prescribing recommendations.

(3) Flexibility as PharmCAT takes various types of PGx calls from other PGx annotation tools to provide guideline-based recommendations.

(4) Modularization of functional parts that meet different clinical and research purposes.

Back to Top

3. Setup for the tutorial

We prepared the VCF files based on the 30x whole-genome sequencing data for three samples from the Genetic Testing Reference Materials (GeT-RM) Coordination Program. The consensus PGx calls for these samples are available on the GeT-RM website.

3.1. (Recommended) Pre-prepared Docker container

This tutorial is going to use a pre-prepared Docker image that comes with all pre-requisite software and dependencies for you to successfully run PharmCAT without worries or extra efforts.

Steps:

  1. Download the Docker Desktop here.

  2. Open the Docker application.

    1. For Mac, Docker Desktop will show up as an icon on the Menu Bar at the top of your screen. (Don't forget to register a Docker account!)

      docker_icon

  3. Pull the PharmCAT Tutorial Docker Image using the following command in your terminal

       $docker pull pgkb/pharmcat-tutorial
    Click to see what it looks like in a terminal.

    terminal_pull_image

  4. Locate the pulled PharmCAT Tutorial on your Docker Desktop. Hover your mouse over the pgkb/pharmcat-tutorial and click on the Run on the right to activate the PharmCAT tutorial.

    Click to see what it looks like in Docker Desktop.

    docker_tutorial_image

  5. Locate and click the Containers tab on the left. You will see a running instance of the PharmCAT tutorial. On the right, under the Actions, click docker_actions_menu, and choose Open in terminal.

    Click to see what it looks like in Docker Desktop.

    docker_open_terminal

  6. You should see an integrated terminal in the Docker Desktop app. ls -l shows you all the files that have already been made available in this PharmCAT tutorial.

    image

3.2. (Alternative) Running in your own computing environment

If you don't want to use the pre-prepared Docker image, you can run PharmCAT using your own computing environment. Make sure you have the following software and dependencies in your system:

  1. Java 17 or higher, e.g., OpenJDK by Adoptium
  2. PharmCAT Jar file from the PharmCAT webpage or the PharmCAT GitHub repository releases page.
  3. PharmCAT's VCF Preprocessor
    1. Downloadable from the PharmCAT GitHub repository releases page
    2. Python >= 3.9.4 (Note that Python 3.11 has not been tested yet)
    3. bcftools >= 1.16
    4. bgzip from htslib >= 1.16
    5. Python3 package: pandas >= 1.5.1
    6. Python3 package: scikit-allell >= 1.3.5
  4. JSON to TSV
    1. R >= 4.0.4
    2. rjson >= 0.2.20
    3. optparse >= 1.6.6
    4. tidyverse >= 1.3.0
    5. foreach >= 1.5.2
    6. doParallel >= 1.0.17

Remember to clone this PharmCAT tutorial GitHub repo to your computing environment for the prepared VCF data. Use the following commands:

# download the tutorial material
git clone [email protected]:PharmGKB/PharmCAT-tutorial.git
cd PharmCAT-tutorial/

# please replace “<latest-release>” with the latest release number
# download the latest PharmCAT release
wget https://github.com/PharmGKB/PharmCAT/releases/download/<latest-release>/pharmcat-<latest-release>-all.jar
# download the VCF Preprocessor
wget https://github.com/PharmGKB/PharmCAT/releases/download/<latest-release>/pharmcat-preprocessor-<latest-release>.tar.gz 
# unzip
tar -xvf pharmcat-preprocessor-<latest-release>.tar.gz
mv preprocessor/* ./

Back to Top

4. Run the PharmCAT VCF Preprocessor

The PharmCAT VCF Preprocessor, written in python 3, makes sure the input VCF file(s) meet the PharmCAT’s VCF requirements. Different genetic testing labs or sequencing companies prepare their own VCF files using different bioinformatics pipelines. This can lead to slight but consequential differences between VCF files from different sources. We highly recommend preparing and normalizing your VCF files using the PharmCAT VCF Preprocessor for the following benefits:

  1. Normalizing and standardizing of VCF files (reference)
  2. Retaining only PGx allele definiting positions of interest
  3. Splitting a multi-sample VCF file into single-sample VCF files for PharmCAT
  4. Many more improvements for the computing performance and the accuracy of your PGx reports!

❗ Below, we will (1) introduce the basics of the preprocessor and (2) provide some real-world examples.

4.1. How to use the PharmCAT VCF Preprocessor

The basic syntax of the PharmCAT VCF Preprocessor is as following:

python3 pharmcat_vcf_preprocessor.py -vcf <path_to_vcf(.gz)>
  • The only mandatory input
    • A VCF file
  • Two sets of Outputs
    1. Single-sample VCF file(s) that are ready for PharmCAT
    2. A report of missing PGx positions in your input VCF

A few arguments that are going to be used in this tutorial include:

  • -vcf <path_to_vcf> = a single-sample VCF file, a multi-sample VCF file, or a list file of VCF file paths. VCF files can be either bgzip-compressed or uncompressed.
  • -refFna <path_to_file> = path to indexed human reference genome sequence on GRCh38/hg38. The reference genome sequence file can be either compressed or non-compressed, but it must be indexed. The reference genome sequence file will be automatically downloaded (~1 GB) and indexed to the current working directory if not provided by user.
  • -refVcf <path_to_file> = by default, the pharmcat_positions.vcf.bgz under the current working directory and used as the list of reference PGx positions to be extracted from the input.
  • -o <path_to_dir> = directory path to write the result files to. By default, outputs will be saved to the same directory as the -vcf input file

4.2. Hands-on Examples

4.2.1. A single-sample VCF file

Let's start with the simplest case where you have only a VCF file for a single sample. We will use NA18526 for example here.

Run the following command to preprocess the VCF file for NA18526.

# copy and paste the command to the docker image
mkdir -p results/pharmcat_ready/
python3 pharmcat_vcf_preprocessor.py \
  -vcf data/PharmCAT_tutorial_get-rm_wgs_30x_grch38.NA18526.vcf.bgz \
  -refFna reference.fna.bgz \
  -refVcf pharmcat_positions.vcf.bgz \
  -o results/pharmcat_ready/
Click to see what it looks like in Docker Desktop

docker_preprocessor_single_sample

4.2.2. A multi-sample VCF file

VCF files are usually comprised of multiple samples. As PharmCAT currently takes only a single-sample VCF, the VCF Preprocessor can help prepare and split the multi-sample VCF file by samples for PharmCAT.

Here we have an exemplary multi-sample VCF file that has genotype data for three (3) samples, NA18526, NA18565, and NA18861.

# copy and paste the command to the docker image
mkdir -p results/pharmcat_ready/
python3 pharmcat_vcf_preprocessor.py \
  -vcf data/PharmCAT_tutorial_get-rm_wgs_30x_grch38.vcf.bgz \
  -refFna reference.fna.bgz \
  -refVcf pharmcat_positions.vcf.bgz \
  -o results/pharmcat_ready/
Click to see what it looks like in Docker Desktop

docker_preprocessor_multiple_samples

4.2.3. Multiple VCFs of non-overlapping genetic blocks

Large-scale genetic data is commonly divided into multiple by-chromosome VCF files or VCF files of consecutive genetic blocks. These VCF files should have the same set of samples and non-overlapping genetic regions. The input VCF list file must be sorted by chromosome positions.

# copy and paste the command to the docker image
mkdir -p results/pharmcat_ready/
python3 pharmcat_vcf_preprocessor.py \
  -vcf data/input_vcf_list.txt \
  -refFna reference.fna.bgz \
  -refVcf pharmcat_positions.vcf.bgz \
  -o results/pharmcat_ready/
Click to see what it looks like in Docker Desktop

docker_preprocessor_chromosomes

Back to Top

5. Run PharmCAT

Now we are getting to the exciting part - running PharmCAT!

5.1. Run the whole PharmCAT

The minimal command you can use to run PharmCAT is as simple as the following:

java -jar <path_to_the_latest_pharmcat_jar> -vcf <sample_file>
  • -jar <path_to_jar_file> = the compiled PharmCAT Jar file.
  • -vcf <sample_file> = a non-compressed, single-sample VCF file, which must comply with PharmCAT’s VCF requirements. If multiple samples are present, only the first one will be analyzed.

Part of the optional arguments and flags:

  • -o <output_dir> = directory path to write the result files to. By default, outputs will be saved - to the same directory as the input VCF file.
  • -bf <output_name> = the prefix for output files (e.g., <output_name>.html).
  • -del = a flag to remove the intermediate outputs and save only the HTML report.

❗ Note that all these optional arguments and flags are effective in individual PharmCAT modules that we are going to introduce later. The up-to-date list of the PharmCAT arguments and flags can always be found on the PharmCAT website. If you are not sure what arguments are available for a specific PharmCAT module, use java -jar pharmcat-<latest_release>-all.jar -h \

Take NA18526 for example again, here to run PharmCAT:

# run the whole pharmcat for a single sample, NA18526
mkdir -p results/pharmcat_all/
java -jar pharmcat.jar \
  -vcf results/pharmcat_ready/NA18526.preprocessed.vcf \
  -o results/pharmcat_all/
Click to see what it looks like in Docker Desktop

docker_run_pharmcat_all

Back to Top

5.2. Incorporate outside PGx calls

PharmCAT allows users to supply genotypes or phenotypes that are derived from other means, referred to as “outside” data as they are not generated by PharmCAT.

PharmCAT expects the outside calls in a tab-delimited file. Each file contains the outside calls for one sample. Each line in the file is the genotype or phenotype information for a certain gene with up to four fields, including (1) HGNC gene symbol, (2) diplotype or a single-allele call, (3) a phenotype, or (4) an activity score for a gene.

For example:

$ cat data/example_outside_calls.txt
CYP2D6	*1/*3
CYP2C9			2.0
G6PD	B (wildtype)/B (wildtype)
HLA-B		*57:01 positive
MT-RNR1	1555A>G

Now, try it yourself. Generate a PharmCAT report with the outside PGx genotype or phenotype data.

java -jar pharmcat.jar \
  -vcf results/pharmcat_ready/NA18526.preprocessed.vcf \
  -po data/outside_calls_from_get-rm.NA18526.txt \
  -bf NA18526.outsidecalls \
  -o results/pharmcat_all/
  • -po <path_to_outside_call> = a tab-delimited file of outside PGx genotype or phenotype data for the sample
Click to see what it looks like in Docker Desktop

docker_pharmcat_outside_calls

Back to Top

5.3. Batch-annotation on multiple samples

Note parallele feature for the PharmCAT VCF Preprocessor and PharmCAT itself will be updated in the near future.

The fast manner of PharmCAT in generating a report (~2 seconds per sample) enables it to process a biobank-scale data.

Depending on the computing environment, you can adapt the following script to parallelize your PharmCAT jobs.

for SINGLE_SAMPLE in $(cat data/test_get-rm_samples.txt)
do
  java -jar pharmcat.jar \
    -vcf results/pharmcat_ready/"$SINGLE_SAMPLE".preprocessed.vcf \
    -reporterJson \
    -o results/pharmcat_all/
done

Incorporating outside genotype or phenotype data files is straightforward. See the following exemplary codes:

for SINGLE_SAMPLE in $(cat data/test_get-rm_samples.txt)
do
  java -jar pharmcat.jar \
    -vcf results/pharmcat_ready/"$SINGLE_SAMPLE".preprocessed.vcf \
    -po data/outside_calls_from_get-rm."$SINGLE_SAMPLE".txt \
    -reporterJson \
    -o results/pharmcat_all/ 
done

Back to Top

6. Extracting the PharmCAT JSON data into a TSV file

The instruction has been moved to the Multi-Sample Analysis webpage on the PharmCAT website.

Back to Top

7. Advanced uses

7.1. Run individual PharmCAT modules

If you want specific results from PharmCAT, say the PGx allele matching results from the PharmCAT Named Allele Matcher or the inferred phenotypes from the PharmCAT Phenotyper, you can run the individual PharmCAT modules.

Using individual modules of PharmCAT is easy. You only need to specify the module that you want to run using the flags - -matcher, -phenotyper, -reporter, or a combination of them.

7.1.1. Named Allele Matcher

The PharmCAT Named Allele Matcher takes the input VCF file, matches the genetic data to the PGx allele definitions in PharmCAT, and infers the sample’s genotypes/diplotypes if available.

Try the following command in the Docker:

mkdir -p results/pharmcat_matcher/
java -jar pharmcat.jar \
  -matcher -matcherHtml \
  -vcf results/pharmcat_ready/NA18526.preprocessed.vcf \
  -o results/pharmcat_matcher/

(For illustration purposes, here we also provides -matcherHtml, which saves the results also in a reader-friendly HTML file.)

Click to see what it looks like in Docker Desktop

docker_pharmcat_matcher

7.1.2. Phenotyper

The PharmCAT Phenotyper provides allele function and predicted phenotype information of a sample by ingesting the genotypes/diplotypes identified by the PharmCAT Name Allele Matcher.

Try the following command in the Docker:

# Use the Named Allele Matcher JSON
mkdir -p results/pharmcat_phenotyper/
java -jar pharmcat.jar \
  -phenotyper \
  -pi results/pharmcat_matcher/NA18526.preprocessed.match.json \
  -bf NA18526.preprocessed \
  -o results/pharmcat_phenotyper/
  • -pi <json_file> = the Phenotyper input. The JSON file generated by the Named Allele Matcher
Click to see what it looks like in Docker Desktop

docker_pharmcat_phenotyper_pi

Now, what if you want to start from the VCF file? You can totally do so. Try out the following:

# Use a VCF file and run both the Named Allele Matcher and the Phenotyper
java -jar pharmcat.jar \
  -matcher  -phenotyper \
  -vcf results/pharmcat_ready/NA18526.preprocessed.vcf \
  -bf from_vcf.NA18526.preprocessed \
  -o results/pharmcat_phenotyper/

Note -pi <json_file> cannot be used with -vcf.

Click to see what it looks like in Docker Desktop

docker_pharmcat_phenotyper_vcf

7.1.3. Reporter

The PharmCAT Reporter takes the genotype/diplotype and phenotype data from the Phenotyper, interprets the data of relevant drug annotation, includes appropriate warnings and caveats, and generates a comprehensive, reader-friendly report.

Try the following command in the Docker:

mkdir -p results/pharmcat_reporter/
java -jar pharmcat.jar \
  -reporter -reporterJson \
  -ri results/pharmcat_phenotyper/NA18526.preprocessed.phenotype.json \
  -o results/pharmcat_reporter/
  • -ri <phenotyper_json_file> = the Reporter input. The JSON file generated by the Phenotyper.
Click to see what it looks like in Docker Desktop

docker_pharmcat_reporter

Back to Top

7.2. PharmCAT research mode

PharmCAT v2.0.0 and above offers two new options for research (more details).

7.2.1. Calling combination or partial alleles

Under reserach combinations mode, PharmCAT will try to call novel PGx genotypes that are combinations of known PGx variants or alleles. This includes:

  1. Partial alleles are one or more genetic variants that make up part of a PGx allele, e.g., CYP2C19*2/[*17+chr10.g.94781859G>A].
  2. Combination alleles are more than one PGx allele on a haplotype, e.g., CYP2C9*1/[*2+*33], which is a *1 on one haplotype and [*2+*33] on the other haplotype.

Note PharmCAT’s syntax for combination calls uses [] to reflect that it is a variation on one gene copy and to distinguish it from gene duplications, e.g., tandem arrangements in CYP2D6*36+*10.

# pharmcat research mode for combination or partial alleles
mkdir -p results/research_combinations/
java -jar pharmcat.jar \
  -vcf results/pharmcat_ready/NA18861.preprocessed.vcf \
  -o results/research_combinations/ \
  -bf combinations.NA18861 \
  -research combinations
Click to see what it looks like in Docker Desktop

docker_pharmcat_research_combinations

7.2.2. Inferring CYP2D6 based on SNPs and INDELs

Note This function should be used at the user's own risk. This option is discouraged if users have access to whole genome sequencing (WGS) CRAM/BAM files. Please refer to our documentation about CYP2D6 calling and more examples on our tutorial manuscript. Calling CYP2D6 from VCF should not be used for clinical purposes.

# pharmcat research mode for inferring cyp2d6 based on only snps and indels
mkdir -p results/research_cyp2d6/
java -jar pharmcat.jar \
  -vcf results/pharmcat_ready/NA18861.preprocessed.vcf \
  -o results/research_cyp2d6/ \
  -bf cyp2d6.NA18861 \
  -research cyp2d6
Click to see what it looks like in Docker Desktop

docker_pharmcat_cyp2d6

7.3. Multiprocessing support for the PharmCAT VCF Preprocessor

This function is desirable for an analysis on a VCF with a large number of samples.

# copy and paste the command to the docker image
mkdir -p results/pharmcat_ready/
python3 pharmcat_vcf_preprocessor.py \
  -vcf data/PharmCAT_tutorial_get-rm_wgs_30x_grch38.vcf.bgz \
  -refFna reference.fna.bgz \
  -refVcf pharmcat_positions.vcf.bgz \
  -o results/pharmcat_ready/ \
  -c 
  • -c = Enabling concurrent mode. This defaults to using one less than the number of CPU cores available.
  • -cp <num processes> = The maximum number of processes to use if concurrent mode is enabled.

Note You will only see slight, if any, difference in runtimes with and without the concurrent mode in this PharmCAT tutorial. The concurrent mode -c is only useful if processing many files/samples. With only a few files/samples, the overhead of using concurrent mode is more than the benefit it may provide.

Back to Top

7.4. Multiprocessing support for JSON-to-TSV

The instruction has been moved to the Multi-Sample Analysis webpage on the PharmCAT website.

8. Transfer files and/or stop the Docker container

8.1. Transfer files

At this step, you probably would want to transfer files between the local host and the Docker container.

# Note, this runs on your terminal

# transfer the result folder from the docker container to your local computing environment
docker cp -a <Docker_Container_ID>:/pharmcat/results/ $PWD
# the command is similar for transfering a file
docker cp <Docker_Container_ID>:/pharmcat/results/ $PWD

# transfer a file from your local host to the docker
docker cp <path/to/local/file.vcf> <Docker_Container_ID>:/pharmcat/

8.2. Stop the container

docker_stop_container

8.3. Remove the image

docker_remove_image

Back to Top

Reference: [^1] Byrska-Bishop, M. et al. High coverage whole genome sequencing of the expanded 1000 Genomes Project cohort including 602 trios. 2021.02.06.430068 Preprint at https://doi.org/10.1101/2021.02.06.430068 (2021).

Acknowledgement

PharmCAT is managed at Stanford University & University of Pennsylvania (NHGRI U24HG010862).