Title
knitr::opts_chunk$set(echo = TRUE, eval = FALSE, cache = TRUE, rows.print=10)
knitr::opts_knit$set(width=75)
This is an R Markdown workflow template created by Jacq. It’s intended to be copy+pasted into a new Notebook file, as a way to maintain consistency and habits across projects.
Almost all of the information here (and much more) can be found in some form in the R Markdown Definitive Guide by Yihui Xie, J. J. Allaire, and Garrett Grolemund, and that link should be your first stop as you edit this templateto suit your own needs. Think of this as a combination “Project Template” and “Beginner’s Guide to Customizing R Notebooks.”
It assumes you have the following things:
- Rstudio
- Optionally;
- The
rmdformats
package installed, for theme/colour information - The
redsquare.png
andgreencheck.png
image files.
- The
- Super optionally;
- The
viridis
, andshades
packages, for ggplot theming.
- The
- A familiarity with code chunks and other functions of r/rmarkdown.
This template reflects a workflow/organizational structure that works for me (Jacq), at a specific point in time (August 2019). Different people and projects will have different needs, and you should manipulate this document so it works for you. In the word of the Frizz – Take chances! Make Mistakes! Break R! Get messy!
YAML Header Explanation
(psst did you know that YAML stands for “YAML Ain’t Markup Language”?)
Output1: Top-level theming
This calls the theme information (the colour scheme and overall layout of the page). rmdformats::readthedown:
is telling the document to use the readthedown
theme from the rmdformats
package. R has loads of themes and you should find one that works for you.
highlight
refers to the syntax highlighting. There are lots! I like tango
, but kate
is good as well. There’s a list here.
code_folding
refers to how code is displayed. When code_folding
is set to hide
, the code isn’t displayed on the page (it’s hidden), but can be revealed by pressing the “Code” button. When it’s set to show
(as it is here), the code is displayed by default, but the button to hide the code is available. When this line isn’t included, code is shown but there’s no option to hide it.
You can also add your own theming via a custom .css file, but you’ll have to remember to include it in every folder you have Notebooks in.
Specific Outputs
html_document:
df_print: paged
code_folding: hide
html_notebook:
toc: yes
toc_float: yes
code_folding: hide
pdf_document:
toc: yes
#---
These values function the same way as the global ones above, but are specific to different kinds of output documents.
df_print
refers to the way dataframes are displayed. paged
means they’s displayed as a paged table (rather than a hugely long/wide one). There are LOTS of options here for displaying data, as well as options to manipulate the way data is displayed in each chunk, but this is a good default.
toc
refers to the Table of Contents (the clickable list on the left-hand side of the page). toc_float
controls whether the contents stays visible after the user scrolls down.
Load Libraries & ggplot
Theme
This are just example packages.
library(dplyr)
library(tidyverse)
library(kableExtra)
library(data.table)
library(shades)
library(extrafont)
library(ggridges)
library(viridis)
library(ggplot2); theme_set(theme_bw())
library(DiagrammeR)
library(lme4)
library(sjPlot)
library(wesanderson)
Using a custom theme for ggplot isn’t super necessary, but it’s fun!
TitleTheme <- theme_ridges() +
theme(text=element_text(family="Trebuchet MS")) +
theme(plot.title = element_text(hjust = 0.5, vjust = 0.5)) +
theme(plot.title = element_text(family="Perpetua Titling MT")) +
theme(plot.subtitle = element_text(family="Perpetua",
face = "bold.italic",
hjust = 0.5,
vjust = 0.5)) +
theme(axis.title = element_text(family="Perpetua", face="bold")) +
theme(axis.title.y = element_text(angle=90,
vjust = 0.5,
hjust = 0.5)) +
theme(axis.title.x = element_text(angle=0,
vjust = 0.5,
hjust = 0.5)) +
theme(axis.text.y = element_text(angle=45)) +
# Legend
# theme(legend.position = c(0.8, 0.8)) +
# theme(legend.background = element_rect(fill=alpha
# ("lightblue",0.2))) +
# theme(legend.background = element_rect(linetype=1,
# size=0.3,
# color=alpha(1, 0.4))) +
theme(legend.position="none")
colourscales <- list(gradiantTheme,
(lightness(scale_fill_viridis_d(option="plasma",
begin = 0.3),
scalefac(1.4))),
lightness(scale_color_viridis_d(option="plasma",
begin = 0.3),
scalefac(0.5)),
lightness(scale_fill_viridis(option="plasma",
begin = 0.3),
scalefac(1.4)),
lightness(scale_color_viridis(option="plasma",
begin = 0.3),
scalefac(0.5)))
Action plan
This is for scoping the work and adding a list of long-term tasks.
- The First Thing
- Green checkboxes are for completed tasks
- Red Squares are for uncompleted tasks
- You can have subtasks too
- Many subtasks
- Pretty much infinite levels of subtasks
- A second thing
- wow
- amazing
- spectacular
- wow
- A third thing
- Tasks can be added easily as you continue working on the project and think of new things to do.
Dailies
These are for keeping track of what you’ve done today. This is good for self-esteem! Tabs keep track of weeks.
Week 2
- Monday
- Thing I did
- Tuesday
- Another thing I did
- A thing I started but didn’t finish
- Day 3
Week 1
- Day 1
- Made a thing
- Day 2
- cleaned up data
- did some other stuf
- Day 3
- Was in meetings all day :(
- Day 4
- You don’t need to keep track of red days if they make you sad
- Day 5
- Did this other thing
Journal
This can work in conjunction with, or replace Dailies. It allows you to use prose to outline your goals for the day, identify problems, or otherwise keep track of your day-to-day work in detail.
July 31
Check-in
Here’s some stuff about how other things happened and some rambley thoughts about the project that I might end up cleaning up later for a conference or paper.
Check Out
A bit more rambling. In a few weeks I’ll come back to this entry and remember this train of thought, and find it inspiring!
July 30
Check-in
I want to focus on X today (around A task and the B meeting). I’ll settle for just getting subset-of-X finished, but I’ll be happy if I can manage more than that.
Some issue came up and I needed to email someone else for troubleshooting. I’ll work on this other thing instead.
Check Out
Actually, they emailed me back more quickly than I anticipated, and I was able to finish what I set out to do! hooray!
July 29
Check-in
The goal today is to do task 1 and 2, and start on 3
Check Out
It’s nearly 6 o clock and it took me hours to read the csv file in :( (This one is a real entry)