#LyX 2.1 created this file. For more info see http://www.lyx.org/ \lyxformat 474 \begin_document \begin_header \textclass article \begin_preamble \renewcommand{\textfraction}{0.05} \renewcommand{\topfraction}{0.8} \renewcommand{\bottomfraction}{0.8} \renewcommand{\floatpagefraction}{0.75} \usepackage[buttonsize=1em]{animate} \end_preamble \use_default_options true \begin_modules knitr \end_modules \maintain_unincluded_children false \language english \language_package none \inputencoding default \fontencoding global \font_roman palatino \font_sans lmss \font_typewriter lmtt \font_math auto \font_default_family default \use_non_tex_fonts false \font_sc true \font_osf false \font_sf_scale 100 \font_tt_scale 100 \graphics default \default_output_format default \output_sync 0 \bibtex_command default \index_command default \paperfontsize default \spacing single \use_hyperref true \pdf_bookmarks true \pdf_bookmarksnumbered true \pdf_bookmarksopen true \pdf_bookmarksopenlevel 2 \pdf_breaklinks false \pdf_pdfborder false \pdf_colorlinks false \pdf_backref false \pdf_pdfusetitle true \pdf_quoted_options "pdfstartview={XYZ null null 1}" \papersize default \use_geometry true \use_package amsmath 1 \use_package amssymb 1 \use_package cancel 1 \use_package esint 1 \use_package mathdots 1 \use_package mathtools 1 \use_package mhchem 1 \use_package stackrel 1 \use_package stmaryrd 1 \use_package undertilde 1 \cite_engine natbib \cite_engine_type authoryear \biblio_style plainnat \use_bibtopic false \use_indices false \paperorientation portrait \suppress_date false \justification true \use_refstyle 1 \index Index \shortcut idx \color #008000 \end_index \leftmargin 2.5cm \topmargin 2.5cm \rightmargin 2.5cm \bottommargin 2.5cm \secnumdepth 2 \tocdepth 2 \paragraph_separation indent \paragraph_indentation default \quotes_language english \papercolumns 1 \papersides 1 \paperpagestyle default \tracking_changes false \output_changes false \html_math_output 0 \html_css_as_file 0 \html_be_strict false \end_header \begin_body \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<setup, include=FALSE, cache=FALSE>>= \end_layout \begin_layout Plain Layout library(knitr) \end_layout \begin_layout Plain Layout ## set global chunk options \end_layout \begin_layout Plain Layout opts_chunk$set(fig.path='figure/manual-', cache.path='cache/manual-', fig.align='ce nter', fig.show='hold', par=TRUE) \end_layout \begin_layout Plain Layout ## I use = but I can replace it with <-; set code/output width to be 68 \end_layout \begin_layout Plain Layout options(formatR.arrow=TRUE, width=68, digits=4) \end_layout \begin_layout Plain Layout ## tune details of base graphics (https://yihui.org/knitr/hooks) \end_layout \begin_layout Plain Layout knit_hooks$set(par=function(before, options, envir){ \end_layout \begin_layout Plain Layout if (before && options$fig.show!='none') par(mar=c(4,4,.1,.1),cex.lab=.95,cex.axis=.9,mg p=c(2,.7,0),tcl=-.3) \end_layout \begin_layout Plain Layout }) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Title knitr: A General-Purpose Tool for Dynamic Report Generation in R \end_layout \begin_layout Author Yihui Xie \end_layout \begin_layout Standard The original paradigm of literate programming was brought forward mainly for software development, or specifically, to mix source code (for computer) and documentation (for human) together. Early systems include \begin_inset CommandInset href LatexCommand href name "WEB" target "http://www.literateprogramming.com/web.pdf" \end_inset and \begin_inset CommandInset href LatexCommand href name "Noweb" target "http://www.cs.tufts.edu/~nr/noweb/" \end_inset ; Sweave \begin_inset CommandInset citation LatexCommand citep key "leisch2002" \end_inset was derived from the latter, but it is less focused on documenting software, instead it is mainly used for reproducible data analysis and generating statistical reports. The \series bold knitr \series default package \begin_inset CommandInset citation LatexCommand citep key "R-knitr" \end_inset is following the steps of Sweave. For this manual, I assume readers have some background knowledge of Sweave to understand the technical details; for a reference of available options, hooks and demos, see the package homepage \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/ \end_layout \end_inset . \end_layout \begin_layout Section Hello World \end_layout \begin_layout Standard A natural question is why to reinvent the wheel. The short answer is that extending Sweave by hacking \family sans SweaveDrivers.R \family default in the \series bold utils \series default package is a difficult job to me. Many features in \series bold knitr \series default come naturally as users would have expected. Figure \begin_inset CommandInset ref LatexCommand ref reference "fig:cars-demo" \end_inset is a simple demo of some features of \series bold knitr \series default . \end_layout \begin_layout Standard \begin_inset Float figure wide false sideways false status open \begin_layout Plain Layout \begin_inset ERT status open \begin_layout Plain Layout <<cars-demo,dev='tikz',fig.width=4,fig.height=2.8,out.width='.45 \backslash \backslash textwidth',message=FALSE,cache=TRUE>>= \end_layout \begin_layout Plain Layout fit=lm(dist~speed,data=cars) # linear regression \end_layout \begin_layout Plain Layout par(mar=c(4, 4, 1, .1), mgp=c(2,1,0)) \end_layout \begin_layout Plain Layout with(cars,plot(speed,dist,panel.last=abline(fit))) \end_layout \begin_layout Plain Layout text(10,100,'$Y = \backslash \backslash beta_0 + \backslash \backslash beta_1x + \backslash \backslash epsilon$') \end_layout \begin_layout Plain Layout library(ggplot2) \end_layout \begin_layout Plain Layout qplot(speed, dist, data=cars)+geom_smooth() \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Plain Layout \begin_inset Caption Standard \begin_layout Plain Layout \begin_inset CommandInset label LatexCommand label name "fig:cars-demo" \end_inset A simple demo of possible output in \series bold knitr \series default : (1) multiple plots per chunk; (2) no need to \emph on print() \emph default objects in \series bold ggplot2 \series default ; (3) device size is \begin_inset Formula $4\times2.8$ \end_inset (inches) but output size is adjusted to \family typewriter .45 \backslash textwidth \family default in chunk options; (4) base graphics and \series bold ggplot2 \series default can sit side by side; (5) use the \emph on tikz() \emph default device in \series bold tikzDevice \series default by setting chunk option \family typewriter dev='tikz' \family default (hence can write native LaTeX expressions in R plots); (6) code highlighting. \end_layout \end_inset \end_layout \end_inset \end_layout \begin_layout Standard I would have chosen to hide the R code if this were a real report, but here I show the code just for the sake of demonstration. If we type \emph on qplot() \emph default in R, we get a plot, and the same thing happens in \series bold knitr \series default . If we draw two plots in the code, \series bold knitr \series default will show two plots and we do not need to tell it how many plots are there in the code in advance. If we set \family typewriter out.width='.49 \backslash \backslash textwidth' \family default in chunk options, we get it in the final output document. If we say \family typewriter fig.align='center' \family default , the plots are centered. That's it. Many enhancements and new features will be introduced later. If you come from the Sweave land, you can take a look at the page of transition first: \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/sweave/ \end_layout \end_inset . \end_layout \begin_layout Section Design \end_layout \begin_layout Standard The flow of processing an input file is similar to Sweave, and two major differences are that \series bold knitr \series default provides more flexibility to the users to customize the processing, and has many built-in options such as the support to a wide range of graphics devices and cache. Below is a brief description of the process: \end_layout \begin_layout Enumerate \series bold knitr \series default takes an input file and automatically determines an appropriate set of \begin_inset CommandInset href LatexCommand href name "patterns" target "https://yihui.org/knitr/patterns/" \end_inset to use if they are not provided in advance (e.g. \family sans file.Rnw \family default will use \family typewriter knit_patterns$get('rnw') \family default ); \end_layout \begin_layout Enumerate a set of output \begin_inset CommandInset href LatexCommand href name "hooks" target "https://yihui.org/knitr/hooks/" \end_inset will also be set up automatically according to the filename extension (e.g. use LaTeX environments or HTML elements to wrap up R results); \end_layout \begin_layout Enumerate the input file is read in and split into pieces consisting of R code chunks and normal texts; the former will be executed one after the other, and the latter may contain global chunk options or inline R code; \end_layout \begin_layout Enumerate for each chunk, the code is evaluated using the \series bold evaluate \series default package \begin_inset CommandInset citation LatexCommand citep key "R-evaluate" \end_inset , and the results may be filtered according to chunk options (e.g. \family typewriter echo=FALSE \family default will remove the R source code) \end_layout \begin_deeper \begin_layout Enumerate if \family typewriter cache=TRUE \family default for this chunk, \series bold knitr \series default will first check if there are previously cached results under the cache directory before really evaluating the chunk; if cached results exist and this code chunk has not been changed since last run (use MD5 sum to verify), the cached results will be (lazy-) loaded, otherwise new cache will be built; if a cached chunk depends on other chunks (see the \family typewriter dependson \family default \begin_inset CommandInset href LatexCommand href name "option" target "https://yihui.org/knitr/options/" \end_inset ) and any one of these chunks has changed, this chunk must be forcibly updated (old cache will be purged) \end_layout \begin_layout Enumerate there are six types of possible output from \series bold evaluate \series default , and their classes are \family typewriter character \family default (normal text output), \family typewriter source \family default (source code), \family typewriter warning \family default , \family typewriter message \family default , \family typewriter error \family default and \family typewriter recordedplot \family default ; an internal S3 generic function \emph on wrap() \emph default is used to deal with different types of output, using output hooks defined in the object \family typewriter knit_hooks \end_layout \begin_layout Enumerate note plots are recorded as R objects before they are really saved to files, so graphics devices will not be opened unless plots have really been produced in a chunk \end_layout \begin_layout Enumerate a code chunk is evaluated in a separate empty environment with the global environment as its parent, and all the objects in this environment after the evaluation will be saved if \family typewriter cache=TRUE \end_layout \begin_layout Enumerate chunk hooks can be run before and/or after a chunk \end_layout \end_deeper \begin_layout Enumerate for normal texts, \series bold knitr \series default will find inline R code (e.g. in \family typewriter \backslash Sexpr{} \family default ) and evaluate it; the output is wrapped by the \family typewriter inline \family default hook; \end_layout \begin_layout Standard The hooks play important roles in \series bold knitr \series default : this package makes almost everything accessible to the users. Consider the following extremely simple example which may demonstrate this freedom: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<simple-example>>= \end_layout \begin_layout Plain Layout 1+1 \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard There are two parts in the final output: the source code \family typewriter 1 + 1 \family default and the output \family typewriter [1] 2 \family default ; the comment characters \family typewriter ## \family default are from the default chunk option \family typewriter comment \family default . Users may define a hook function for the source code like this to use the \family typewriter lstlisting \family default environment: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<hook-source, eval=FALSE>>= \end_layout \begin_layout Plain Layout knit_hooks$set(source = function(x, options) { \end_layout \begin_layout Plain Layout paste(' \backslash \backslash begin{lstlisting} \backslash n', x, ' \backslash \backslash end{lstlisting} \backslash n', sep = '') \end_layout \begin_layout Plain Layout }) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Similarly we can put other types of output into other environments. There is no need to hack at \family sans Sweave.sty \family default for \series bold knitr \series default and you can put the output in any environments. What is more, the output hooks make \series bold knitr \series default ready for other types of output, and a typical one is HTML (there are built-in hooks). The website has provided many examples demonstrating the flexibility of the output. \end_layout \begin_layout Section Features \end_layout \begin_layout Standard The \series bold knitr \series default package borrowed features such as tikz graphics and cache from \series bold pgfSweave \series default and \series bold cacheSweave \series default respectively, but the implementations are different. New features like code reference from an external R script as well as output customization are also introduced. The feature of hook functions in Sweave is re-implemented and hooks have new usage now. There are several other small features which are motivated from my everyday use of Sweave. For example, a progress bar is provided when knitting a file so we roughly know how long we still need to wait; output from inline R code (e.g. \family typewriter \backslash Sexpr{x[1]} \family default ) is automatically formatted in TeX math notation (like \begin_inset ERT status collapsed \begin_layout Plain Layout \backslash Sexpr{123456789} \end_layout \end_inset ) if the result is numeric. You may check out a number of specific manuals dedicated to specific features such as graphics in the website: \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/ \end_layout \end_inset . \end_layout \begin_layout Subsection Code Decoration \end_layout \begin_layout Standard The \series bold highr \series default package \begin_inset CommandInset citation LatexCommand citep key "R-highr" \end_inset is used to highlight R code, and the \series bold formatR \series default package \begin_inset CommandInset citation LatexCommand citep key "R-formatR" \end_inset is used to reformat R code (like \family typewriter keep.source=FALSE \family default in Sweave but will also try to retain comments). For LaTeX output, the \series bold framed \series default package is used to decorate code chunks with a light gray background. If this LaTeX package is not found in the system, a version will be copied directly from \series bold knitr \series default . The prompt characters are removed by default because they mangle the R source code in the output and make it difficult to copy R code. The R output is masked in comments by default based on the same rationale. It is easy to revert to the output with prompts (set option \family typewriter prompt=TRUE \family default ), and you will quickly realize the inconvenience to the readers if they want to copy and run the code in the output document: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<stupid-prompts, prompt=TRUE, comment=NA, highlight=FALSE>>= \end_layout \begin_layout Plain Layout x=rnorm(5) \end_layout \begin_layout Plain Layout x \end_layout \begin_layout Plain Layout var(x) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard The example below shows the effect of \family typewriter tidy=TRUE/FALSE \family default : \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<tidy-no, eval=FALSE, tidy=FALSE>>= \end_layout \begin_layout Plain Layout ## option tidy=FALSE \end_layout \begin_layout Plain Layout for(k in 1:10){j=cos(sin(k)*k^2)+3;print(j-5)} \end_layout \begin_layout Plain Layout @ \end_layout \begin_layout Plain Layout <<tidy-yes, eval=FALSE, tidy=TRUE>>= \end_layout \begin_layout Plain Layout ## option tidy=TRUE \end_layout \begin_layout Plain Layout for(k in 1:10){j=cos(sin(k)*k^2)+3;print(j-5)} \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Note \family typewriter = \family default is replaced by \family typewriter <- \family default because \family typewriter options('formatR.arrow') \family default was set to be \family typewriter TRUE \family default in this document; see the documentation of \emph on tidy.source() \emph default in \series bold formatR \series default for details. \end_layout \begin_layout Standard Many highlighting themes can be used in \series bold knitr \series default , which are borrowed from the \series bold highlight \series default package by \begin_inset CommandInset href LatexCommand href name "Andre Simon" target "http://www.andre-simon.de/" \end_inset \begin_inset Foot status open \begin_layout Plain Layout not the R package mentioned before; for a preview of these themes, see \begin_inset Flex URL status collapsed \begin_layout Plain Layout http://www.andre-simon.de/dokuwiki/doku.php?id=theme_examples \end_layout \end_inset \end_layout \end_inset ; it is also possible to use themes from \begin_inset Flex URL status collapsed \begin_layout Plain Layout http://www.eclipsecolorthemes.org/ \end_layout \end_inset by providing a theme id to \series bold knitr \series default \begin_inset Foot status open \begin_layout Plain Layout many thanks to \begin_inset CommandInset href LatexCommand href name "Ramnath Vaidyanathan" target "https://github.com/ramnathv" \end_inset for the work on themes \end_layout \end_inset . See \family typewriter ?knit_theme \family default for details. \end_layout \begin_layout Subsection Graphics \end_layout \begin_layout Standard Graphics is an important part of reports, and several enhancements have been made in \series bold knitr \series default . For example, grid graphics may not need to be explicitly printed as long as the same code can produce plots in R (in some cases, however, they have to be printed, e.g. in a loop, because you have to do so in an R terminal). \end_layout \begin_layout Subsubsection Graphical Devices \end_layout \begin_layout Standard Over a long time, a frequently requested feature for Sweave was the support for other graphics devices, which has been implemented since R 2.13.0. Instead of using logical options like \family typewriter png \family default or \family typewriter jpeg \family default (this list can go on and on), \series bold knitr \series default uses a single option \family typewriter dev \family default (like \family typewriter grdevice \family default in Sweave) which has support for more than 20 devices. For instance, \family typewriter dev='png' \family default will use the \emph on png() \emph default device, and \family typewriter dev='CairoJPEG' \family default uses the \emph on CairoJPEG() \emph default device in the \series bold Cairo \series default package (it has to be installed first, of course). If none of these devices is satisfactory, you can provide the name of a customized device function, which must have been defined before it is called. \end_layout \begin_layout Subsubsection Plot Recording \end_layout \begin_layout Standard As mentioned before, all the plots in a code chunk are first recorded as R objects and then \begin_inset Quotes eld \end_inset replayed \begin_inset Quotes erd \end_inset inside a graphical device to generate plot files. The \series bold evaluate \series default package will record plots per \emph on expression \emph default basis, in other words, the source code is split into individual complete expressions and \series bold evaluate \series default will examine possible plot changes in snapshots after each single expression has been evaluated. For example, the code below consists of three expressions, out of which two are related to drawing plots, therefore \series bold evaluate \series default will produce two plots by default: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<low-level-plots, fig.keep='all', dev='tikz', fig.width=2.5, fig.height=2.5, out.width='.3 \backslash \backslash textwidth', cache=TRUE>>= \end_layout \begin_layout Plain Layout par(mar=c(3,3,.1,.1)) \end_layout \begin_layout Plain Layout plot(1:10, ann=FALSE,las=1) \end_layout \begin_layout Plain Layout text(5,9,'mass $ \backslash \backslash rightarrow$ energy \backslash n$E=mc^2$') \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard This brings a significant difference with traditional tools in R for dynamic report generation, since low-level plotting changes can also be recorded. The option \family typewriter fig.keep \family default controls which plots to keep in the output; \family typewriter fig.keep='all' \family default will keep low-level changes as separate plots; by default ( \family typewriter fig.keep='high' \family default ), \series bold knitr \series default will merge low-level plot changes into the previous high-level plot, like most graphics devices do. This feature may be useful for teaching R graphics step by step. Note, however, low-level plotting commands in a single expression (a typical case is a loop) will not be recorded accumulatively, but high-level plotting commands, regardless of where they are, will always be recorded. For example, this chunk will only produce 2 plots instead of 21 plots because there are 2 complete expressions: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<low-plot-loop, eval=FALSE>>= \end_layout \begin_layout Plain Layout plot(0,0,type='n',ann=FALSE) \end_layout \begin_layout Plain Layout for(i in seq(0, 2*pi,length=20)) points(cos(i),sin(i)) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard But this will produce 20 plots as expected: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<high-plot-loop, eval=FALSE>>= \end_layout \begin_layout Plain Layout for(i in seq(0, 2*pi,length=20)) {plot(cos(i),sin(i),xlim=c(-1,1),ylim=c(-1,1))} \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard As I showed in the beginning of this manual, it is straightforward to let \series bold knitr \series default keep all the plots in a chunk and insert them into the output document, so we no longer need the \family typewriter cat(' \backslash \backslash includegraphics{}') \family default trick. \end_layout \begin_layout Standard We can discard all previous plots and keep the last one only by \family typewriter fig.keep='last' \family default , or keep only the first plot by \family typewriter fig.keep='first' \family default , or discard all plots by \family typewriter fig.keep='none' \family default . \end_layout \begin_layout Subsubsection Plot Rearrangement \end_layout \begin_layout Standard The option \family typewriter fig.show \family default can decide whether to hold all plots while evaluating the code and \begin_inset Quotes eld \end_inset flush \begin_inset Quotes erd \end_inset all of them to the end of a chunk ( \family typewriter fig.show='hold' \family default ), or just insert them to the place where they were created (by default \family typewriter fig.show='asis' \family default ). Here is an example of \family typewriter fig.show='asis' \family default : \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<fig-hold, fig.show='asis', dev='pdf', fig.width=6, fig.height=4, out.width='.35 \backslash \backslash linewidth'>>= \end_layout \begin_layout Plain Layout contour(volcano) # contour lines \end_layout \begin_layout Plain Layout filled.contour(volcano) # fill contour plot with colors \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Beside \family typewriter hold \family default and \family typewriter asis \family default , the option \family typewriter fig.show \family default can take a third value: \family typewriter animate \family default , which makes it possible to insert animations into the output document. In LaTeX, the package \series bold animate \series default is used to put together image frames as an animation. For animations to work, there must be more than one plot produced in a chunk. The option \family typewriter interval \family default controls the time interval between animation frames; by default it is 1 second. Note you have to add \family typewriter \backslash usepackage{animate} \family default in the LaTeX preamble, because \series bold knitr \series default will not add it automatically. Animations in the PDF output can only be viewed in Adobe Reader. \end_layout \begin_layout Standard As a simple demonstration, here is a \begin_inset CommandInset href LatexCommand href name "Mandelbrot animation" target "http://en.wikipedia.org/wiki/Mandelbrot_set" \end_inset taken from the \series bold animation \series default package \begin_inset CommandInset citation LatexCommand citep key "R-animation" \end_inset ; note the PNG device is used because PDF files are too large. You should be able to see the animation immediately with Acrobat Reader since it was set to play automatically: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<animate-demo, fig.show='animate', dev='png', out.width='.45 \backslash \backslash linewidth', interval=.5, aniopts='controls,loop,autoplay', cache=TRUE>>= \end_layout \begin_layout Plain Layout library(animation) \end_layout \begin_layout Plain Layout demo('Mandelbrot', echo = FALSE, package = 'animation') \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Subsubsection Plot Size \end_layout \begin_layout Standard The \family typewriter fig.width \family default and \family typewriter fig.height \family default options specify the size of plots in the graphics device, and the real size in the output document can be different (see \family typewriter out.width \family default and \family typewriter out.height \family default ). When there are multiple plots per chunk, it is possible to arrange more than one plot per line in LaTeX -- just specify \family typewriter out.width \family default to be less than half of the current line width, e.g. \family typewriter out.width='.49 \backslash \backslash linewidth' \family default . \end_layout \begin_layout Subsubsection The tikz Device \end_layout \begin_layout Standard Beside PDF, PNG and other traditional R graphical devices, \series bold knitr \series default has special support to tikz graphics via the \series bold tikzDevice \series default package \begin_inset CommandInset citation LatexCommand citep key "R-tikzDevice" \end_inset , which is similar to \series bold pgfSweave \series default . If we set the chunk option \family typewriter dev='tikz' \family default , the \emph on tikz() \emph default device in \series bold tikzDevice \series default will be used to save plots. Options \family typewriter sanitize \family default and \family typewriter external \family default are related to the tikz device: see the documentation of \emph on tikz() \emph default for details. Note \family typewriter external=TRUE \family default in \series bold knitr \series default has a different meaning with \series bold pgfSweave \series default -- it means \family typewriter standAlone=TRUE \family default in \emph on tikz() \emph default , and the tikz graphics output will be compiled to PDF \emph on immediately \emph default after it is created, so the \begin_inset Quotes eld \end_inset externalization \begin_inset Quotes erd \end_inset does not depend on the \series bold tikz \series default package; to maintain consistency in (font) styles, \series bold knitr \series default will read the preamble of the input document and use it in the tikz device. At the moment, I'm not sure if this is a faithful way to externalize tikz graphics, but I have not seen any problems so far. The assumption to make, however, is that you declare all the styles in the preamble; \series bold knitr \series default is agnostic of \emph on local \emph default style changes in the body of the document. \end_layout \begin_layout Standard Below is an example taken from StackOverflow \begin_inset Foot status open \begin_layout Plain Layout \begin_inset Flex URL status collapsed \begin_layout Plain Layout http://stackoverflow.com/q/8190087/559676 \end_layout \end_inset \end_layout \end_inset ; we usually have to write R code like this to obtain a math expression \begin_inset Formula $\mathrm{d}\mathbf{x}_{t}=\alpha[(\theta-\mathbf{x}_{t})\mathrm{d}t+4]\mathrm{d}B_{t}$ \end_inset in R graphics: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<math-expr-R, eval=FALSE>>= \end_layout \begin_layout Plain Layout qplot(1:10, 1:10) + opts(title = substitute(paste(d * \end_layout \begin_layout Plain Layout bolditalic(x)[italic(t)] == alpha * (theta - bolditalic(x)[italic(t)]) * \end_layout \begin_layout Plain Layout d * italic(t) + lambda * d * italic(B)[italic(t)]), list(lambda = 4))) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard With the tikz device, it is both straightforward and more beautiful: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<math-expr-tikz, dev='tikz', fig.width=5, fig.height=3, out.width='.55 \backslash \backslash linewidth', cache=TRUE, message=FALSE>>= \end_layout \begin_layout Plain Layout library(ggplot2) \end_layout \begin_layout Plain Layout qplot(1:10, 1:10) + \end_layout \begin_layout Plain Layout labs(title = sprintf('$ \backslash \backslash mathrm{d} \backslash \backslash mathbf{x}_{t} = \backslash \backslash alpha[( \backslash \backslash theta - \backslash \backslash mathbf{x}_{t}) \backslash \backslash mathrm{d}t + %d] \backslash \backslash mathrm{d}B_{t}$', 4)) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard The advantage of tikz graphics is the consistency of styles \begin_inset Foot status collapsed \begin_layout Plain Layout Users are encouraged to read the vignette of \series bold tikzDevice \series default , which is the most beautiful vignette I have ever seen in R packages: \begin_inset Flex URL status collapsed \begin_layout Plain Layout http://cran.r-project.org/web/packages/tikzDevice/vignettes/tikzDevice.pdf \end_layout \end_inset \end_layout \end_inset , and one disadvantage is that LaTeX may not be able to handle too large tikz files (it can run out of memory). For example, an R plot with tens of thousands of graphical elements may fail to compile in LaTeX if we use the tikz device. In such cases, we can switch to the PDF or PNG device, or reconsider our decision on the type of plots, e.g., a scatter plot with millions of points is usually difficult to read, and a contour plot or a hexagon plot showing the 2D density can be a better alternative (they are smaller in size). \end_layout \begin_layout Standard The graphics manual contains more detailed information and you can check it out in the \begin_inset CommandInset href LatexCommand href name "website" target "https://yihui.org/knitr/demo/graphics/" \end_inset . \end_layout \begin_layout Subsection Cache \end_layout \begin_layout Standard The feature of cache is not a new idea -- both \series bold cacheSweave \series default and \series bold weaver \series default have implemented it based on Sweave, with the former using \series bold filehash \series default and the latter using \family sans .RData \family default images; \series bold cacheSweave \series default also supports lazy-loading of objects based on \series bold filehash \series default . The \series bold knitr \series default package directly uses internal base R functions to save ( \emph on tools:::makeLazyLoadDB() \emph default ) and lazy-load objects ( \emph on lazyLoad() \emph default ). These functions are either undocumented or marked as internal, but as far as I understand, they are the tools to implement lazy-loading for packages. The \series bold cacheSweave \series default vignette has clearly explained lazy-loading, and roughly speaking, lazy-loading means an object will not be really loaded into memory unless it is really used somewhere. This is very useful for cache; sometimes we read a large object and cache it, then take a subset for analysis and this subset is also cached; in the future, the initial large object will not be loaded into R if our computati on is only based on the object of its subset. \end_layout \begin_layout Standard The paths of cache files are determined by the chunk option \family typewriter cache.path \family default ; by default all cache files are created under a directory \family sans cache \family default relative to the current working directory, and if the option value contains a directory (e.g. \family typewriter cache.path='cache/abc-' \family default ), cache files will be stored under that directory (automatically created if it does not exist). The cache is invalidated and purged on any changes to the code chunk, including both the R code and chunk options \begin_inset Foot status open \begin_layout Plain Layout One exception is the \family typewriter include \family default option, which is not cached because \family typewriter include=TRUE/FALSE \family default does not affect code evaluation; meanwhile, the value \family typewriter getOption('width') \family default is also cached, so if you change this option, the cache will also be invalidate d (this option affects the width of text output) \end_layout \end_inset ; this means previous cache files of this chunk are removed (filenames are identified by the chunk label). Unlike \series bold pgfSweave \series default , cache files will never accumulate since old cache files will always be removed in \series bold knitr \series default . Unlike \series bold weaver \series default or \series bold cacheSweave \series default , \series bold knitr \series default will try to preserve these side-effects: \end_layout \begin_layout Enumerate printed results: meaning that any output of a code chunk will be loaded into the output document for a cached chunk, although it is not really evaluated. The reason is \series bold knitr \series default also cache the output of a chunk as a character string. Note this means graphics output is also cached since it is part of the output. It has been a pain for me for a long time to have to lose output to gain cache; \end_layout \begin_layout Enumerate loaded packages: after the evaluation of each cached chunk, the list of packages used in the current R session is written to a file under the cache path named \family sans __packages \family default ; next time if a cached chunk needs to be rebuilt, these packages will be loaded first. The reasons for caching package names are, it can be slow to load some packages, and a package might be loaded in a previous cached chunk which is not available to the next cached chunk when only the latter needs to be rebuilt. Note this only applies to cached chunks, and for uncached chunks, you must always use \emph on library() \emph default to load packages explicitly; \end_layout \begin_layout Standard Although \series bold knitr \series default tries to keep some side-effects, there are still other types of side-effects like setting \emph on par() \emph default or \emph on options() \emph default which are not cached. Users should be aware of these special cases, and make sure to clearly separate the code which is not meant to be cached to other chunks which are not cached, e.g., set all global options in the first chunk of a document and do not cache that chunk. \end_layout \begin_layout Standard Sometimes a cached chunk may need to use objects from other cached chunks, which can bring a serious problem -- if objects in previous chunks have changed, this chunk will not be aware of the changes and will still use old cached results, unless there is a way to detect such changes from other chunks. There is an option called \family typewriter dependson \family default in \series bold cacheSweave \series default which does this job. We can explicitly specify which other chunks this chunk depends on by setting an option like \family typewriter dependson='chunkA;chunkB' \family default or equivalently \family typewriter dependson=c('chunkA', 'chunkB') \family default . Each time the cache of a chunk is rebuilt, all other chunks which depend on this chunk will lose cache, hence their cache will be rebuilt as well. \end_layout \begin_layout Standard Another way to specify the dependencies among chunks is to use the chunk option \family typewriter autodep \family default and the function \emph on dep_auto() \emph default . This is an experimental feature borrowed from \series bold weaver \series default which frees us from setting chunk dependencies manually. The basic idea is, if a latter chunk uses any objects created from a previous chunk, the latter chunk is said to depend on the previous one. The function \emph on findGlobals() \emph default in the \series bold codetools \series default package is used to find out all global objects in a chunk, and according to its documentation, the result is an approximation. Global objects roughly mean the ones which are not created locally, e.g. in the expression \family typewriter function() {y <- x} \family default , \family typewriter x \family default should be a global object, whereas \family typewriter y \family default is local. Meanwhile, we also need to save the list of objects created in each cached chunk, so that we can compare them to the global objects in latter chunks. For example, if chunk A created an object \family typewriter x \family default and chunk B uses this object, chunk B must depend on A, i.e. whenever A changes, B must also be updated. When \family typewriter autodep=TRUE \family default , \series bold knitr \series default will write out the names of objects created in a cached chunk as well as those global objects in two files named \family sans __objects \family default and \family sans __globals \family default respectively; later we can use the function \emph on dep_auto() \emph default to analyze the object names to figure out the dependencies automatically. See \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/cache/ \end_layout \end_inset for examples. \end_layout \begin_layout Standard Yet another way to specify dependencies is \emph on dep_prev() \emph default : this is a conservative approach which sets the dependencies so that a cached chunk will depend on all its previous chunks, i.e. whenever a previous chunk is updated, all later chunks will be updated accordingly. \end_layout \begin_layout Subsection Code Externalization \end_layout \begin_layout Standard It can be more convenient to write R code in a separate file, rather than mixing it into a LaTeX document; for example, we can run R code successively in a pure R script from one chunk to the other without jumping through other texts. Since I prefer using LyX to write reports, Sweave is even more inconvenient because I have to recompile the whole document each time, even if I only want to know the results of a single chunk. Therefore \series bold knitr \series default introduced the feature of code externalization to a separate R script. Currently the setting is like this: the R script also uses chunk labels (marked in the form \family typewriter ## ---- chunk-label \family default by default); if the code chunk in the input document is empty, \series bold knitr \series default will match its label with the label in the R script to input external R code. For example, suppose this is a code chunk labelled as \family typewriter Q1 \family default in an R script named \family sans homework1-xie.R \family default which is under the same directory as the Rnw document: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<ext-r-code, eval=FALSE>>= \end_layout \begin_layout Plain Layout ## ---- Q1 --------------------- \end_layout \begin_layout Plain Layout gcd = function(m, n) { \end_layout \begin_layout Plain Layout while ((r <- m %% n) != 0) { \end_layout \begin_layout Plain Layout m = n; n = r \end_layout \begin_layout Plain Layout } \end_layout \begin_layout Plain Layout n \end_layout \begin_layout Plain Layout } \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard In the Rnw document, we can first read the script using the function \emph on read_chunk() \emph default : \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<read-chunk, eval=FALSE>>= \end_layout \begin_layout Plain Layout read_chunk('homework1-xie.R') \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard This is usually done in an early chunk, and we can use the chunk \family typewriter Q1 \family default later in the Rnw document: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<use-ext-chunk, echo=FALSE, comment=NA>>= \end_layout \begin_layout Plain Layout cat('<<Q1, echo=TRUE, tidy=TRUE>>=','@',sep=' \backslash n') \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Different documents can read the same R script, so the R code can be reusable across different input documents. \end_layout \begin_layout Subsection Evaluation of Chunk Options \begin_inset CommandInset label LatexCommand label name "sub:conditional" \end_inset \end_layout \begin_layout Standard By default \series bold knitr \series default uses a new syntax to parse chunk options: it treats them as function arguments instead of a text string to be split to obtain option values. This gives the user much more power than the old syntax; we can pass arbitrary R objects to chunk options besides simple ones like \family typewriter TRUE \family default / \family typewriter FALSE \family default , numbers and character strings. The page \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/sweave/ \end_layout \end_inset has given two examples to show the advantages of the new syntax. Here we show yet another useful application. \end_layout \begin_layout Standard Before \series bold knitr \series default 0.3, there was a feature named \begin_inset Quotes eld \end_inset conditional evaluation \begin_inset Quotes erd \end_inset \begin_inset Foot status open \begin_layout Plain Layout request from \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://plus.google.com/u/0/116405544829727492615/posts/43WrRUffjzK \end_layout \end_inset \end_layout \end_inset . The idea is, instead of setting chunk options \family typewriter eval \family default and \family typewriter echo \family default to be \family typewriter TRUE \family default or \family typewriter FALSE \family default (constants), their values can be controlled by global variables in the current R session. This enables \series bold knitr \series default to conditionally evaluate code chunks according to variables. For example, here we assign \family typewriter TRUE \family default to a variable \family typewriter dothis \family default : \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<cond-variable>>= \end_layout \begin_layout Plain Layout dothis=TRUE \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard In the next chunk, we set chunk options \family typewriter eval=dothis \family default and \family typewriter echo=!dothis \family default , both are valid R expressions since the variable \family typewriter dothis \family default exists. As we can see, the source code is hidden, but it was indeed evaluated: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<cond-out1, eval=dothis, echo=!dothis>>= \end_layout \begin_layout Plain Layout print('you cannot see my source because !dothis is FALSE') \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Then we set \family typewriter eval=dothis \family default and \family typewriter echo=dothis \family default for another chunk: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<cond-out2,eval=dothis,echo=dothis>>= \end_layout \begin_layout Plain Layout dothis \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard If we change the value of \family typewriter dothis \family default to \family typewriter FALSE \family default , neither of the above chunks will be evaluated any more. Therefore we can control many chunks with a single variable, and present results selectively. \end_layout \begin_layout Standard This old feature requires \series bold knitr \series default to treat \family typewriter eval \family default and \family typewriter echo \family default specially, and we can easily see that it is no longer necessary with the new syntax: \family typewriter eval=dothis \family default will tell R to find the variable \family typewriter dothis \family default automatically just like we call a function \family typewriter foobar(eval = dothis) \family default . What is more, all options will be evaluated as R expressions unless they are already constants which do not need to be evaluated, so this old feature has been generalized to all other options naturally. \end_layout \begin_layout Subsection Customization \end_layout \begin_layout Standard The \series bold knitr \series default package is ready for customization. Both the patterns and hooks can be customized; see the package website for details. Here I show an example on how to save \series bold rgl \series default plots \begin_inset CommandInset citation LatexCommand citep key "R-rgl" \end_inset using a customized hook function. First we define a hook named \family typewriter rgl \family default using the function \emph on hook_rgl() \emph default in \series bold rgl \series default : \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<rgl-demo>>= \end_layout \begin_layout Plain Layout library(rgl) \end_layout \begin_layout Plain Layout knit_hooks$set(rgl = hook_rgl) \end_layout \begin_layout Plain Layout head(hook_rgl) # the hook function is defined as this \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Then we only have to set the chunk option \family typewriter rgl=TRUE \family default : \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<fancy-rgl, rgl=TRUE, dev='png', fig.width=5, fig.height=5, out.width='2in', message=FALSE, warning=FALSE, cache=TRUE>>= \end_layout \begin_layout Plain Layout library(rgl) \end_layout \begin_layout Plain Layout demo('bivar', package='rgl', echo=FALSE) \end_layout \begin_layout Plain Layout par3d(zoom=.7) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Due to the flexibility of output hooks, \series bold knitr \series default supports several different output formats. The implementation is fairly easy, e.g., for LaTeX we put R output in \family typewriter verbatim \family default environments, and in HTML, it is only a matter of putting output in \family typewriter div \family default layers. These are simply character string operations. Many demos in \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/ \end_layout \end_inset show this idea clearly. This manual did not cover all the features of \series bold knitr \series default , and users are encouraged to thumb through the website to know more possible features. \end_layout \begin_layout Section Editors \end_layout \begin_layout Standard You can use any text editors to write the source documents, but some have built-in support for \series bold knitr \series default . Both RStudio ( \begin_inset Flex URL status collapsed \begin_layout Plain Layout http://www.rstudio.org \end_layout \end_inset ) and LyX ( \begin_inset Flex URL status collapsed \begin_layout Plain Layout http://www.lyx.org \end_layout \end_inset ) have full support for \series bold knitr \series default , and you can compile the document to PDF with just one click. See \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/rstudio/ \end_layout \end_inset and \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://yihui.org/knitr/demo/lyx/ \end_layout \end_inset respectively. It is also possible to support other editors like \begin_inset CommandInset href LatexCommand href name "Eclipse" target "https://yihui.org/knitr/demo/eclipse/" \end_inset , \begin_inset CommandInset href LatexCommand href name "Texmaker and WinEdt" target "https://yihui.org/knitr/demo/editors/" \end_inset ; see the demo list in the website for configuration instructions. \end_layout \begin_layout Section* About This Document \end_layout \begin_layout Standard This manual was written in LyX and compiled with \series bold knitr \series default (version \begin_inset ERT status collapsed \begin_layout Plain Layout \backslash Sexpr{packageVersion('knitr')} \end_layout \end_inset ). The LyX source and the Rnw document exported from LyX can be found under these directories: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<source-location, eval=FALSE>>= \end_layout \begin_layout Plain Layout system.file('examples', 'knitr-manual.lyx', package='knitr') # lyx source \end_layout \begin_layout Plain Layout system.file('examples', 'knitr-manual.Rnw', package='knitr') # Rnw source \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard You can use the function \emph on knit() \emph default to knit the Rnw document (remember to put the two \family sans .bib \family default files under the same directory), and you need to make sure all the R packages used in this document are installed: \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout <<required-packages, eval=FALSE>>= \end_layout \begin_layout Plain Layout install.packages(c('animation', 'rgl', 'tikzDevice', 'ggplot2')) \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard Feedback and comments on this manual and the package are always welcome. Bug reports and feature requests can be sent to \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://github.com/yihui/knitr/issues \end_layout \end_inset , and questions can be delivered to the \begin_inset CommandInset href LatexCommand href name "mailing list" target "knitr@googlegroups.com" type "mailto:" \end_inset \begin_inset Flex URL status collapsed \begin_layout Plain Layout https://groups.google.com/group/knitr \end_layout \end_inset . \end_layout \begin_layout Standard \begin_inset ERT status open \begin_layout Plain Layout % when knitr is updated, this chunk will be updated; why? \end_layout \begin_layout Plain Layout <<auto-bib, version=packageVersion('knitr'), echo=FALSE, cache=TRUE, message=FAL SE, warning=FALSE>>= \end_layout \begin_layout Plain Layout # write all packages in the current session to a bib file \end_layout \begin_layout Plain Layout write_bib(c(.packages(), 'evaluate', 'formatR', 'highr'), file = 'knitr-packages.b ib') \end_layout \begin_layout Plain Layout @ \end_layout \end_inset \end_layout \begin_layout Standard \begin_inset CommandInset bibtex LatexCommand bibtex bibfiles "knitr-manual,knitr-packages" options "jss" \end_inset \end_layout \end_body \end_document