Title: | Retrieves Condition-Specific Variants in RNA-Seq Data |
---|---|
Description: | Retrieves condition-specific variants in RNA-seq data (SNVs, alternative-splicings, indels). It has been developed as a post-treatment of 'KisSplice' but can also be used with user's own data. |
Authors: | Clara Benoit-Pilven [aut], Camille Marchet [aut], Janice Kielbassa [aut], Lilia Brinza [aut], Audric Cologne [aut], Aurélie Siberchicot [aut, cre], Vincent Lacroix [aut], Frank Picard [ctb], Laurent Jacob [ctb], Vincent Miele [ctb] |
Maintainer: | Aurélie Siberchicot <[email protected]> |
License: | GPL (>= 2) |
Version: | 1.27.0 |
Built: | 2025-01-06 03:20:21 UTC |
Source: | https://github.com/bioc/kissDE |
The kissDE package retrieves condition-specific variants in RNA-seq data. Each variation (SNVs, alternative splicing events) is represented as a pair of variants. The quantification of each variant is summarized as a count, in each condition and each replicate where it was measured. The package tests for enrichment of a variant in a condition. Data counts are modelled using either a poisson or a negative binomial. Likelihood ratio tests are then performed using the GLM (Generalized Linear Model) framework.
Main functions:
diffExpressedVariants(countsData, conditions, pvalue = 1, filterLowCountsVariants = 10, flagLowCountsConditions = 10, technicalReplicates = FALSE)
qualityControl(countsData, conditions, storeFigs = FALSE)
kissplice2counts(fileName, counts = 0, pairedEnd = FALSE, order = NULL, exonicReads = TRUE, k2rg = FALSE, keep = c("All"), remove = NULL)
writeOutputKissDE(resDiffExprVariant, output, adjPvalMax = 1, dPSImin = 0, writePSI = FALSE)
kissDE(fileName, conditions, output, counts = 2, pairedEnd = FALSE, order = NULL, exonicReads = TRUE, k2rg = FALSE, keep = c("All"), remove = NULL, pvalue = 1, filterLowCountsVariants = 10, flagLowCountsConditions = 10, technicalReplicates = FALSE, nbCore = 1, adjPvalMax = 1, dPSImin = 0, writePSI = FALSE)
Authors of the package: Clara Benoit-Pilven, Camille Marchet, Janice Kielbassa, Lilia Brinza, Audric Cologne and Vincent Lacroix all contributed code and ideas.
Contributors of the package: Franck Picard and Laurent Jacob provided statistical expertise for the models underlying kissDE. Vincent Miele provided expertise for the development of the R package.
Maintainer of the package: Aurélie Siberchicot
Function that retrieves condition-specific variants in RNA-seq data.
diffExpressedVariants(countsData, conditions, pvalue = 1, filterLowCountsVariants = 10, flagLowCountsConditions = 10, technicalReplicates = FALSE, nbCore = 1)
diffExpressedVariants(countsData, conditions, pvalue = 1, filterLowCountsVariants = 10, flagLowCountsConditions = 10, technicalReplicates = FALSE, nbCore = 1)
countsData |
a data frame containing the counts in the appropriate format (see Details below). |
conditions |
a character vector containing the experimental conditions. |
pvalue |
a numerical value indicating the p-value threshold below which the events will be kept in the final data frame. |
filterLowCountsVariants |
a numerical value indicating the global variant count value (see Details below) below which events are filtered out in order to increase statistical power of the analysis. Both variant must have a read coverage below this value in order to remove the event. This filter is done after the normalization and the overdispersion estimation. |
flagLowCountsConditions |
a numerical value indicating the global condition count value (see Details below) below which we flag events as 'lowCounts' in the final data frame. At least n-1 conditions (over n conditions) must have low counts to flag the event as 'lowCounts'. |
technicalReplicates |
a boolean value indicating if the counts in
|
nbCore |
an integer indicating the number of cores to use for the model fitting step. |
The countsData
data frame must be formatted as follows:
Column 1: names of the events
Column 2: lengths (in bp) of the variants
Column 3 to n: counts corresponding to each replicate of each experimental condition of one variant
Each row corresponds to one variant, thus an event correspond to two rows with
the longest variant (or inclusion variant) in the first row (thus denotated as
upper path: UP) and the smallest variant (or exclusion variant) in the second
row (thus denotated as lower path: LP).
This data frame can be obtained using kissplice2counts
function.\
The global variant count is the minimal number of reads that cover one or the
other variant across all the replicates (sum by variant).\
The global condition count is the minimal number of reads that cover one or
the other condition (sum by replicates for each conditions).
diffExpressedVariants
returns a list of 6 objects:
finalTable |
a data frame containing the columns
|
correctedPval |
a numeric vector containing p-values after correction for multiple testing |
uncorrectedPVal |
a numeric vector containing p-values before correction for multiple testing |
resultFitNBglmModel |
a data frame containing the results of the fitting of the model to the data |
f/psiTable |
a data frame containing the allele frequency (f)/Percent Spliced In (PSI) of each replicate |
k2rgFile |
a string containing either the |
Lopez-Maestre et al., 2016. Snp calling from rna-seq data without a reference genome: identification, quantification, differential analysis and impact on the protein sequence. Nucleic Acids Research, 44(19):e148. doi:10.1093/nar/gkw655
fpath1 <- system.file("extdata", "output_kissplice_SNV.fa", package = "kissDE") mySNVcounts <- kissplice2counts(fpath1, counts = 0, pairedEnd = TRUE) mySNVconditions <- c("EUR", "EUR", "TSC", "TSC") # diffSNV <- diffExpressedVariants(mySNVcounts, mySNVconditions) fpath2 <- system.file("extdata", "table_counts_alt_splicing.txt", package = "kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") mySplicingcounts <- read.table(fpath2, header = TRUE) # diffSplicing <- diffExpressedVariants(mySplicingcounts, mySplicingconditions)
fpath1 <- system.file("extdata", "output_kissplice_SNV.fa", package = "kissDE") mySNVcounts <- kissplice2counts(fpath1, counts = 0, pairedEnd = TRUE) mySNVconditions <- c("EUR", "EUR", "TSC", "TSC") # diffSNV <- diffExpressedVariants(mySNVcounts, mySNVconditions) fpath2 <- system.file("extdata", "table_counts_alt_splicing.txt", package = "kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") mySplicingcounts <- read.table(fpath2, header = TRUE) # diffSplicing <- diffExpressedVariants(mySplicingcounts, mySplicingconditions)
This function will read the rds file created by
writeOutputKissDE
and creat an interactive Shiny
application allowing users to explore and plot the results of kissDE.
exploreResults(rdsFile)
exploreResults(rdsFile)
rdsFile |
a string indicating the path to the rds file outputed by
|
None.
kissplice2refgenome_file <- system.file("extdata", "output_k2rg_alt_splicing.txt", package="kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") counts <- kissplice2counts(fileName=kissplice2refgenome_file, counts=2, pairedEnd=TRUE, k2rg=TRUE) # res <- diffExpressedVariants(countsData=counts, # conditions=mySplicingconditions) # writeOutputKissDE(res, output="results.tsv") # exploreResults("results.tsv.rds")
kissplice2refgenome_file <- system.file("extdata", "output_k2rg_alt_splicing.txt", package="kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") counts <- kissplice2counts(fileName=kissplice2refgenome_file, counts=2, pairedEnd=TRUE, k2rg=TRUE) # res <- diffExpressedVariants(countsData=counts, # conditions=mySplicingconditions) # writeOutputKissDE(res, output="results.tsv") # exploreResults("results.tsv.rds")
This function will sequentially call the
kissplice2counts
, diffExpressedVariants
and
writeOutputKissDE
functions in order to run a complete
kissDE analysis. It may also call the qualityControl
and
the exploreResults
functions.
kissDE(fileName, conditions, output, counts = 2, pairedEnd = FALSE, order = NULL, exonicReads = TRUE, k2rg = FALSE, keep = c("All"), remove = NULL, pvalue = 1, filterLowCountsVariants = 10, flagLowCountsConditions = 10, technicalReplicates = FALSE, nbCore = 1, adjPvalMax = 1, dPSImin = 0, writePSI = TRUE, doQualityControl = TRUE, resultsInShiny=TRUE)
kissDE(fileName, conditions, output, counts = 2, pairedEnd = FALSE, order = NULL, exonicReads = TRUE, k2rg = FALSE, keep = c("All"), remove = NULL, pvalue = 1, filterLowCountsVariants = 10, flagLowCountsConditions = 10, technicalReplicates = FALSE, nbCore = 1, adjPvalMax = 1, dPSImin = 0, writePSI = TRUE, doQualityControl = TRUE, resultsInShiny=TRUE)
fileName |
a string indicating the path to the |
conditions |
a character vector containing the experimental conditions. |
output |
a character indicating the path and file name to save
|
counts |
an interger (0, 1 or 2) corresponding to the |
pairedEnd |
a logical indicating if the data is paired-end ( |
order |
a numeric vector indicating the actual order of the corresponding
paired reads in the columns of the |
exonicReads |
a logical indicating if exonic/intronic read counts will be
kept ( |
k2rg |
a logical indicating if the input file is a
|
keep |
a character vector listing the names of the events to be kept for
the statistical test (for |
remove |
a character vector listing the names of the events to remove
for the statistical test (for |
pvalue |
a numerical value indicating the p-value threshold below which the events will be kept in the final data frame. |
filterLowCountsVariants |
a numerical value indicating the global variant count value (see Details below) below which events are filtered out in order to increase statistical power of the analysis. Both variant must have a read coverage below this value in order to remove the event. This filter is done after the normalization and the overdispersion estimation. |
flagLowCountsConditions |
a numerical value indicating the global condition count value (see Details below) below which we flag events as 'lowCounts' in the final data frame. At least n-1 conditions (over n conditions) must have low counts to flag the event as 'lowCounts'. |
technicalReplicates |
a boolean value indicating if the counts in
|
nbCore |
an integer indicating the number of cores to use for the model fitting step. |
adjPvalMax |
a double indicating the threshold for adjusted p-value. Only SNVs/splicing events with an adjusted p-value lower than this threshold will be kept in the output file. |
dPSImin |
a double indicating the threshold for the deltaPSI. Only SNVs/splicing events having an absolute value of deltaf/deltaPSI higher than this threshold will be kept in the output file. |
writePSI |
a boolean indicating if the user wants the f/PSI table to be
printed ( |
doQualityControl |
a boolean indicating if the user wants quality control plots to be written in the output folder ( |
resultsInShiny |
a boolean indicating if the user wants the results to be printed in a Shiny application ( |
None.
kissplice2refgenome_file <- system.file("extdata", "output_k2rg_alt_splicing.txt", package="kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") #kissDE(fileName=kissplice2refgenome_file, conditions=mySplicingconditions, # output="results.tsv", counts=2, pairedEnd=TRUE, k2rg=TRUE)
kissplice2refgenome_file <- system.file("extdata", "output_k2rg_alt_splicing.txt", package="kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") #kissDE(fileName=kissplice2refgenome_file, conditions=mySplicingconditions, # output="results.tsv", counts=2, pairedEnd=TRUE, k2rg=TRUE)
KisSplice
or KisSplice2RefGenome
outputsFunction that converts KisSplice
(.fa
) output or
KisSplice2RefGenome (tab-delimited)
output to a counts data frame that
can be used by other functions of the KissDE
package.
kissplice2counts(fileName, counts = 2, pairedEnd = FALSE, order = NULL, exonicReads = TRUE, k2rg = FALSE, keep = c("All"), remove = NULL)
kissplice2counts(fileName, counts = 2, pairedEnd = FALSE, order = NULL, exonicReads = TRUE, k2rg = FALSE, keep = c("All"), remove = NULL)
fileName |
a string indicating the path to the |
counts |
an interger (0, 1 or 2) corresponding to the |
pairedEnd |
a logical indicating if the data is paired-end ( |
order |
a numeric vector indicating the actual order of the corresponding
paired reads in the columns of the |
exonicReads |
a logical indicating if exonic/intronic read counts will be
kept ( |
k2rg |
a logical indicating if the input file is a
|
keep |
a character vector listing the names of the events to be kept for
the statistical test (for |
remove |
a character vector listing the names of the events to remove
for the statistical test (for |
The counts
parameter:
By default, as in KisSplice
, the counts
option is set
to 0, assuming there is no special counting option. Below, an example of the
upper path counts format output by
KisSplice
when counts
is set to 2:
|AS1_0|SB1_0|S1_0|ASSB1_0|AS2_27|SB2_41|S2_0|ASSB2_21|
AS3_0|SB3_0|S3_0|ASSB3_0|AS4_7|SB4_8|S4_0|ASSB4_2.
In a regular KisSplice
output (counts = 0
), it would be:
|C1_0|C2_47|C3_1|C4_13 (with 47 = 27+41+0-21 and 13 = 7+8+0-2)
The order
parameter:
If the reads corresponding to a paired-end fragments have not been passed to
Kissplice
next to each other, the order needs to be explicitly given to
the kissplice2counts
function.
For instance, if there are two paired-end samples and if the input in
Kissplice
has been: -r sample1_readPair1.fa
-r sample2_readPair1.fa
-r sample1_readPair2.fa
-r sample2_readPair2.fa
,
the input is not organised with the reads of one pair next to each other.
The vector order
to give would be order = c(1, 2, 1, 2)
.
The keep
and remove
parameters:
The options keep
and remove
allow the user to select the type of
alternative splicing events from KisSplice2RefGenome
that have to be
analysed. To work only with intron retention events, the vector should be:
keep = c("IR")
. To work on all events except insertions and
deletions, the vector should be remove = c("insertion","deletion")
.
To work specifically on single exon skipping (ES) events (only
one exon can be included or excluded), both keep
and remove
options must be used. The keep
option should
be set to c("ES")
and the remove
option should be set to
c("alt","altA","altD","altAD","MULTI")
.
kissplice2counts
returns a list of 4 objects:
countsEvents |
a data frame containing several columns: a first column
( |
psiInfo |
a data frame containing information to compute the PSI values.
This data frame is used only when |
exonicReadsInfo |
a logical indicating if |
k2rgFile |
a string containing the |
Only countsEvents
is shown when kissplice2counts
output
is printed.
fpath <- system.file("extdata", "output_kissplice_SNV.fa", package="kissDE") mySNVcounts <- kissplice2counts(fpath, counts = 0, pairedEnd=TRUE) names(mySNVcounts) str(mySNVcounts) head(mySNVcounts$countsEvents)
fpath <- system.file("extdata", "output_kissplice_SNV.fa", package="kissDE") mySNVcounts <- kissplice2counts(fpath, counts = 0, pairedEnd=TRUE) names(mySNVcounts) str(mySNVcounts) head(mySNVcounts$countsEvents)
Function that provide some helpful plots about the data to
ensure that the experimental plan passed to diffExpressedVariants
is correct and to control the quality of the data.
This function should be run before launching
diffExpressedVariants
, to validate the data.
qualityControl(countsData, conditions, storeFigs = FALSE, returnPCAdata = FALSE)
qualityControl(countsData, conditions, storeFigs = FALSE, returnPCAdata = FALSE)
countsData |
the output of the |
conditions |
a character vector that gives the conditions' order. It has as many elements as there are samples in total. |
storeFigs |
a logical or a string indicating if the plots should be
stored and in which directory. If the |
returnPCAdata |
a logical indicating if the data frame used in the PCA
analysis should be returned. By default ( |
countsData
input must be formatted as follows: in its first column the
names of the events, in its second column the lengths of the events, and in
the following columns, the counts corresponding to each replicate of each
experimental condition of one variant. Each row corresponds to one variant.
The figures are saved or displayed in the R session.
fpath <- system.file("extdata", "output_kissplice_SNV.fa", package="kissDE") mySNVcounts <- kissplice2counts(fpath, counts = 0, pairedEnd=TRUE) mySNVconditions <- c("EUR", "EUR", "TSC", "TSC") qualityControl(mySNVcounts, mySNVconditions)
fpath <- system.file("extdata", "output_kissplice_SNV.fa", package="kissDE") mySNVcounts <- kissplice2counts(fpath, counts = 0, pairedEnd=TRUE) mySNVconditions <- c("EUR", "EUR", "TSC", "TSC") qualityControl(mySNVcounts, mySNVconditions)
diffExpressedVariants
function in a file and in a rds object.If a KisSplice
fasta file was used as input for the
analysis, writeOutputKissDE
will output a tab-delimited file
containing one alternative splicing event/SNV per line. The columns are: the
ID of the variation, the variable part length, the counts of each variant for
each condition, the adjusted p-value (FDR), the deltaPSI and a boolean
indicating if the splicing event/SNV was sufficiently expressed (controled by
the flagLowCountsConditions
option from the
diffExpressedVariants
function).
If a KisSplice2RefGenome
file was used as input for the analysis,
this function will add five columns to the KisSplice2RefGenome
file, with the following KissDE
results: normalized counts,
PSI computed from normalized counts, adjusted p-value, deltaPSI and a boolean
indicating if the splicing event/SNV was sufficiently expressed in at least
half of the conditions (controled by the flagLowCountsConditions
option
from the diffExpressedVariants
function).
In both cases, an rds object is saved in the output folder, that can be used to
explore the results of kissDE through a Shiny application with the
exploreResults
function.
writeOutputKissDE(resDiffExprVariant, output, adjPvalMax = 1, dPSImin = 0, writePSI = FALSE)
writeOutputKissDE(resDiffExprVariant, output, adjPvalMax = 1, dPSImin = 0, writePSI = FALSE)
resDiffExprVariant |
a list, returned by
|
output |
a character indicating the path and file name to save
|
adjPvalMax |
a double indicating the threshold for adjusted p-value. Only SNVs/splicing events with an adjusted p-value lower than this threshold will be kept in the output file. |
dPSImin |
a double indicating the threshold for the deltaPSI. Only SNVs/splicing events having an absolute value of deltaf/deltaPSI higher than this threshold will be kept in the output file. |
writePSI |
a boolean indicating if the user wants the f/PSI table to be
printed ( |
None.
kissplice2refgenome_file <- system.file("extdata", "output_k2rg_alt_splicing.txt", package="kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") counts <- kissplice2counts(fileName=kissplice2refgenome_file, counts=2, pairedEnd=TRUE, k2rg=TRUE) # res <- diffExpressedVariants(countsData=counts, # conditions=mySplicingconditions) # writeOutputKissDE(res, output="results.tsv") # writeOutputKissDE(res, output="significants_results.tsv", # adjPvalMax=0.05, dPSImin=0.1) # writeOutputKissDE(res, output="psi_results.tsv", adjPvalMax=0.05, # dPSImin=0.1, writePSI=TRUE)
kissplice2refgenome_file <- system.file("extdata", "output_k2rg_alt_splicing.txt", package="kissDE") mySplicingconditions <- c("C1", "C1", "C2", "C2") counts <- kissplice2counts(fileName=kissplice2refgenome_file, counts=2, pairedEnd=TRUE, k2rg=TRUE) # res <- diffExpressedVariants(countsData=counts, # conditions=mySplicingconditions) # writeOutputKissDE(res, output="results.tsv") # writeOutputKissDE(res, output="significants_results.tsv", # adjPvalMax=0.05, dPSImin=0.1) # writeOutputKissDE(res, output="psi_results.tsv", adjPvalMax=0.05, # dPSImin=0.1, writePSI=TRUE)