Workflow Type: Nextflow
Stable

The Polygenic Score Catalog Calculator (pgsc_calc)

Documentation Status pgscatalog/pgsc_calc CI DOI

Nextflow run with docker run with singularity run with conda

Introduction

pgsc_calc is a bioinformatics best-practice analysis pipeline for calculating polygenic [risk] scores on samples with imputed genotypes using existing scoring files from the Polygenic Score (PGS) Catalog and/or user-defined PGS/PRS.

Pipeline summary

[!IMPORTANT]

The workflow performs the following steps:

  • Downloading scoring files using the PGS Catalog API in a specified genome build (GRCh37 and GRCh38).
  • Reading custom scoring files (and performing a liftover if genotyping data is in a different build).
  • Automatically combines and creates scoring files for efficient parallel computation of multiple PGS
    • Matching variants in the scoring files against variants in the target dataset (in plink bfile/pfile or VCF format)
  • Calculates PGS for all samples (linear sum of weights and dosages)
  • Creates a summary report to visualize score distributions and pipeline metadata (variant matching QC)

And optionally:

  • Genetic Ancestry: calculate similarity of target samples to populations in a reference dataset (1000 Genomes (1000G)), using principal components analysis (PCA)
  • PGS Normalization: Using reference population data and/or PCA projections to report individual-level PGS predictions (e.g. percentiles, z-scores) that account for genetic ancestry

See documentation for a list of planned features under development.

PGS applications and libraries

pgsc_calc uses applications and libraries internally developed at the PGS Catalog, which can do helpful things like:

  • Query the PGS Catalog to bulk download scoring files in a specific genome build
  • Match variants from scoring files to target variants
  • Adjust calculated PGS in the context of genetic ancestry

If you want to write Python code to work with PGS, check out the pygscatalog repository to learn more.

If you want a simpler way of working with PGS, ignore this section and continue below to learn more about pgsc_calc.

Quick start

  1. Install Nextflow (>=23.10.0)

  2. Install Docker or Singularity (v3.8.3 minimum) (please only use Conda as a last resort)

  3. Download the pipeline and test it on a minimal dataset with a single command:

    nextflow run pgscatalog/pgsc_calc -profile test,
    
  4. Start running your own analysis!

    nextflow run pgscatalog/pgsc_calc -profile  --input samplesheet.csv --pgs_id PGS001229
    

See getting started for more details.

Documentation

Full documentation is available on Read the Docs

Credits

pgscatalog/pgsc_calc is developed as part of the PGS Catalog project, a collaboration between the University of Cambridge’s Department of Public Health and Primary Care (Michael Inouye, Samuel Lambert) and the European Bioinformatics Institute (Helen Parkinson, Laura Harris).

The pipeline seeks to provide a standardized workflow for PGS calculation and ancestry inference implemented in nextflow derived from an existing set of tools/scripts developed by Inouye lab (Rodrigo Canovas, Scott Ritchie, Jingqin Wu) and PGS Catalog teams (Samuel Lambert, Laurent Gil).

The adaptation of the codebase, nextflow implementation, and PGS Catalog features are written by Benjamin Wingfield, Samuel Lambert, Laurent Gil with additional input from Aoife McMahon (EBI). Development of new features, testing, and code review is ongoing including Inouye lab members (Rodrigo Canovas, Scott Ritchie) and others. If you use the tool we ask you to cite our paper describing software and updated PGS Catalog resource:

  • Lambert, Wingfield et al. (2024) Enhancing the Polygenic Score Catalog with tools for score calculation and ancestry normalization. Nature Genetics. doi:10.1038/s41588-024-01937-x.

This pipeline is distrubuted under an Apache License amd uses code and infrastructure developed and maintained by the nf-core community (Ewels et al. Nature Biotech (2020) doi:10.1038/s41587-020-0439-x), reused here under the MIT license.

Additional references of open-source tools and data used in this pipeline are described in CITATIONS.md.

This work has received funding from EMBL-EBI core funds, the Baker Institute, the University of Cambridge, Health Data Research UK (HDRUK), and the European Union’s Horizon 2020 research and innovation programme under grant agreement No 101016775 INTERVENE.

Version History

v2.0.0 (latest) Created 1st Nov 2024 at 11:50 by Samuel Lambert

Merge pull request #382 from PGScatalog/integrate-utils-1.4.1

2.0.0 release


Frozen v2.0.0 205cbfd

v2.0.0-beta.3 Created 17th Oct 2024 at 12:44 by Samuel Lambert

2.0.0-beta.3 (#349)

  • bump version

  • bump pgscatalog-utils version to 1.3.0

  • update scoring files used in test profile

  • add warnings to the test profile

  • test log warning -> info

  • add error for -profile test and --run_ancestry

  • bump match version in test suite

  • Update modules.config

  • Update environment.yml

  • Update test.yml

  • update test profile message

  • check scoring variants matches input listed variants

  • fix sscore.vars path

  • suppress zcat warnings

  • use --force instead of --quiet to handle uncompressed data

  • stop using System.exit, which is deprecated by nextflow

  • make CI ignore docs

  • ignore docs on PRs too

  • bump fraposa version

  • bump fraposa version

  • drop subscribe on error checking because it hides error causes


Frozen v2.0.0-beta.3 96fbb23

v2.0.0-beta.2 Created 17th Oct 2024 at 12:44 by Samuel Lambert

Merge pull request #341 from PGScatalog/dev

v2.0.0-beta.2


Frozen v2.0.0-beta.2 69c467e

v2.0.0-alpha.1 Created 11th Aug 2023 at 15:30 by Samuel Lambert

v2.0.0-alpha.1 (#153)

  • fix test profile

  • change standard test to pull workflow with -r ${GITHUB_REF}

  • fix standard test

  • use local data for pytest

  • fix nextflow -r ${branch name}

  • oops

  • change report tag dev -> 2.0

  • update changelog


Frozen v2.0.0-alpha.1 28a0971

v1.3.2 Created 10th Aug 2023 at 10:10 by Samuel Lambert

add singularity to test suite


Frozen v1.3.2 bd1ca59

v2.0.0-alpha Created 10th Aug 2023 at 10:09 by Samuel Lambert

Merge pull request #135 from PGScatalog/dev

v2 release


Frozen v2.0.0-alpha af4882c

main @ d14e43e (earliest) Created 10th Aug 2023 at 10:01 by Samuel Lambert

use mamba in test


Frozen main d14e43e
help Creators and Submitter
Creators
Submitter
Activity

Views: 3965   Downloads: 955

Created: 10th Aug 2023 at 10:01

Last updated: 1st Nov 2024 at 11:50

Annotated Properties
help Attributions

None

Total size: 6.15 MB
Powered by
(v.1.16.0-main)
Copyright © 2008 - 2024 The University of Manchester and HITS gGmbH