Title: | Toolkit for the analysis of multi-state QTL data |
---|---|
Description: | A collection of tools for doing various analyses of multi-state QTL data, with a focus on visualization and interpretation. The package 'multistateQTL' contains functions which can remove or impute missing data, identify significant associations, as well as categorise features into global, multi-state or unique. The analysis results are stored in a 'QTLExperiment' object, which is based on the 'SummarisedExperiment' framework. |
Authors: | Christina Del Azodi [aut], Davis McCarthy [ctb], Amelia Dunstone [cre, ctb] |
Maintainer: | Amelia Dunstone <[email protected]> |
License: | GPL-3 |
Version: | 1.3.1 |
Built: | 2025-01-16 03:25:17 UTC |
Source: | https://github.com/bioc/multistateQTL |
Call associations as significant in each state.
callSignificance(object, ...) callSignificance(object, ...) <- value ## S4 method for signature 'QTLExperiment' callSignificance( object, thresh = 0.05, secondThresh = thresh, feature = .feature_id, assay = "pvalues", mode = "simple", p.adjust.method = "fdr", ... )
callSignificance(object, ...) callSignificance(object, ...) <- value ## S4 method for signature 'QTLExperiment' callSignificance( object, thresh = 0.05, secondThresh = thresh, feature = .feature_id, assay = "pvalues", mode = "simple", p.adjust.method = "fdr", ... )
object |
A QTLExperiment object. |
... |
arguments passed to |
value |
Value to place in getSignificance |
thresh |
Significance threshold. |
secondThresh |
Significance threshold for associations with significance in one state. |
feature |
rowData column name with feature identifier. |
assay |
assay name with significance score. |
mode |
Method to determine significance threshold per state. Options are 'simple', 'feature-wise-FDR', and 'global-FDR'. |
p.adjust.method |
Method of multiple-test correction if mode != simple |
This function adds a new assay to multistateQTL object with TRUE/FALSE significance calls for each test for each state.
A 'QTLExperiment' object with a new assay called 'significant' and with a column called nSignificant added to the colData.
Christina B Azodi
wilcox.test
, on which this function is based.
qtle <- mockQTLE() assays(qtle) qtle <- callSignificance(qtle) # There is now an assay called 'significant' assays(qtle) # Use feature-wise FDR correction ------------------------------------------- qtle_feat <- callSignificance(qtle, thresh=0.1, mode="feature-wise-FDR")
qtle <- mockQTLE() assays(qtle) qtle <- callSignificance(qtle) # There is now an assay called 'significant' assays(qtle) # Use feature-wise FDR correction ------------------------------------------- qtle_feat <- callSignificance(qtle, thresh=0.1, mode="feature-wise-FDR")
Method to filter QTLExperiment objects to remove tests with greater than the permitted rate of missing values.
getComplete(qtle, n = 1, verbose = FALSE)
getComplete(qtle, n = 1, verbose = FALSE)
qtle |
A 'QTLExperiment' object |
n |
Number (or percent if n < 1) of states requiring non-null values |
verbose |
logical. Whether to print progress messages. |
a subset of the 'QTLExperiment' object, with only tests with fewer NAs than specified by n.
# Create a QTLExperiment object with NA values ------------------------------ sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) # Randomly remove 1000 elements from the betas matrix. na_pattern <- sample(seq(1, ncol(sim)*nrow(sim)), 1000) sim_na <- sim assay(sim_na, "betas")[na_pattern] <- NA # Original object has more rows than the output of getComplete() dim(sim_na) sim_complete <- getComplete(sim_na) dim(sim_complete)
# Create a QTLExperiment object with NA values ------------------------------ sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) # Randomly remove 1000 elements from the betas matrix. na_pattern <- sample(seq(1, ncol(sim)*nrow(sim)), 1000) sim_na <- sim assay(sim_na, "betas")[na_pattern] <- NA # Original object has more rows than the output of getComplete() dim(sim_na) sim_complete <- getComplete(sim_na) dim(sim_complete)
Filter to only QTLs significant in at least one state
getSignificant(qtle, n = 1, assaySig = "significant", verbose = FALSE)
getSignificant(qtle, n = 1, assaySig = "significant", verbose = FALSE)
qtle |
'QTLExperiment' object |
n |
Number (or percent if n < 1) of states with significant association |
assaySig |
The assay containing TRUE/FALSE significance calls for each QTL test. |
verbose |
logical. Whether to print progress messages. |
a subset of the 'QTLExperiment' object, where all rows are significant in at least one state.
qtle <- mockQTLE() qtle <- callSignificance(qtle) dim(qtle) qtle_sig <- getSignificant(qtle) # There are fewer rows because we have removed tests which are not significant # in any state. dim(qtle_sig)
qtle <- mockQTLE() qtle <- callSignificance(qtle) dim(qtle) qtle_sig <- getSignificant(qtle) # There are fewer rows because we have removed tests which are not significant # in any state. dim(qtle_sig)
Method to return a subset of a QTLExperiment object containing only the tests that are top hits. Top hits are defined as the test for each feature with the most significant test statistic. Returns an array of the top QTL for each feature across all states
getTopHits( qtle, mode = c("global", "state"), assay = "pvalues", assaySig = "significant", verbose = FALSE )
getTopHits( qtle, mode = c("global", "state"), assay = "pvalues", assaySig = "significant", verbose = FALSE )
qtle |
A 'QTLExperiment' object |
mode |
global/state to specify if the top hit per feature is desired from across all states or for each state. |
assay |
The assay containing the test statistic to minimize. |
assaySig |
The assay containing TRUE/FALSE significance calls for each QTL test. |
verbose |
logical. Whether to print progress messages. |
A subset of the 'QTLExperiment' object, with only tests that are the top hits for each feature ('mode=global') or for each feature for each state ('mode=state').
sumstats <- mockSummaryStats(nStates=10, nQTL=100, names=TRUE) qtle <- QTLExperiment( assay=list( betas=sumstats$betas, errors=sumstats$errors, pvalues=sumstats$pvalues, lfsrs=sumstats$pvalues)) # Add 'significant' assay to object qtle <- callSignificance(qtle) # Filter to the top tests for each feature qtle_glob <- getTopHits(qtle, assay="lfsrs", mode="global", verbose = TRUE) # There are 3 rows corresponding to the three features. table(feature_id(qtle_glob)) # At most one QTL is retained for each combination of feature_id and state_id qtle_feat <- getTopHits(qtle, assay="lfsrs", mode="state", verbose = TRUE) table(feature_id(qtle_feat))
sumstats <- mockSummaryStats(nStates=10, nQTL=100, names=TRUE) qtle <- QTLExperiment( assay=list( betas=sumstats$betas, errors=sumstats$errors, pvalues=sumstats$pvalues, lfsrs=sumstats$pvalues)) # Add 'significant' assay to object qtle <- callSignificance(qtle) # Filter to the top tests for each feature qtle_glob <- getTopHits(qtle, assay="lfsrs", mode="global", verbose = TRUE) # There are 3 rows corresponding to the three features. table(feature_id(qtle_glob)) # At most one QTL is retained for each combination of feature_id and state_id qtle_feat <- getTopHits(qtle, assay="lfsrs", mode="state", verbose = TRUE) table(feature_id(qtle_feat))
Convenience method for comparing the assay value, specified by assay, between two states.
plotCompareStates( object, x, y, assay = "betas", FUN = identity, assaySig = "significant", alpha = 0.2, colBoth = "#4477AA", colDiverging = "#EE6677", colNeither = "gray50", colX = "#CCBB44", colY = "#AA3377" )
plotCompareStates( object, x, y, assay = "betas", FUN = identity, assaySig = "significant", alpha = 0.2, colBoth = "#4477AA", colDiverging = "#EE6677", colNeither = "gray50", colX = "#CCBB44", colY = "#AA3377" )
object |
an |
x |
Name of state for x-axis |
y |
Name of state for y-axis |
assay |
name of assay to plot. |
FUN |
Function to be applied to fillBy assay before plotting (e.g. identity, abs, log10). |
assaySig |
name of assay with TRUE/FALSE significance calls. |
alpha |
Transparency. |
colBoth |
Color for tests significant in both states. |
colDiverging |
Color for tests significant in both states, with diverging effect sizes. |
colNeither |
Color for null tests. |
colX |
Color for tests significant in the x-axis state only. |
colY |
Color for tests significant in the y-axis state only. |
Returns a list containing the counts for each color category and the plot object.
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runPairwiseSharing(sim_top) sim_top <- runTestMetrics(sim_top) plotCompareStates(sim_top, x="S01", y="S02")
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runPairwiseSharing(sim_top) sim_top <- runTestMetrics(sim_top) plotCompareStates(sim_top, x="S01", y="S02")
Methods to plot a heatmap of the pairwise sharing of QTL as calculated by 'runPairwiseSharing'.
plotPairwiseSharing( object, slot = "pairwiseSharing", annotateRowsBy = NULL, annotateColsBy = NULL, annotateCells = FALSE, colourRange = NULL, name = "colnames", distMethod = "pearson", size = 8, ... )
plotPairwiseSharing( object, slot = "pairwiseSharing", annotateRowsBy = NULL, annotateColsBy = NULL, annotateCells = FALSE, colourRange = NULL, name = "colnames", distMethod = "pearson", size = 8, ... )
object |
A |
slot |
Name of slot in metadata list with Pairwise Sharing matrix. |
annotateRowsBy |
character or array of characters specifying the column(s) in colData to be plotted as row annotations. |
annotateColsBy |
character or array of characters specifying the column(s) in colData to be plotted as column annotations. |
annotateCells |
Logical to annotate cells with their values. |
colourRange |
Optional range for the color legend |
name |
character specifying the column in colData to use to label rows and columns. Default is colnames(qtle). |
distMethod |
Distance method used for hierarchical clustering. Valid values are the supported methods in dist() function. |
size |
numeric scalar giving default font size for plotting theme. |
... |
further arguments passed to |
Returns a ComplexHeatmap
object.
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runPairwiseSharing(sim_top) plotPairwiseSharing(sim_top) # Plot with complex column annotations plotPairwiseSharing(sim_top, annotateColsBy = c("nSignificant", "multistateGroup"))
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runPairwiseSharing(sim_top) plotPairwiseSharing(sim_top) # Plot with complex column annotations plotPairwiseSharing(sim_top, annotateColsBy = c("nSignificant", "multistateGroup"))
Convenience method for plotting values from any assay specified by fillBy across states and tests.
plotQTLClusters( object, fillBy = "betas", FUN = identity, minSig = 1, annotateColsBy = NULL, annotateRowsBy = NULL, show_row_names = FALSE, state_id = "state_id", columnOrder = NULL, rowOrder = NULL, row_km = 0, column_km = 0 )
plotQTLClusters( object, fillBy = "betas", FUN = identity, minSig = 1, annotateColsBy = NULL, annotateRowsBy = NULL, show_row_names = FALSE, state_id = "state_id", columnOrder = NULL, rowOrder = NULL, row_km = 0, column_km = 0 )
object |
an |
fillBy |
name of assay to use for main heatmap object. |
FUN |
Function to be applied to fillBy assay before plotting (e.g. identity, abs, log10). |
minSig |
minimum number of significant states for QTL to be included. |
annotateColsBy |
character or array of characters specifying the column(s) in colData to be plotted to annotate states. |
annotateRowsBy |
character or array of characters specifying the column(s) in rowData to be plotted to annotate QTL tests. |
show_row_names |
Logical to plot row (i.e. test) names. |
state_id |
colData column to use to label states. |
columnOrder |
Null for clustering or array to overwrite state order |
rowOrder |
Null for clustering or array to overwrite test order |
row_km |
Set k for k-means clustering of tests. |
column_km |
Set k for k-means clustering of states |
Returns a ComplexHeatmap
object.
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runTestMetrics(sim_top) sim_top <- runPairwiseSharing(sim_top) sim_top_ms <- subset(sim_top, qtl_type_simple == "multistate") plotQTLClusters(sim_top) # Plot with annotations for multi state group plotQTLClusters(sim_top_ms, annotateColsBy = c("multistateGroup"), annotateRowsBy = c("qtl_type", "mean_beta", "QTL"))
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runTestMetrics(sim_top) sim_top <- runPairwiseSharing(sim_top) sim_top_ms <- subset(sim_top, qtl_type_simple == "multistate") plotQTLClusters(sim_top) # Plot with annotations for multi state group plotQTLClusters(sim_top_ms, annotateColsBy = c("multistateGroup"), annotateRowsBy = c("qtl_type", "mean_beta", "QTL"))
Distribution of estimated simulation parameters
plotSimulationParams(params, n = 1e+05)
plotSimulationParams(params, n = 1e+05)
params |
Estimated simulation parameters from qtleEstimate. |
n |
Number of random values to sample for plots. |
A ggplot2 object
qtle <- mockQTLE() params <- qtleEstimate(qtle, threshSig = 0.05, threshNull = 0.5) plotSimulationParams(params=params)
qtle <- mockQTLE() params <- qtleEstimate(qtle, threshSig = 0.05, threshNull = 0.5) plotSimulationParams(params=params)
Convenient method to plot an UpSet plot showing the number of QTL that are significant in sets of states.
plotUpSet( object, assay = "significant", name = "colnames", minShared = 10, minDegree = 2, maxDegree = NULL, annotateColsBy = NULL, comb_order = "comb_size", set_order = order(ss), ... )
plotUpSet( object, assay = "significant", name = "colnames", minShared = 10, minDegree = 2, maxDegree = NULL, annotateColsBy = NULL, comb_order = "comb_size", set_order = order(ss), ... )
object |
an |
assay |
Name of assay to use to assess significance. |
name |
character specifying the column in colData to use to label rows and columns. Default is colnames(qtle). |
minShared |
minimum number of shared QTL for set to be included. |
minDegree |
minimum degree of sharing for set to be included. |
maxDegree |
maximum degree of sharing for set to be included. |
annotateColsBy |
character or array of characters specifying the column(s) in colData to be plotted as annotations. |
comb_order |
characters specifying how sets should be ordered. Options include the set size (set_size), combination size (comb_size), degree (deg). |
set_order |
Array specifying order of states. |
... |
further arguments passed to |
Returns a ComplexHeatmap
object.
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runPairwiseSharing(sim_top) plotUpSet(sim_top) # Upset plot with complex row annotations plotUpSet(sim_top, annotateColsBy = c("nSignificant", "multistateGroup"))
sim <- qtleSimulate( nStates=10, nFeatures=100, nTests=1000, global=0.2, multi=0.4, unique=0.2, k=2) sim <- callSignificance(sim, mode="simple", assay="lfsrs", thresh=0.0001, secondThresh=0.0002) sim_sig <- getSignificant(sim) sim_top <- getTopHits(sim_sig, assay="lfsrs", mode="state") sim_top <- runPairwiseSharing(sim_top) plotUpSet(sim_top) # Upset plot with complex row annotations plotUpSet(sim_top, annotateColsBy = c("nSignificant", "multistateGroup"))
Estimate parameters from real data for simulating multi-state QTL summary statistics
qtleEstimate( data, assay = "pvalues", threshSig = 0.001, threshNull = 0.1, verbose = TRUE )
qtleEstimate( data, assay = "pvalues", threshSig = 0.001, threshNull = 0.1, verbose = TRUE )
data |
A 'QTLExperiment' object or named list containing "betas" and "errors" matrices. |
assay |
Assay containing test statistic information to use. |
threshSig |
Max threshold (pval/lfsr) for calling tests as significant. |
threshNull |
Min threshold (pval/lfsr) for calling tests as null. |
verbose |
Logical. |
The simulation consists of user defined number of equal numbers of four different types of effects: null, equal among conditions, present only in first condition, independent across conditions
A list with parameter estimates for the QTLExperiment object.
qtle <- mockQTLE() qtleEstimate(qtle)
qtle <- mockQTLE() qtleEstimate(qtle)
Returns a list of the default values used for parameters when simulating multistateQTL data. Parameters include:
betas.sig.shape
betas.sig.rate
cv.sig.shape
cv.sig.rate
betas.null.shape
betas.null.rate
cv.null.shape
cv.null.rate
qtleParams()
qtleParams()
The default parameters returned by this function were generated using expression QTL (eQTL) summary statistics from the Genotype-Tissue Expression (GTEx) Project (Version 8) for the ten tissues with the largest sample sizes for eQTL mapping. The eQTL tests were filtered to include only eQTLs on chromosome 1 that were available in all 10 tissues.
A list with the default parameter values which can be used when simulating multistateQTL data.
qtleParams()
qtleParams()
Create simulated multistateQTL data for testing purposes
qtleSimulate( params = qtleParams(), nTests = 100, nFeatures = NULL, nStates = 5, global = 0.5, multi = 0, unique = 0, k = 2, betaSd = 0.1, lfsr = TRUE, verbose = TRUE )
qtleSimulate( params = qtleParams(), nTests = 100, nFeatures = NULL, nStates = 5, global = 0.5, multi = 0, unique = 0, k = 2, betaSd = 0.1, lfsr = TRUE, verbose = TRUE )
params |
list of parameters required to simulate betas and beta errors. Generated by 'qtleEstimate()' or 'qtleParams()'. |
nTests |
number of QTL tests |
nFeatures |
number of QTL features to simulate tests for, NULL mean nFeatures = nTests. |
nStates |
number of states |
global |
percent of QTL tests with significant effects shared across all states |
multi |
percent of QTL tests with significant effects shared across a subset of states. |
unique |
percent of QTL tests with significant effects in only one state |
k |
number of multi-state clusters or an array with the cluster assignments. |
betaSd |
The desired standard deviation or an array of standard deviations equal to the length of states for sampling beta values for each state. |
lfsr |
Logical to calculate lfsr using mashr_1by1. |
verbose |
Logical. |
The simulation consists of user defined number of equal numbers of four different types of effects: null, equal among conditions, present only in first condition, independent across conditions
A simulated 'QTLExperiment' object.
qtleSimulate(nTests=100, nStates=5, global=0.1, multi=0.2, unique=0.05)
qtleSimulate(nTests=100, nStates=5, global=0.1, multi=0.2, unique=0.05)
A convenience function for imputing or filling in NAs in a 'QTLExperiment' object.
replaceNAs( object, methods = list(betas = 0, errors = "mean", pvalues = 1, lfsrs = 1), verbose = FALSE )
replaceNAs( object, methods = list(betas = 0, errors = "mean", pvalues = 1, lfsrs = 1), verbose = FALSE )
object |
A 'QTLExperiment' object |
methods |
A named list with the method for each assay. Available methods are to replace with a given integer or with the row mean or median. |
verbose |
logical. Whether to print progress messages. |
A 'QTLExperiment' object with the same dimensions as the original object, but with the NA values replaced according to the input specifications.
#' # Create a QTLExperiment object with NA values ------------------------------ qtle <- mockQTLE() # Randomly remove 1000 elements from the betas matrix. na_pattern <- sample(seq(1, ncol(qtle)*nrow(qtle)), 1000) qtle_na <- qtle assay(qtle_na, "betas")[na_pattern] <- NA # There are some NA values in the "betas" assay any(is.na(betas(qtle_na))) qtle_complete <- replaceNAs(qtle_na) # Now we don't have any NA values any(is.na(betas(qtle_complete))) ## Specify a specific method to impute NAs ---------------------------------- qtle_median <- replaceNAs( qtle_na, methods=list(betas = 0, errors = "median", pvalues = 1), verbose=TRUE)
#' # Create a QTLExperiment object with NA values ------------------------------ qtle <- mockQTLE() # Randomly remove 1000 elements from the betas matrix. na_pattern <- sample(seq(1, ncol(qtle)*nrow(qtle)), 1000) qtle_na <- qtle assay(qtle_na, "betas")[na_pattern] <- NA # There are some NA values in the "betas" assay any(is.na(betas(qtle_na))) qtle_complete <- replaceNAs(qtle_na) # Now we don't have any NA values any(is.na(betas(qtle_complete))) ## Specify a specific method to impute NAs ---------------------------------- qtle_median <- replaceNAs( qtle_na, methods=list(betas = 0, errors = "median", pvalues = 1), verbose=TRUE)
Compute the proportion of (significant) QTL shared by pairs of conditions
runPairwiseSharing( qtle, assay = "betas", assaySig = "significant", factor = 0.5, FUN = identity, ... )
runPairwiseSharing( qtle, assay = "betas", assaySig = "significant", factor = 0.5, FUN = identity, ... )
qtle |
A 'QTLExperiment' object. |
assay |
The assay containing the metric used to determine sharing (i.e. the metric to be within a factor X to be considered shared). |
assaySig |
The assay containing significance information. |
factor |
a number in [0,1] the factor within which effects are considered to be shared |
FUN |
a function to be applied to the estimated effect sizes before assessing sharing. Default 'FUN=identity', 'FUN=abs' ignores the sign of the effects when assessing sharing. |
... |
Additional parameters to pass on to internal functions. |
For each pair of states, the effects that are significant (as determined by 'callSignificance') in at least one of the two states are identified. Then the fraction of those with an estimated effect size (i.e. betas) within a factor 'factor' of one another is computed and returned.
The 'QTLExperiment' object with a matrix called pairwiseSharing added to the metadata.
m <- mockQTLE() m <- callSignificance(m, assay="pvalues") runPairwiseSharing(m) # sharing by magnitude (same sign) runPairwiseSharing(m, factor=0) # sharing by sign runPairwiseSharing(m, FUN=abs) # sharing by magnitude when sign is ignored
m <- mockQTLE() m <- callSignificance(m, assay="pvalues") runPairwiseSharing(m) # sharing by magnitude (same sign) runPairwiseSharing(m, factor=0) # sharing by sign runPairwiseSharing(m, FUN=abs) # sharing by magnitude when sign is ignored
This function adds a summary of the features with significant QTL in each state to the metadata of the QTLExperiment object.
runSignificantFeatures(object, assay = "significant")
runSignificantFeatures(object, assay = "significant")
object |
A QTLExperiment object with multiple QTL tests (i.e., rows) for at least one feature. |
assay |
Assay containing T/F significance calls for each test. |
The 'QTLExperiment' object with a summary of significant features in the metadata and a new column 'nSignificantFeatures' in the colData.
qtle <- mockQTLE() qtle <- callSignificance(qtle) # There is an assay called 'significant' assays(qtle) # Obtain summary of significant features for each state qtle <- runSignificantFeatures(qtle) # There is a summary added to the metadata of the object metadata(qtle)
qtle <- mockQTLE() qtle <- callSignificance(qtle) # There is an assay called 'significant' assays(qtle) # Obtain summary of significant features for each state qtle <- runSignificantFeatures(qtle) # There is a summary added to the metadata of the object metadata(qtle)
Takes the results from 'callSignificance()' and from the assay 'betas' to categorize each QTL test using two classification strategies:
Strategy 1 (qtl_type): (1) global-shared, (2) global-diverging, (3) multi-state-shared, (4) multi-state-diverging, or (5) unique.
Strategy 2 (qtl_type_simple): (1) global, (2) multi-state, or (3) unique.
runTestMetrics( qtle, assay = "betas", assaySig = "significant", globalBuffer = 0, ... )
runTestMetrics( qtle, assay = "betas", assaySig = "significant", globalBuffer = 0, ... )
qtle |
QTLExperiment qtle |
assay |
Name of assay containing QTL effect size estimate (e.g. betas) |
assaySig |
Name of assay with TRUE/FALSE significance calls |
globalBuffer |
Number of states that can be not-significant and the QTL will still be called as global, for example, if globalBuffer=1, then a QTL will be considered global if if is significant in all or all but 1 state. |
... |
arguments passed to |
If a test is significant in more than one sign across different states, returns TRUE in rowData(qtle)$diverging
The 'QTLExperiment' object with the following columns added to the rowData: nSignificant, effect_sd, qtl_type, qtl_type_simple
m <- mockQTLE() m <- callSignificance(m) m <- runTestMetrics(m)
m <- mockQTLE() m <- callSignificance(m) m <- runTestMetrics(m)
Performance metrics for multistateQTL simulations
simPerformance(qtle, assay = "significant")
simPerformance(qtle, assay = "significant")
qtle |
A 'multistateQTL' object. |
assay |
Name of the 'multistateQTL' assay containing the significance calls |
description
sim <- qtleSimulate() sim <- callSignificance(sim, assay="lfsrs", thresh=0.1) simPerformance(sim)
sim <- qtleSimulate() sim <- callSignificance(sim, assay="lfsrs", thresh=0.1) simPerformance(sim)