美文网首页单细胞Python 生信单细胞组学
python分析单细胞数据,多细胞去除的模块

python分析单细胞数据,多细胞去除的模块

作者: 单细胞空间交响乐 | 来源:发表于2019-11-02 23:23 被阅读0次

    hi,各位道友,上次我们介绍了R包DoubletFinder用于去除多细胞那么python是否也有类似的模块去除多细胞呢,答案是有的。这次我们就来使用一下python模块去除多细胞

    Scrublet

    Single-Cell Remover of Doublets
    Python code for identifying doublets in single-cell RNA-seq data
    给定一个原始的(未归一化的)UMI,以细胞为行,基因为列的矩阵counts_matrix计数,计算每个单元的多细胞得分。

    import scrublet as scr
    scrub = scr.Scrublet(counts_matrix)
    doublet_scores, predicted_doublets = scrub.scrub_doublets()
    

    scr.scrub_doublets()从观察到的数据模拟双峰,并使用k最近邻分类器为每个转录组计算一个连续doublet_score(介于0和1之间)。 分数将自动设置为阈值以生成predicted_doublets,这是一个布尔数组,对于预测的doublets为True,否则为False。
    最佳做法:
    一、处理来自多个样本的数据时,请分别对每个样本运行Scrublet。 因为Scrublet旨在检测由两个细胞的随机共封装形成的多细胞捕获,所以它在多个样本的合并数据集上可能表现不佳(原因大家都懂的)。
    二、检查doublet分数阈值是否合理(在理想情况下,如本例所示,将双峰模拟doublet分数直方图的两个峰分开),并在必要时进行手动调整。例子在本文的后面展示。
    三、可视化二维嵌入中的多细胞预测(例如UMAP或t-SNE)。 预测的双峰应该大体上共定位(可能在多个群集中)。 如果不是,则可能需要调整doublet得分阈值,或更改预处理参数以更好地解析数据中存在的单元格状态。

    接下来我们看一下如何使用
    第一步,导入必要的模块

    import scrublet as scr
    import scipy.io
    import matplotlib.pyplot as plt
    import numpy as np
    import os
    import pandas as pd
    

    第二步:读入矩阵,要求如上述所讲,计算多细胞比率

    scrub = scr.Scrublet(counts_matrix, expected_doublet_rate=0.06)
    

    这一步包括
    Initialize Scrublet object
    相关参数是:
    expected_doublet_rate:预期多细胞的比率,通常为0.05-0.1。 结果对该参数不是特别敏感。
    sim_doublet_ratio:相对于观察到的转录组数量,要模拟的双峰数量。 此值应该足够高,以使所有的doublet状态都能通过模拟doublet很好地表示。 设置得太高在计算上是耗时的。 默认值是2,尽管低至0.5的值会为已测试的数据集提供非常相似的结果。
    n_neighbors:用于构造观察到的转录组和模拟多细胞的KNN分类器的邻居数。 通常,round(0.5 * sqrt(n_cells))的默认值效果很好。
    运行默认pipeline,其中包括:
    双重模拟
    标准化,基因过滤,重新缩放,PCA
    多细胞计算
    多细胞得分阈值检测和双峰调用

    doublet_scores, predicted_doublets = scrub.scrub_doublets(min_counts=2, 
                                                              min_cells=3, 
                                                              min_gene_variability_pctl=85, 
                                                              n_prin_comps=30)
    

    绘制观察到的转录组和模拟多细胞的多细胞得分直方图
    模拟的多细胞直方图通常是双峰的。左模式对应于由具有相似基因表达的两个细胞产生的“嵌入”多细胞。 右边的的模式对应于“新型”多细胞,其由具有不同基因表达的细胞产生。 Scrublet只能检测”新型“双峰,这一点和doubleFinder的R包一样。
    要比较单细胞与多细胞,我们必须设置一个阈值多细胞得分,理想情况下,应在模拟的双峰直方图的两种模式之间设置最小值。 scrub_doublets()尝试自动识别这一点,并且在本示例中做得很好。 但是,如果自动阈值检测效果不佳,则可以使用call_doublets()函数调整阈值。 例如:
    scrub.call_doublets(threshold=0.25)
    接下来我们画一下这个多细胞分布的直方图:

    scrub.plot_histogram()
    
    zhaoyunfei.png

    获取二维嵌入以可视化结果(Tsne同理)

    scrub.set_embedding('UMAP', scr.get_umap(scrub.manifold_obs_, 10, min_dist=0.3))
    scrub.plot_embedding('UMAP', order_points=True)
    # scrub.plot_embedding('tSNE', order_points=True);
    # scrub.plot_embedding('FA', order_points=True);
    
    zhaoyunfei.png

    相关文章

      网友评论

        本文标题:python分析单细胞数据,多细胞去除的模块

        本文链接:https://www.haomeiwen.com/subject/rbohbctx.html