-
Notifications
You must be signed in to change notification settings - Fork 0
/
ch02_intro_RStudio_coding_basics.R
243 lines (142 loc) · 5.5 KB
/
ch02_intro_RStudio_coding_basics.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
###################################################
## Chapter 2 : The basics of RStudio and coding ##
##################################################
### Good practices
## Create a project: here -> LearningR.proj
getwd() # tells you which folder R can see and search from, shoudl be LearningR
# Create the generally useful subfolders: data, figures
# Learn to comment your code using the pound (#) sign, it's useful and a must
# for reproducibility
### Start creating objects and using the console and/or a script
# You can get output from R by simply doing math:
5+78 # execute this either here by using ctrl+enter or in the console by using enter
198/3
# You can also store this data, which will be useful for the future
target_gene <- 6 # you are assigning the value 6 to the variable named target_gene
# or you can also use
gene_all = 8 # = is common to multiple languages whereas <- (alt+dash) is only in R
# Choose short variable names that do not start with numbers
# R is case-sensitive so Gene_name and gene_name are considered different
# avoid using dots in the name (data.set > dataset)
# When assigning a value to a variable, R stores it but does not print the value itself
# to see what is inside your value, either use
print(gene_all)
# or
gene_all
# You can now play with your variable
(target_gene/gene_all)*100
### Types of objects
## The vector : The most common data structure
gene_freq <- c(0.01,20,65,0.3)
# A vector can also contain characters
gene_names <- c("PRKAA1","MTOR","ULK1","SLC1A4")
# The quotes are essential as, without the quotes, R will look for
# variables names PRKAA1 and not find them
# this will create an error message in the console
gene_names <- c(PRKAA1,MTOR,ULK1,SLC1A4)
# Importantly, all elements in a vector are of the same type of data
######### Data types in R ###########
# Characters: "MTOR", "10", "TRUE"
# Numeric : 2, 15.5, 120.2354
# Logical : TRUE FALSE
#####################################
class(gene_names) # to inspect the class of elements
# So what happens if you mix them?
x <- c("FR", 10, "BE")
x[1] # to access the first element of the vector use [1]
x[2]
# NB: MATLAB and R start counting from 1
# But C/C++, Python and Java start counting from 0
class(x[2]) # The 10 as been transformed into a "10" which is a character
# Try seeing what will happen in each of those examples
num_chr <- c(1, 2, 3, "a")
num_logi <- c(1, 2, 3, TRUE)
chr_logi <- c("a", "b", "c", TRUE)
tricky <- c(1, 2, 3, "4")
class(num_chr)
class(num_logi)
class(chr_logi)
class(tricky)
# this class coercion has a logic:
# logical → numeric → character ← logical
# If you wanted to select more elements of the vector, you could use
x[c(1,3)]
x[c(3,1)]
x[-2] # all but the second one
x[-c(2,3)] # all but the second and third one
# If you want to add elements to a vector
x <- c(x,"This","Is","Longer")
# If you want to sort them by alphabetical order
sort(x)
## The list (not Schindler's)
# Behave like containers. Unlike vectors, they can contain
# different data types
x <- list(1,"PRKAA2", TRUE)
x
class(x[1])
class(x[[1]]) # to access the content of your first sublist use [[1]]
class(x[[2]])
## The matrix : Reloaded
# Matrices are an extension of vectors. They are vectors with dimensions.
# Meaning that they only tolerate one data type at the same time
# You can check their dimensions by using dim()
m <-matrix(1:6, nrow = 2, ncol = 3)
m
dim(m)
nrow(m)
ncol(m)
# Could also have been created by doing
x <- c(1,2)
y <- c(3,4)
z <- c(5,6)
m1 <- cbind(x,y,z)
?cbind # if you don't know what a function does, this is how you access its documentation
# or
x <- c(1,3,5)
y <- c(2,4,6)
m2 <- rbind(x,y)
# We can check whether or not they are similar by using the ==
m==m1
m1==m2
# If we had tried
x <- c(1,3,5)
y <- c(2,4,6,7)
m3 <- rbind(x,y)
length(x)
length(y)
length(x)==length(y)
# To access the first row of the matrix
m[1] # will not work, is accessing the 1,1 of the matrix
m[1,]
# To access the first column of the matrix
m[,1]
# Try accessing the value in the second row and third column
## The dataframe
# A data frame is a very important data type in R. It’s the de facto data
# structure for most tabular data and what we use for statistics
# A dataframe is a special type of list with additional attributes such as
# rownames(), colnames()
# They are often imported into R by using read.csv() or read.tsv() or read.table()
# Or even... from excel tables. But we will talk about this in the following classes.
# To create a dataframe in R:
set.seed(2)
data <- data.frame(ID = 2355:2361,
name = c("PRKAA1", "CFTR", "EGFR","MYC","RAS","P53","CD14"),
expr = round(runif(7,0,1), 2)) # 7 numbers between 0 and 1
data
rownames(data)
colnames(data)
data$ID
data$name
sort(data)
data[,data$expr>0.5]
# These operations are made possible and easier by the tidyverse and dplyr
# packages, one of the biggest strengths of R -> Next class
## Additional exercises
# Create a vector of 7 random pvalues between 0.0001 and 0.01 and add it to the "data" dataframe
# hint: create a vector and fill it with the runif() function
# If not already done,
# call the column you added "pvalue"
# and change the rownames of the "data" dataframe to the IDs of the genes
# remove the ID column
# or