【单细胞转录组】TooManyCells识别并可视化单细胞进化枝

简介:

简单说,就是如果觉得目前的聚类软件的分类效果不太好,可以用这个软件用可视化进化分支的形式将细胞分群

详细教程

安装

由于不想安装那么多的依赖包,下面的操作全部基于Docker

docker pull gregoryschwartz/too-many-cells:0.2.2.0

启动docker容器

docker run -it --rm -v "/home/luohb:/share/nas1/Data/Users/luohb/Personalization/20191206/TooManyCells" gregoryschwartz/too-many-cells:0.2.2.0 -h
too-many-cells, Gregory W. Schwartz. Clusters and analyzes single cell data.

Usage: too-many-cells (make-tree | interactive | differential | diversity |
                      paths)

Available options:
  -h,--help                Show this help text

Available commands:
  make-tree                
  interactive              
  differential             
  diversity                
  paths     

输入文件构建

这里输入既可以是一个文件夹(里面放 10X cellranger 的 3 个文件),也可以是一个 csv 格式的普通表达矩阵

1. 矩阵:

PS:如果是一个count矩阵文件记得第一行的第一列是逗号,行名标签和列标签可以没有双引号

"","A22.D042044.3_9_M.1.1","C5.D042044.3_9_M.1.1","D10.D042044.3_9_M.1.1","E13.D042044.3_9_M.1.1","F19.D042044.3_9_M.1.1","H2.D042044.3_9_M.1.1","I9.D042044.3_9_M.1.1",...
"0610005C13Rik",0,0,0,0,0,0,0,...
"0610007C21Rik",0,112,185,54,0,96,42,...
"0610007L01Rik",0,0,0,0,0,153,170,...
"0610007N19Rik",0,0,0,0,0,0,0,...
"0610007P08Rik",0,0,0,0,0,19,0,...
"0610007P14Rik",0,58,0,0,255,60,0,...
"0610007P22Rik",0,0,0,0,0,65,0,...
"0610008F07Rik",0,0,0,0,0,0,0,...
"0610009B14Rik",0,0,0,0,0,0,0,...
...

2. 标签文件

item,label
AAACCTGCAGTAACGG-1,Marrow
AAACGGGAGACCGGAT-1,Marrow
AAACGGGAGCGCTCCA-1,Marrow
AAACGGGAGGACGAAA-1,Marrow
AAACGGGAGGTACTCT-1,Marrow
...

这里的标签文件,可以是细胞的样本来源信息,或者认为分群的标签,只作为最后上色的结果,不影响最后进化树的分支结构

运行

docker run -it --rm -v /share/nas1/Data/Users/luohb/Personalization/TooManyCells/test:/test \
      gregoryschwartz/too-many-cells:0.2.2.0 make-tree \
      --matrix-path /test/count.csv \
      --labels-file /test/OrigIdent.labels.csv \
      --draw-collection "PieRing" \
      --output /test/LabelsBySamples > log

结果类似这样


“修剪”分支

默认参数下的分支太细了,可以通过两种方式来调整:

  • 直接设置 --min-size :规定最小分支细胞数。使用参数将叶子的最小大小设置为100个细胞
  • 设置 --smart-cutoff ,通过 n*中位数绝对偏差(MAD) ,改变树上叶子的数量。
    可以结合--min-size--max-proportion--min-distance,或--min-distance-search一起用

另外,我们不需要重新计算整个树!我们可以使用参数--prior来提供以前的结果(我们也可以用--prior删除--matrix-path 来加快处理速度,不过可能会失去某些功能特性)

docker run -it --rm -v /share/nas1/Data/Users/luohb/Personalization/TooManyCells/test:/test \
      gregoryschwartz/too-many-cells:0.2.2.0  make-tree \
      --prior /test/LabelsBySamples --labels-file /test/OrigIdent.labels.csv \
      --smart-cutoff 1 --min-size 1 \
      --draw-collection "PieChart"   #末端改成饼图 \
      --output /test/pruned_LabelsBySamples > log1_2

最后结果类似


提取子集

cp log3_2 clusters_pruned.csv
vi clusters_pruned.csv
# vim中
%s/^M$//g

各个节点的结果在Docker中会显示有些问题,需要手动修改成以下形式

$ head clusters_pruned.csv
cell,cluster,path
AAACGGGAGGTGTTAA.1,9,9/8/7/6/5/4/3/2/1/0
AACACGTTCGGCGGTT.1,9,9/8/7/6/5/4/3/2/1/0
AACCGCGGTATATGAG.1,9,9/8/7/6/5/4/3/2/1/0
ACACCCTTCTGGTTCC.1,9,9/8/7/6/5/4/3/2/1/0
ACCTTTAAGGTGTTAA.1,9,9/8/7/6/5/4/3/2/1/0
ACGAGGACACGTTGGC.1,9,9/8/7/6/5/4/3/2/1/0
AGGGAGTCAGGCTCAC.1,9,9/8/7/6/5/4/3/2/1/0
AGGGATGAGCGATAGC.1,9,9/8/7/6/5/4/3/2/1/0
AGTGGGAAGATGTAAC.1,9,9/8/7/6/5/4/3/2/1/0

标注上节点信息

docker run -it --rm -v /share/nas1/Data/Users/luohb/Personalization/TooManyCells/test:/test \
    gregoryschwartz/too-many-cells:0.2.2.0 make-tree 
    --prior /test/LabelsBySplitGroup \
    --labels-file /test/SplitGroup.labels.csv --smart-cutoff 1 --min-size 1 --draw-collection "PieChart" \
    --draw-node-number  #加上节点信息\
    --output /test/number_pruned_LabelsBySplitGroup > log7

然后可以根据节点对应的barcode去提取细胞子集

基因表达情况

docker run -it --rm -v /share/nas1/Data/Users/luohb/Personalization/TooManyCells/test:/test \
    gregoryschwartz/too-many-cells:0.2.2.0 make-tree \
    --prior /test/LabelsBySplitGroup \
    --matrix-path /test/count.csv \
    --labels-file /test/SplitGroup.labels.csv  \
    --smart-cutoff 1 \
    --min-size 1 \
    --draw-leaf "DrawItem (DrawThresholdContinuous [(\"gene1\", 0), (\"gene2\", 0)])" \
    --draw-colors "[\"#e41a1c\", \"#377eb8\", \"#4daf4a\", \"#eaeaea\"]"\
    --draw-scale-saturation 10 \
    --output /test/out_gene_expression \
    > clusters_pruned_gene_expression.csv

结果类似


差异基因分析

根据提供的标签进行差异基因分析

两个节点之间的差异分析

$docker run -it --rm -v /share/nas1/Data/Users/luohb/TooManyCells/test:/test \
    gregoryschwartz/too-many-cells:0.2.2.0 differential \
    --prior /test/LabelsBySplitGroup \
    --matrix-path /test/count.csv \
    --labels-file /test/SplitGroup.labels.csv  \
    -n "([70, 3, 105, 166], [45])" \
    > clusters_pruned_gene_expression.csv

对所有节点进行查找Marker基因

$cat run12.sh 
$docker run -it --rm -v /share/nas1/Data/Users/luohb/TooManyCells/test:/test \
    gregoryschwartz/too-many-cells:0.2.2.0 differential \
    --prior /test/LabelsBySplitGroup \
    --matrix-path /test/count.csv \
    -n "([], [])" \
    --normalization "UQNorm" \
    +RTS -N26
    --plot-output /test/plot.pdf
    -t 5  #限定节点层级

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