空间单细胞|10x Visium数据分析、可视化与整合(1)

引言

本文[1]介绍了使用Seurat分析具有空间分辨率的RNA测序数据的方法,重点在于将空间信息与分子数据相结合。将包括以下常见于空间数据分析的任务:

  • 数据标准化
  • 降维和数据聚类
  • 发现空间变异性特征
  • 与单细胞RNA测序数据的整合
  • 处理多个样本切片

首先,将加载Seurat及其所需的其他包以进行本教程的操作。

library(Seurat)
library(SeuratData)
library(ggplot2)
library(patchwork)
library(dplyr)

数据集

本文将介绍一个最新发布的小鼠脑矢状面切片数据集,该数据集是利用Visium v1化学技术生成的。数据集包括两组连续的前脑切片和两组(配对的)后脑切片。

您可以利用Seurat中的Load10X_Spatial()函数将其导入。该函数能够读取spaceranger流程的输出结果,并生成一个包含点级表达数据和相应组织切片图像的Seurat对象。

此外,您还可以通过SeuratData包轻松获取数据,如下面的示例所示。安装完数据集之后,输入命令?stxBrain即可获取更多相关信息。

InstallData("stxBrain")

brain <- LoadData("stxBrain", type = "anterior1")

数据预处理

对基因表达数据的初步处理过程与一般的单细胞RNA测序实验相仿。首先,需要对数据进行标准化处理,以校正不同数据点之间测序深度的差异。发现,空间数据集在分子计数或点上的变异可能非常显著,尤其是当组织中的细胞密度不同时。在这里观察到了显著的异质性,这就需要进行有效的数据标准化。

plot1 <- VlnPlot(brain, features = "nCount_Spatial", pt.size = 0.1) + NoLegend()
plot2 <- SpatialFeaturePlot(brain, features = "nCount_Spatial") + theme(legend.position = "right")
wrap_plots(plot1, plot2)
alt

这些图表证明了分子计数的变异不单纯是技术层面的问题,还与组织结构有关。例如,组织中神经元较少的区域(如大脑皮层的白质部分),通常会显示出较低的分子计数。因此,一些常规方法(如LogNormalize()函数),它们要求每个数据点在标准化后具有相同的“基数”,可能会引起问题。

建议改用sctransform方法(Hafemeister和Satija,2019年发表于《基因组生物学》),这种方法通过建立基因表达的正则化负二项模型,旨在消除技术误差,同时保留生物学上的变异。sctransform能够对数据进行标准化处理,识别变异性大的特征,并将这些数据保存在SCT检测项中。

brain <- SCTransform(brain, assay = "Spatial", verbose = FALSE)

基因表达可视化

Seurat的SpatialFeaturePlot()函数是对FeaturePlot()的一个扩展,它允许在组织学图像上叠加分子层面的数据。例如,在小鼠大脑的这个数据集中,Hpca基因是海马区的一个强烈指示标志,而Ttr基因则是脉络丛的标志。

SpatialFeaturePlot(brain, features = c("Hpca""Ttr"))
alt
library(ggplot2)
plot <- SpatialFeaturePlot(brain, features = c("Ttr")) + theme(legend.text = element_text(size = 0),
    legend.title = element_text(size = 20), legend.key.size = unit(1"cm"))
jpeg(filename = "../output/images/spatial_vignette_ttr.jpg", height = 700, width = 1200, quality = 50)
print(plot)
dev.off()

## agg_png 
##       2

在Seurat中,默认设置更侧重于分子数据的可视化效果。不过,您可以通过调整一些参数来改变点的尺寸(和透明度),从而提升组织学图像的可视性:

  • pt.size.factor 参数用于调整点的尺寸大小,其默认值为1.6。
  • alpha 参数用来设置点的透明度范围,其默认值是c(1, 1),即完全不透明到完全透明。

您可以尝试将alpha参数设置为c(0.1, 1),这样可以降低那些表达量较低的点的透明度,使得可视化效果更加突出。

p1 <- SpatialFeaturePlot(brain, features = "Ttr", pt.size.factor = 1)
p2 <- SpatialFeaturePlot(brain, features = "Ttr", alpha = c(0.11))
p1 + p2
alt
Reference
[1]

Source: https://satijalab.org/seurat/articles/spatial_vignette#overview

本文由 mdnice 多平台发布

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在R语言中,可以使用一些包来读取和处理空间转录组数据,常用的包有Seurat、SpatialTranscriptomics和STUtility等。这里以Seurat包为例,介绍如何读取空间转录组数据。 1. 安装Seurat包 在R语言中,需要先安装Seurat包。可以使用以下代码进行安装: ``` install.packages("Seurat") ``` 2. 读取数据 在使用Seurat包之前,需要将空间转录组数据读入R语言环境中。通常使用的数据格式有10x Genomics Visium、NanoString GeoMx和Spatial Transcriptomics等。Seurat包中提供了一些函数来读取这些数据格式,如Read10X()、ReadVisium()和ReadSpatial()等。 例如,使用以下代码读取10x Genomics Visium格式的空间转录组数据: ``` library(Seurat) data <- ReadVisium("path/to/data") ``` 其中,"path/to/data"是数据文件的路径。 3. 数据预处理 读入数据后,需要进行一些数据预处理,如基因过滤、归一化和批次效应校正等。Seurat包提供了一些函数来进行这些预处理操作,如FilterCells()、NormalizeData()和IntegrateData()等。 例如,使用以下代码对数据进行基因过滤和归一化: ``` data <- FilterCells(data, min.cells = 3, min.genes = 200) data <- NormalizeData(data) ``` 其中,FilterCells()函数可以去除低质量的细胞和基因,min.cells和min.genes参数分别表示每个细胞和每个基因的最小表达量。NormalizeData()函数可以将数据进行归一化。 4. 可视化 数据预处理完成后,可以使用Seurat包中的SpatialPlot()函数对空间转录组数据进行可视化。SpatialPlot()函数可以将细胞和基因的空间位置信息与基因表达量进行可视化,并使用t-SNE或UMAP等算法将细胞投影到二维空间中。 例如,使用以下代码对空间转录组数据进行可视化: ``` data <- RunTSNE(data) SpatialPlot(data, label = "gene", gene = "ACTB") ``` 其中,RunTSNE()函数使用t-SNE算法将细胞投影到二维空间中,SpatialPlot()函数用于可视化数据。gene参数用于指定要可视化的基因,label参数用于指定标签的类型,可以是"cell"、"gene"或"both"。 5. 差异表达基因分析 可视化完成后,可以使用Seurat包中的FindMarkers()函数对不同空间区域之间的差异表达基因进行分析。FindMarkers()函数可以使用Wilcoxon秩和检验或t检验等方法来进行差异分析,并计算每个基因在不同空间区域中的平均表达量和差异表达程度。 例如,使用以下代码对不同空间区域之间的差异表达基因进行分析: ``` markers <- FindMarkers(data, ident.1 = "area1", ident.2 = "area2") head(markers) ``` 其中,ident.1和ident.2参数分别表示要比较的两个空间区域的标识符,FindMarkers()函数会返回一个包含差异表达基因信息的数据框。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值