用ENIGMA-toolbox作图

89c088b2c3071ac5034c83178cff9caa.jpeg

之前一直使用ggseg呈现结果,最近想试一试其他绘图工具。ENIGMA-toolbox有所了解,绘图功能看起来门槛不高,所以就试着用它呈现一些结果。Matlab版本的ENIGMA-toolbox直接使用就是SurfStat的功能绘图,Python版本的绘图功能应该是根据SurfStat的绘图思路进行改写的。

  1. 下载和安装

参照官网不再赘述。需要注意的是该工具包依赖的numpy和pandas版本较老,若不想降级numpy和pandas的话,可以到工具包安装位置,使用VScode将工具包中以下内容进行修改。

  • numpy已经没有.float和.int的属性了,因此np.float 应该改成float, np.int改成int

  • pandas新版本不再使用error_bad_lines作为输入,因此需要将error_bad_lines=False改为on_bad_lines='skip'

当然另外一种办法就是conda建立虚拟环境,按要求安装依赖也是可行的。

2. 准备Desikan结果-->载入python-->根据标签匹配顺序-->绘图

绘制统计结果,只需要将其按照工具包所需的格式准备即可,具体而言就是脑区的顺序需要和ENIGMA-Toolbox保持一致。这个工具并不像ggseg一样是根据脑区的标签进行数据匹配的,因此使用该工具时需要确保标签和数据的顺序与工具包默认的顺序一致 x 3!

Desikan 68个区域(第一列结束后紧接第二列)

a220d2ef18be5dd312e5d1bbe2ef7032.png

皮层下区域(第一列结束后紧接第二列)

655add4b1c3f37e3b56ff736b3bbb26e.png

快速找到这些区域顺序的方式就是载入ENIGMA-Toolbox自带的一个结果文件

from enigmatoolbox.datasets import load_summary_stats
sum_stats = load_summary_stats('22q')
CT_vector = sum_stats['CortThick_case_vs_controls']['Structure']
SV_vector = sum_stats['SubVol_case_vs_controls']['Structure']

把它做成一个dataFrame用于匹配顺序

CT_order_df = pd.DataFrame(CT_vector.tolist(), columns=['Dependent Variable'])
SV_order_df = pd.DataFrame(SV_vector.tolist(), columns=['Dependent Variable'])

使用Merge的方式将载入的数据集,根据标签的顺序进行匹配。当然这不是必须的,如果将结果载入之前已经确保顺序没问题,就可以直接用数据作图。

CT_df_reordered = pd.merge(CT_order_df, CT_df, on='Dependent Variable', how='left')
SV_df_reordered = pd.merge(SV_order_df, SV_df, on='Dependent Variable', how='left')

获取需要呈现的统计值(这里是Cohen's d),然后使用parcel_to_surface函数将各个区域的数据映射到surface的vertex上面,就可以绘图了。

from enigmatoolbox.utils.parcellation import parcel_to_surface
from enigmatoolbox.plotting import plot_cortical, plot_subcortical
CT_d = CT_df_reordered['Cohen\'s d']
CT_d_fsa5 = parcel_to_surface(CT_d, 'aparc_fsa5')
# Project the results on the surface brain
plot_cortical(array_name=CT_d_fsa5,surface_name="fsa5",size=(1200, 600),cmap='RdBu_r',color_bar=False,color_range=(-1.8, 1.8),screenshot=True,filename=os.path.join(plot_path,'CT_d_all.png'),background=(1, 1, 1),transparent_bg=False,scale= (3,3))

4a55b3aa020d5737b63779183d0bb650.png

对于皮层下区域,由于区域比较少,不需要单独做parcel_to_surface,直接绘图即可。

SV_d = SV_df_reordered['Cohen\'s d']
plot_subcortical(array_name=SV_d, size=(1200, 600),cmap='RdBu_r', color_bar=False, color_range=(-1, 1),screenshot=True,filename=os.path.join(plot_path,'SV_d_all.png'),background=(1, 1, 1),transparent_bg=False,scale= (1,1))

869552fd62b9a191964862a7ba94165b.png

parcellated<->vertexwise的转换比想象中的简单,surface_to_parcel或者parcel_to_surface函数使用了一个vertex到ROI的映射表进行相互转换。

这是该工具包提供的映射表,有desikan, glasser360, schaefer100, 200,300,400, economo_koskinas,都是可以用该方式绘制和保存的,没有的模板也可以自己制作映射表绘制。

495870000b494acd918316d878c9e556.png

另外可以试用matlab的这个函数查看annot文件相关信息,判断映射表中区域的信息是否准确。

read_annotation('fsa5_lh_aparc.annot')

3. 保存

无论是plot_cortical还是plot_subcortical都默认使用了VTK生成图形,它们可以缩放和旋转,要保存图片需要将画图函数中的screenshot设置为True,并设置filename为保存文件的位置和名称。此外,由于后续有拼图的需要,建议将colorbar关闭,拼图完成后手动添加一个colorbar。

4. 拼图

Python拼图的工具好像不多(?!),此外plot_cortical和plot_subcortical函数都是基于VTK作图,保存是截图的方式,并不返回plt内容,大部分的拼图工具可能也不好使。所以建立一个简单工作流完成拼图:

  1. 读取图片

  2. subplot展示图片

  3. 裁剪(删除全白色的行和列)

    裁剪时如果想留白某一位置,可以将该位置加入非白元素。

  4. 保存

将上述步骤封装为函数方便多次调用。

def merge_images(images_dict, output_file, trim_edges=False):"""Merges a list of images into a single figure and saves it, based on provided image information.Parameters:- images_dict: List of dictionaries, each containing 'file_path' and 'title' for each image.- output_file: Path where the merged image should be saved.- trim_edges: Whether to trim white edges from the merged image before saving.# Example usage:images_dict = [{'file_path': os.path.join(plot_path, 'CT_d_all.png'), 'title': 'Cortical'},{'file_path': os.path.join(plot_path, 'SV_d_all.png'), 'title': 'Subcortical'}]output_file = os.path.join(plot_path, 'CT_SV_d_all.png')merge_images(images_dict, output_file, trim_edges=True)"""n_images = len(images_dict)fig, axs = plt.subplots(n_images, 1, figsize=(12, 7 * n_images))for i, img_info in enumerate(images_dict):img = mpimg.imread(img_info['file_path'])axs[i].imshow(img)axs[i].axis('off')title_text = img_info.get('title', '')axs[i].set_title(title_text, y=0.7, fontdict={'family': 'sans-serif', 'fontsize': 18},)# Adding a subtle marker (barely visible)axs[i].text(0.5, 0.65, '|', fontsize=12, color=(0.995, 0.995, 0.995), ha='center', transform=axs[i].transAxes)axs[i].text(0.5, 0.75, '|', fontsize=22, color=(0.995, 0.995, 0.995), ha='center', transform=axs[i].transAxes)plt.tight_layout()plt.savefig(output_file, bbox_inches='tight',dpi=300)if trim_edges:# Load the saved image, trim edges, and save againmerged_img = mpimg.imread(output_file)trimmed_img = trim_white_edges(merged_img)plt.imsave(output_file, np.ascontiguousarray(trimmed_img),dpi=300)def trim_white_edges(img_array):"""Trim white edges from an image with pixel values normalized to the 0 to 1 range.Parameters:- img_array: Image array with pixel values in the range [0, 1].Returns:- Cropped image array with white edges removed."""# Detect pixels that are not completely white (assuming white is [1, 1, 1])mask = np.any(img_array < 1, axis=-1)# Find the rows and columns that contain non-white pixelsrows = np.any(mask, axis=1)cols = np.any(mask, axis=0)# Crop the image to these rows and columnscropped_img = img_array[rows][:, cols]return cropped_img

调用函数即可拼图

images_dict = [{'file_path': os.path.join(plot_path, 'CT_d_all.png'), 'title': 'Cortical'},{'file_path': os.path.join(plot_path, 'SV_d_all.png'), 'title': 'Subcortical'}
]
output_file = os.path.join(plot_path, 'CT_SV_d_all.png')
merge_images(images_dict, output_file, trim_edges=True)

图中在subplot标题下加入了非白元素(肉眼难以识别),从而增加title和图片的距离;另外可以看到由于subplot标题的存在,左右半球之间的空白区域并未被移除,正好使得布局看起来更美观。美中不足的是皮层下区域看起来略大,所以在手动加colorbar的时候可以调一下大小。

43c930bdaf4782ff6d226682bd71dae1.png

该函数可以一次拼接多个png图片,比如以下病例-对照结果:

images_dict = [{'file_path': os.path.join(plot_path, 'CT_d_{}.png'.format(condition_name)), 'title': condition_name} for condition_name, _ in conditions]
output_file = os.path.join(plot_path, 'all_CT_d_maps.png')
merge_images(images_dict, output_file, trim_edges=True)

f7c78bf57f5c35b8d55e7a4f10a49a1f.png

往期推荐

ENIGMA-Toolbox

R|ggsegExtra绘制Desterieux统计结果

R| ggseg 绘制统计结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/589399.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

蓝桥杯刷题第八天(dp专题)

这道题有点像小学奥数题&#xff0c;解题的关键主要是&#xff1a; 有2种走法固走到第i级阶梯&#xff0c;可以通过计算走到第i-1级和第i-2级的走法和&#xff0c;可以初始化走到第1级楼梯和走到第2级楼梯。分别为f[1]1;f[2]1(11)1(2)2.然后就可以循环遍历到后面的状态。 f[i…

014——超声波模块驱动开发Plus(基于I.MX6uLL、SR04和poll机制)

目录 一、基础知识 二、分析为什么打印会影响中断 三、驱动程序 四、应用程序 五、验证及其它 一、基础知识 013——超声波模块驱动开发&#xff08;基于I.MX6uLL与SR04&#xff09;-CSDN博客 二、分析为什么打印会影响中断 asmlinkage __visible int printk(const ch…

Chatgpt掘金之旅—有爱AI商业实战篇|聊天机器人|(四)

演示站点&#xff1a; https://ai.uaai.cn 对话模块 聊天机器人企业知识库&#xff1a;https://work.jingyuai.com/ 鲸鱼AI知识库 官方论坛&#xff1a; www.jingyuai.com 京娱AI 聊天机器人创建服务&#xff0c;随着企业越来越多地寻求创新的方式与客户互动&#xff0c;聊天机…

Linux部分命令

目录 1.文件介绍 2.ls命令 3.目录命令 4.相对路径以及绝对路径 5.命令创建目录&#xff08;文件夹&#xff09; 6.which命令 7.find命令 8.grep命令 9.wc命令 10.echo、tail、重定向符 1.文件介绍 和window不同&#xff0c;Linux没有盘路径&#xff0c;所有的文件都存…

家用洗地机选购指南,哪款洗地机性价比高且用户评价好?

在当今快节奏的生活中&#xff0c;无论是商业场所还是家庭&#xff0c;清洁环境都是我们追求的目标之一。而一台高性价比的洗地机在频繁清洁地面时尤为重要。市面上的洗地机种类繁多&#xff0c;如何选择适合自己的洗地机成为了一个挑战。那么&#xff0c;到底哪款牌子的洗地机…

Intel TBB安装​​​​

下载 windows 版本&#xff0c;如: oneapi-tbb-2021.11.0-win.zip Releases oneapi-src/oneTBB (github.com)https://github.com/oneapi-src/oneTBB/releases 下载后解压&#xff0c;执行 env 文件夹下的 vars.bat 即可 Intel TBB&#xff0c;全称Intel Threading Building…

LLM大模型可视化-以nano-gpt为例

内容整理自&#xff1a;LLM 可视化 --- LLM Visualization (bbycroft.net)https://bbycroft.net/llm Introduction 介绍 Welcome to the walkthrough of the GPT large language model! Here well explore the model nano-gpt, with a mere 85,000 parameters. 欢迎来到 GPT 大…

【Jenkins】关于账号,证书验证的设置问题

当你的电脑启动了Jenkins&#xff0c;这时候一定要小心更改管理员账号和密码~~~ 当你的电脑启动了Jenkins&#xff0c;这时候一定要小心更改管理员账号和密码~~~ 当你的电脑启动了Jenkins&#xff0c;这时候一定要小心更改管理员账号和密码~~~ 重要的事情说3遍&#xff0c;如…

Redis高可用及持久化

文章目录 一、Redis高可用1、Redis高可用概述2、Redis高可用策略 二、Redis持久化1、Redis持久化的功能2、Redis持久化的两种方式2.1 RDB持久化2.2 AOF持久化&#xff08;append only file&#xff09; 3、RDB持久化3.1 触发条件3.1.1 手动触发3.1.2 自动触发3.1.2.1 配置方式3…

【数据结构与算法篇】动态顺序表实战项目:通讯录

【数据结构与算法】动态顺序表实战项目&#xff1a;通讯录 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;数据结构与算法&#x1f345; 目录 【数据结构与算法】动态顺序表实战项目&#xff1a;通讯录 ​编辑 1. PerInfo.h 头文件…

搭建电商网站外贸网站用API接口可以实现哪些功能(天猫API接口|京东API接口)

在电商领域&#xff0c;API接口可以实现多种功能&#xff0c;起到连接内外部系统及优化电商业务流程等多种作用&#xff0c;从而来提高电商企业的运营效率。 具体来看&#xff0c;API接口接入可以用来&#xff1a; 商品管理&#xff1a; API接口能够用来获取商品详情等&#…

收下这份地表最强参会指南,4月16日,玩转百度Create大会不迷路

欢迎来到英杰社区&#xff1a; https://bbs.csdn.net/topics/617804998 欢迎来到阿Q社区&#xff1a; https://bbs.csdn.net/topics/617897397 &#x1f4d5;作者简介&#xff1a;热爱跑步的恒川&#xff0c;致力于C/C、Java、Python等多编程语言&#xff0c;热爱跑步&#xff…