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

您所在的位置:网站首页 scrub什么意思怎么读 python分析单细胞数据,多细胞去除的模块

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

2024-01-07 04:46| 来源: 网络整理| 查看: 265

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


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3