Welcome to class!

About Us

About Us

About Us

About Us - TAs

Grant Schumock

PhD Candidate, Department of Biostatistics, JHSPH

BS in Nuclear Engineering

Email: gschumo1@jhmi.edu

Grant's picture

About Us - TAs

Qier Meng

ScM Student, Department of Biostatistics, JHSPH

Bachelor’s Degree in Mathematics

Bachelor’s Degree in Neuroscience

Email: qmeng11@jhmi.edu

Qier's picture

What is R?

What is R?

Why R?

  • High level language designed for statistical computing

  • Powerful and flexible - especially for data wrangling and visualization

  • Free (open source)

  • Extensive add-on software (packages)

  • Strong community

R-Ladies - a non-profit civil society community [source: https://rladies-baltimore.github.io/]

Why not R?

Introductions

What do you hope to get out of the class?

Why do you want to use R?

image of rocks with word hope painted on [Photo by Nick Fewings on Unsplash]

Course Website

Learning Objectives

  • Understanding basic programming syntax
  • Reading data into R
  • Recoding and manipulating data
  • Using add-on packages (more on what this is soon!)
  • Making exploratory plots
  • Performing basic statistical tests
  • Writing R functions

Course Format

  • Lecture with slides (possibly “Interactive”)
  • Lab/Practical experience
  • Two 10 min breaks each day - timing may vary
  • Jan 10-21, 2022, 8:30AM-11:50AM on Zoom
  • No class on Jan 17th for Martin Luther King Jr. Day

CoursePlus

Grading

  1. Attendance/Participation: 20% - this can be asynchronous - just some sort of interaction with the instructors/TAs (turning in assignments, emailing etc.)
  2. Homework: 3 x 15%
  3. Final “Project”: 35%

Homeworks and Final Project due by Wednesday, Jan 26, 2022 at 11:59pm EST.

If you turn homework in earlier this can allow us to potentially give you feedback earlier.

Note: Only people taking the course for credit must turn in the assignments. However, we will evaluate all submitted assignments in case others would like feedback on their work.

Installing R

Getting files from downloads

Basic terms

R jargon: https://link.springer.com/content/pdf/bbm%3A978-1-4419-1318-0%2F1.pdf

Package - a package in R is a bundle or “package” of code (and or possibly data) that can be loaded together for easy repeated use or for sharing with others.

Packages are sort of analogous to a software application like Microsoft Word on your computer. Your operating system allows you to use it, just like having R installed (and other required packages) allows you to use packages.

R hex stickers for packages

Basic terms

Function - a function is a particular piece of code that allows you to do something in R. You can write your own, use functions that come directly from installing R, or use functions from additional packages.

A function might help you add numbers together, create a plot, or organize your data. More on that soon!

sum(1, 20234)
[1] 20235

Basic terms

Argument - what you pass to a function

  • can be data like the number 1 or 20234
sum(1, 20234)
[1] 20235
  • can be options about how you want the function to work
round(0.627, digits = 2)
[1] 0.63
round(0.627, digits = 1)
[1] 0.6

Basic terms

Object - an object is something that can be worked with in R - can be lots of different things!

  • a matrix of numbers
  • a plot
  • a function

… many more

Variable and Sample

  • Variable: something measured or counted that is a characteristic about a sample

examples: temperature, length, count, color, category

  • Sample: individuals that you have data about -

examples: people, houses, viruses etc.

head(iris)
  Sepal.Length Sepal.Width Petal.Length Petal.Width Species
1          5.1         3.5          1.4         0.2  setosa
2          4.9         3.0          1.4         0.2  setosa
3          4.7         3.2          1.3         0.2  setosa
4          4.6         3.1          1.5         0.2  setosa
5          5.0         3.6          1.4         0.2  setosa
6          5.4         3.9          1.7         0.4  setosa

Columns and Rows

R hex stickers for packages [source]

Sample = Row
Variable = Column

Data objects that looks like this is often called a data frame.

Fancier versions from the tidyverse are called tibbles (more on that soon!).

Tidyverse and Base R

We will mostly show you how to use tidyverse packages and functions.

This is a newer set of packages designed for data science that can make your code more intuitive as compared to the original older Base R.

Tidyverse advantages:
- consistent structure - making it easier to learn how to use different packages
- particularly good for wrangling (manipulating, cleaning, joining) data
- more flexible for visualizing data

Packages for the tidyverse are managed by a team of respected data scientists at RStudio.

Tidyverse hex sticker

See this article for more info.

Collection of R packages

We have an R package called jhur that will make sure all the packages are installed.

You can just copy and paste the below code into your console - we’ll explain what it all means in the next day or two

install.packages("remotes")
remotes::install_github("muschellij2/jhur")

Note it may take ~5-10 minutes to run.

Useful (+ mostly Free) Resources

Want more?

Useful (+ mostly Free) Resources

Useful (+ mostly Free) Resources