3 + 5
[1] 8
In this workshop we’ll use R in the extremely useful RStudio software. For the most part we’ll work interactively, meaning we’ll type stuff straight into the R console in RStudio (Usually this is a window on the left or lower left) and get our results there too (usually in the console or in a window on the right).
Panels like the ones below mimic the interaction with R and first show the thing to type into R, and below the calculated result from R.
Let’s look at how R works by using it for it’s most basic job - as a calculator:
3 + 5
[1] 8
12 * 2
[1] 24
1 / 3
[1] 0.3333333
12 * 2
[1] 24
Fairly straightforward, we type in the expression and we get a result. That’s how this whole book will work, you type the stuff in, and get answers out. It’ll be easiest to learn if you go ahead and copy the examples one by one. Try to resist the urge to use copy and paste. Typing longhand really encourages you to look at what you’re entering.
As far as the R output itself goes, it’s really straightforward - its just the answer with a [1]
stuck on the front. This [1]
tells us how many items through the output we are. Often R will return long lists of numbers and it can be helpful to have this extra information.
We can save the output of operations for later use by giving it a name using the assignment symbol <-
. Read this symbol as ‘gets’, so x <- 5
reads as ‘x gets 5’. These names are called variables, because the value they are associated with can change.
Let’s give five a name, x
then refer to the value 5 by it’s name. We can then use the name in place of the value. In the jargon of computing we say we are assigning a value to a variable.
<- 5
x x
[1] 5
* 2 x
[1] 10
<- 3
y * y x
[1] 15
This is of course of limited value with just numbers but is of great value when we have large datasets, as the whole thing can be referred to by the variable.
At the top level, R is a simple language with two types of thing: functions and objects. As a user you will use functions to do stuff, and get back objects as an answer. Functions are easy to spot, they are a name followed by a pair of brackets. A function like mean()
is the function for calculating a mean. The options (or arguments) for the function go inside the brackets:
sqrt(16)
[1] 4
Often the result from a function will be more complicated than a simple number object, often it will be a vector (simple list), like from the rnorm()
function that returns lists of random numbers
rnorm(100)
[1] -0.298550659 1.778244867 0.004703987 0.500514638 2.507598897
[6] 0.720259391 -0.709911530 -0.650791603 1.225922386 -0.907495748
[11] 0.295183561 -1.591058444 1.206228754 0.350107343 0.762103195
[16] -1.275454838 -1.209509980 0.194488994 0.444078042 0.499289298
[21] -0.209512012 0.268428495 -0.188130173 -0.551814268 0.156401739
[26] 0.491734177 -1.635673577 1.694140982 -0.080726409 -0.943876658
[31] 0.489402221 0.122299509 0.158570480 0.507346850 -2.369714818
[36] 1.257845328 0.535305412 0.444440019 0.349703309 -0.731945397
[41] 0.034385651 1.283130382 -0.913161794 0.241682571 0.977325828
[46] 0.175301401 0.237961757 0.668144008 0.266323319 1.779748766
[51] 0.279412226 0.760342538 1.403066153 -0.444334946 -0.963231284
[56] 0.481283396 -0.967081338 -0.181728252 0.857832871 -1.943427131
[61] -0.698660764 1.019109079 -1.076316843 -0.738543126 1.155576083
[66] -0.482211713 1.315151672 -0.208498664 -1.563272479 1.265274971
[71] 0.035002036 0.833768216 -1.083182554 1.018550883 0.599451853
[76] -0.480474500 0.947490020 -0.657592753 -0.205206237 -0.269101957
[81] 1.447316876 -0.938678546 1.143479587 0.376699624 -0.346353889
[86] 1.570358581 -0.277540194 1.109845023 -1.527544828 0.711256862
[91] 0.974334900 1.678073658 -0.469390796 0.192986379 0.334762067
[96] 0.211840104 -0.523579326 -0.567765476 1.582717262 0.125886791
We can combine objects, variables and functions to do more complex stuff in R, here’s how we get the mean of 100 random numbers.
<- rnorm(100)
numbers mean(numbers)
[1] -0.03988566
Here we created a vector object with rnorm(100)
and assigned it to the variable numbers
. We than used the mean()
function, passing it the variable numbers
. The mean()
function returned the mean of the hundred random numbers.
One of the more common objects that R uses is a dataframe. The dataframe is a rectangular table-like object that contains data, think of it like a spreadsheet tab. Like the spreadsheet, the dataframe has rows and columns, the columns have names and the different columns can have different types of data in. Here’s a little one
names age score
1 Guido 24 51.840610
2 Marty 45 3.704237
3 Alan 11 81.271576
Usually we get a dataframe by loading in data from an external source or as a result from functions, occasionally we’ll want to hand make one, which can be done with various functions, data.frame
being the most common.
data.frame(
names = c("Guido", "Marty", "Alan"),
age = c(24,45,11),
score = runif(3) * 100
)
Many of the tools we use in will come in R packages, little nuggets of code that group related functions together. Installing new packages can be done using the Packages
pane of RStudio or the install.packages()
function. When we wish to use that code we use the library()
function
library(somepackage)
R provides a command, called ?
that will display the documentation for functions. For example ?mean
will display the help for the mean()
function.
?mean
As in all programming languages the internal documentation in R is written with some assumption that the reader is familiar with the language. This can be a pain when you are starting out as the help will seem a bit obscure at times. Don’t worry about this, usually the Examples
section will give you a good idea of how to use the function and as your experience grows then the more things will make more sense.
Complete the interactive tutorial online https://danmaclean.shinyapps.io/r-start