class: center, middle, inverse, title-slide .title[ # Creating basic R workflows and literate programming ] .author[ ### Ernest Guevarra ] .date[ ### 26 November 2024 ] --- # Outline * Project-oriented workflows in R * Why organise workflows into projects * How to organise workflows into projects * Literate programming * Why use literate programming * RMarkdown for literate programming * Practical session --- class: inverse, center, middle # Project-orientd workflows in R --- # Why organise workflows into projects * key word is *"organise"*; * organisation ensures *coherence* and *order* which is helpful to the user whenever he/she goes back to the same work again later; * organisation supports good documentation; and, * organisation allows for collaboration. --- # How to organise workflows into projects * a unique piece of *"work"* should be its own *project*; * all resources and tools needed for a *project* should be within the same directory; and, * group resources and tools within appropriately into their own directories with the project directory. .pull-left[ .center[data:image/s3,"s3://crabby-images/0e204/0e2046c605b8d59041b1fee1da3e4c5ffa6242e9" alt=""] ] .pull-right[ .center[data:image/s3,"s3://crabby-images/227f9/227f9286d9c1eea1d60c39f3133a5c2b9c4c4e71" alt=""] ] --- class: inverse, center, middle # Literate programming --- # Why use literate programming * write code that satisfies both the machine/computer and the human reader/user; * highlight and give as much importance to the documentation of the processes and the outputs that your code represents; * focus on communication and understanding of the process and the output; and, * single document that integrates both code and textual documentation. --- # R Markdown for literate programming * R Markdown provides an authoring framework for literate programming; * A single R Markdown file is used to both save and execute code, and generate high quality reports that can be shared with an audience; and, * R Markdown documents are fully reproducible and support dozens of static and dynamic output formats. --- # R Markdown example - PDF report .pull-left[ .center[data:image/s3,"s3://crabby-images/3146d/3146d949f9bb7dba62441bc14d566047e0601b75" alt=""] ] .pull-right[ <img src="images/rmd_output_example1.png" height="500px" > ] --- # R Markdown example - HTML report .pull-left[ .center[data:image/s3,"s3://crabby-images/45783/4578379e2db4e00e75f10f572f150fef274699f7" alt=""] ] .pull-right[ .center[data:image/s3,"s3://crabby-images/33f49/33f49f1ae7b697612829ed8c648097fa10b72cdc" alt=""] ] --- # R Markdown example - Website .pull-left[ .center[data:image/s3,"s3://crabby-images/62e9d/62e9dde9dd8c4c587c14a3284e095086debaa81d" alt=""] ] .pull-right[ .center[data:image/s3,"s3://crabby-images/eefd4/eefd47fb2f7165c8f91fc420af83e8facb288326" alt=""] ] --- # R Markdown example - slide deck .pull-left[ .center[data:image/s3,"s3://crabby-images/a68bb/a68bbeb129c5ee5d749eded2ddbb909b9adab39b" alt=""] ] .pull-right[ .center[data:image/s3,"s3://crabby-images/97640/97640c1bfc487dfb82de44391c669d82bee6d969" alt=""] ] --- # Basics of R Markdown * An R Markdown document is written in markdown (an easy-to-write plain text format) and contains chunks of embedded R code, like the document below. .center[data:image/s3,"s3://crabby-images/e80a1/e80a1c2e8f6086fa3a185475bec05b0d5612a76d" alt=""] --- # Basic Markdown syntax .pull-left[ ### Markdown syntax * ```*italics*``` or ```_italics_``` * ```**bold**``` or ```__bold__``` * ```> block quote``` * ```# Header 1``` * ```## Header 2``` * ```### Header 3``` * ```#### Header 4``` ] .pull-right[ ### Resulting output * *italics* * **bold** * > block quote * # Header 1 * ## Header 2 * ### Header 3 * #### Header 4 ] --- # Basic Markdown syntax .pull-left[ ### Markdown syntax * ```[link to Open Reproducible Science website](https://oxford-ihtm.io/open-reproducible-science/)``` * adding an image: ```data:image/s3,"s3://crabby-images/053b6/053b64c1abca3e4f06d3ce0eeb1b1beab06b9b51" alt=""``` ] .pull-right[ ### Resulting output * [link to Open Reproducible Science website](https://oxford-ihtm.io/open-reproducible-science/) * adding an image: data:image/s3,"s3://crabby-images/3cddc/3cddcbb10a8ec050b0a92278b2e69850299c0d33" alt="" ] --- class: inverse, center, middle # Questions? --- class: inverse, center, middle # Practical session We'll work through *Exercise 5 - Extending R with packages* in Practical R for Epidemiologists (https://practical-r.org/exercise5.html) as a GitHub Classroom assignment --- class: inverse, center, middle # Thank you! Slides can be viewed at https://oxford-ihtm.io/open-reproducible-science/session5.html PDF version of slides can be downloaded at https://oxford-ihtm.io/open-reproducible-science/pdf/session5-literate-programming.pdf R scripts for slides available [here](https://github.com/OxfordIHTM/open-reproducible-science/blob/main/session5.Rmd)