-
Notifications
You must be signed in to change notification settings - Fork 33
/
Copy pathmain.tex
386 lines (315 loc) · 16.5 KB
/
main.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
\documentclass[9pt,a4paper]{extarticle}\usepackage[]{graphicx}\usepackage[]{color}
%% maxwidth is the original width if it is less than linewidth
%% otherwise use linewidth (to make sure the graphics do not exceed the margin)
\makeatletter
\def\maxwidth{ %
\ifdim\Gin@nat@width>\linewidth
\linewidth
\else
\Gin@nat@width
\fi
}
\makeatother
\definecolor{fgcolor}{rgb}{0.345, 0.345, 0.345}
\newcommand{\hlnum}[1]{\textcolor[rgb]{0.686,0.059,0.569}{#1}}%
\newcommand{\hlstr}[1]{\textcolor[rgb]{0.192,0.494,0.8}{#1}}%
\newcommand{\hlcom}[1]{\textcolor[rgb]{0.678,0.584,0.686}{\textit{#1}}}%
\newcommand{\hlopt}[1]{\textcolor[rgb]{0,0,0}{#1}}%
\newcommand{\hlstd}[1]{\textcolor[rgb]{0.345,0.345,0.345}{#1}}%
\newcommand{\hlkwa}[1]{\textcolor[rgb]{0.161,0.373,0.58}{\textbf{#1}}}%
\newcommand{\hlkwb}[1]{\textcolor[rgb]{0.69,0.353,0.396}{#1}}%
\newcommand{\hlkwc}[1]{\textcolor[rgb]{0.333,0.667,0.333}{#1}}%
\newcommand{\hlkwd}[1]{\textcolor[rgb]{0.737,0.353,0.396}{\textbf{#1}}}%
\let\hlipl\hlkwb
\usepackage{framed}
\makeatletter
\newenvironment{kframe}{%
\def\at@end@of@kframe{}%
\ifinner\ifhmode%
\def\at@end@of@kframe{\end{minipage}}%
\begin{minipage}{\columnwidth}%
\fi\fi%
\def\FrameCommand##1{\hskip\@totalleftmargin \hskip-\fboxsep
\colorbox{shadecolor}{##1}\hskip-\fboxsep
% There is no \\@totalrightmargin, so:
\hskip-\linewidth \hskip-\@totalleftmargin \hskip\columnwidth}%
\MakeFramed {\advance\hsize-\width
\@totalleftmargin\z@ \linewidth\hsize
\@setminipage}}%
{\par\unskip\endMakeFramed%
\at@end@of@kframe}
\makeatother
\definecolor{shadecolor}{rgb}{.97, .97, .97}
\definecolor{messagecolor}{rgb}{0, 0, 0}
\definecolor{warningcolor}{rgb}{1, 0, 1}
\definecolor{errorcolor}{rgb}{1, 0, 0}
\newenvironment{knitrout}{}{} % an empty environment to be redefined in TeX
\usepackage{alltt}
\usepackage{f1000_styles}
%\usepackage{Bioconductor}
\usepackage{natbib}
\usepackage{hyperref}
\usepackage{float}
\makeatletter
\def\maxwidth{ %
\ifdim\Gin@nat@width>\linewidth
\linewidth
\else
\Gin@nat@width
\fi
}
\makeatother
%%%%%%%%%%%%%%%%%%%%%%%Replace BiocStyle%%%%%%%%%%%%%%%%%%%%%%%
\RequirePackage{color}
\definecolor{BiocBlue}{RGB}{24,129,194}
\definecolor{BiocGreen}{RGB}{135,177,63}
\definecolor{BiocGray}{cmyk}{0,0,0,0.50}
\definecolor{BiocMagenta}{rgb}{1, 0, 1}
\definecolor{BiocRed}{rgb}{1, 0, 0}
\definecolor{BiocBittersweet}{cmyk}{0,0.75,1,0.24}
\usepackage{xspace}
% R
\let\proglang=\textit
\let\code=\texttt
\newcommand{\Rcode}{\code}
\newcommand{\pkgname}[1]{\textit{#1}\xspace}
\newcommand{\Rpkg}[1]{\pkgname{#1} \xspace}
\newcommand{\citepkg}[1]{\cite{#1}}
% CRAN
\newcommand{\CRANurl}[1]{\url{http://cran.r-project.org/package=#1}}
%% CRANpkg
\makeatletter
\def\CRANpkg{\@ifstar\@CRANpkg\@@CRANpkg}
\def\@CRANpkg#1{\href{http://cran.r-project.org/package=#1}{\pkgname{#1}}}
%\footnote{\CRANurl{#1}}}
\def\@@CRANpkg#1{\href{http://cran.r-project.org/package=#1}{\pkgname{#1}}} %package\footnote{\CRANurl{#1}}}
\makeatother
%% citeCRANpkg
\makeatletter
\def\citeCRANpkg{\@ifstar\@citeCRANpkg\@@citeCRANpkg}
\def\@citeCRANpkg#1{\CRANpkg{#1}\cite*{Rpackage:#1}}
\def\@@citeCRANpkg#1{\CRANpkg{#1}~\cite{Rpackage:#1}}
\makeatother
\newcommand{\CRANnmf}{\href{http://cran.r-project.org/package=NMF}{CRAN}}
\newcommand{\CRANnmfURL}{\url{http://cran.r-project.org/package=NMF}}
% Bioconductor
\newcommand{\BioCurl}[1]{\url{http://www.bioconductor.org/packages/release/bioc/html/#1.html}}
\newcommand{\BioCpkg}[1]{\href{http://www.bioconductor.org/packages/release/bioc/html/#1.html}{\pkgname{#1}}}
%\footnote{\BioCurl{#1}}}
\newcommand{\citeBioCpkg}[1]{\BioCpkg{#1}~\cite{Rpackage:#1}}
% Bioconductor annotation
\newcommand{\BioCAnnurl}[1]{\url{http://www.bioconductor.org/packages/release/data/annotation/html/#1.html}}
\newcommand{\BioCAnnpkg}[1]{\href{http://www.bioconductor.org/packages/release/data/annotation/html/#1.html}{\Rcode{#1}} annotation package\footnote{\BioCAnnurl{#1}}}
\newcommand{\citeBioCAnnpkg}[1]{\BioCAnnpkg{#1}~\cite{Rpackage:#1}}
\newcommand\Githubpkg[1]{\GithubSplit#1\relax}
\def\GithubSplit#1/#2\relax{{\href{https://github.com/#1/#2}%
{\Rpackage{#2}}}}
%
%\newcommand{\Rcode}[1]{\texttt{#1}}
\newcommand{\Rfunction}[1]{\Rcode{#1}}
\newcommand{\Robject}[1]{\Rcode{#1}}
\newcommand{\Rclass}[1]{\textit{#1}}
\newcommand{\Rpackage}[1]{\textit{#1}}
%
\newcommand{\bioccomment}[1]{\textsl{\textcolor{BiocGray}{comment: #1}}}
\newcommand{\warning}[1]{\textsl{\textcolor{BiocMagenta}{warning: #1}}}
\newcommand{\fixme}[1]{\textsl{\textcolor{BiocBittersweet}{fixme: #1}}}
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%Replace BiocStyle%%%%%%%%%%%%%%%%%%%%%%%%%%
\IfFileExists{upquote.sty}{\usepackage{upquote}}{}
\graphicspath{{figure/}{dadafigure/}{analysisfigure/}{phyloseqfigure/}}
\IfFileExists{upquote.sty}{\usepackage{upquote}}{}
\begin{document}
\pagestyle{front}
\title{\textit{Bioconductor} Workflow for Microbiome Data Analysis: from raw reads to community analyses.}
%\titlenote{The title should be detailed enough for someone to know whether the article would be of interest to them, but also concise. Please ensure the broadness and claims within the title are appropriate to the content of the article itself.}
\author[1]{Ben J Callahan}
\author[1]{Kris Sankaran}
\author[1]{Julia A Fukuyama}
\author[2]{Paul J McMurdie}
\author[1*]{Susan P Holmes}
\affil[1]{{\tt\{benjc,kriss1,jaf88\}@stanford.edu}, Statistics Department, Sequoia Hall, Stanford, CA 94305}
\affil[2]{{\tt [email protected]}, Whole Biome Inc, San Francisco, CA 94107 }
\affil[1*]{Corresponding author, {\tt [email protected]}, Statistics Department, Sequoia Hall, Stanford, CA 94305}
\maketitle \thispagestyle{front}
%Please provide full affiliation
%information (including full institutional address, ZIP code and e-mail
%address) for all authors, and identify who is/are the corresponding
%author(s).
\begin{abstract}
High-throughput sequencing of PCR-amplified taxonomic markers
(like the 16S rRNA gene)
has enabled a new level of analysis of
complex bacterial communities known as microbiomes. Many tools exist
to quantify and compare abundance levels or OTU composition of
communities in different conditions. The sequencing reads have to be
denoised and assigned to the closest taxa from a reference
database. Common approaches use a notion of 97\% similarity and
normalize the data by subsampling to equalize library sizes. In this
paper, we show that statistical models allow more accurate abundance
estimates. By providing a complete workflow in R, we enable the user
to do sophisticated downstream statistical analyses, whether
parametric or nonparametric. We provide examples of using the R
packages {\tt dada2, phyloseq, DESeq2, ggplot2} and {\tt vegan} to filter, visualize and
test microbiome data. We also provide examples of supervised analyses using random
forests and nonparametric testing using community networks and the {\tt ggnetwork}
package.
\end{abstract}
\section*{Revisions in Version 2}
In version 2 of the manuscript:
We have updated the procedure for storing the
filtered and trimmed files during the call to
{\tt dada2}, this avoids overwriting
the files if the workflow is run several times.
We have replaced the {\tt msa} alignment function with {\tt AlignSeqs} function from
from the \BioCpkg{DECIPHER}\citep{DECIPHER} package, making the workflow more computationally efficient.
We have expanded the phyloseq section and reduced the number of network plots.
We have also
provided detailed discussion of our choice {\bf not} to make the PCoA and PCA plots square.
We have added more detailed instructions in the Github repository as to how one can run only parts
of the workflow and how to generate the full paper from scratch using the {\tt main.rnw} file.
As suggested by reviewers, we have added more extended captions to figures. We have however refrained from
providing a complete
evaluation of DADA2 vs. OTUs or pooled/unpooled data to this manuscript. Performing such evaluations well is a significant undertaking and would take significant space to explain, and our primary purpose here is to demonstrate the many features of an R/Bioconductor amplicon analysis workflow.
We thank the three reviewers and a commentator who have provided useful feedback and we hope the revision has enhanced the readability and explained the code more completely.
\section*{Introduction}
The {\em microbiome} is formed of the ecological communities of
microorganisms that dominate the living world. Bacteria can now be
identified through the use of next generation sequencing applied at
several levels. Shotgun sequencing of all bacteria in a sample
delivers knowledge of all the genes present. Here we will only be
interested in the identification and quantification of individual taxa
(or species) through a `fingerprint gene' called 16s rRNA which is
present in all bacteria. This gene presents several variable regions
which can be used to identify the different taxa.
Previous standard workflows depended on clustering all 16s rRNA
sequences (generated by next generation amplicon sequencing)
that occur within a 97\% radius of similarity and then
assigning these to `OTUs' from reference trees
\cite{caporaso2010qiime,mothur}. These approaches do not
incorporate all the data, in particular sequence quality information and statistical information
available on the reads were not incorporated into the assignments.
In contrast, the {\bf de novo} read counts used here will be
constructed through the incorporation of both the quality scores and sequence frequencies in
a probabilistic noise model for nucleotide transitions. For more details
on the algorithmic implementation of this
step see \cite{dada2}.
After filtering the sequences and removing the chimer\ae, the data
are compared to a standard database of bacteria and labeled.
In this workflow, we have used
the labeled sequences to build a de novo phylogenetic with the
\CRANpkg{phangorn}.
The key step in the sequence analysis is the manner in which reads are
denoised and assembled into groups we have chosen to call {RSVs (Ribosomal Sequence Variants)} instead of
the traditional {OTUs (Operational Taxonomic Units)}.
This article describes a computational workflow for performing
denoising, filtering, data transformations, visualization,
supervised learning analyses, community network tests,
hierarchical testing and linear models. We provide all the code and give
several examples of different types of analyses and use-cases.
There are often many
different objectives in experiments involving microbiome data and we
will only give a flavor for what could be possible once the data has
been imported into R.
In addition, the code can be easily adapted to accommodate batch
effects, covariates and multiple experimental factors.
The workflow is based on software packages from the open-source
Bioconductor project \citep{Huber:2015}. We provide all steps
necessary from the denoising and identification of the reads input as
raw sequences in {\tt fastq} files to the comparative testing and multivariate
analyses of the
samples and analyses of the abundances according to multiple available
covariates.
\section*{Methods}
%%%%%%%%%%%%
\input{PartIdada.tex}
%%%%%%%%%%%%%
\input{PartIIphyloseq.tex}
%%%%%%%%%%%%%
\input{PartIIIanalysis.tex}
%%%%%%%%%%%%%
\subsection*{Operation}
The programs and source for this article can be run using version {\tt 3.3}
of \href{https://cran.r-project.org}{R} and version {\tt 3.3} of \href{https://www.bioconductor.org/install/}{Bioconductor}.
\section*{Conclusions} % Optional - only if novel data or analyses are included
We have shown how a complete workflow in {\tt R} is now available to denoise, identify
and normalize next generation amplicon sequencing reads
using probabilistic models with parameters fit using the data at hand.
We have provided a brief overview of all the analyses that
become possible once the data has been imported into the {\tt R} environment.
Multivariate projections using the phylogenetic tree as the relevant distance between
OTUs/RSVs can be done using weighted unifrac or double principal coordinate analyses
using the \BioCpkg{phyloseq} package.
Biplots provide the user with an interpretation key. These biplots have been extended
to triplots in the case of multidomain data incorporating genetic, metabolic and taxa abundances.
We illustrate the use of network based analyses, whether the community graph is provided from other sources
or from a taxa co-occurrence computation using a Jaccard distance.
We have briefly covered a small example of using three
supervised learning functions (random forests, partial least squares and
) to predict a response variable,
The main challenges in tackling microbiome data come from the many
different levels of heterogeneity both at the input and output levels.
These are easily accommodated through R's capacity to combine data
into S4 classes. We are able to include layers of
information, trees, sample data description matrices, contingency table
in the phyloseq data sctructures. The plotting facilities of
\CRANpkg{ggplot2} and \CRANpkg{ggnetwork} allow for the layering of information in the output into
plots that combine graphs, multivariate information and maps of the relationships
between covariates and taxa abundances. The layering concept allows the user to provide
reproducible
publication level figures with multiple heterogeneous sources of information.
Our main goal in providing these tools has been to enhance the statistical power
of the analyses by enabling the user to combine frequencies, quality scores and
covariate information into complete and testable projections.
\section*{Summary}
This illustration of possible workflows for microbiome data combining trees, networks,
normalized read counts and sample information showcases the capabilities
and reproducibility of an R based system for analysing bacterial communities.
We have implemented key components in {\tt C} wrapped within the
Bioconductor package
\BioCpkg{dada2} to enable the different steps to be undertaken on a laptop.
Once the sequences have been filtered and tagged they can be assembled into a phylogenetic tree directly
in R using the maximum likelihood tree estimation available in \CRANpkg{phangorn}.
The sequences are then assembled into a phyloseq object containing all the sample covariates,
the phylogenetic tree and the sample-taxa contingency table.
These data can then be visualized interactively with Shiny-phyloseq, plotted with one line
wrappers in phyloseq and filtered or transformed very easily.
The last part of the paper shows more complex analyses that require direct plotting and advanced statistical analyses.
Multivariate ordination methods allow useful lower dimensional projections in the presence of phylogenetic
information or multi-domain data as shown in an example combining metabolites, OTU abundances,
Supervised learning methods provide lists of the most relevant taxa in
discriminating between groups.
Bacterial communities can be represented as co-occurrence graphs
using network based plotting procedures available in R. We have also
provided examples where these graphs can be used to test
community structure through non parametric permutation resampling.
This provides implementations of the Friedman Rafsky\cite{friedman1979multivariate} tests for microbiome data
which have not been published previously.
\section*{Data availability} % Optional - only if novel data or analyses are included
Intermediary data for the analyses are made available
both on GitHub at
\url{https://github.com/spholmes/F1000_workflow}
and
at the Stanford
digital repository permanent url for this paper: \\
\url{http://purl.stanford.edu/wh250nn9648}.
All other data have been previously published and the links are included in
the paper.
\section*{Software availability}
Nothing changed here.
\section*{Author contributions}
BJC, KS, JAF, PJM and SPH developed the software tools,
BJC, KS, JAF, PJM and SPH developed statistical
methods and tested the workflow on the Mouse data sets.
BJC, KS, JAF, PJM and SPH wrote the article.
\section*{Competing interests}
No competing interests were disclosed.
\section*{Grant information}
This work was partially supported by the NSF (DMS-1162538 to S.P.H.), the NIH (TR32 to KS and R01AI112401 to SPH), and a Stanford Interdisciplinary Graduate Fellowship supported JAF.
\section*{Acknowledgments}
The authors would like to thank the members of the Relman Lab for their valuable insights on microbiology and sequencing.
The are also grateful to Nandita Garud, Leo Lahti, Zachary Charlop-Powers for reviewing the paper and to
Martina Fu and Shaheen Essabhoy for
code testing and suggestions for the revised version.
{\small\bibliographystyle{unsrt}
\bibliography{F1000WF}}
\end{document}