knitr::opts_chunk$set( collapse = TRUE, comment = "#>", dpi = 80 )
This vignette demonstrates how to perform multi-trait colocalization analysis using a mixed-type dataset, including both individual level data and summary statistics. ColocBoost provides a flexible framework to integrate data both at the individual level or at the summary statistic level, allowing the handling of scenarios where the individual data is available for some traits (like xQTLs) and the summary data is available for other traits (disease/trait GWAS).
library(colocboost)
To get started, load both Ind_5traits
and Sumstat_5traits
datasets into your R session. Once loaded, create a mixed dataset as follows:
LD
could be calculated from the X
data in the Ind_5traits
dataset, but it is not included in the Sumstat_5traits
dataset.The dataset features two causal variants with indices 194 and 589.
# Load example data data(Ind_5traits) data(Sumstat_5traits) # Create a mixed dataset X <- Ind_5traits$X[1:4] Y <- Ind_5traits$Y[1:4] sumstat <- Sumstat_5traits$sumstat[5] LD <- get_cormat(Ind_5traits$X[[1]])
For analyze a specific one type of data, you can refer to the following tutorials Individual Level Data Colocalization and Summary Level Data Colocalization.
Due to the file size limitation of CRAN release, this is a subset of simulated data. See full dataset in colocboost paper repo.
The preferred format for colocalization analysis in ColocBoost using mixed-type dataset:
Individual level data: X
and Y
are organized as lists, matched by trait index,
(X[1], Y[1])
contains individual level data for trait 1,(X[2], Y[2])
contains individual level data for trait 2,Summary level data:
sumstat
is organized as a list of data.frames for all traitsLD
is a matrix of linkage disequilibrium (LD) information for all variants across all traits.This function requires specifying genotypes X
and phenotypes Y
from the individual-level dataset and summary statistics sumstat
and LD matrix LD
from summary dataset:
# Run colocboost res <- colocboost(X = X, Y = Y, sumstat = sumstat, LD = LD) # Identified CoS res$cos_details$cos$cos_index
For comprehensive tutorials on result interpretation and advanced visualization techniques, please visit our tutorials portal at Visualization of ColocBoost Results and Interpret ColocBoost Output.
When integrating with GWAS data, to mitigate the risk of biasing early updates toward stronger xQTL signals in LD proximity-and should in fact colocalize with-weaker signals from the disease trait of interest, we also implement a disease-prioritized mode of ColocBoost as a soft prioritization strategy to colocalize variants with putative causal effects on the focal trait.
To run the disease-prioritized mode, you need to specify the focal_outcome_idx
argument in the colocboost()
function.
focal_outcome_idx
indicates the index of the focal trait in all traits of interest.focal_outcome_idx
are counted from individual level data to summary statistics.
Therefore, in this example, focal_outcome_idx = 5
is used to indicate the index of the focal trait from (4 individual level traits) and (1 summary statistics).# Run colocboost res <- colocboost(X = X, Y = Y, sumstat = sumstat, LD = LD, focal_outcome_idx = 5) # Plotting the focal only results colocalization results colocboost_plot(res, plot_focal_only = TRUE)
Unlike the other existing methods, the disease-prioritized mode of ColocBoost only used a soft prioritization strategy. Therefore, it not only identify the colocalization of the focal trait, but also the colocalization across the other traits without the focal trait. To extract all CoS and visualization of all colocalization results, you can use the following code:
# Identified CoS res$cos_details$cos$cos_index # Plotting all results colocboost_plot(res)
For comprehensive tutorials on result interpretation and advanced visualization techniques, please visit our tutorials portal at Visualization of ColocBoost Results and Interpret ColocBoost Output.
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.