实验记录9:Monocle包的使用方法

梗概

参照官网教程:http://cole-trapnell-lab.github.io/monocle-release/docs/#getting-started-with-monocle
或在R中运行以下命令:

browseVignettes("monocle")

关于Monocle

Monocle introduced the strategy of ordering single cells in pseudotime,
placing them along a trajectory corresponding to a biological process such as cell differentiation. Monocle learns this trajectory directly from the data, in either a fully unsupervised or a semi-supervised manner. It also performs differential gene expression and clustering to identify important genes and cell states.

Monocle是用于分析single-cell RNA-seq的R包,能够将细胞按照模拟的时间顺序进行排列,显示它们的发展轨迹如细胞分化等生物学过程。Monocle从数据中用无监督或半监督(?)的方式直接获得这个轨迹。除此之外,它还能够做差异表达分析和聚类来揭示重要的基因和细胞。

在发育过程中,为了响应刺激和生命,细胞从一种功能性“状态”转变为另一种功能性“状态”。处于不同状态的细胞表达不同的基因组,产生蛋白质和代谢物的动态重复序列,从而完成它们的工作。当细胞在状态之间移动时,经历转录重组的过程,一些基因被沉默,另一些被新激活。这些瞬态通常难以表征,因为在更稳定的端点状态之间纯化细胞可能是困难的或不可能的。单细胞RNA-Seq可以让您在不需要纯化的情况下查看这些状态。但是,为此,我们必须确定每个单元格的可能状态范围。

Monocle介绍了使用RNA-Seq进行单细胞轨迹分析的策略。Monocle不是通过实验将细胞纯化为离散状态,而是使用算法来学习每个细胞必须经历的基因表达变化的序列,作为动态生物过程的一部分。一旦它了解了基因表达变化的整体“轨迹”,Monocle就可以将每个细胞放置在轨迹中的适当位置。然后,您可以使用Monocle的差异分析工具包来查找在轨迹过程中受到调控的基因,如“ 查找作为假性函数的变化的基因 ”一节中所述。如果该过程有多个结果,Monocle将重建“分支”轨迹。这些分支对应于细胞“决策”,Monocle提供了强大的工具来识别受其影响的基因并参与制作它们。您可以在“分析单细胞轨迹中的分支”一节中查看如何分析分支。Monocle依赖于称为反向图嵌入的机器学习技术来构建单细胞轨迹。您可以 在Monocle理论背后的部分中阅读更多关于Monocle方法的理论基础,或参考小插图末尾显示的参考文献

什么是伪时间?

Pseudotime是衡量单个细胞通过细胞分化等过程取得多少进展的量度。在许多生物过程中,细胞不能完美同步。在诸如细胞分化的过程的单细胞表达研究中,捕获的细胞可以在进展方面广泛分布。也就是说,在完全同时捕获的细胞群中,一些细胞可能很远,而其他细胞甚至可能尚未开始该过程。当您想要了解细胞从一个状态转换到另一个状态时发生的调节变化的顺序时,这种不同步会产生重大问题。跟踪同时捕获的细胞的表达产生非常压缩的基因动力学感觉,以及该基因的明显变异性' 的表达会非常高。通过沿着学习轨迹根据其进度对每个单元进行排序,Monocle减轻了由于不同步引起的问题。Monocle不是根据时间跟踪表达式的变化,而是根据轨迹上的进度跟踪变化,我们称之为pseudotime'。Pseudotime是一个抽象的进展单元:它只是一个单元格与轨迹起点之间的距离,沿着最短路径测量。轨迹的总长度是根据细胞从起始状态移动到最终状态时经历的转录变化的总量来定义的。


实验记录

伪时间分析实验技术流程主要包括三个步骤,而每一步都是一个机器学习任务:

step1:选择输入基因用于机器学习

这个过程称为feature selection(特征选择),这些基因对轨迹的形状有着最重要的影响。我们应该要选择的是最能反映细胞状态的基因。
如果直接通过Seurat输出的一些重要的基因(比如每个cluster中的高FC值基因)作为输入对象的话就能够实现一个“无监督”分析。或者也可以利用生物学知识手动选择一些重要的基因进行“半监督”分析。

step2:数据降维

利用Reversed graph embedding算法将数据降维。没有太懂。
相对于PCA来说这个算法更能够反应数据的内部结构(据说是这样)

step3:将细胞按照伪时间排序

这个过程称为manifold learning(流形学习)。Monocle利用轨迹来描述细胞如何从一个状态转换到另一个状态。得到的是一个树状图,树的根部或树干表示的是细胞最初的状态(如果有的话),随着细胞的变化就沿着分叉树枝发展。一个细胞的伪时间值(pseudotime value)为它的位置沿着树枝到根部的距离。


以下是正式实验记录:

step0:数据输入

下载与安装

实验要求——
R version 3.4 or higher, Bioconductor version 3.5, and monocle 2.4.0 or higher to have access to the latest features.
查看R版本:

sessionInfo()
R version 3.4.4 (2018-03-15)
Platform: x86_64-apple-darwin15.6.0 (64-bit)
Running under: OS X El Capitan 10.11.6

安装bioconductor以及monocle

source("http://bioconductor.org/biocLite.R")
biocLite("monocle")

加载程辑包:

library(monocle)

将Seurat Object导入

Monocle包可以利用importCDS()命令将Seurat包中的数据导入,同时也能用exportCDS()将数据导出到其他包中。
由于之前的Seurat变量已经被覆盖,故重新创建一个。

spleen_monocle <- CreateSeuratObject(raw.data = spleen.data, min.cells = 3, min.genes = 200, project = "10X_spleen")
spleen_monocle <- importCDS(spleen_monocle, import_all = TRUE)

查看数据:

spleen_monocle
CellDataSet (storageMode: environment)
assayData: 15655 features, 1959 samples 
  element names: exprs 
protocolData: none
phenoData
  sampleNames: AAACCTGAGGTGATAT AAACCTGAGTCATCCA ... TTTGTCAGTCGTCTTC (1959 total)
  varLabels: nGene nUMI orig.ident Size_Factor
  varMetadata: labelDescription
featureData
  featureNames: RP11-34P13.7 FO538757.2 ... AC240274.1 (15655 total)
  fvarLabels: gene_short_name
  fvarMetadata: labelDescription
experimentData: use 'experimentData(object)'
Annotation:  
head(fData(spleen_monocle))
              gene_short_name
RP11-34P13.7     RP11-34P13.7
FO538757.2         FO538757.2
AP006222.2         AP006222.2
RP4-669L17.10   RP4-669L17.10
RP11-206L10.9   RP11-206L10.9
LINC00115           LINC00115

head(pData(spleen_monocle))
                 nGene nUMI orig.ident Size_Factor
AAACCTGAGGTGATAT  1072 3999 10X_spleen          NA
AAACCTGAGTCATCCA  1562 4640 10X_spleen          NA
AAACCTGCAGTGAGTG   995 3489 10X_spleen          NA
AAACGGGAGACTGGGT  1704 7397 10X_spleen          NA
AAACGGGAGACTTGAA   976 3102 10X_spleen          NA
AAACGGGAGATAGGAG  1236 4548 10X_spleen          NA

15655个基因,1959个细胞,与之前创建的的Seurat对象相符。
(细胞名是一些barcode序列)


step1:选择输入基因用于机器学习

①脾脏数据subset的获取

因为脾脏是在4个时间点经过缺血处理的,

spleen_monocle <- detectGenes(spleen_monocle)

查看数据,添加了一列num_cells_expressed

head(fData(spleen_monocle))
              gene_short_name num_cells_expressed
RP11-34P13.7     RP11-34P13.7                   3
FO538757.2         FO538757.2                 214
AP006222.2         AP006222.2                 157
RP4-669L17.10   RP4-669L17.10                  10
RP11-206L10.9   RP11-206L10.9                  25
LINC00115           LINC00115                  35
print(pData(spleen_monocle))
                 nGene  nUMI orig.ident percent.mito res.0.6 Size_Factor num_genes_expressed
AAACCTGAGGTGATAT  1072  3999 10X_spleen 0.0115086315       3          NA                1070
AAACCTGAGTCATCCA  1562  4640 10X_spleen 0.0370929480       5          NA                1560
AAACCTGCAGTGAGTG   995  3489 10X_spleen 0.0395528805       3          NA                 995
AAACGGGAGACTGGGT  1704  7397 10X_spleen 0.0285250777       0          NA                1704
AAACGGGAGACTTGAA   976  3102 10X_spleen 0.0493230174       2          NA                 976
AAACGGGAGATAGGAG  1236  4548 10X_spleen 0.0268249780       1          NA                1236
AAACGGGGTCCGAACC  2430  6863 10X_spleen 0.0379119277       6          NA                2425
AAACGGGTCAGGTAAA  1256  4750 10X_spleen 0.0381052632       1          NA                1256
AAACGGGTCGTCACGG  1887  8095 10X_spleen 0.0302730755       5          NA                1885
AAAGATGAGCGATGAC  1473  5729 10X_spleen 0.0185088179       4          NA                1471

…………

step2:数据降维

step3:将细胞按照伪时间排序



(此段内容舍弃)将Seurat Object导入

Monocle包可以利用importCDS()命令将Seurat包中的数据导入,同时也能用exportCDS()将数据导出到其他包中。

spleen_monocle <- importCDS(spleen, import_all = TRUE)

查看数据:

spleen_monocle
CellDataSet (storageMode: environment)
assayData: 15655 features, 1940 samples 
  element names: exprs 
protocolData: none
phenoData
  sampleNames: AAACCTGAGGTGATAT AAACCTGAGTCATCCA ... TTTGTCAGTCGTCTTC (1940 total)
  varLabels: nGene nUMI ... Size_Factor (6 total)
  varMetadata: labelDescription
featureData
  featureNames: RP11-34P13.7 FO538757.2 ... AC240274.1 (15655 total)
  fvarLabels: gene_short_name
  fvarMetadata: labelDescription
experimentData: use 'experimentData(object)'
Annotation:  

15655个基因,1940个细胞,与之前的Seurat对象相符。

选择数据分布类型

需要根据实验的数据类型选择数据的分布,比如是相对表达量的数据/基于计数的数据(如UMI),官方认为:“FPKM/TPM values are generally log-normally distributed, while UMIs or read counts are better modeled with the negative binomial.”即利用负二项式的模型会更加适合UMI计数的实验数据。

参数描述.png
spleen_M <- newCellDataSet(spleen_monocle, expressionFamily=negbinomial.size())

报错:spleen_monocle不是矩阵.

Error in newCellDataSet(spleen_monocle, expressionFamily = negbinomial.size()) : 
  Error: argument cellData must be a matrix (either sparse from the Matrix package or dense)
In addition: Warning message:
In newCellDataSet(spleen_monocle, expressionFamily = negbinomial.size()) :
  Warning: featureData must contain a column verbatim named 'gene_short_name' for certain functions

预估size factors和分散

spleen_monocle <- estimateSizeFactors(spleen_monocle)
spleen_monocle <- estimateDispersions(spleen_monocle)
removing 9 outliers.

比较奇怪,在输入这两个命令之后显示去除了9个异常值,但是查看spleen_monocle变量时返回:

CellDataSet (storageMode: environment)
assayData: 15655 features, 1940 samples 
  element names: exprs 
protocolData: none
phenoData
  sampleNames: AAACCTGAGGTGATAT AAACCTGAGTCATCCA ... TTTGTCAGTCGTCTTC (1940 total)
  varLabels: nGene nUMI ... Size_Factor (6 total)
  varMetadata: labelDescription
featureData
  featureNames: RP11-34P13.7 FO538757.2 ... AC240274.1 (15655 total)
  fvarLabels: gene_short_name
  fvarMetadata: labelDescription
experimentData: use 'experimentData(object)'
Annotation:  
> dim(spleen_monocle)
Features  Samples 
   15655     1940 

仍然是15655个基因,1940个细胞,与之前无异。因此采用了另一种输入方式。

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

推荐阅读更多精彩内容