Seurat 可视化
[本文](https://satijalab.org/seurat/articles/visualization_vignette "Source")将使用从 2,700 PBMC 教程计算的 Seurat 对象来演示 Seurat 中的可视化技术。您可以从 (https://github.com/satijalab/seurat-data "Data") 下载此数据集。```R
SeuratData::InstallData("pbmc3k")
library(Seurat)
library(SeuratData)
library(ggplot2)
library(patchwork)
pbmc3k.final <- LoadData("pbmc3k", type = "pbmc3k.final")
pbmc3k.final$groups <- sample(c("group1", "group2"), size = ncol(pbmc3k.final), replace = TRUE)
features <- c("LYZ", "CCL5", "IL32", "PTPRCAP", "FCGR3A", "PF4")
pbmc3k.final
```
```sh
## An object of class Seurat
## 13714 features across 2638 samples within 1 assay
## Active assay: RNA (13714 features, 2000 variable features)
##3 layers present: data, counts, scale.data
##2 dimensional reductions calculated: pca, umap
```
## marker 特征表达的五种可视化
### 1. RidgePlot
```R
# Ridge plots - from ggridges. Visualize single cell expression distributions in each cluster
RidgePlot(pbmc3k.final, features = features, ncol = 2)
```
data:image/s3,"s3://crabby-images/798e8/798e86da2f9bf9fc5a90aea4ac898185ba16853b" alt=""
data:image/s3,"s3://crabby-images/e40f9/e40f93c46a0ffe957e58115ab32f49a986308caf" alt=""
### 2. VlnPlot
```R
# Violin plot - Visualize single cell expression distributions in each cluster
VlnPlot(pbmc3k.final, features = features)
```
data:image/s3,"s3://crabby-images/73125/731256287532ea93de884bd3432f9690e3b1fcba" alt=""
```R
# Violin plots can also be split on some variable. Simply add the splitting variable to object
# metadata and pass it to the split.by argument
VlnPlot(pbmc3k.final, features = "percent.mt", split.by = "groups")
```
data:image/s3,"s3://crabby-images/424da/424dacecb668c639c430319c887d95437a1414a4" alt=""
### 3. FeaturePlot
```R
# Feature plot - visualize feature expression in low-dimensional space
FeaturePlot(pbmc3k.final, features = features)
```
data:image/s3,"s3://crabby-images/16ebe/16ebeb83d420510a0dd41c073d85a72e750cb674" alt=""
```R
# Plot a legend to map colors to expression levels
FeaturePlot(pbmc3k.final, features = "MS4A1")
```
data:image/s3,"s3://crabby-images/01a75/01a754e26b41965b40535e5c5dbc1380befc0dce" alt=""
```R
# Adjust the contrast in the plot
FeaturePlot(pbmc3k.final, features = "MS4A1", min.cutoff = 1, max.cutoff = 3)
```
data:image/s3,"s3://crabby-images/673ef/673ef70af8690f943b4b919a98ba4db8418b56c6" alt=""
```R
# Calculate feature-specific contrast levels based on quantiles of non-zero expression.
# Particularly useful when plotting multiple markers
FeaturePlot(pbmc3k.final, features = c("MS4A1", "PTPRCAP"), min.cutoff = "q10", max.cutoff = "q90")
```
data:image/s3,"s3://crabby-images/cb701/cb701f4dcbaf2277444d0ce855771554aad2d7c6" alt=""
```R
# Visualize co-expression of two features simultaneously
FeaturePlot(pbmc3k.final, features = c("MS4A1", "CD79A"), blend = TRUE)
```
!(data/attachment/forum/plugin_zhanmishu_markdown/202406/e274aa3f2c9f410735f47b2febe5ff71_1718846472_2226.png)
```R
# Split visualization to view expression by groups (replaces FeatureHeatmap)
FeaturePlot(pbmc3k.final, features = c("MS4A1", "CD79A"), split.by = "groups")
```
data:image/s3,"s3://crabby-images/6a208/6a208518fc31f6634672d81f76497a43a14bd3a5" alt=""
### 4. DotPlot
```R
# Dot plots - the size of the dot corresponds to the percentage of cells expressing the
# feature in each cluster. The color represents the average expression level
DotPlot(pbmc3k.final, features = features) + RotatedAxis()
```
data:image/s3,"s3://crabby-images/a9210/a9210696592e0642d8db2311756a7c1655a564c1" alt=""
```R
# SplitDotPlotGG has been replaced with the `split.by` parameter for DotPlot
DotPlot(pbmc3k.final, features = features, split.by = "groups") + RotatedAxis()
```
data:image/s3,"s3://crabby-images/e51e6/e51e6a17f9591da315cccdf99fe6e80cbad26afa" alt=""
### 5. DoHeatmap
```R
## Single cell heatmap of feature expression
DoHeatmap(subset(pbmc3k.final, downsample = 100), features = features, size = 3)
```
data:image/s3,"s3://crabby-images/c03d3/c03d38736c1bdda8921024a98e1d10f0dee1c326" alt=""
## 新绘图函数
### DimPlot
```R
# DimPlot replaces TSNEPlot, PCAPlot, etc. In addition, it will plot either 'umap', 'tsne', or
# 'pca' by default, in that order
DimPlot(pbmc3k.final)
```
data:image/s3,"s3://crabby-images/cd3e0/cd3e0b7f13bc142b9914a86b2abf79e5b9611670" alt=""
```R
pbmc3k.final.no.umap <- pbmc3k.final
pbmc3k.final.no.umap[["umap"]] <- NULL
DimPlot(pbmc3k.final.no.umap) + RotatedAxis()
```
data:image/s3,"s3://crabby-images/ad714/ad714653c13a663b2fea235e9b139a4c7793f203" alt=""
### DoHeatmap
```R
# DoHeatmap now shows a grouping bar, splitting the heatmap into groups or clusters. This can
# be changed with the `group.by` parameter
DoHeatmap(pbmc3k.final, features = VariableFeatures(pbmc3k.final), cells = 1:500, size = 4,
angle = 90) + NoLegend()
```
data:image/s3,"s3://crabby-images/2d29a/2d29a2358b0022280ae7f118f76026f9df5e7270" alt=""
## 将主题应用于绘图
使用 Seurat,所有绘图函数默认返回基于 ggplot2 的绘图,允许人们像任何其他基于 ggplot2 的绘图一样轻松捕获和操作绘图。
```R
baseplot <- DimPlot(pbmc3k.final, reduction = "umap")
# Add custom labels and titles
baseplot + labs(title = "Clustering of 2,700 PBMCs")
```
data:image/s3,"s3://crabby-images/839ae/839aea93ad2a8cb0e2f7d2d6931964e11d569255" alt=""
```R
# Use community-created themes, overwriting the default Seurat-applied theme Install ggmin
# with remotes::install_github('sjessa/ggmin')
baseplot + ggmin::theme_powerpoint()
```
data:image/s3,"s3://crabby-images/b0100/b01000eb4d846ca7a02365f285f9be73566b9970" alt=""
```R
# Seurat also provides several built-in themes, such as DarkTheme; for more details see
# ?SeuratTheme
baseplot + DarkTheme()
```
data:image/s3,"s3://crabby-images/051a0/051a0d730bbfd45b9ed81c41f5267feb9297cf12" alt=""
```R
# Chain themes together
baseplot + FontSize(x.title = 20, y.title = 20) + NoLegend()
```
data:image/s3,"s3://crabby-images/5ff22/5ff22b5f19924fdf321862c4f98e7cff4dcaaaaf" alt=""
## 交互式绘图功能
Seurat 利用 R 的绘图库来创建交互式绘图。此交互式绘图功能适用于任何基于 ggplot2 的散点图(需要 geom_point 图层)。使用时,只需制作一个基于 ggplot2 的散点图(例如 DimPlot() 或 FeaturePlot())并将结果图传递给 HoverLocator()
```R
# Include additional data to display alongside cell names by passing in a data frame of
# information.Works well when using FetchData
plot <- FeaturePlot(pbmc3k.final, features = "MS4A1")
HoverLocator(plot = plot, information = FetchData(pbmc3k.final, vars = c("ident", "PC_1", "nFeature_RNA")))
```
data:image/s3,"s3://crabby-images/9b1b7/9b1b721818c2627c4c55dfdfc0ea0d19506ec605" alt=""
Seurat 提供的另一个交互功能是能够手动选择细胞以进行进一步研究。我们发现这对于小簇特别有用,这些小簇并不总是使用无偏聚类来分离,但看起来却截然不同。现在,您可以通过创建基于 ggplot2 的散点图(例如使用 DimPlot() 或 FeaturePlot(),并将返回的图传递给 CellSelector() 来选择这些单元格。CellSelector() 将返回一个包含所选点名称的向量,这样您就可以将它们设置为新的身份类并执行微分表达式。
例如,假设 DC 在聚类中与单核细胞合并,但我们想根据它们在 tSNE 图中的位置来了解它们的独特之处。
```R
pbmc3k.final <- RenameIdents(pbmc3k.final, DC = "CD14+ Mono")
plot <- DimPlot(pbmc3k.final, reduction = "umap")
select.cells <- CellSelector(plot = plot)
```
data:image/s3,"s3://crabby-images/b5b62/b5b62dfe2998bd86e6ec46f5d7706d173fdf1307" alt=""
## 绘图配件
除了为绘图添加交互功能的新函数之外,Seurat 还提供了用于操作和组合绘图的新辅助功能。
```R
# LabelClusters and LabelPoints will label clusters (a coloring variable) or individual points
# on a ggplot2-based scatter plot
plot <- DimPlot(pbmc3k.final, reduction = "pca") + NoLegend()
LabelClusters(plot = plot, id = "ident")
```
data:image/s3,"s3://crabby-images/35951/35951176a86b1f8d630ca1007f4ac81df5731939" alt=""
```R
# Both functions support `repel`, which will intelligently stagger labels and draw connecting
# lines from the labels to the points or clusters
LabelPoints(plot = plot, points = TopCells(object = pbmc3k.final[["pca"]]), repel = TRUE)
```
data:image/s3,"s3://crabby-images/7f115/7f1152065dc7644fe75a8c0f017d4f0c273a543f" alt=""
绘制多个图之前是通过CombinePlot() 函数实现的。我们不赞成使用此功能,转而使用拼凑系统。下面是一个简短的演示,但请参阅此处的 (https://patchwork.data-imaginist.com/ "patchwork") 包网站以获取更多详细信息和示例。
```R
plot1 <- DimPlot(pbmc3k.final)
# Create scatter plot with the Pearson correlation value as the title
plot2 <- FeatureScatter(pbmc3k.final, feature1 = "LYZ", feature2 = "CCL5")
# Combine two plots
plot1 + plot2
```
data:image/s3,"s3://crabby-images/bd9ab/bd9abdf7db922f967500ced6b35fd21ae59f2660" alt=""
```R
# Remove the legend from all plots
(plot1 + plot2) & NoLegend()
```
data:image/s3,"s3://crabby-images/7e5d4/7e5d49cdef7f2124e423aa2f0e18a5f373f8c26c" alt=""
页:
[1]