class: center, middle, inverse, title-slide # Writing dynamic and reproducible documents ## An introduction to R Markdown ### Olivier Gimenez ### last updated: 2021-03-21 --- # Credits - Garrett Grolemund [RStudio webinar](https://github.com/garrettgman/webinars/tree/master/12-Getting-started-with-R-Markdown) data:image/s3,"s3://crabby-images/1c30a/1c30a24d769a1c69143e184011c51e2a9b107122" alt="" - Ulrik Lyngs [workshop material](https://github.com/ulyngs/rmarkdown-workshop-2019) data:image/s3,"s3://crabby-images/31beb/31beb7a17c74b3f9163035b0d6ae4ca8c9c58164" alt="" --- .center[data:image/s3,"s3://crabby-images/65d91/65d91a76217a7301d05f2f721f4510f9bbd33611" alt=""] --- # Literate programming * A programming paradigm introduced by Donald E. Knuth * Treat program as literature meant to be understandable to human beings * Makes it easy to comment code, and share your analyses/thoughts with collaborators * Move away from writing programs in the manner and order imposed by the computer * Focus instead on the logic and flow of human thought and understanding * Single document to integrate data analysis (executable code) with textual documentation, linking data, code, and text --- # R Markdown workflow .center[data:image/s3,"s3://crabby-images/0d104/0d104c1d189d6e20ba1c703e3530f30d8ce45511" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/0ca23/0ca23fa6b640104bbeb867a7bfa363a49622406b" alt="" https://yongfu.name/2019-fju-rmd-talk/slide/#1 ] --- class: inverse, center, middle # Demo Open RStudio Create a new Rmd file Identify 3 components (frontmatter, content, chunks) --- .center[data:image/s3,"s3://crabby-images/6f3d0/6f3d0bfc90a176f5b6036e7b435d355dbda72e73" alt=""] --- .center[data:image/s3,"s3://crabby-images/69edf/69edf55a39c0b6744805049e643c45dca6a90da3" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/0ca23/0ca23fa6b640104bbeb867a7bfa363a49622406b" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/5bd5d/5bd5de2ed094ce259d6571b38de333941947d897" alt=""] --- class: inverse, center, middle # Format your text with Markdown --- # What is Markdown? - A way to write stuff - Mostly plain words, with some formating .center[data:image/s3,"s3://crabby-images/09ad7/09ad71ba908fe88e4b0e8239d9e8036a6d00f323" alt=""] --- # Websites that use Markdown - GitHub <https://github.com/> - StackOverflow <https://stackoverflow.com/> - HackMD <https://hackmd.io> - Many more --- # Headers - Use # to create headers - Multiple #'s create lower level headers .center[data:image/s3,"s3://crabby-images/ee897/ee897ec2748a7f5bdcababf5e35516374b079e86" alt=""] --- # Text - Text is rendered as plain text .center[data:image/s3,"s3://crabby-images/dcb06/dcb066403a92e4a76c316fbcd10e910d008bc728" alt=""] --- # Lists - Use asterisks to make bullet points - Use numbers to make numbered lists - Use 4 spaces or 1 tab for indentation .center[data:image/s3,"s3://crabby-images/3482c/3482c97848a2f06c9f2ee3d1fd958e9502ff4213" alt=""] --- # Hyperlinks - To add a hyperlink, put your text between brackets - Then place the URL between parentheses .center[data:image/s3,"s3://crabby-images/50ed6/50ed60360249792acc61dbf39774208bbdc98a2e" alt=""] --- # Equations - Write equations with Latex syntax .center[data:image/s3,"s3://crabby-images/bb0f2/bb0f2b8d93fab3805eb367fa16c71de511e9433f" alt=""] --- # Equation blocks .center[data:image/s3,"s3://crabby-images/e9045/e90457b9f43042f93d203549805d6d2cb95a689f" alt=""] --- # Images - Use a link preceded by an ! to insert an image - The link text should be - a URL if the image is hosted online - a file path if the image is saved on your computer .center[data:image/s3,"s3://crabby-images/63fcf/63fcfb3f7b73dcc3fb9edaac7ea73a4f01cbf626" alt=""] --- # Tables ```md | header A | header B | |---------:|:---------| | data | data | Table:title ``` - A bit of a hassle... - Use a [generator of Tables for Markdown](https://www.tablesgenerator.com/markdown_tables) - Wait for next section to learn how to generate tables from `R` --- # R Markdown Reference Guide <https://rstudio.com/wp-content/uploads/2015/03/rmarkdown-reference.pdf> .center[data:image/s3,"s3://crabby-images/0a607/0a607a30d46efec51165a9266d5fb3972ca2210a" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/0ca23/0ca23fa6b640104bbeb867a7bfa363a49622406b" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/6c69c/6c69c2d649d8622b895d1e34e682e04da52f18fa" alt=""] --- class: inverse, center, middle ## Code, figures and tables --- # Embed code - Insert chunk of `R` code - R Markdown runs code and includes results. .center[data:image/s3,"s3://crabby-images/af2d9/af2d90a1f22e68e6d4f95de9f2a95509c6117a09" alt=""] --- # Inline code - Place code in a sentence with - R Markdown replaces code with results .center[data:image/s3,"s3://crabby-images/4793a/4793a2df34cec6f05f23a2fa8f62646031c509bc" alt=""] --- # Chunk options - By default, R markdown includes both code and results .center[data:image/s3,"s3://crabby-images/1f5c1/1f5c1fccc8883f0fc891afb4d63cd49d3a726082" alt=""] --- # echo - Add options between brackets after `r`. - `echo = FALSE` hides code. .center[data:image/s3,"s3://crabby-images/d9569/d956964d22a98b1eccc4cdb2b8de794bfcdb60ec" alt=""] --- # echo - Add options between brackets after `r`. - `echo = FALSE` hides code. .center[data:image/s3,"s3://crabby-images/3c906/3c90696fa8da83962e25febd11612be7d8790408" alt=""] --- # eval - `eval = FALSE` prevents code from being run - No results is displayed, only code .center[data:image/s3,"s3://crabby-images/0cff3/0cff3db4597a489d86b063f1fb2a4d3c7ba3190c" alt=""] --- # fig.height, fig.width - Specify dimension of plots (in inches) with fig.width and fig.height - Separate multiple arguments with commas. .center[data:image/s3,"s3://crabby-images/25870/25870436940baf3425709165642416c027a61546" alt=""] --- # message - `message = FALSE` prevents messages from appearing in output .center[data:image/s3,"s3://crabby-images/c2ec0/c2ec071076ed7f66b1e4cbe0c6e31259de9bd329" alt=""] --- # Default chunk options - Repeating chunk options can be painful - If you have `echo = FALSE` in every single chunk, how to set the default chunk option to `echo = FALSE` ? - Use `knitr::opts_chunk$set(echo = FALSE)` - You may overwrite the default for each chunk - For chunk options, check out <https://yihui.name/knitr/options/> --- # Cache time-consuming code chunks - When you time-consuming calculations (simulations, Bayes stuff), and/or a looooong document - Use `cache = TRUE` in all chunks or the chunk that takes long to compile - Skip execution if executed before and nothing has changed since then - If you do modifications to the cached chunk(s), previous cache will be automatically invalidated, and new cache is built --- # Including tables ```r # cars is a built-in-to-R data set of cars # and their stopping distances cars %>% head(5) %>% knitr::kable(format = "html", caption = "A kable table") ``` <table> <caption>A kable table</caption> <thead> <tr> <th style="text-align:right;"> speed </th> <th style="text-align:right;"> dist </th> </tr> </thead> <tbody> <tr> <td style="text-align:right;"> 4 </td> <td style="text-align:right;"> 2 </td> </tr> <tr> <td style="text-align:right;"> 4 </td> <td style="text-align:right;"> 10 </td> </tr> <tr> <td style="text-align:right;"> 7 </td> <td style="text-align:right;"> 4 </td> </tr> <tr> <td style="text-align:right;"> 7 </td> <td style="text-align:right;"> 22 </td> </tr> <tr> <td style="text-align:right;"> 8 </td> <td style="text-align:right;"> 16 </td> </tr> </tbody> </table> - The [`kable`](https://www.rdocumentation.org/packages/knitr/versions/1.21/topics/kable) package is often used with the [`kableExtra`](https://cran.r-project.org/web/packages/kableExtra/vignettes/awesome_table_in_html.html) package - A number of other packages are available for making pretty tables, see [rmarkdown.rstudio.com](https://rmarkdown.rstudio.com/lesson-7.html) --- # R Markdown Reference Guide <https://rstudio.com/wp-content/uploads/2015/03/rmarkdown-reference.pdf> .center[data:image/s3,"s3://crabby-images/31ae9/31ae9b7cded7079d4e68c97ceda52c1130fd47d6" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/0ca23/0ca23fa6b640104bbeb867a7bfa363a49622406b" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/64062/6406214e17fc141bd437592332f1ce01520ee887" alt=""] --- class: inverse, center, middle # YAML Yet Another Markup Language --- # YAML in brief - Contains the metadata of the document - Starts and ends by three dashes - Comes first in the document --- # Simplest example .center[data:image/s3,"s3://crabby-images/585eb/585eb32a8132f70b5fe6daa0f991c0878666079e" alt=""] --- # Output formats .center[data:image/s3,"s3://crabby-images/a7495/a7495c78a6187cd950de06bc60c3d6869c91f372" alt=""] --- # Knit <div style="width:100%;height:0;padding-bottom:61%;position:relative;"><iframe src="https://giphy.com/embed/3oEhmHmWP3Y9wQxoli" width="100%" height="100%" style="position:absolute" frameBorder="0" class="giphy-embed" allowFullScreen></iframe></div><p> --- # Output formats .center[data:image/s3,"s3://crabby-images/07f76/07f76880f85ebfe43535282299f7a91c25d60c59" alt=""] --- # Appearance and style - In HTML output, you can use `theme` or a custom **.css** style sheet - `theme` options ([bootswatch.com](https://bootswatch.com/)) : *“cerulean”, “journal”, “flatly”, “darkly”, “readable”, “spacelab”, “united”, “cosmo”, “lumen”, “paper”, “sandstone”, “simplex”, “yeti”* - You may also use LaTeX templates with R Markdown, and write [reproducible scientific paper](https://github.com/rstudio/rticles) - You can also [use Word templates in R Markdown](http://rmarkdown.rstudio.com/articles_docx.html) (see also [this short video](https://vimeo.com/110804387)) --- # Managing bibliography -- <ol> <li> Put references in a plain text file with the extension **.bib**, in **BibTex** format (my advice: use [Zotero](https://www.zotero.org)) </ol> ```bibtex *@article{Shea2014, author = {Shea, Nicholas and Boldt, Annika}, journal = {Trends in Cognitive Sciences}, pages = {186--193}, title = {{Supra-personal cognitive control}}, volume = {18}, year = {2014}, doi = {10.1016/j.tics.2014.01.006}, } ``` -- <ol start = 2> <li>Reference this file in your YAML header </ol> ```yaml --- title: "Citation test" *bibliography: example.bib output: html_document --- ``` --- # Citations <ol start = 3> <li>In your text, citations go inside brackets and separated by semicolons </ol> -- .pull-left[ ### This... Blah blah [@Shea2014; @Lottridge2012]. ] .pull-right[ ### turns into this... Blah blah (Shea et al. 2014; Lottridge et al. 2012). ] --- class: larger-body # Citations <ol start = 3> <li>In your text, citations go inside brackets and separated by semicolons </ol> .pull-left[ ### This... Blah blah [@Shea2014; @Lottridge2012]. @Shea2014 says blah. Blah blah [see @Shea2014, pp. 33-35; also @Wu2016, ch. 1]. ] .pull-right[ ### turns into this... Blah blah (Shea et al. 2014; Lottridge et al. 2012). Shea et al. (2014) says blah. Blah blah (see Shea et al. 2014, 33–35; also Wu 2016, ch. 1). ] --- class: larger-body # Citations <ol start = 3> <li>In your text, citations go inside brackets and separated by semicolons </ol> .pull-left[ ### This... Blah blah [@Shea2014; @Lottridge2012]. @Shea2014 says blah. Blah blah [see @Shea2014, pp. 33-35; also @Wu2016, ch. 1]. ] .pull-right[ ### turns into this... Blah blah (Shea et al. 2014; Lottridge et al. 2012). Shea et al. (2014) says blah. Blah blah (see Shea et al. 2014, 33–35; also Wu 2016, ch. 1). ] - Add e.g `csl: my-style.csl` in the YAML header to change to other formats - Browse through and download styles at [zotero.org/styles](https://www.zotero.org/styles) --- # Citations For an easy way to insert citations, try the [`citr`](https://github.com/crsh/citr) RStudio add-in. <img src="https://raw.githubusercontent.com/crsh/citr/master/tools/images/addin_demo.gif" width="75%" /> --- # R Markdown Reference Guide <https://rstudio.com/wp-content/uploads/2015/03/rmarkdown-reference.pdf> .center[data:image/s3,"s3://crabby-images/ace08/ace086497bc200c6d6d6dd0de1f7686952d1a4b6" alt=""] --- .center[data:image/s3,"s3://crabby-images/d6a26/d6a2649567c3190245bb9f675ede04f853b2070d" alt=""] --- class: inverse, center, middle ## What else can we reproduce with R Markdown? --- # Let's have a tour <div style="width:100%;height:0;padding-bottom:61%;position:relative;"><iframe src="https://awesome-rmarkdown-2019.netlify.app/imgs/gallery.gif" width="100%" height="100%" style="position:absolute" frameBorder="0"></iframe></div><p> R Markdown gallery <https://rmarkdown.rstudio.com/gallery.html> --- # Websites - Use package `blogdown` <https://bookdown.org/yihui/blogdown/> - Customize with Hugo <https://themes.gohugo.io/> - Deploy via GitHub pages or Netlify - See a video tutorial [here](https://www.youtube.com/watch?v=4OUEss2XF7E&t=4s) --- # Reproducibility and collective work * How to work with Word using [`redoc`](https://bookdown.org/yihui/rmarkdown-cookbook/word-redoc.html): generate a Word document, revise the Word document, and convert the revised Word document back to R Markdown * How to collaborate on Rmd documents with [Google Drive](https://bookdown.org/yihui/rmarkdown-cookbook/google-drive.html). --- ## .center[data:image/s3,"s3://crabby-images/759e7/759e745a0a11ae1234b3af1daebc156448f8a193" alt=""] --- class: inverse, center, middle ## To go further --- # Books data:image/s3,"s3://crabby-images/d9d75/d9d75ce0ec632412da45f2aee4a90f53d2d42a7b" alt=""