R包Seurat instruction1数据处理

2019-2-1 来自https://satijalab.org/seurat/

1.启动Seurat

library(Seurat)

library(dplyr)

##上传数据集

pbmc.data <- Read10X(data.dir = "~/Downloads/filtered_gene_bc_matrices/hg19/")

##检测常规和稀疏矩阵的内存。

dense.size <- object.size(x = as.matrix(x = pbmc.data))

dense.size


sparse.size <- object.size(x = pbmc.data)

sparse.size


dense.size/sparse.size

##用rawdata创建object;去除少于3个细胞表达的基因(~0.1% of the data),去除少于200基因的细胞

pbmc <- CreateSeuratObject(raw.data = pbmc.data, min.cells = 3, min.genes = 200,

    project = "10X_PBMC")

2.标准预处理流程

包括新建object,基于质量控制进行细胞的筛选和滤过,数据标准化和缩放,以及高度可变基因的检测。Seurat v2之前的版本将这一过程都囊括到了Set up这一步。v2版本则将这一步分开。

3.质控和筛选后续分析的细胞

CreatSeuratObject设置了最小基因数量截点的同时,可以根据技术或者生物学参数滤过细胞。Seurat包可以进行QC标准的简单探索和基于使用者设定标准过滤细胞。

Seurat主要是通过作图剔除outlier:

可视化gene coutns和molecule counts,绘制散点图,除去基因数异常点(潜在multiplets);还可以基于线粒体基因比例除去细胞。

##自动计算genes和UMIs的数量(nGene /nUMI表示) ;无UMI的数据,nUMI代表细胞内非标准化数值的总数

##计算线粒体基因的比例,用AddMetaData保存为percent.mito

##用object@raw.data代表未经转化和log标准化的counts

##定位为线粒体基因的UMI%为常见的QC标准。


具体command:

mito.genes <- grep(pattern = "^MT-", x = rownames(x = pbmc@data), value = TRUE)

percent.mito <- Matrix::colSums(pbmc@raw.data[mito.genes, ])/Matrix::colSums(pbmc@raw.data)



# AddMetaData 增加栏目到object@meta.data,存储QC stat值


pbmc <- AddMetaData(object = pbmc, metadata = percent.mito, col.name = "percent.mito")

#绘制小提琴图


VlnPlot(object = pbmc, features.plot = c("nGene", "nUMI", "percent.mito"), nCol = 3)

#绘制GenePlot


par(mfrow = c(1, 2))

GenePlot(object = pbmc, gene1 = "nUMI", gene2 = "percent.mito")

GenePlot(object = pbmc, gene1 = "nUMI", gene2 = "nGene")


#过滤细胞:除去>2500和少于200基因数的细胞

#用low.thresholds和high.thresholds设立阈值,如果不想要更低或者更高的阈值,可以用-Inf和Inf


pbmc <- FilterCells(object = pbmc, subset.names = c("nGene", "percent.mito"),  low.thresholds = c(200, -Inf), high.thresholds = c(2500, 0.05))


4.标准化数据

筛选数据之后下一步是标准化数据。默认使用“LogNormalize”,乘以scale factor(默认10000),在进行log转换。


pbmc <- NormalizeData(object = pbmc, normalization.method = "LogNormalize", scale.factor = 10000)


5.检测单个细胞中高度可变基因

目的:检测高度可变基因并用于下游分析。

用FindVariableGenes计算平均表达量和离差,将这些基因放入bins,计算bin的z-score。可以用于控制变异和平均表达量之间的关系。

官方建议使用者设置这些参数标记dispersion plot上可视化的异常点,但具体的参数设置必须基于数据类型、样本异质性和标准化策略。

这里的参数可以鉴定~2000可变基因,是标准化到1e4 分子数的UMI数据的经典参数设置。


pbmc <- FindVariableGenes(object = pbmc, mean.function = ExpMean, dispersion.function = LogVMR, x.low.cutoff = 0.0125, x.high.cutoff = 3, y.cutoff = 0.5)

length(x = pbmc@var.genes)

6.数据缩放和除去不要变异来源

常见混杂的变异来源有:技术噪音,批次效应,生物学来源的变异(如细胞周期)。

Buettneret al, NBT, 2015, 认为剔除这些信号可以改善下游降维分析和聚类分析效果(https://www.nature.com/articles/nbt.3102)

Seurat基于使用者给定的变量建立线性模型从而预测基因表达。这些模型缩放的z-score残差存储在scale.data slot,用于降维和聚类分析。可以回归批次效应、cell alignment rate(针对Drop-seq data)检测分子数以及线粒体基因表达带来的细胞-细胞变异。

对于细胞周期细胞,可以学习“cell-cycle”评分,进行回归化。

v2版本将regression作为scale的一部分,所以原来的RegressOut弃用,代为ScaleData的vars.to.regress。

pbmc <- ScaleData(object = pbmc, vars.to.regress = c("nUMI", "percent.mito"))

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,923评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,154评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,775评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,960评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,976评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,972评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,893评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,709评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,159评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,400评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,552评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,265评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,876评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,528评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,701评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,552评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,451评论 2 352

推荐阅读更多精彩内容