-
Notifications
You must be signed in to change notification settings - Fork 3
/
Part1-Introduction.R
571 lines (427 loc) · 19.4 KB
/
Part1-Introduction.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
#
# Let's get familiar with R
# =========================
#
# In this section we will investigate the following questions:
# [[ How does R understand data? ]]
#
# 1. How to use this script and R
# 2. Creating objects and using logicals
# 3. Sequences and vectors (1-D)
# 4. Data frames, basic data manipulation (subsetting, renaming, joining),
# and finding help for using functions
#
# Step 1: How to use this R script
# ---------------------------------
#
# A script is a text document that contains instructions and commands The #
# symbol is used to leave comments, which R will not try to interpret as a
# command.
#
# The console (below) is for submitting commands to be interpreted in R. To run
# a command in the console, you can copy+paste it into the console and press
# enter.
#
# Copy and paste the following into the console and run it:
print("the instructor's name is Sydney")
# Run a single line of your script in the console by placing your cursor on the
# line you want to submit and use your cursor to press the "Run" button at the
# top right. You can also use the shortcut key strokes cmd+enter (mac) or
# ctrl+enter (PC) to run a single line at a time.
#
# The two other most important keyboard shortcuts that you'll want to use are the
# *Tab* key to auto-complete your typing at the command line and ctrl+up arrow or
# cmd+up arrow to access the most recently typed commands.
#
# You can also select only part of a line to have it run on the console.
#
# Let's do an exercise:
#
# ### Exercise 1: Use the function `print` to print the sentence
# ### "my name is ____".
print("my name is _____")
# R can also be used to perform calculations, such as the following:
5+1/3
# What rules does R apply for the order of operations and how do you find out?
#
# Let's modify the statement above to see if adding parentheses changes the
# result:
(5+1)/3
# Does it matter if there are spaces added into this?
#
( 5 + 1 ) / 3
# That shows us that the spaces did not matter for the calculation.
#
# R also has some pre-defined matematical terms that you can use, such as pi.
#
# What is pi times pi ?
pi*pi
pi^2 # this does the same thing because ^ is, here, interpreted as "taken to the exponent"
#
# Step 2: Creating objects and using logicals
# --------------------------------------------
#
# Objects are like shortcuts. They are a way to store data without having to
# re-type them. By virtue, objects are only created once something has been
# assigned to them. Anything can be stored in an object, including figures!
# Let's repeat our simple math calculation above, this time using objects. If we
# want to calculate (5+1)/3 using objects, it needs to look like this: (a+b)/c
# The objects a, b, and c do not exist yet, so we need to assign values to them
# in order to create them. R interprets the less than symbol and dash as
# "assign". So we need to do the following:
a <- 5 # assign the number 5 to a
b <- 1 # assign number 1 to b
c = 3 # we can also use `=` to assign 3 to c. But `<-` is the preferred assignment
# operator as `=` is used to call arguments in function calls.
# As you are assigning these numbers to objects, they appear in your environment
# (top right). These objects are not being saved to a hard drive, they are
# stored in memory of your computer only.
#
# > **NOTE** if you assign something to an object that already exists, R will do
# > what you tell it and overwrite that obect with the new assignment.
#
# Now we can execute our calculation using objects instead of numbers. Try it!
(a+b)/c
# Avoid creating object names that start with a number because R will look at
# the first character and try to interpret the entire name as a mathematical
# term. Try this:
2foxes <- 1
# The error here tells us that something went wrong and R cannot proceed.
#
# If we want to assign (a+b)/c to a new object called `answer` -- what will the
# object contain? Find out:
answer <- (a+b)/c
# Take a look at the object `answer` by typing the name into the command line:
answer
# What would you get if you multiplied answer by 2?
answer*2
# We can also use logical operations in R. The answer to a logical question is
# always TRUE or FALSE.
# Is `a` greater than `b`?
a > b # You can look at the Values on your right to check the answer.
# Is `b` greater than 10?
b > 10
# Is `b + c` greater than `a`?
b + c > a
# R will first evaluate the algebraic operation (`+`) and then evaluate the
# logical operation (`>`). So, we don't need to use `(b+c) > a`.
# Is `a` equal to 7?
a = 7
# Oops! We did not get any answer. What went wrong? Let's print `a`.
a
# `a = 7` changed the value of `a` to '7'. So, how do we find if `a` is
# equal to '7'?
a == 7 # We need to put two '=' signs to check equality.
# Is `a` not equal to '7'?
a != 7
# Are both `a` and `b` greater than c?
(a > c) & (b > c)
# Is either `a` or `b` greater than c?
(a > c) | (b > c)
# The examples above dealt with numeric values assigned to objects. We can also
# store character data in objects. We need to place the character data (words,
# phrases, etc.) inside quotation marks, otherwise R will try to interpret
# the character data as an object and will produce an error.
#
# Let's use my name for this exercise. Let's create two objects, one for my
# first name and another for my last name.
first.name <- "Sydney"
last.name <- 'Everhart' # Single quotes work too!
# We now have those two objects. Let's look at them.
first.name
last.name
# Since we each have a first name and a family name, let's do another exercise.
#
# ### Exercise 2: Modify the objects `first.name` and `last.name` so that
# ### instead of my name, they contain your name.
first.name <- "____" # Replace ____ with your own name
last.name <- "____"
# Did this work? Let's look at the two objects:
first.name
Last.name
# Oops! What went wrong? R is case-sensitive, so `last.name` is interpreted
# differently than `Last.name`. Let's try again:
first.name
last.name # It works!
# Using a function c() we can tell R to *combine* these two objects. This
# function will combine values from the first object with the second object and
# return them as a single observation. Let's try it:
c(first.name, last.name)
# Notice how the names are returned inside quotation marks, which tells us that
# these are interpreted as character data in R. You'll also notice that each
# name is placed inside quotes and that's because c() combined names into a
# single vector that contains two elements, your first and your last name. This
# brings us to the next step in our introduction, vectors.
#
# Step 3: Vectors and sequences
# ------------------------------
#
# Up to here, the objects we've created only contained a single element. You can
# store more than one element in a 1-dimensional object of unlimited length. Let's
# create an object that is a vector of our first and last names using the two
# objects that we created previously.
#
# *Avoid re-typing your commands.* Since the last command that we ran contained
# what we want, we can simply use the up arrow to access the most recently
# submitted command and modify it. You can also access the *History* tab in the
# top right panel of RStudio or, at the command line, access a list of the most
# recent commands using the cmd + up arrow OR the ctrl + up arrow.
name <- c(first.name, last.name)
# We can inspect this object by typing *name* at the command line. We can
# inspect the structure of this object using the function str() on name.
str(name)
# This shows us that this is a vector because the elements in it are ordered from 1
# to 2 as shown by the [1:2]. This also tells us that this list is a *character*
# list, which is indicated by the *chr* label. We also see the two elements in this
# vector, which is your first and last name.
#
# What is the length of your name? We can find out using the function length()
length(name)
# Let's compare this to a vector that contains only numeric data. For this
# example, let's create three objects to represent today's date in numbers for
# the month (02), day (19), and year (2020).
month <- 02
day <- 19
year <- 2020
# combine those three objects using the *combine* function:
today <- c(month, day, year)
# Inspect this object by typing the name `today` at the command line. You'll see
# that R has eliminated the zero that preceeds the 4 and has kept the order we
# provided for these elements in the vector. Let's take a look at the structure of
# today.
str(today)
# You'll notice that the vector has three elements [1:3] and it contains only
# numeric data.
#
# Let's do the same thing using the name February for month and see how that changes
# our vector. Notice that we are not modifying the object *month*, we are simply
# combining our two existing objects with the word "February".
c("February", day, year)
# In this case we didn't re-assign the object named `today`. To inspect the
# structure of this vector, we can wrap the statement within the str() function,
# as shown below. We also want to inspect the data class (ie. whether numeric or
# character) using the function class(). Don't forget to use the up-arrow to
# access the last like that you ran!
str(c("February", day, year)) # this shows us the structure of the object
class(c("February", day, year))
# Notice how R is trying to keep our data organized according to type. Rather
# than coding this vector as containing numbers and characters, it has decided
# that because it can't call everything in our vector a number that it will call
# everything characters. This process is called *coercion*.
#
# Let's say we wanted to create a table that showed every date this month:
#
# ```
# day month year
# 1 2 2020
# 2 2 2020
# 3 2 2020
# ...
# ```
#
# We know there are 29 days in the month (it's a leap year!), so we can modify the object day to
# contain all of the 29 days in this month. Instead of typing each number out by
# hand, we can place a colon (`:`) between 1 and 29, which is a shortcut in R
# for creating sequences of numbers.
1:29
# You see at in the console that this created a sequence of 29 numbers from 1 to
# 29. Let's go ahead and assign this to the object `day`.
day <- 1:29
# For the objects month and year, we don't need to modify them, however, we want
# to repeat each of them a total of 29 times because we need to repeat each,
# once for each day.
#
# We can easily repeat the number 2 a total of 29 times using the function
# `rep()`, specifying how many `times` we should repeat this object. Let's
# assign `2` to `month` and modify the object month to contain 29 copies.
month <- 2
month <- rep(month, times = 29)
month
# Let's check to make sure that month is correct using the function `length()`:
length(month)
# There are 29 elements in this vector and we can inspect individual elements in the
# vector based on their ordered position using square brackets:
month[19] # the number inside the brackets corresponds to location of element in list, not value
day[19]
# In this case, the 19th element in `month` is 2, and the 19th element in `day` is 19
# which confirms that we created this correctly.
#
# > Type `day[32]` into your R console. What do you get? What does it mean? Ask
# > yourself the question, "Are there any months with 32 days?"
#
# We can create the object `year` to contain 29 repeats of 2020, however, this
# time, let's say we wanted to make sure that this object was always the same
# length as the number of days we have in a month. Instead of specifying `29`,
# we can simply get that information using the `length()` function. Here, we'll
# replace `29` with `length(day)`, which is equivalent.
year <- rep(2020, times = length(day))
year
length(year)
# We now have three vectors to create our table and they are exactly the same length:
length(day)
length(month)
length(year)
# Step 4: Data frames, basic data manipulation, and finding help
# --------------------------------------------------------------
#
# Remember that our goal here is to create a table with the columns "month",
# "day", and "year". First, here's a quick reminder of what we want this to
# look like:
#
# ```
# day month year
# 1 2 2020
# 2 2 2020
# 3 2 2020
# ...
# ```
#
# In order to create a data frame, we can use the command `data.frame()`. This
# function will create columns out of vectors that are all the same length. In
# the function, we just have to specify name of the column and populate it with
# vector data.
February <- data.frame(day = day, month = month, year = year)
# Let's inspect this new object in the same way as vectors:
February
length(February)
# Using the `length()` function, we see it says 3. This is because `February` has three
# columns: day, month, and year. A data frame is a two-dimensional object which
# stores its information in rows and columns.
#
# Because this is a 2-dimensional object, we can inspect the dimensions using
# the `dim()` function:
dim(February)
# This tells us that we have 29 rows and 3 columns. R also provides the `nrow()`
# and `ncol()` functions to make it easier to remember which is which:
nrow(February)
ncol(February)
# What happens when we use the `str()` function?
str(February)
# We can see that it's listing the columns we have in our table and showing us
# how they are represented. Notice the `$` to the left of each column name,
# this is how we access the columns of the data frame:
February$day
February$month
February$year
# You can see that these are the same as the vectors we created earlier.
#
# Because this object is rather large, we didn't get to see the top rows of the
# obect. A quick way to look at the top of the object is with the `head()`
# function and if we wanted to look at the bottom, we would use `tail()`.
head(February) # if this didn't work, double-check that you spelled the object name correctly
# Now that we have our table, the question becomes, how do we inspect different elements?
#
# Just like we can inspect the 19th element in the `day` vector using `day[19]`,
# we can also use the brackets to subset a table, the only catch is that we have
# to use the coordinates of the row(s) and the column(s) we want. We can do this
# by specifying `[row, column]`. These are analagous to X and Y Cartesian
# coordinates. Let's take a look at the elements in the 19th row, separately:
February[19, 1] # day
February[19, "month"] # you can use characters when the elements are named!
February[19, 3] # year
February[19, -3] # here `-` means all columns except the third (year)
February[19, -2] # day and year
# If we don't specify a dimension, R will give us the entire contents of that
# dimension. Let's look at the row that contains today's date:
February[19, ]
# You can also use this to access just one column of the matrix. Let's look at month:
February[, 2]
# Notice, however that this result now appears to be a a vector! This is because
# of a sneaky default option called `drop = TRUE`. R tries to "help" by removing
# the dimensions of your data frame if you choose only one column. If you want
# to keep this as a data frame, you can turn off this option *inside the
# brackets*:
February[, 2, drop = FALSE]
# Now that we've inspected the object `February`, let's create the same thing for
# the month of March. How should we do this?
# One option would be to create new obects for day, month, and year and combine
# them just like we did for February. What is the simplest method to do this, using
# the fewest number of steps?
# We can simply make a copy of `February` and add two vectors with information about
# the 30th and 31st days. Let's do this step by step.
March <- February
# Inspect what we have now:
str(March) # we have an extra column
tail(March) # we only have 29 days
# We need to change the month column so that it says 3 instead of 2, how can we
# do this? Let's just look at the column first:
March$month
# We need to add 1 to each of these values, so let's try that!
March$month + 1
# This worked, so now we just need to replace values in March[,2] with the new
# expression:
March$month <- March$month + 1 # Did it work?
str(March)
# Now, we need to create two vectors for the 30th and 31st days of March
March_30 <- c(30, 3, 2020)
March_31 <- c(31, 3, 2020)
# Great! Let's add these vectors to the above table. R provides two functions `rbind()`
# and `cbind()`, which bind a data frame with a vector (or another data frame) by rows
# and columns, respectively. Which one should we use? If you’re unsure, try both!
#
# ### Exercise 3: Use `cbind()` and `rbind()` to figure out the correct
# ### function to stack the two vectors below the table.
cbind(March, March_30, March_31) # Do you think it will work?
# We have an error! R is trying to stack them side by side and is failing to do so because
# of different number of rows.
rbind(March, March_30, March_31) # This works!
March <- rbind(March, March_30, March_31)
# We overwrote March by creating another object with the same name
March
# Let's combine both of these tables into an object called 'Spring'. You know what
# function to use, right?
Spring <- rbind(February, March)
# Inspect this object to ensure it was made correctly.
str(Spring)
head(Spring)
tail(Spring)
# We now have a new object Spring that contains only numeric data. Let's revise
# this object so that it uses names for the month instead of numbers. We want
# it to look like this:
# ```
# day month year
# 1 "February" 2020
# 2 "February" 2020
# 3 "February" 2020
# ...
# ```
# Months need to be changed from the number 2 to "February" and from 3 to "March" in
# the second column. Let's first look at the month column.
Spring$month
# We want to specify only the cells in this list that are 2. We know that rows 1
# to 29 contain 2's and the rest contain 3's, which means we can inspect
# those rows in the object Spring:
Spring[1:29, "month"] # February
Spring[-c(1:29), "month"] # March
# > Notice that we used `-c(1:29)`, what do you think this is doing? Why would
# > this give us the values for the month of March?
#
# We can use the `ifelse()` function to replace the values in our column. How
# do we use this function? A good first step to figuring out how you can use a
# function is to look at its help page. The way you can do that is by typing
# either `help("function_name")` or `?function_name`.
?ifelse
# ### Exercise 4: Type `?ifelse` and answer these three questions:
# #### 1. What does it do? (Description)
# #### 2. What are the arguments? (Usage/Arguments)
# #### 3. What does it return? (Value)
# In order to use `ifelse`, we will need to provide three things:
#
# 1. A logical question about the elements of an object : Spring$month == 2
# 2. Values for TRUE elements : "February"
# 3. Values for FALSE elements : "March"
ifelse(Spring$month == 2, yes = "February", no = "March")
Spring$month <- ifelse(Spring$month == 2, yes = "February", no = "March")
# > Notice that we had to use `==` to indicate equality. This is so that R
# > doesn't get confused and assume we are using the argument assignment, `=`.
# Now, let's inspect Spring.
str(Spring)
head(Spring)
tail(Spring)
# Let's change first letter of every column name to uppercase i.e., replace
# "day" with "Day" and so on. We can do this using `colnames()` function.
colnames(Spring) # Current column names
colnames(Spring) <- c("Day", "Month", "Year") # New column names
# Let's inspect Spring again.
str(Spring)
head(Spring)