单细胞RNA速率分析: scVelo入门教程

简介: 单细胞RNA速率分析: scVelo入门教程

引言

本系列讲解 单细胞(scRNA-seq)中RNA“速率”分析 教程,持续更新,欢迎关注,转发!

简介

接下来,将简单介绍如何使用 scVelo。当你熟悉基本操作后,后续教程会直接带你进入 RNA 速率、潜在时间、驱动因子识别等高级分析内容。

scVelo 的输入数据主要包括两个计数矩阵,分别记录未成熟(未剪接)和成熟(已剪接)的丰度信息。这些数据可以通过标准测序流程获得,例如使用 velocytokallisto 计数工具。

scVelo 工作流程概览

首先,导入 Scanpyscvelo 库:

import scanpy as sc
import scvelo as scv

为了获得更美观的可视化效果,你可以将 matplotlib 的设置调整为默认样式:

scv.set_figure_params()

读取数据

使用以下命令读取你的数据文件(如 loom、h5ad、csv 等格式):

adata = sc.read(filename, cache=True)

读取后,数据将被存储为多个部分:数据矩阵(adata.X)、细胞或观察的注释信息(adata.obs)、基因或变量的注释(adata.var)、非结构化注释(如图,存储在 adata.uns 中),以及额外的数据层(adata.layers),其中包含剪接和未剪接的计数信息。

如果你已经有一个经过预处理的 adata 对象,可以直接通过以下方式合并剪接和未剪接的计数:

ldata = sc.read(filename.loom, cache=True)
adata = scv.utils.merge(adata, ldata)

如果你还没有自己的数据集,也可以使用内置的数据集进行练习,例如:

adata = scv.datasets.pancreas()

整个工作流程通常包括三个步骤:预处理(scv.pp.)、分析(scv.tl.)和绘图(scv.pl.*)。

基本预处理

在完成基因选择和标准化等基本预处理后,会计算一阶和二阶矩(均值和未中心化方差),用于后续的速率估计:

scv.pp.filter_and_normalize(adata, **params)
scv.pp.moments(adata, **params)

速率工具

该软件的核心功能是高效且稳健地估算速率。这些速率是通过以下方法计算得出的:

scv.tl.velocity(adata, mode='stochastic', **params)

速率是在基因表达空间中的向量,通过求解转录动态的随机模型来获得。如果设置 mode='deterministic',则可以得到确定性模型的解。

如果设置 mode='dynamical',则可以得到动态模型的解,但在此之前需要先运行 scv.tl.recover_dynamics(adata, **params)。

计算出的速率会被存储在 adata.layers 中,与计数矩阵的存储方式相同。

速率会被投影到低维嵌入中,方法是将其转化为可能的细胞转换。具体来说,对于每一个速率向量,会找到与该方向一致的可能的细胞转换。细胞从一个状态转换到另一个状态的概率是通过计算余弦相似性(在潜在的细胞转换和速率向量之间)得出的,并存储在一个名为“速率图”的矩阵中:

scv.tl.velocity_graph(adata, **params)

可视化

最终,速率可以在单细胞水平上,或者以网格线、流线的形式,在任何嵌入(例如 UMAP)中进行投影和可视化:

scv.pl.velocity_embedding(adata, basis='umap', **params)
scv.pl.velocity_embedding_grid(adata, basis='umap', **params)
scv.pl.velocity_embedding_stream(adata, basis='umap', **params)

每个工具模块都配有相应的绘图功能,方便你详细检查分析结果,例如:

scv.pl.velocity(adata, var_names=['gene_A', 'gene_B'], **params)
scv.pl.velocity_graph(adata, **params)
相关文章
|
数据可视化
绘制热图时看不出颜色差异?四种方式转换处理使结果显而“易”见
绘制热图时看不出颜色差异?四种方式转换处理使结果显而“易”见
20855 2
|
1月前
|
编解码 数据可视化 数据挖掘
空间转录组: Visium HD 数据集分析 (1)
空间转录组: Visium HD 数据集分析 (1)
214 27
空间转录组: Visium HD 数据集分析 (1)
|
6月前
|
编解码 算法 数据可视化
Scanpy 分析 scRNA-seq:细胞类型注释
Scanpy 分析 scRNA-seq:细胞类型注释
Scanpy 分析 scRNA-seq:细胞类型注释
|
数据采集 数据挖掘 数据库
单细胞分析 | 使用 Monocle 3 进行发育轨迹分析
单细胞分析 | 使用 Monocle 3 进行发育轨迹分析
1146 0
单细胞分析 | 使用 Monocle 3 进行发育轨迹分析
|
5月前
|
存储 编解码 移动开发
空间转录组:数据格式介绍
空间转录组:数据格式介绍
空间转录组:数据格式介绍
|
4月前
|
存储 数据可视化 数据挖掘
单细胞分析: Scanpy 核心绘图 (1)
单细胞分析: Scanpy 核心绘图 (1)
|
6月前
单细胞RNA速率分析: scVelo
单细胞RNA速率分析: scVelo
单细胞RNA速率分析: scVelo
|
5月前
|
数据挖掘 数据处理
单细胞RNA“速率”分析:差异动力学
单细胞RNA“速率”分析:差异动力学
单细胞RNA“速率”分析:差异动力学
|
8月前
|
人工智能 运维 自然语言处理
2025保姆级JupyterLab 4.0安装指南|全平台部署+AI编程环境配置
JupyterLab 是下一代交互式计算开发环境,2025年发布的4.0版本新增多语言内核支持(Python/R/Julia/JavaScript一键切换)、实时协作功能、AI辅助编程(集成GPT-5代码补全与错误诊断)和可视化调试器等特性。本文详细介绍其技术定位、跨平台安装方案、安装流程、高阶功能配置、典型应用场景及故障排查指南,帮助用户高效使用JupyterLab进行开发。
|
数据安全/隐私保护
(只需五步)注册谷歌账号详细步骤,解决“此电话号码无法验证”问题
注册google一直不方便,因为如果直接去google官网注册,那么它大概率会显示“此电话号码无法用于进行验证”接下来,按着教程来一步步做,就可以实现跳过此限制,成功用手机号注册google了。很简单的。
20863 1