单细胞工具箱|singleR-单细胞类型自动注释(含数据版)

简介: 单细胞工具箱|singleR-单细胞类型自动注释(含数据版)


单细胞研究中细胞类型注释是很重要的环节,大致分为人工注释和软件注释。

(1)人工注释需要借助文献检索marker或者结合常用的注释数据库-


(2)软件自动化注释一般是使用软件内置数据集进行注释,操作相对简单。但是准确性会相对稍差,不过可以作为一种很好的辅助注释手段。


自动化注释的软件很多,本次先简单的分享如何使用singleR进行自动注释。

SingleR是一个用于对单细胞RNA-seq测序(scRNA-seq)数据进行细胞类型自动注释的R包(Aran et al.2019)。依据已知类型标签的细胞样本作为参考数据集,对测试数据集中的细胞进行标记注释。

一 内置数据库


使用SingleR的最简单方法是使用内置参考对细胞进行注释。singleR自带的7个参考数据集,其中5个是人类数据,2个是小鼠的数据:

BlueprintEncodeData Blueprint (Martens and Stunnenberg 2013) and Encode (The ENCODE Project Consortium 2012) (人)
DatabaseImmuneCellExpressionData The Database for Immune Cell Expression(/eQTLs/Epigenomics)(Schmiedel et al. 2018)(人)
HumanPrimaryCellAtlasData the Human Primary Cell Atlas (Mabbott et al. 2013)(人)
MonacoImmuneData, Monaco Immune Cell Data - GSE107011 (Monaco et al. 2019)(人)
NovershternHematopoieticData Novershtern Hematopoietic Cell Data - GSE24759(人)
ImmGenData the murine ImmGen (Heng et al. 2008) (鼠)
MouseRNAseqData a collection of mouse data sets downloaded from GEO (Benayoun et al. 2019).鼠)

二 数据库,R包


2.1 singleR包安装

#if (!requireNamespace("BiocManager", quietly = TRUE))
#    install.packages("BiocManager")
BiocManager::install("SingleR")
BiocManager::install("Seurat")

2.2 加载数据集,数据

加载数据库,可能会比较慢。建议下载好数据库后进行保存。

library(SingleR)
library(celldex)
library(Seurat)
library(pheatmap)
##下载注释数据库
hpca.se <- HumanPrimaryCellAtlasData()
hpca.se
#直接load下载好的数据库
load("HumanPrimaryCellAtlas_hpca.se_human.RData")
load("BlueprintEncode_bpe.se_human.RData")


后台回复“注释”即可获取注释数据库以及测试数据的Rdata文件。


2.3 查看seurat结果

使用单细胞工具箱|Seurat官网标准流程得到的pbmc的seurat的结果,

(1)查看seuret聚类结果

load("pbmc_tutorial.RData")
pbmc
meta=pbmc@meta.data #pbmc的meta文件,包含了seurat的聚类结果
head(meta)
                 orig.ident nCount_RNA nFeature_RNA percent.mt percent.HB RNA_snn_res.0.5 seurat_clusters   labels
AAACATACAACCAC-1     pbmc3k       2419          779  3.0177759          0               0               0  T_cells
AAACATTGAGCTAC-1     pbmc3k       4903         1352  3.7935958          0               3               3   B_cell
AAACATTGATCAGC-1     pbmc3k       3147         1129  0.8897363          0               2               2  T_cells
AAACCGTGCTTCCG-1     pbmc3k       2639          960  1.7430845          0               1               1 Monocyte
AAACCGTGTATGCG-1     pbmc3k        980          521  1.2244898          0               6               6  NK_cell
AAACGCACTGGTAC-1     pbmc3k       2163          781  1.6643551          0               2               2  T_cells


(2)查看umap和tsne图

plot1 <- DimPlot(pbmc, reduction = "umap", label = TRUE)
plot2<-DimPlot(pbmc, reduction = "tsne",
               label = TRUE)
plot1 + plot2


三 singleR注释


3.1 singleR使用内置数据集注释

#进行singleR注释
pbmc_for_SingleR <- GetAssayData(pbmc, slot="data") ##获取标准化矩阵
pbmc.hesc <- SingleR(test = pbmc_for_SingleR, ref = hpca.se, labels = hpca.se$label.main) #
pbmc.hesc
#seurat 和 singleR的table表
table(pbmc.hesc$labels,meta$seurat_clusters)




3.2 绘制umap/tsne图

pbmc@meta.data$labels <-pbmc.hesc$labels
print(DimPlot(pbmc, group.by = c("seurat_clusters", "labels"),reduction = "umap"))



3.3 使用多个数据库注释

使用BP和HPCA两个数据库综合注释,使用list函数读入多个数据库

pbmc3 <- pbmc
pbmc3.hesc <- SingleR(test = pbmc_for_SingleR, ref = list(BP=bpe.se, HPCA=hpca.se), 
                      labels = list(bpe.se$label.main, hpca.se$label.main)) 
table(pbmc3.hesc$labels,meta$seurat_clusters)
pbmc3@meta.data$labels <-pbmc3.hesc$labels
print(DimPlot(pbmc3, group.by = c("seurat_clusters", "labels"),reduction = "umap"))


可以看到多了一些hpca没有注视到的细胞类型。

四 注释结果诊断


4.1 基于scores within cells

print(plotScoreHeatmap(pbmc.hesc))



细胞在一个标签的得分很显著的高于其他标签得分,注释结果比较清晰。


4.2 基于 per-cell “deltas”诊断

plotDeltaDistribution(pbmc.hesc, ncol = 3)


Delta值低,说明注释结果不是很明确。


4.3 与cluster结果比较

tab <- table(label = pbmc.hesc$labels,
             cluster = meta$seurat_clusters)
pheatmap(log10(tab + 10))




相关文章
|
7月前
单细胞分析|映射和注释查询数据集
单细胞分析|映射和注释查询数据集
102 3
|
搜索推荐 Linux Python
VET:一个基于R语言的VCF数据提取工具,支持按基因ID、物理位置、样品名称提取指定变异信息
VET:一个基于R语言的VCF数据提取工具,支持按基因ID、物理位置、样品名称提取指定变异信息
|
7月前
|
存储 数据可视化 数据挖掘
单细胞分析(Signac): PBMC scATAC-seq 基因组区域可视化
单细胞分析(Signac): PBMC scATAC-seq 基因组区域可视化
54 0
|
7月前
|
数据可视化
cfDNAPro|cfDNA片段数据生物学表征及可视化的R包
cfDNA是指存在于血液中的游离DNA片段,来源于正常和异常细胞的死亡。这些片段长度通常为160-180碱基对,研究cfDNA在非侵入性诊断、疾病监测、早期检测和理解生理及病理状态方面有重要意义。cfDNAPro是一个工具,用于分析cfDNA的片段长度分布,提供数据表征和可视化。它能展示片段长度的整体、中位数和众数,以及峰和谷的分布,还有振荡周期性。通过上图和下图的对比,可以观察到不同队列中cfDNA片段长度的差异。此外,cfDNAPro还能展示DNA片段的模态长度,分析10bp周期性振荡模式,帮助科学家深入了解cfDNA的特征。
129 0
|
Linux 测试技术 数据处理
R语言丨根据VCF文件设计引物,自动识别两样本差异SNP位点,调用samtools获取上下游参考序列,快速得到引物序列
R语言丨根据VCF文件设计引物,自动识别两样本差异SNP位点,调用samtools获取上下游参考序列,快速得到引物序列
|
数据可视化 数据挖掘 Linux
转录组下游分析丨利用limma包进行差异表达分析,结果可视化绘制火山图和热图
转录组下游分析丨利用limma包进行差异表达分析,结果可视化绘制火山图和热图
|
数据可视化 数据挖掘 Linux
科研绘图丨使用R语言Pheatmap包快速绘制基因表达量热图的方法,支持聚类和配色自定义修改
科研绘图丨使用R语言Pheatmap包快速绘制基因表达量热图的方法,支持聚类和配色自定义修改
|
数据可视化 数据挖掘 C#
单细胞工具箱|Cell Ranger-V6.0 开启单细胞之旅(上)
单细胞工具箱|Cell Ranger-V6.0 开启单细胞之旅(上)
624 1
|
数据采集 机器学习/深度学习 自然语言处理
实现文本数据数值化、方便后续进行回归分析等目的,需要对文本数据进行多标签分类和关系抽取
实现文本数据数值化、方便后续进行回归分析等目的,需要对文本数据进行多标签分类和关系抽取
214 0
|
数据挖掘 atlas 数据库
单细胞工具箱|singleR-单细胞类型自动注释
单细胞工具箱|singleR-单细胞类型自动注释
368 0