%\VignetteIndexEntry{vignette source} %\VignetteEngine{knitr::knitr} %\VignetteEncoding{UTF-8} \documentclass{article} \setlength\parindent{0pt} \usepackage{hyperref} \hypersetup{colorlinks = true,allcolors = blue} \usepackage{amsmath} \title{globalSeq: testing for association between \mbox{RNA-Seq} and high-dimensional data} \date{\today} \author{\textbf{A Rauschenberger}, \textbf{MA Jonker}, \textbf{MA van de Wiel} \\ and \textbf{RX Menezes}} \bibliographystyle{plain} \begin{document} \maketitle This vignette introduces the R~package \textbf{globalSeq}. The function \hyperref[omnibus]{\mbox{omnibus}} tests for association between an overdispersed count variable and a high-dimensional covariate set. The function \hyperref[proprius]{\mbox{proprius}} decomposes the test statistic to show the contributions of individual samples or covariates. And the function \hyperref[cursus]{\mbox{cursus}} performs genome-wide analyses. \section{Initialisation} \label{initialisation} Start with installing the R package \textbf{globalSeq} from Bioconductor: <>= if (!requireNamespace("BiocManager", quietly=TRUE)) install.packages("BiocManager") BiocManager::install("globalSeq") @ Please type the following command to load and attach the package: <<>>= library(globalSeq) @ If you want to reproduce the examples, you should attach the toy database: <>= attach(toydata) @ % alternative to the function "attach" <>= names <- names(toydata) for(i in 1:length(names)){ assign(names[i], toydata[[i]]) } rm(names) @ The following commands access the R documentation: <>= utils::help(globalSeq) utils::vignette("globalSeq") @ %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \newpage %%%%%%%%%%%%%%%%%%%%%%%% \section{Test of association} %%% \label{omnibus} %%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \subsection{Data} \label{omnibus_data} Data is available for \Sexpr{nrow(X)}~individuals and \Sexpr{ncol(X)+1}~variables. <<>>= cbind(y,X) @ \subsection{Minimal example} \label{omnibus_minimal_example} We are interested whether the response variable~$\boldsymbol{y}$ is associated with the covariate matrix~$\boldsymbol{X}$. Looking at the data might already lead to an answer.\footnote{Note that the response variable takes higher values for individuals~$4$ and~$6$ than for the other individuals. Looking at the covariate matrix, we observe that individuals~$2$, $4$ and~$6$ are peculiar. We conclude: The data on individuals~$4$ and~$6$ speak for an association, but the data on individual~$2$ speaks against an association. Covariates~$12$, $13$ and~$14$ are uninformative, and the role of other covariates is less clear.} Because the number of covariates exceeds the sample size, classical tests cannot test their joint significance. But the function \textbf{omnibus} also works in high-dimensional settings: <<>>= set.seed(1) omnibus(y,X) @ \newpage \subsection{Offset} \label{omnibus_offset} Suppose that an offset is available. Relative to the offset, the response~$\boldsymbol{y}$ is more or less constant across samples: <<>>= rbind(y,offset) @ If we account for this offset, there is no evidence for an association between the response~$\boldsymbol{y}$ and the covariate matrix~$\boldsymbol{X}$: <<>>= set.seed(1) omnibus(y,X,offset=offset) @ \subsection{Confounding variable} \label{omnibus_confounding_variable} Suppose that each sample belongs either to group~$1$ or to group~$2$. We can observe that $\boldsymbol{y}$ tends to take small values in one group, and large values in the other: <<>>= rbind(y,group) @ We suspect that the group membership explains some variation of the response~$\boldsymbol{y}$ or the covariate matrix~$\boldsymbol{X}$. Therefore we account for this confounding variable by using stratified permutations: <<>>= set.seed(1) omnibus(y,X,group=group) @ \newpage \subsection{Overdisperion} \label{omnibus_overdispersion} Setting the dispersion parameter of the negative binomial distribution equal to zero is equivalent to using the Poisson distribution: <<>>= set.seed(1) omnibus(y,X,phi=0) @ \subsection{Multiple covariate sets} \label{omnibus_multiple_covariate_sets} Suppose that two covariate sets are available: <<>>= X1 <- X[,c(1:11,15)] X2 <- X[,12:14] @ We are interested in testing for associations between $\boldsymbol{y}$ on one hand, and $\boldsymbol{X1}$ or $\boldsymbol{X2}$ on the other: <<>>= set.seed(1) omnibus(y,list(X1,X2)) @ The output includes the \mbox{$p$-value} and the test statistic for the joint test, the \mbox{$p$-values} for the individual tests, and the numbers of tested covariates. \subsection{P-values} \label{omnibus_p_values} When testing single covariate sets, the user can choose between three different types of \mbox{$p$-values}. By default \mbox{$p$-values} are calculated by permutation without repetitions (${\verb+kind+=1}$). Alternatively, permutation can be interrupted when it becomes impossible to reach a predefined significance level (${0 < \verb+kind+ < 1}$), or the method of control variables can be used (${\verb+kind+=0}$). <>= omnibus(y,X,kind=1) # crude permutation test omnibus(y,X,kind=0.05) # interrupting permutation omnibus(y,X,kind=0) # method of control variables @ %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \newpage %%%%%%%%%%%%%%%%%%%%%%%% \section{Decomposition} %%%%%%%%% \label{proprius} %%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \subsection{Minimal example} \label{proprius_minimal_example} Even though a single hypothesis is tested on the covariate set, the function \textbf{proprius} can obtain the contributions of individual covariates or samples to the test statistic. <>= proprius(y,X,type="samples") proprius(y,X,type="covariates") @ We observe that individual~$2$ contributes negatively to the test statistic, whereas the contributions of individuals~$4$ and $6$ are positive. We also observe that several covariates have large positive contributions. Summing over the individual contributions gives back the test statistic. \subsection{Null distribution} \label{proprius_null_distribution} If a significance level~$\alpha$ is specified, then the \mbox{$1-\alpha$}~lower quantile under the null hypothesis is plotted: <>= proprius(y,X,type="covariates",alpha=0.05) @ \subsection{Further arguments} \label{proprius_further_arguments} Offsets are included as in section~\ref{omnibus_offset}, confounding variables are taken into account as in section~\ref{omnibus_confounding_variable}, and overdispersion is treated as in section~\ref{omnibus_overdispersion}. The decompositions have not been implemented for multiple covariate sets. %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \newpage %%%%%%%%%%%%%%%%%%%%%%%% \section{Genome-wide analysis} %% \label{cursus} %%%%%%%%%%%%%%%%%% %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \subsection{Data} \label{cursus_data} Suppose the matrix~$\boldsymbol{Y}$ contains expression levels of \Sexpr{nrow(Y)}~genes and \Sexpr{ncol(Y)}~individuals, and the matrices~$\boldsymbol{V}$ and~$\boldsymbol{W}$ represent two different molecular profiles. Suppose that we furthermore know the locations of the genes ($\boldsymbol{Yloc}$), the locations of the genetic or epigenetic alterations ($\boldsymbol{Vloc}$ and $\boldsymbol{Wloc}$), and the chromosome indicators $\boldsymbol{Ychr}$, $\boldsymbol{Vchr}$ and $\boldsymbol{Wchr}$. <<>>= cbind(Yloc,Ychr,Y) cbind(Vloc,Vchr,V) cbind(Wloc,Wchr,W) @ \subsection{Minimal example} \label{cursus_minimal_example} We are interested in testing the expression of each gene for associations with \textit{local} genetic or epigenetic alterations. Setting the argument window to~$5$ entails that each gene is tested for association with all covariates that are located no further than $5$~units from the gene. In this example the covariates of interest are: <>= for(i in 1:length(Yloc)){ cat(paste(names(Yloc[i]),": ",sep="")) cat(names(Vloc)[Yloc[i]-5 < Vloc & Vloc < Yloc[i]+5],"\n") } @ The chromosome-wide analysis will not return any \mbox{$p$-value} for genes~$1$ and $2$, because no covariates are in their vicinity. <>= set.seed(1) cursus(Y,Yloc,V,Vloc,window=5) @ \subsection{Multiple chromosomes} \label{cursus_mutiple_chromosomes} If multiple chromosomes are analysed, it is important to include the chromosome indicators. They make sure that genes are mapped to covariates on the same chromosome: <>= set.seed(1) cursus(Y,Yloc,V,Vloc,window=5,Ychr,Vchr) @ \subsection{Different library sizes} \label{cursus_different_library_sizes} To account for different sequencing depths, an offset can be included: <>= offset <- colSums(Y) # library sizes set.seed(1) cursus(Y,Yloc,V,Vloc,window=5,offset=offset) @ Otherwise the offset is calculated based on $\boldsymbol{Y}$. \newpage \subsection{Multiple molecular profiles} \label{cursus_multiple_molecular_profiles} For the simultaneous analysis of multiple molecular profiles, the function \textbf{cursus} expects one covariate matrix, one location vector and one window size for each profile. <>= set.seed(1) cursus(Y,Yloc,list(V,W),list(Vloc,Wloc),list(5,50)) @ \subsection{Further arguments} \label{cursus_further_arguments} Confounding variables are taken into account as in section~\ref{omnibus_confounding_variable}. By setting ${\verb+phi=rep(0,q)+}$ where \verb+q+ is the number of genes, the user can restrict the negative binomial distribution to the Poisson distribution. By default, offsets and dispersion parameters are calculated internally, but they can also be inserted. The following example uses the R package \textbf{edgeR} from Bioconductor: <>= list <- edgeR::DGEList(Y) list <- edgeR::calcNormFactors(list) list <- edgeR::estimateDisp(list) lib.size <- colSums(Y) offset <- lib.size/exp(mean(log(lib.size))) norm.factors <- list$samples$norm.factors offset <- norm.factors*offset phi <- list$tagwise.dispersion cursus(Y,Yloc,V,Vloc,window=5,offset=offset,phi=phi) @ \newpage \section*{References} The R package \textbf{globalSeq} is based on Rauschenberger et al.~\cite{Rauschenberger2016}, where detailed references to previous work are given. If you use \textbf{globalSeq} for publications, please cite Rauschenberger et al.~\cite{Rauschenberger2016}. \newline \newline Based on calculations from le Cessie and van Houwelingen~\cite{leCessie1995} and using the generalised linear modelling framework from McCullagh et al.~\cite{McCullagh1989}, Goeman et al.~\cite{Goeman2004} showed how to test for association between a response variable from the exponential family of distributions and a high-dimensional covariate set, and derived the contributions of samples and covariates to the test statistic. Menezes et al.~\cite{Menezes2016} extended this test to multiple covariate sets. Rauschenberger et al.~\cite{Rauschenberger2016} adapted the methods from Goeman et al.~\cite{Goeman2004} and Menezes et al.~\cite{Menezes2016} to the negative binomial distribution with an unknown dispersion parameter. This permutation test was made computationally efficient using ideas from Wieringen et al.~\cite{Wieringen2008} and Senchaudhuri et al.~\cite{Senchaudhuri1995}. \begingroup \renewcommand{\section}[2]{} \bibliography{references} \endgroup \end{document}