-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathscrna-cell-types-2019-12.Rmd
308 lines (221 loc) · 9.26 KB
/
scrna-cell-types-2019-12.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
---
title: "Cell Type Annotation"
output:
html_notebook:
theme: readable
toc: yes
toc_float: yes
code_folding: none
---
## Introduction
This is a brief tutorial on automatic cell type annotation of single-cell RNA sequencing (scRNA-seq) data. The primary dataset used here is a set of 2,700 Peripheral Blood Mononuclear Cells (PBMCs) processed using the standard Seurat workflow as demonstrated in Seurat's clustering tutorial. It is a reasonably small dataset with well-established cell types that is commonly used in scRNA-seq benchmarking studies.
## Load data
This tutorial includes some Bioconductor dependencies. Before proceeding, confirm that Bioconductor is installed and its version is at least 3.10.
```{r bioc-version}
if (!requireNamespace("BiocManager", quietly = TRUE)) {
install.packages("BiocManager")
}
BiocManager::version()
```
If this is not the case, remove all versions of BiocVersion with `remove.packages("BiocVersion")`. Then update Bioconductor packages using `BiocManager::install()`.
Since we are using a Seurat object, load Seurat and related packages.
```{r load-seurat, message=FALSE, warning=FALSE}
if (!require("Seurat")) {
BiocManager::install("Seurat", update = FALSE)
library(Seurat)
}
library(ggplot2)
library(cowplot)
```
Load other relevant packages.
```{r load-other, message=FALSE, warning=FALSE}
if (!require("dplyr")) {
BiocManager::install("dplyr", update = FALSE)
library(dplyr)
}
if (!require("stringr")) {
BiocManager::install("stringr", update = FALSE)
library(stringr)
}
```
Load the PBMC dataset using the `SeuratData` package.
```{r load-seurat-data, message=FALSE, warning=FALSE}
if (!require("SeuratData")) {
BiocManager::install("satijalab/seurat-data", update = FALSE)
library(SeuratData)
}
InstallData("pbmc3k")
data("pbmc3k")
pbmc3k
```
The dataset includes both the raw and the processed versions.
```{r check-pbmc-final}
pbmc3k.final
```
Check the original Seurat cell type labels overlaid onto the UMAP visualization. See the [original Seurat guided clustering tutorial](https://satijalab.org/seurat/v3.0/pbmc3k_tutorial.html) for details on how the data was processed and the labels were assigned.
```{r original-umap}
DimPlot(pbmc3k.final, reduction = "umap") +
scale_color_brewer(palette = "Set1")
```
## Annotation (using SingleR)
Load SingleR.
```{r load-singler, message=FALSE, warning=FALSE}
if (!require("SingleR")) {
BiocManager::install("SingleR", update = FALSE)
library(SingleR)
}
```
SingleR expects the input as a matrix or a SummarizedExperiment object.
```{r exp-mat}
exp_mat = GetAssayData(pbmc3k.final, assay = "RNA", slot = "data")
exp_mat = as.matrix(exp_mat)
dim(exp_mat)
```
### HPCA main cell types
The SingleR package provides normalized expression values and cell types labels based on bulk RNA-seq, microarray, and single-cell RNA-seq data from several different datasets. See the [SingleR vignette](https://bioconductor.org/packages/3.10/bioc/vignettes/SingleR/inst/doc/SingleR.html#5_available_references) for the description.
We can try the Human Primary Cell Atlas dataset as the reference. It provides normalized expression values for 713 microarray samples that have been assigned to one of 37 main cell types and 157 subtypes.
```{r hpca-se-load, message=FALSE, warning=FALSE}
singler_se = HumanPrimaryCellAtlasData()
```
It is possible that this fails with a `No internet connection using 'localHub=TRUE'` error. This may be resolved by running `ExperimentHub::setExperimentHubOption("PROXY", "http://127.0.0.1:10801")`.
```{r hpca-se-show}
singler_se
```
Restrict to common genes between the test and reference datasets.
```{r hpca-common-genes}
common_genes = intersect(rownames(exp_mat), rownames(singler_se))
common_genes = sort(common_genes)
exp_common_mat = exp_mat[common_genes, ]
singler_se = singler_se[common_genes, ]
length(common_genes)
```
Perform SingleR annotation.
```{r hpca-singler}
singler_pred = SingleR(
test = exp_common_mat,
ref = singler_se,
labels = singler_se$label.main
)
```
Each row of the output data frame contains prediction results for a single cell.
```{r hpca-df}
head(as.data.frame(singler_pred))
```
SingleR provides a method to display the scores for all cells across all reference labels to inspect the confidence of the predicted labels across the dataset.
```{r score-heatmap}
plotScoreHeatmap(singler_pred, show.labels = TRUE, fontsize = 8)
```
As expected, the non-immune populations have very low scores in these cells.
Add the assigned labels to the Seurat object.
```{r hpca-addmetadata}
pbmc_labeled_obj = AddMetaData(pbmc3k.final, as.data.frame(singler_pred))
```
Compare the assigned labels to the original labels.
```{r hpca-table}
[email protected] %>% select(labels, seurat_annotations) %>% table(useNA = "ifany")
```
SingleR also attempts to remove low quality or ambiguous assignments. Ambiguous assignments are based on the difference between the score for the assigned label and the median across all labels for each cell. Tuning parameters can be adjusted with `pruneScores()`. We can check how many cells are considered ambiguous and which populations they potentially belong to.
```{r hpca-pruned-table}
[email protected] %>% select(pruned.labels, labels) %>% table(useNA = "ifany")
```
Check the HPCA cell type labels overlaid onto the original UMAP visualization.
```{r hpca-umap}
DimPlot(pbmc_labeled_obj, reduction = "umap", group.by = "labels") +
scale_color_brewer(palette = "Set1")
```
### HPCA subtypes
In addition to the 37 main cell types, the HPCA dataset also contains 157 subtypes. You can perform SingleR annotation for the subtypes.
```{r hpca-fine-singler}
singler_pred = SingleR(
test = exp_common_mat,
ref = singler_se,
labels = singler_se$label.fine
)
```
Add the assigned labels to the Seurat object.
```{r hpca-fine-addmetadata}
pbmc_labeled_obj = AddMetaData(pbmc3k.final, as.data.frame(singler_pred))
```
Check the assigned labels.
```{r hpca-fine-table}
select(labels) %>%
table(useNA = "ifany")
```
Compare the assigned labels to the original labels. Subset to T-cells to keep the output more compact.
```{r hpca-fine-table-t}
select(labels, seurat_annotations) %>%
filter(str_detect(seurat_annotations, "T")) %>%
droplevels() %>%
table(useNA = "ifany")
```
Compare the assigned labels to the original labels. Subset to monocytes to keep the output more compact.
```{r hpca-fine-table-mono}
select(labels, seurat_annotations) %>%
filter(str_detect(seurat_annotations, "Mono")) %>%
droplevels() %>%
table(useNA = "ifany")
```
## Annotation (using clustermole)
SingleR is able to label cells, but it requires a reference dataset. This is not a problem for PBMCs, but a perfect reference dataset may not always be available or you may have some unexpected populations.
A more exploratory and unbiased approach is possible with [clustermole](https://github.com/igordot/clustermole), an R package that provides a collection of cell type markers for thousands of human and mouse cell populations sourced from a variety of databases as well as methods to query them.
```{r load-cluster-mole, message=FALSE, warning=FALSE}
if (!require("clustermole")) {
install.packages("clustermole")
}
library(clustermole)
```
### Available cell types
We can retrieve a list of all markers in the ClusterMole database to see all the available options. Each row in the returned data frame is a combination of a single gene and its associated cell type.
```{r clustermole-markers-table}
markers_tbl = clustermole_markers()
head(markers_tbl)
```
Check the available cell types (ignore gene columns).
```{r clustermole-markers-summary}
markers_tbl %>% distinct(celltype, organ, db)
```
### Marker gene overlaps
We can find markers for the B-cell cluster Seurat's `FindMarkers` function.
```{r find-markers-b}
b_markers_df = FindMarkers(pbmc3k.final, ident.1 = "B", verbose = FALSE)
```
Check the markers table.
```{r find-markers-b-head}
head(b_markers_df)
```
With the default cutoffs, this gives us a data frame with hundreds of genes. Let's subset to just the top 20 genes.
```{r markers-top-genes}
b_markers = rownames(b_markers_df)
b_markers = head(b_markers, 20)
b_markers
```
Check overlap of our B-cell markers with all cell type signatures.
```{r clustermole-overlaps}
overlaps_tbl = clustermole_overlaps(genes = b_markers, species = "hs")
```
Check the top scoring cell types for the B-cell cluster.
```{r clustermole-overlaps-result}
head(overlaps_tbl, 10)
```
### Enrichment of markers
Calculate the average expression levels for the clusters for enrichment analysis using Seurat's `AverageExpression` function, convert to a matrix, and log-transform.
```{r avg-exp}
avg_exp_mat = AverageExpression(pbmc3k.final, assays = "RNA", slot = "data")
avg_exp_mat = as.matrix(avg_exp_mat$RNA)
avg_exp_mat = log1p(avg_exp_mat)
```
Check the average exression matrix.
```{r avg-exp-head}
head(avg_exp_mat)
```
Run enrichment of all cell type signatures across all clusters.
```{r clustermole-enrichment}
enrichment_tbl = clustermole_enrichment(expr_mat = avg_exp_mat, species = "hs")
```
Check the top scoring cell types for the B-cell cluster.
```{r clustermole-enrichment-result}
enrichment_tbl %>% filter(cluster == "B") %>% head(10)
```