CryoEM - 冷冻电镜聚类中心(2D Class)粒子图像的解析

2023-11-20 18:20

本文主要是介绍CryoEM - 冷冻电镜聚类中心(2D Class)粒子图像的解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

欢迎关注我的CSDN:https://spike.blog.csdn.net/
本文地址:https://blog.csdn.net/caroline_wendy/article/details/126244406

冷冻电镜粒子图像聚类:

  1. Import Particles:读取原始的冷冻电镜粒子图像

  2. 2D Class:2D聚类,获取聚类中心的清晰粒子图像

image-20220807235834719

下载图像的 聚类中心(MRC文件) 和 标签信息(CS文件):

  • MRC:cryosparc_P1_J12_020_class_averages.mrc
  • CS:cryosparc_P1_J12_020_particles.cs

image-20220808142238715

加载MRC文件函数:

def mrc_loader(mrc_path):"""加载MRC文件"""mrc = mrcfile.open(mrc_path, permissive=True)data = mrc.dataarr = np.zeros(shape=data.shape, dtype=data.dtype)arr[:] = data[:]return arr

解析MRC文件:

def mrc_parser(mrc_path, out_dir, is_log=False):"""读取MRC文件,获取Particle图像的最小、最大值,归一化,存储于输出文件夹:param mrc_path: MRC文件:param out_dir: 输出文件夹:param is_log: 日志:return: None"""arr = mrc_loader(mrc_path)i_min, i_max = np.min(arr), np.max(arr)for i in tqdm(range(arr.shape[0]), desc="particles"):img = np.squeeze(arr[i, :, :])img = (img - i_min) / (i_max - i_min)img = np.clip(img * 255., 0, 255)img = img.astype(np.uint8)out_path = os.path.join(out_dir, "{}.png".format(i))cv2.imwrite(out_path, img)if is_log:print(f"[Info] arr: {arr.shape}, i_min: {i_min}, i_max: {i_max}")print(f"[Info] out_dir: {out_dir}")

样本:

01234
image-20220808003133191image-20220808003159115image-20220808003204626image-20220808003210275image-20220808003218445

安装PyEM包,用于处理CS文件:参考 Install pyem with Miniconda

conda activate cryosparc-master
conda install numpy scipy matplotlib seaborn numba pandas natsort
conda install -c conda-forge pyfftw healpy pathos   # 安装速度较慢git clone https://github.com/asarnow/pyem.git
cd pyem
pip install --no-dependencies -e .

使用PyEM:参考 Export from cryoSPARC v2

运行脚本:

cd workspace/pyem
conda activate cryosparc-masterpython csparc2star.py cryosparc_P1_J12_020_particles.cs cryosparc_P1_J12_020_particles.star --relion2

数据,与待处理的particle图像,同名文件:

  • _rlnAnglePsi #2 :面内旋转,PSI(ψ),Peptide torsion angles:肽扭转角
  • _rlnClassNumber #15 :类别,1~50
  • 样本从第20行开始,4个head行+15个label行
000001@J11/imported/017214887957000494328_000000855321499642015_stack_1293_cor2_DW_particles.mrc 83.571426 -0.450000 -5.250000 300.000000 10000.000000 1.082500 13015.895508 12950.861328 9.064259 2.700000 0.000000 0.100000 0.000000 29
000002@J11/imported/017214887957000494328_000000855321499642015_stack_1293_cor2_DW_particles.mrc 254.387726 -2.550000 1.050000 300.000000 10000.000000 1.082500 12611.307617 12546.273438 9.064259 2.700000 0.000000 0.100000 0.000000 15

测试,图像旋转效果:

  • 原始路径:datasets/cryoEM/kongfang/Data/extract
  • 替换路径:去掉索引017214887957000494328
Data/extract/000000855321499642015_stack_1293_cor2_DW_particles.mrc

28聚类中心角度差异较大:

image-20220808144537732

测试Case:

000005@J11/imported/017214887957000494328_000000855321499642015_stack_1293_cor2_DW_particles.mrc 247.040802 -2.850000 0.750000 300.000000 10000.000000 1.082500 13292.802734 13227.768555 9.064259 2.700000 0.000000 0.100000 0.000000 28
000020@J11/imported/004046678624515756479_000077449707304157065_stack_2096_cor2_DW_particles.mrc 70.714287 -0.150000 0.750000 300.000000 10000.000000 1.082500 17615.394531 17506.113281 -3.673789 2.700000 0.000000 0.100000 0.000000 28

路径变换:

Data/extract/000000855321499642015_stack_1293_cor2_DW_particles.mrc

图像:

rawlowpassrotated center
image-20220808155257093image-20220808155244360image-20220808161714604

旋转聚类中心图像的源码:

def rotate(img, angle, out_wh=None):"""旋转粒子粒子图像,填充背景像素:param img: 待旋转的图像:param angle: 旋转角度,来源于_rlnAnglePsi,顺时针旋转:param out_wh: 输出尺寸:return: 旋转之后的图像"""h, w = img.shape[:2]bkg_val = int(np.argmax(np.bincount(img.flatten())))  # 背景像素,用于填充# 旋转图像img, _ = rotate_img_with_bound(img, 360-angle, border_value=bkg_val)# 截取图像中心img = center_crop(img, h, w)if out_wh:img = cv2.resize(img, out_wh)return img

这篇关于CryoEM - 冷冻电镜聚类中心(2D Class)粒子图像的解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI