-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path04-NCBIsequences.Rmd
495 lines (299 loc) · 17 KB
/
04-NCBIsequences.Rmd
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
<!-- Add in pictures of the plots. -->
# NCBI SARS-CoV-2 Genome Sequences
## Getting Sequences from NCBI
![](./Figures/ncbi1.png){width=100%}
Navigate to the NCBI Virus, SARS-CoV-2 Data Hub at the link below:
https://www.ncbi.nlm.nih.gov/labs/virus/vssi/#/virus?SeqType_s=Nucleotide&VirusLineage_ss=taxid:2697049
You know you're in the correct place if it looks like the screenshot below. Note that we can look at nucleotide sequences and protein sequences, so always be sure you're collecting the correct data sets:
![](./Figures/ncbi2.png){width=100%}
Now refine your search results to include the following:
![](./Figures/ncbi3.png){width=100%}
When we download data, we want to be sure that we all have the exact same information. If we don't select the same columns to include in our downloads, we will run into trouble later when running code and comparing results. Add the colums as you see below:
![](./Figures/ncbi4.png){width=100%}
Click here to select all of the samples listed based on your refined search.
![](./Figures/ncbi5.png){width=100%}
We can generate pylogenetic trees and multiple sequence alignments directly from this webpage. We can also use a number of bioinformatic tools to generate sequence alignments and phylogenies.
![](./Figures/ncbi6.png){width=100%}
![](./Figures/ncbi7.png){width=100%}
![](./Figures/ncbi8.png){width=100%}
To visualize your data geographically and over time, click on "Visual Filters for GenBank Sequences" as shown below
![](./Figures/ncbi9.png){width=100%}
We can also look at the frequencies of the viral lineages
![](./Figures/ncbi10.png){width=100%}
![](./Figures/ncbi11.png){width=100%}
![](./Figures/ncbi12.png){width=100%}
https://www.ncbi.nlm.nih.gov/labs/virus/vssi/#/virus?SeqType_s=Nucleotide&VirusLineage_ss=taxid:2697049
Change the name of the sequence file with Denmark, Norway, and Sweden to DNS.sequences.fasta
<details>
<summary>Click for Answer</summary>
mv sequences.fasta DNS.sequences.fasta
</details>
\
Change the name of your three countries file to something that identifies the countries.
## Exploring Sequence Files
Let's start with the Denmark, Norway, Sweden files. Make sure you are in the NCBIdata directory.
1. Grab just the sequence header lines.
2. How many sequences are there for Denmark?
3. Grab just the country out of the fasta headers
Your headers should have these fields, delimitted by a pipe (make sure you put the pipes in quotes so it doesn't interpret it):
```
1) Accession
2) Genbank Title
3) Collection Date
4) Country
5) GEO Location
6) Length
7) Pangolin (variant)
8) SRA Accession
9) Sequence Type
```
4. How many sequences are there for each country?
Hint: Use sort then uniq -c (the latter gets counts of all the unique values).
5. How many sequences are there for each Geo Location? Some will just have the country there but others will have more granular information.
6. How many sequences are there for each pangolin variant? What is the dominant one? Look up more information for the dominant lineage at this site: https://cov-lineages.org/lineage_list.html
7. Haw many sequences are there for each pangolin variant in each country?
8. How many sequences are not blank in the collection data field?
```
Hint: Use "^$" in grep to find lines that have nothing between the start "^" and end "$" of the line.
```
9. What is the first and last date in your sequence file?
Hint: There are lots of different ways to do this, some of which involve more scrolling than others. Here is one strategy that just gets the earliest dates. Do each step and check it then pipe it into the next step. Repeat and get the latest date.
```
a) Get the header lines
b) Grab the collection data column (#3)
c) Remove blanks
d) Sort numerically: sort -n
e) grab the last line
```
10. Find the first and last collection date in your sequence file for each country. Try to use a for loop. Since we haven't used these much I'll put an answer here for you.
<details>
<summary>Click for Answer</summary>
```
for i in 'Denmark' 'Norway' 'Sweden'; do
echo $i
grep $i sequences.fasta | cut -f 3 -d '|' | grep -v "^$" | sort -n | head -1
done
```
</details>
\
<details>
<summary>Click for All Answers</summary>
Note that there are often several ways to do things in linux and not all methods are shown.
Since the number of sequences in NCBI changes, the numbers given below might have changed.
```
1. grep '>' sequences.fasta
2. grep -c 'Denmark' sequences.fasta
14 sequences for Denmark
3. grep '>' sequences.fasta | cut -f 4 -d '|'
4. grep '>' sequences.fasta | cut -f 4 -d '|' | sort |uniq -c
14 Denmark
5 Norway
616 Sweden
5. grep '>' sequences.fasta | cut -f 5 -d '|' | sort |uniq -c
14 Denmark
2 Norway
3 Norway: Bergen
566 Sweden
1 Sweden:Goteborg
44 Sweden: Orebro
5 Sweden:Stockholm, Sweden
6. grep '>' sequences.fasta | cut -f 7 -d '|' | sort |uniq -c
The dominant pangolin variant is B.1 which occurs 429 times.
7. grep '>' sequences.fasta | cut -f 4,7 -d '|' | sort |uniq -c
8. grep '>' sequences.fasta | cut -f 3 -d '|' |grep -c "^$"
9. grep '>' sequences.fasta | cut -f 3 -d '|' | grep -v "^$" | sort -n | (head -1; tail -1)
10. The first is for the earliest date and the second for the latest date.
for i in 'Denmark' 'Norway' 'Sweden'; do
echo $i
grep $i sequences.fasta | cut -f 3 -d '|' | grep -v "^$" | sort -n | head -1
done
for i in 'Denmark' 'Norway' 'Sweden'; do
echo $i
grep $i sequences.fasta | cut -f 3 -d '|' | grep -v "^$" | sort -n | tail -1
done
```
</details>
## Practice with your 3 countries
Run through these exercises again with your 3 countries and record the answers in your project powerpoint or elsewhere. We'll talk about what you found.
## Plotting
We'll plot some of the information about our sequences using R on the command line and the ggplot2 library. Get into a screen if you aren't already in one (screen -dr will reconnect you to a previous screen). Navigate to your NCBIdata directory.
Note that your plots might be slightly different than those shown below because more sequences may have been added to the database.
## R
The R Project for Statistical Computing
https://www.r-project.org/
R studio (Integrated Development Environment)
https://posit.co/download/rstudio-desktop/
## ggplot2
Handy gglot2 references:
ggplot2 gallery
http://www.r-graph-gallery.com/portfolio/ggplot2-package/
ggplot2 cheatsheets
http://ggplot2.tidyverse.org/reference/
ggplot2 documentation
https://cran.r-project.org/web/packages/ggplot2/ggplot2.pdf
11. Make a tab-delimitted text file with the information from your sequence headers.
```
1) Grab the sequence headers
2) Remove the greater than sign at the beginning of the header line
3) Replace the pipes with tabs (Hint: In sed use \t to represent a tab)
4) Put it into a file called Denmark_Norway_Sweden_seq_info.txt
```
Open up R.
```
R
```
<!-- using the default R: /usr/bin/R -->
Now we are in R. The R command line is similar to linux but the commands are a little bit different as you will notice as we walk through it. Note that you can use the up arrow to get back previous commands as in linux. ctrl-c works the same as well.
Load the ggplot2 library.
```
library(ggplot2)
```
See what your working directory is (it should be the directory you were in when you entered R). Note that you can change your working directory with the setwd() command, putting the path to the new directory in the parentheses.
```
getwd()
```
Let's read in the tab-delimitted file we created. We'll use the read.table command. To find out more, let's look at the help for that command using a question mark before the command (equivalent to the man command in linux).
```
?read.table
```
It prints out a lot of documentation including commands that are similar. The first part is below. The help documentation describes the command and gives you all the arguments you can use along with their defaults. Arguments go in the parentheses. Some are required but others are optional.
12. The two arguments that I use the most are "header" and "sep". Look at the usage section of the help below or in your terminal. What are the defaults for these two arguments?
13. Scroll down in the help (the up and down arrows go up or down line by line; the space bar jumps you down a page at a time) to the arguments section. Read about header and sep. What do these arguments do? What do the defaults mean?
Note: To get out of help, hit "q".
Read in our data file and put it into a variable. We'll name our variable dns for Denmark, Norway, Sweden.
```
dns = read.table("Denmark_Norway_Sweden_seq_info.txt", header=FALSE, sep="\t")
```
Let's take a look at the variable with our data. The head command in R has 6 rows by default and it wraps lines as a group if they are too long for the screen.
```
head(dns)
```
14. Take a look at the help for the head command and see if you can figure out how to show 10 lines.
15. How do you think you could look at the end of the dns variable?
When you look at the dns variable, it shows column and row names. Since we didn't have a header line in our tab-delimitted file, it just defaults to V1, V2 (V stands for vector). Since we didn't have row names, it defaults to numbers. Let's fix the column names. The "c" concatenates a list of things together to be fed in as a group.
```
colnames(dns) = c("Accession", "Genbank_Title", "Collection_Date", "Country", "GEO_Location", "Length", "Pangolin_Variant", "SRA_Accession", "Sequence_Type", "Genbank")
```
Then check it with the head command.
```
Accession
1 OR079912.1
2 OQ843561.1
3 OQ816151.1
4 OQ816152.1
5 OQ816154.1
6 OQ816156.1
Genbank Title
1 Severe acute respiratory syndrome coronavirus 2 isolate SARS-CoV-2/human/NOR/P9/2020, complete genome
2 Severe acute respiratory syndrome coronavirus 2 isolate SARS-CoV-2/human/DNK/DK-AHH8/2022, complete genome
3 Severe acute respiratory syndrome coronavirus 2 isolate SARS-CoV-2/human/SWE/01_SE100_21CS503718/2020, complete genome
4 Severe acute respiratory syndrome coronavirus 2 isolate SARS-CoV-2/human/SWE/01_SE100_21CS504474/2020, complete genome
5 Severe acute respiratory syndrome coronavirus 2 isolate SARS-CoV-2/human/SWE/01_SE100_21CS503085/2020, complete genome
6 Severe acute respiratory syndrome coronavirus 2 isolate SARS-CoV-2/human/SWE/01_SE100_21CS502014/2020, complete genome
Collection Date Country GEO Location Length Pangolin Variant SRA Accession
1 2020-10-14 Norway Norway 29825 B.1.258
2 2022-12-01 Denmark Denmark 29752 BQ.1.1.20
3 2020-03-03 Sweden Sweden 29736 B.1
4 2020-03-10 Sweden Sweden 29736 B.1
5 2020-03-11 Sweden Sweden 29736 B.1
6 2020-03-13 Sweden Sweden 29736 B.1
Sequence Type
1 GenBank
2 GenBank
3 GenBank
4 GenBank
5 GenBank
6 GenBank
```
\
The Collection Date wasn't recognized as a date so let's fix that. The $ after the dns refers to a column. We will just overwrite it in the same column.
```
dns$Collection_Date = as.Date(myTable$Collection_Date, format="%Y-%m-%d")
```
Time to plot!
The gglot2 library allows you to have a large amount of control over nearly all aspects of the plot. It also allows you to plot in layers, getting a base plot and then adding colors, lines, text, etc on top of it. It is part of the tidyverse universe and uses a Layered Grammar of Graphics (https://towardsdatascience.com/a-comprehensive-guide-to-the-grammar-of-graphics-for-effective-visualization-of-multi-dimensional-1f92b4ed4149 and https://www.jstor.org/stable/pdf/25651297.pdf?casa_token=KAMBWbsPZdwAAAAA:VHQTVEC762l7U6s6GWzRlYJNz5JaqfduQy1S04_LF6f3PUZjAh71Bva7WEIpROPBUx2BF9GL5bM0HOtDH_Zft81ycAcJ0971YeHDfrfHKBrgyw6G6fAG) to concisely describe graphical components that are shared across different graphs. In other words, it gives you tools to add and manipulate specific pieces of graphical output.
We will put each plot into a png file. Note that we can also put it into a pdf file by changing the code below to pdf. The pdf has the advantage of being able to put in multiple plots on separate pages. After plotting we need to use dev.off() so that R closes the file it is printing to.
### Histogram of Collection Dates
```
png("dates_histogram.png")
ggplot(dns, aes(x=Collection_Date)) + geom_histogram()
dev.off()
```
![](./Figures/dates_histogram.png){width=50%}
### Plot Length x Variants
Let's plot the genome length by the variant to see if there are any patterns. Some variants have insertions or deletions compared to others, for instance. On the other hand, not all genome assemblies make it to the ends of the viral RNA genome so this will add some noise.
We'll use a scatter plot. First we identify the data frame (dns) that we want to use. Then we assign fields to the x and y axis. After that we'll add the scatter plot layer (geom_point). We'll add another layer to limit the x axis.
```
png("lengthxvariants.png")
ggplot(dns, aes(x=Length,y=Pangolin_Variant)) + geom_point() + xlim(29500,30000)
dev.off()
```
![](./Figures/lengthxvariants.png){width=50%}
Now, let's color the points by Country.
```
png("lengthxvariants.color.png")
ggplot(dns, aes(x=Length,y=Pangolin_Variant,color=Country)) + geom_point() + xlim(29500,30000)
dev.off()
```
![](./Figures/lengthxvariants.color.png){width=50%}
### BONUS
If you have too many variants on the y axis and your labels are overlapping, there are several things that you can do. Here are a few.
1. Increase the height of the plot
```
png("lengthxvariants.color.png", height = 5000)
```
2. Make the font size smaller (but this will make it harder to read on your poster). There are lots of ways to do this but one way is to add a layer that changes the font size to the end of your plot code.
```
+
theme(
axis.title.y = element_text(size = 8)
)
```
3. Randomly subsample the rows in your data frame, then plot the subsample. Here we are grabbing 100 rows but you could grab more or less.
```
dns2=dns[sample(nrow(dns),100),]
```
or
```
library(dplyr)
dns2 = dns %>% slice_sample(n = 100)
```
4. Subsample only the variants that occur the most for plotting. Here we will plot variants that occur at least 5 times in the data frame. Some of you will need to go much higher than that.
```
library(dplyr)
# Count the number of each variant
dns_count=as.data.frame(dns %>% group_by(Pangolin_Variant) %>%tally() )
# Get the Pangolin variants that occur at least 5 times
dns_count_5 = subset(dns_count, n>=5, select=Pangolin_Variant)
# Filter the original data frame so it contains only those lines that have pangolin variants that occur at least 5 times.
dns_sub=dns %>% filter(Pangolin_Variant %in% dns_count_5$Pangolin_Variant)
```
You can compare how many variants there are in the original and the subsetted data frames like this.
```
unique(dns$Pangolin_Variant)
unique(dns_sub$Pangolin_Variant)
```
### Plot Collection Date x Variants
16. Now try to plot the collection date (x axis) by the variants (y axis), coloring by the country.
### Plot Collection Date x Variants for your 3 countries
Now make a plot of Collection Date x Variants for your 3 countries and add it to your powerpoint.
Go to https://covariants.org/ to scroll down to the table and the phylogenetic tree to put some context around the variants.
At that same site, explore the "per country" and "cases" buttons for your 3 countries. Note that the graphs are interactive so you can hover over specific dates where you might have a lot of NCBI genome sequences. Grab screenshots to put into your powerpoint (be sure to record the date you grabbed the screenshot on the slide). How representative are the NCBI genome sequences?
Note: we'll be getting sequences from another source as well so don't worry if they aren't too representative.
<details>
<summary>Click for All Answers</summary>
```
11. grep '>' sequences.fasta | sed 's/>//'|sed 's/|/\t/g' > Denmark_Norway_Sweden_seq_info.txt
12. header = FALSE and sep = ""
13. The header arguement determines whether you have a header line in your file with the names of variables.
While the header default is false, if you don't explicitly put in header=FALSE, it might decide that there is a header line if the first row has one fewer field than the rest. I like to explicitly tell read.table whether there is a header row or not.
The sep variable determines the field separator character.
The sep default is blank ("") and means white space. In other words, read.table will split the file up on one or more spaces, tabs, etc. With tab-delimitted files, you don't normally have to specify the tab variable but since we also have spaces in some of our fields, if we keep sep as whitespace, it will separate on all the spaces as well. So we will need to specify it.
14. head(dns, n=10) or head(dns, n=10L)
15. tail(dns)
16.
png("datexvariants.color.png")
ggplot(dns, aes(x=Collection_Date,y=Pangolin_Variant,color=Country)) + geom_point()
dev.off()
```
</details>