class: center, middle, inverse, title-slide # Writing dynamic and reproducible documents ## An introduction to R Markdown ### Olivier Gimenez ### November 2020 --- # Credits - Garrett Grolemund [RStudio webinar](https://github.com/garrettgman/webinars/tree/master/12-Getting-started-with-R-Markdown) data:image/s3,"s3://crabby-images/00818/008183c30ba27889807b3c271d3e64ce3b391292" alt="" - Ulrik Lyngs [workshop material](https://github.com/ulyngs/rmarkdown-workshop-2019) data:image/s3,"s3://crabby-images/ada30/ada303dc663c4f5ac8f7b75bddd675c0059ed5fc" alt="" --- class: inverse, center, middle # Motivation --- <iframe width="1300" height="600" src="https://www.youtube.com/embed/s3JldKoA0zw" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe> Credit: [Ignasi Bartomeus, PhD](https://bartomeuslab.com/) --- # .center[data:image/s3,"s3://crabby-images/d0f2c/d0f2c5072f206b9c7bf59ee343c755efa1951cad" alt=""] --- # How can you reproduce results? .center[data:image/s3,"s3://crabby-images/0468e/0468e43ea94627126acc21f9e3c75ff6e75f3735" alt=""] --- # What do we need to make research reproducible? - Something to integrate text, figures and code * `R`, `Python`, etc - Something that can be continuously edited and updated * Living or dynamic document - Something that can be easily used in versioning tools * Git --- .center[data:image/s3,"s3://crabby-images/44637/4463756742115f8c09eae31125039d6daa0b207b" alt=""] --- # R Markdown workflow .center[data:image/s3,"s3://crabby-images/43390/43390cb1aeea128714cb1c7c4a34e0a26c53bcef" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/3f721/3f7210156b6fa1eb9e997c951c01874669cb5190" 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/44e19/44e1946476f8e7b0bea783b501d7e9cbf65bf2d1" alt=""] --- .center[data:image/s3,"s3://crabby-images/bfa89/bfa89dc602fe70525d7c63da5862ce44b862ca7a" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/3f721/3f7210156b6fa1eb9e997c951c01874669cb5190" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/25253/25253e082cc07ec36a037786977932f7d60c3ee4" 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/015fc/015fc821a8d09040938a2c7c59bf2b1600a88260" 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/5e6a0/5e6a0b2ca99187d06653aeda8586247c01de8c89" alt=""] --- # Text - Text is rendered as plain text .center[data:image/s3,"s3://crabby-images/ac693/ac69323c3c1b94f2910bba57d2b34d17461ef068" 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/c9185/c91858a23b57fd6c86572c62bcaf22061721720a" alt=""] --- # Hyperlinks - To add a hyperlink, put your text between brackets - Then place the URL between parentheses .center[data:image/s3,"s3://crabby-images/d53ad/d53adb4bf2e00165a805e20de5df06dd8e602bcf" alt=""] --- # Equations - Write equations with Latex syntax .center[data:image/s3,"s3://crabby-images/a76b4/a76b47cfc3eed55bc399761c2fdad4f63b58b320" alt=""] --- # Equation blocks .center[data:image/s3,"s3://crabby-images/93136/9313656feda5bd50bbda013696825df0755ec46f" 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/ef647/ef647e0de9b9c52cf68634a91ceafcc829102590" 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/aafdd/aafdd242c251281417e4ddd01f42e3fd62b1f68d" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/3f721/3f7210156b6fa1eb9e997c951c01874669cb5190" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/cad99/cad997268746615e7169ab6239d0a996f6c9fa3f" 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/e1699/e169956dbfb0a9f4b6a4a932e97685ede013fb8d" alt=""] --- # Inline code - Place code in a sentence with - R Markdown replaces code with results .center[data:image/s3,"s3://crabby-images/aca2b/aca2bb7978b05a461ee364bd610ada32076f9edd" alt=""] --- # Chunk options - By default, R markdown includes both code and results .center[data:image/s3,"s3://crabby-images/48ebd/48ebd9a939c0a402b085a7379732cb4a621fa6e3" alt=""] --- # echo - Add options between brackets after `r`. - `echo = FALSE` hides code. .center[data:image/s3,"s3://crabby-images/daf8a/daf8a8aff70c9b15d6bdc4d080b8cf9e6e0bc7f5" alt=""] --- # echo - Add options between brackets after `r`. - `echo = FALSE` hides code. .center[data:image/s3,"s3://crabby-images/53656/536565eb2239a9454a6c8e8db918442b8a3c0083" alt=""] --- # eval - `eval = FALSE` prevents code from being run - No results is displayed, only code .center[data:image/s3,"s3://crabby-images/b2bb5/b2bb550d5cefb90e703249178970c12649944e13" 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/6f4c4/6f4c434e2db8c0e2e4e3fbb271caa2e4c36c976c" alt=""] --- # message - `message = FALSE` prevents messages from appearing in output .center[data:image/s3,"s3://crabby-images/ce98a/ce98a96f3c9342f8ab3c005917dde2f22a09b63c" 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/> --- # 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/2355f/2355fe1fec9705be1075f43cd58a0251e17b3b6f" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/3f721/3f7210156b6fa1eb9e997c951c01874669cb5190" alt=""] --- # Structure of a R Markdown document .center[data:image/s3,"s3://crabby-images/c8fc4/c8fc43e96eb67cd31bc72ea5a86b3c9d71cc0473" 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/b107d/b107d6c069abd8c20b20614b9a01fba4329fa879" alt=""] --- # Output formats .center[data:image/s3,"s3://crabby-images/35392/353929edd1b59e6434a8cea4e1e6e4112730c682" 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/2e282/2e282488d1ac30872930f82aa90c113fee8f8300" 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/d3442/d34428911cf99d02a411973b8cfb5c8bddf463ce" alt=""] --- .center[data:image/s3,"s3://crabby-images/187ec/187ecae9dbf7de1809318b13a5a43e3f0ca0c8fb" 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 --- class: inverse, center, middle # Live demo ## Build your own website in a few minutes --- ## .center[data:image/s3,"s3://crabby-images/e369d/e369d4d6b9ff9332085f98db1723301f79f6367f" alt=""] --- class: inverse, center, middle ## To go further --- # Books data:image/s3,"s3://crabby-images/6d0ac/6d0ac57230ff65fa8dc762480972985a0f3b5b2f" alt="" --- class: title-slide-final, middle background-size: 55px background-position: 9% 15% # Thanks! ### I created these slides with [xaringan](https://github.com/yihui/xaringan) and [R Markdown](https://rmarkdown.rstudio.com/) using the [rutgers css](https://github.com/jvcasillas/ru_xaringan) that I slightly modified. ### Credit: I borrowed slides from [Garrett Grolemund](https://rstudio.com/speakers/garrett-grolemund/) and [Ulrik Lyngs](https://ulriklyngs.com/). I also used the beautiful illustrations shared by [Allison Horst](https://github.com/allisonhorst/stats-illustrations). | | | | :--------------------------------------------------------------------------------------------------------- | :-------------------------------- | |
| **olivier.gimenez@cefe.cnrs.fr** | |
| [**https://oliviergimenez.github.io/**](https://oliviergimenez.github.io/) | |
| [**@oaggimenez**](https://twitter.com/oaggimenez) | |
| [**@oliviergimenez**](https://github.com/oliviergimenez)