使用机器学习来测量基因间的相关性:一个多特征模型(Using Machine Learning to Measure Relatedness Between Genes)

本文主要是介绍使用机器学习来测量基因间的相关性:一个多特征模型(Using Machine Learning to Measure Relatedness Between Genes),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 摘要

    测量一对基因间的条件亲缘关系是计算生物学的一项基本技术,也是一个重大的挑战。论文提出了一个新的机器学习模型—多特征相关性(MFR),通过将表达相似度和基于先验知识的相似度纳入评估标准,来准确地测量一对基因之间的条件相关性。

2. 介绍

    基因之间的相互作用通常被建模为一对基因之间0/1(非相互作用/相互作用)的二元关系,而亲缘性则意味着一对基因之间的某种程度的关系。

    相关性可以通过两种特征来衡量:表达相似度和基于先验知识的相似度。第一种特性通常是在一定条件下测量一对基因的共表达水平,第二种类型的特征通常是使用公共生物数据和功能注释数据库来测量基因的相关性。

    论文提出的机器学习模型MFR,通过使用带线性核的支持向量机,整合表达相似度和基于先验知识的相似度,保留并推荐具有高表达相似性和高先验知识相似性的基因对,准确地测量基因间的条件相关性。

3. 材料和方法

3.1 MFR工作流程

如图1所示,MFR工作流程有5个步骤:
(i)从已发表的研究成果中收集基因对样本;
(ii)从GEO、GO和orthoDB数据库中提取基因特征,用于评估基于相似性的基因对功能;
(iii)利用4个基因特征和反应体数据库和HTRIdb数据库计算12个基于相似性的基因对特征
(iv)通过10倍交叉验证构建基于svm的模型。
(v)实验验证基因-基因相互作用,预测基因功能,并与其他模型和方法进行比较。

3.2 基因特征

    MFR使用12个相似的基因对特征来评估一对基因之间的条件相关性。

表达数据。使用GEO数据库中的15679个样本作为表达数据源,进行预处理步骤,最终保留16,391个编码蛋白的基因,以供进一步的表达数据分析。

基因本体论数据。 GO注释使用GO数据库(共435975)中43340个与实验相关的生物学过程。

相应的数据。使用了5000多个物种的2200万个基因,其中包括20个物种的169376个人类同源基因。

亚细胞定位数据。从GO数据库中获得的人类基因的160537个细胞成分注释被用作亚细胞源来衡量一对基因之间亚细胞定位的相似性。

3.3 基因对特征计算

    MFR中使用了12个基于相似性的基因对特征,定义如下。

    7个基于表达相似性的特征:每个基因exp1和exp2的平均表达水平,PCC度量的线性共表达关系,SRC和MI用于测量的非线性共表达关系,MI度量的两个基因表达水平的联合分布与因子边际分布的产物相似性。

GO相似性(goSim),因为相互作用的基因被认为参与了类似的生物过程:

在这里插入图片描述
其中,Oi和Oj分别表示用于注释基因i和j的GO项集;A(o, q)是GO项o和q的共同祖先集;P(o)为GO项o实例注释的一个基因的概率;D(o)和D(root)分别表示GO项o的后代GO项集和根GO项集。

亚细胞定位相似度(lcSim),用来计算两个蛋白质编码基因出现在一个普通细胞器中的概率:
在这里插入图片描述

其中Li和Lj是由基因i和j编码的亚细胞定位组。

同源相似性(hgSim),使用改进的皮尔逊相关方法:

在这里插入图片描述
其中,ni和nj分别为基因组中包含i和j基因同源基因的物种数目;N =21 是我们使用的物种 的总数和,M为基因组中同时包含i和j基因同源基因的物种数量。

基因对的归一化距离(rxSim),从反应体途径得到的202772个基因-基因相互作用被用来构建一个未加权图,其中节点表示基因,边表示基因之间的相互作用:

在这里插入图片描述
其中disi,j为基因i与j之间的最短距离,dismax为图中最远的一对基因之间的最短距离。

基于转录调控相似度(trSim),如果有一个基因对有转录调控相互作用的记录,trSim为1,否则为0。

3.4 支持向量机模型

由于文章在服务器上,全文详见:
http://bbit.vip/service/main.php?version=1&type=article&id=87

这篇关于使用机器学习来测量基因间的相关性:一个多特征模型(Using Machine Learning to Measure Relatedness Between Genes)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

C#中lock关键字的使用小结

《C#中lock关键字的使用小结》在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时,其他线程无法访问同一实例的该代码块,下面就来介绍一下lock关键字的使用... 目录使用方式工作原理注意事项示例代码为什么不能lock值类型在C#中,lock关键字用于确保当一个线程位于给定实例的代码块中时

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND