squidpy 教程 3:使用 Napari 进行交互式可视化

2023-11-09 20:21

本文主要是介绍squidpy 教程 3:使用 Napari 进行交互式可视化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

「写在前面」

学习一个软件最好的方法就是啃它的官方文档。本着自己学习、分享他人的态度,分享官方文档的中文教程。软件可能随时更新,建议配合官方文档一起阅读。推荐先按顺序阅读往期内容:
文献篇:
1.文献阅读:Squidpy: 一个可扩展的空间组学分析框架
教程篇:
1.squidpy 教程 1:在 AnnData 和 Squidpy 中导入空间数据
2.squidpy 教程 2:ImageContainer 对象


目录

  • 1 可视化 AnnData 的观测和特征
  • 2 使用形状层注释组织区域

官网教程:https://squidpy.readthedocs.io/en/stable/notebooks/tutorials/tutorial_napari.html

本教程展示如何在 Napari 中可视化 squidpy.im.ImageContainer 和 AnnData。

以交互方式探索 Scanpy/Squidpy 分析结果非常有用。Napari 是 Python 的多维图像查看器,这使得它非常方便地实现此目的。在本教程中,我们将展示 Squidpy 如何实现 Napari 与 AnnData 对象的无缝集成,从而非常轻松地交互式探索分析结果并在 ImageContainer 中包含的高分辨率组织图像上将其可视化。

对于本教程,您可能需要安装其他库,请确保使用 pip install 'squidpy[interactive]' 安装了 Squidpy。

像往常一样,让我们导入相关库并加载数据。

import squidpy as sq

print(f"squidpy=={sq.__version__}")
## squidpy==1.2.2
adata = sq.datasets.visium_hne_adata()
img = sq.datasets.visium_hne_image()

该步骤可能因为网络问题无法自动下载数据,需要自己手动下载数据: https://ndownloader.figshare.com/files/26098397 https://ndownloader.figshare.com/files/26098124

在下面的行中,我们实际上启动了 Napari。您会注意到,将弹出一个带有 Napari viewer 的附加窗口。我们将 Napari viewer 分配给一个新变量,viewer,以便执行一些有用的操作,例如屏幕截图。对于熟悉 napari 的用户来说,viewernapari.Viewer 的包装器,而不是同一个对象。

viewer = img.interactive(adata)

通过方便地捕获当前图像的屏幕截图,我们始终可以在此笔记本中可视化 Napari 会话。这可以通过 viewer.screenshot() 来完成。所有描述的功能均基于 Napari layers 和 widget。您可能想熟悉一些 Napari tutorials。

在这里,我们截取画布以及带有所有可用小部件的 GUI 的屏幕截图。

viewer.screenshot(canvas_only=False)
alt

1 可视化 AnnData 的观测和特征

在 Napari GUI 的右侧,您可以选择并可视化 AnnData 对象中的不同插槽,例如:

  • 来自默认 layer adata.X 或其他 layers 例如 adata.raw 的 Genes。
  • Observations 保存在 adata.obs 中(例如聚类结果、QC 指标、其他类型的 observation-level 注释)。
  • 来自 adata.obsm 的特征(例如,PCA 结果、计算图像特征和其他 observation-level 表示)。

这些 widgets 是可搜索的,这意味着您可以输入首字母缩写,例如您最喜欢的基因,菜单将自动滚动到该位置。为了将感兴趣的特征可视化为附加 layer,您可以按 Enter 键或双击它。

例如,让我们可视化 Olig1 的表达水平……

viewer.screenshot(canvas_only=False)
alt

如果您希望仅可视化画布,则默认情况下 canvas_only = True。这是放大的可视化:

viewer.screenshot()
alt

如前所述,我们可以可视化保存在 adata.obs['cluster'] 下的聚类注释。请注意,通过选择并单击注释,将在 Napari 中创建一个新图层,位于前一个图层的顶部(请参见 Napari GUI 的左侧)。您可以通过简单地关闭图层(单击“眼睛”图标)或修改不透明度(左上角)来修改图层的可视化。

viewer.screenshot(canvas_only=False)
alt

adata.obsm 中的插槽也可以搜索并且可以可视化。例如,Squidpy 将图像特征提取步骤的结果存储在 adata.obsm 中。出于本教程的目的,让我们可视化第三主成分(选择 X_pca,然后在右下菜单中搜索它)。

viewer.screenshot(canvas_only=False)
alt

您只需单击 GUI 中左侧的 “bin” 即可删除所有图层。

viewer.screenshot(canvas_only=False)
alt

2 使用形状层注释组织区域

Napari 不仅可以用作交互式图像查看器,还可以用于手动注释组织中感兴趣的区域。为此,您需要选择 Napari 中的 Shapes layer(左侧的小部件,形状像梯形的图标),然后选择 add polygons 图标并在感兴趣的区域中绘制多边形。您可以查看 Napari shapes layer tutorial 以获取更多说明。

在这里,我们将裁剪 2 个感兴趣的区域(分配给相同的 Shapes 图层)。

viewer.screenshot(canvas_only=False)
alt

现在,在组织上绘制多边形可能很有趣,但不一定有用。如果我们能够将组织区域注释的信息转移到我们的观察结果中(存储在 adata.obs 中),那将会非常有用。幸运的是,使用我们的包装器很简单:只需键入 SHIFT+E,注释就会“转换”为 adata.obs 中的布尔向量。如果该 spot 被多边形“包含”,则它将被注释为 True,否则为 False

viewer.screenshot(canvas_only=False)
alt

当键入 SHIFT+E 时,注释将保存在 adata.obs 下,并且可以方便地进行可视化。

这种交互式注释在癌症病理学背景下特别有用,病理学家经常根据形态信息对组织进行注释,并且分析人员可能希望在下游分析中将此注释与其他类型的特征(离散或连续)相关联。

最后,回想一下,Napari 查看器上出现(并且可以可视化)的所有内容都存储在 AnnData 对象中。因此,我们可以随时使用 Squidpy 访问它并可视化它。

sq.pl.spatial_scatter(viewer.adata, color=["ROI_brain_shapes", "cluster"])
alt

本教程到此结束,欢迎查看其他 Squidpy 教程以及 Napari resources。

viewer.close()

「结束」
alt

本文由 mdnice 多平台发布

这篇关于squidpy 教程 3:使用 Napari 进行交互式可视化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/378282

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca