WGDI之深入理解blockinfo输出结果

2023-10-23 15:40

本文主要是介绍WGDI之深入理解blockinfo输出结果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

blockinfo模块输出文件以csv格式进行存放,共23列,可以用EXCEL直接打开。

block info

其中16列非常容易裂解,描述如下

  1. id 即共线性的结果的唯一标识

  2. chr1,start1,end1 即参考基因组(点图的左边)的共线性范围(对应GFF1的位置)

  3. chr2,start2,end2 即参考基因组(点图的上边)的共线性范围(对应GFF2的位置)

  4. pvalue 即共线性结果评估,常常认为小于0.01的更合理些

  5. length 即共线性片段中基因对数目

  6. ks_median 即共线性片段上所有基因对ks的中位数(主要用来评判ks分布的)

  7. ks_average 即共线性片段上所有基因对ks的平均值

  8. block1,block2分别为共线性片段上基因order的位置。

  9. ks共线性片段上所有基因对的ks

  10. density1,density2 共线性片段的基因分布密集程度。值越小表示稀疏。

最后两列,class1class2会在 alignment 模块中用到,对应的是两个block分组,默认值是0表示两个block是同一组。这两列后期需要自己根据覆盖率,染色体核型等多个方面进行确定。举个例子,我们可以根据 homo1 的取值范围对class1进行赋值,例如-1~-0.5 是 1,-0.5 ~ 0.5 是2,0.5~1是3,最后在alignment中会就会用三种颜色来展示,例如下图的1,2,3分别对应red,blue,green.

alignment

中间的homo1,homo2,homo3,homo4,homo5并非那么直观,先说结论:

  • 这里的homoN(N=1,2,3,4,5) 表示一个基因有N个最佳匹配时的取值

  • N由mutiple参数确定,对应点阵图(dotplot)中的红点

  • multiple的取值一般取1即可,表示最近一次的WGD可能是一次二倍化事件,因此每个基因只会有一个最佳匹配。如果设置为2,可能是一次3倍化,每个基因由两个最佳匹配。当然实际情况可能会更加复杂,比如说异源四倍体,或者异源六倍体,或者没有多倍化只是小规模的基因复制(small-scale gene duplication) 等情况,也会影响multiple的设置。

  • homoN会在后面过滤共线性区块时用到,一般最近的WGD事件所产生的共线性区块会比较接近1,而古老的WGD产生的共线性区块则接近-1.

接着,我们将根据源代码 blast_homo和blast_position 来说明结算过程。

首先需要用到blast_homo函数,用来输出每个基因对在不同最佳匹配情况下的取值(-1,0,1)。

def blast_homo(self, blast, gff1, gff2, repeat_number):index = [group.sort_values(by=11, ascending=False)[:repeat_number].index.tolist()for name, group in blast.groupby([0])]blast = blast.loc[np.concatenate(np.array([k[:repeat_number] for k in index], dtype=object)), [0, 1]]blast = blast.assign(homo1=np.nan, homo2=np.nan,homo3=np.nan, homo4=np.nan, homo5=np.nan)for i in range(1, 6):bluenum = i+5redindex = np.concatenate(np.array([k[:i] for k in index], dtype=object))blueindex = np.concatenate(np.array([k[i:bluenum] for k in index], dtype=object))grayindex = np.concatenate(np.array([k[bluenum:repeat_number] for k in index], dtype=object))blast.loc[redindex, 'homo'+str(i)] = 1blast.loc[blueindex, 'homo'+str(i)] = 0blast.loc[grayindex, 'homo'+str(i)] = -1return blast

for循环前的代码作用是提取每个基因BLAST后的前N个最佳结果。循环的作用基因对进行赋值,主要规则是基因对如果在点图中为红色,赋值为1,蓝色赋值为0,灰色赋值为-1。

  • homo1 对应 redindex = 0:1, bluenum = 1:6, grayindex = 6:repeat_number

  • homo2 对应redindex = 0:2, bluenum = 2:7, grayindex = 7:repeat_number

  • ...

  • homo5对应redindex=0:5, bluenum=5:10, grayindex = 10:repeat_number

最终函数返回的就是每个基因对,在不同最佳匹配数下的赋值结果。

0          1  homo1  homo2  homo3  homo4  homo5
185893  AT1G01010  AT4G01550    1.0    1.0    1.0    1.0    1.0
185894  AT1G01010  AT1G02230    0.0    1.0    1.0    1.0    1.0
185899  AT1G01010  AT4G35580   -1.0    0.0    0.0    0.0    0.0
185900  AT1G01010  AT1G33060   -1.0   -1.0    0.0    0.0    0.0
185901  AT1G01010  AT3G49530   -1.0   -1.0   -1.0    0.0    0.0
185902  AT1G01010  AT5G24590   -1.0   -1.0   -1.0   -1.0    0.0
250822  AT1G01030  AT1G13260    0.0    0.0    0.0    1.0    1.0
250823  AT1G01030  AT1G68840    0.0    0.0    0.0    0.0    1.0
250825  AT1G01030  AT1G25560    0.0    0.0    0.0    0.0    0.0
250826  AT1G01030  AT3G25730   -1.0    0.0    0.0    0.0    0.0
250824  AT1G01030  AT5G06250   -1.0   -1.0    0.0    0.0    0.0

然后block_position函数, 会用 for k in block[1]的循环提取每个共线性区块中每个基因对的homo值,然后用 df = pd.DataFrame(blk_homo)homo = df.mean().values求均值。

def block_position(self, collinearity, blast, gff1, gff2, ks):data = []for block in collinearity:blk_homo, blk_ks = [],  []if block[1][0][0] not in gff1.index or block[1][0][2] not in gff2.index:continuechr1, chr2 = gff1.loc[block[1][0][0],'chr'], gff2.loc[block[1][0][2], 'chr']array1, array2 = [float(i[1]) for i in block[1]], [float(i[3]) for i in block[1]]start1, end1 = array1[0], array1[-1]start2, end2 = array2[0], array2[-1]block1, block2 = [], []## 提取block中对应基因对的homo值for k in block[1]:block1.append(int(float(k[1])))block2.append(int(float(k[3])))if k[0]+","+k[2] in ks.index:pair_ks = ks[str(k[0])+","+str(k[2])]blk_ks.append(pair_ks)elif k[2]+","+k[0] in ks.index:pair_ks = ks[str(k[2])+","+str(k[0])]blk_ks.append(pair_ks)else:blk_ks.append(-1)if k[0]+","+k[2] not in blast.index:continueblk_homo.append(blast.loc[k[0]+","+k[2], ['homo'+str(i) for i in range(1, 6)]].values.tolist())ks_arr = [k for k in blk_ks if k >= 0]if len(ks_arr) == 0:ks_median = -1ks_average = -1else:arr_ks = [k for k in blk_ks if k >= 0]ks_median = base.get_median(arr_ks)ks_average = sum(arr_ks)/len(arr_ks)# 对5列homo值求均值    df = pd.DataFrame(blk_homo)homo = df.mean().valuesif len(homo) == 0:homo = [-1, -1, -1, -1, -1]blkks = '_'.join([str(k) for k in blk_ks])block1 = '_'.join([str(k) for k in block1])block2 = '_'.join([str(k) for k in block2])data.append([block[0], chr1, chr2, start1, end1, start2, end2, block[2], len(block[1]), ks_median, ks_average, homo[0], homo[1], homo[2], homo[3], homo[4], block1, block2, blkks])data = pd.DataFrame(data, columns=['id', 'chr1', 'chr2', 'start1', 'end1', 'start2', 'end2','pvalue', 'length', 'ks_median', 'ks_average', 'homo1', 'homo2', 'homo3','homo4', 'homo5', 'block1', 'block2', 'ks'])data['density1'] = data['length'] / \((data['end1']-data['start1']).abs()+1)data['density2'] = data['length'] / \((data['end2']-data['start2']).abs()+1)return data

最终得到的homo1的homo5,是不同最佳匹配基因数下计算的值。如果共线性的点大部分为红色,那么该值接近于1;如果共线性的点大部分为蓝色,那么该值接近于0;如果共线性的点大部分为灰色,那么该值接近于-1。也就是我们可以根据最初的点图中的颜色来确定将来筛选不同WGD事件所产生共线性区块。

这也就是为什么homoN可以作为共线性片段的筛选标准。


http://www.taodudu.cc/news/show-8043475.html

相关文章:

  • VMware安装虚拟机时提示错误“Failed to install the hcmon driver.“有效解决办法
  • Sdust ACM Weekly #5
  • C语言_SDUST_OJ(6)
  • Java程序设计实验4---sdust
  • Java程序设计实验2---sdust
  • Java程序设计实验5---sdust
  • Java程序设计实验3---sdust
  • SDUST第三次作业
  • SDUST 一元二次方程类
  • C++工程笔记(配合SDUST OJ食用)
  • (SDUST) STP配置
  • 数据库设计三大范式及事务
  • 如何用 Java 对 PDF 文件进行电子签章(四)如何生成PKCS12证书
  • E-R图与三范式
  • python ------SQL
  • 【年薪百万之IT界大神成长之路】一文带你搞懂SSL证书和WEB数据加密
  • 数学建模:思想与方法
  • 3. 子查询、事务
  • 【数据库原理系列】数据库E-R模型
  • 报告显示,亲综艺用户35岁以下超八成,未婚单身比例高
  • 频道
  • RecycleView频道管理
  • Flutter布局详解,必知必会
  • 频道管理+TabLayout+ViewPager联动
  • 前端之CSS——盒子模型和浮动
  • 新政满月,官媒区块链报道已从“科普宣传”转向打假监管
  • 出生即红海时代,RPA初创企业切记,要长远生存勿贪眼下荣光
  • 情感元素+微博新媒体=成功的品牌营销
  • 用Navicat 在 SQLServer或mysql 数据库如何附加mdf、ldf文件
  • Mac 恢复SQLserver 的 bak 备份 【数据系列 2 】
  • 这篇关于WGDI之深入理解blockinfo输出结果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

    相关文章

    spring IOC的理解之原理和实现过程

    《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

    MySQL数据库约束深入详解

    《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

    Java Stream流使用案例深入详解

    《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

    深入理解Apache Kafka(分布式流处理平台)

    《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka

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

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

    一文带你深入了解Python中的GeneratorExit异常处理

    《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例

    python多种数据类型输出为Excel文件

    《python多种数据类型输出为Excel文件》本文主要介绍了将Python中的列表、元组、字典和集合等数据类型输出到Excel文件中,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一.列表List二.字典dict三.集合set四.元组tuplepython中的列表、元组、字典

    Spring AI集成DeepSeek实现流式输出的操作方法

    《SpringAI集成DeepSeek实现流式输出的操作方法》本文介绍了如何在SpringBoot中使用Sse(Server-SentEvents)技术实现流式输出,后端使用SpringMVC中的S... 目录一、后端代码二、前端代码三、运行项目小天有话说题外话参考资料前面一篇文章我们实现了《Spring

    Rust格式化输出方式总结

    《Rust格式化输出方式总结》Rust提供了强大的格式化输出功能,通过std::fmt模块和相关的宏来实现,主要的输出宏包括println!和format!,它们支持多种格式化占位符,如{}、{:?}... 目录Rust格式化输出方式基本的格式化输出格式化占位符Format 特性总结Rust格式化输出方式

    深入解析Spring TransactionTemplate 高级用法(示例代码)

    《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT