本文为入门级的基因调控网络文章,主要介绍一些基本概念及常见的GRN模型。

概念:基因调控网络 (Gene Regulatory Network, GRN),简称调控网络,指细胞内或一个基因组内基因和基因之间的相互作用关系形成的网络,特指基因调控 (gene regulation) 导致基因之间的作用。
GRN是生物体内控制基因表达的机制,基因表达的主要过程是转录+翻译

GRN构建方法:
多数方法使用静态数据来分析基因网络,如基因表达矩阵,该矩阵是一个时刻的基因表达情况。实际上,我们需要考虑动态网络,这样才能逼近真实的GRN。
一些网络模型:
1、布尔网络
布尔网络是一种最简单的模型。布尔网络中,每个基因的状态只有“开”和“关”,“开”表示基因有表达,“关”表示基因未表达。基因间相互作用由布尔表达式表示:and, or, not,如 A and not B -> C。
该网络过于简化,存在局限。
2、线性模型
线性模型是一种连续的GRN模型。在线性模型中,一个基因的表达水平由若干其他基因表达水平的加权和表示,权是基因之间相互关系的定量化:正权表示基因激发,负权表示基因抑制,0权表示两个基因没有关系。
Xi(t+Δt)=∑wij Xj(t)+η
该网络是一种简单的数学模型,只能处理具有线性关系的基因表达数据,应用范围小。

相关模型:加权矩阵模型
3、马尔可夫模型
马尔可夫链是一种随机过程,适用于分析时间序列的基因表达数据。在马尔可夫模型中,马尔可夫链假设某一时刻的基因表达水平决定了下一时刻的基因表达水平,公式如下:
C(t)=J C(t-1)
构建GRN过程中,基于马尔可夫模型对gene expression profile的特征提取和聚类都表现出良好的适应性。
如果要提高模型的准确性,可提高马尔可夫模型的阶数。
4、微分方程模型
微分方程模型假设一个基因为一个变量,由n个基因组成的网络可以由如下n维微分方程表示:
dxi(t)/dt=fi(x1,x2,…,xn),xi(t)是第i个基因的表达水平,n表示网络中的基因数。
根据生物数据和建模的不同要求,函数fi根据实际确定。通常有如下两种形式:
fi(xjij,α)=xjα/(xjijα)
fi(xj,α)=e-αxj/(1+e-αxj)
微分方程构建GRN的优点:强大灵活,有利于描述基因网络中的复杂关系。
5、贝叶斯网络模型
以贝叶斯定理和假设为理论基础,用有向无环图 (DAG) 的形式表示随机变量间的概率关系,网络中每个基因是一个节点,每个调控关系是一条边。
该模型可以处理随机事件,控制噪声,可以获得变量间的因果关系,在GRN模型中,贝叶斯网络比其他模型更有优势
相关模型:神经网络模型,图解高斯模型
6、互信息关联模型
互信息关联模型用熵和互信息描述基因之间的关联。
一个基因表达模式A的熵,P(xi)是基因表达值出现在xi的频率,n为表达水平的区间数目。熵越大,基因表达水平越趋近随机分布。

两个基因表达模式之间的互信息MI(A,B)=H(A)+H(B)-H(A,B),若MI(A,B)=0,则两个基因不相关,若MI(A,B)越大,两个基因越非随机相关,之间的生物关系越密切。
7、随机方程模型

......

构建GRN模型时可参考的一些经验:GRN是稀疏的,也就是并不是所有基因之间都有相互作用关系 [3];基因调控网络的大多数变量是连续的,粗糙的离散化会丢失信息,精细的离散化参数太多,最好直接用连续变量 [4];

Ref:

[1]. https://baike.baidu.com/item/%E8%B0%83%E6%8E%A7%E7%BD%91%E7%BB%9C/5844691

[2]. https://wenku.baidu.com/view/34dff5ef19e8b8f67c1cb958.html

[3]. Maetschke S R, Ragan M A. Characterizing cancer subtypes as attractors of Hopfield networks[J]. Bioinformatics, 2014, 30(9): 1273-1279.

[4]. 雷耀山,史定华,王翼飞.基因调控网络的生物信息学研究[J].自然杂志,2004(01):7-12.

基因调控网络 (Gene Regulatory Network) 01的更多相关文章

  1. 基于基因调控网络(Hopfield network)构建沃丁顿表观遗传景观

    基因调控网络的概念在之前已经简要介绍过:https://www.cnblogs.com/pear-linzhu/p/12313951.html 沃丁顿表观遗传景观(The Waddington's e ...

  2. 【转】理解Docker容器网络之Linux Network Namespace

    原文:理解Docker容器网络之Linux Network Namespace 由于2016年年中调换工作的原因,对容器网络的研究中断过一段时间.随着当前项目对Kubernetes应用的深入,我感觉之 ...

  3. VMware虚拟机上网络连接(network type)的三种模式--bridged、host-only、NAT

    VMware虚拟机上网络连接(network type)的三种模式--bridged.host-only.NAT VMWare提供了三种工作模式,它们是bridged(桥接模式).NAT(网络地址转换 ...

  4. [USACO08JAN]手机网络Cell Phone Network

    [USACO08JAN]手机网络Cell Phone Network 题目描述 Farmer John has decided to give each of his cows a cell phon ...

  5. linux 网络虚拟化: network namespace 简介

    linux 网络虚拟化: network namespace 简介 network namespace 是实现网络虚拟化的重要功能,它能创建多个隔离的网络空间,它们有独自的网络栈信息.不管是虚拟机还是 ...

  6. 洛谷 P2812 校园网络【[USACO]Network of Schools加强版】 解题报告

    P2812 校园网络[[USACO]Network of Schools加强版] 题目背景 浙江省的几所OI强校的神犇发明了一种人工智能,可以AC任何题目,所以他们决定建立一个网络来共享这个软件.但是 ...

  7. Solaris11.1网络配置(Fixed Network)

    Solaris11的网络配置与Solaris10有很大不同,Solaris11通过network configuration profiles(NCP)来管理网络配置. Solaris11网络配置分为 ...

  8. 洛谷P2899 [USACO08JAN]手机网络Cell Phone Network

    P2899 [USACO08JAN]手机网络Cell Phone Network 题目描述 Farmer John has decided to give each of his cows a cel ...

  9. (58)zabbix网络拓扑图配置network map

    zabbix网络地图介绍 “zabbix network map”可以简单的理解为动态网络拓扑图,可以针对业务来配置zabbix map, 通过map可以了解应用的整体状况:服务器是否异常.网络是否有 ...

随机推荐

  1. cf 785#

    23333再次水惨了..(心酸啊) A题呵呵呵呵呵 #include<cstdio> #include<iostream> using namespace std; int m ...

  2. 我的Java语言学习日志1_"简单的银行管理系统实现"

    设计步骤:注意:本篇代码,直接建两个类( Bank_Account.BankManage)在BankManage往里面填方法就行.是为了让和我一样自学朋友可以更快的接受.但是代码优化的空间还是很大的( ...

  3. Machine Learning Note Phase 1( Done!)

    Machine Learning 这是第一份机器学习笔记,创建于2019年7月26日,完成于2019年8月2日. 该笔记包括如下部分: 引言(Introduction) 单变量线性回归(Linear ...

  4. 利用ThoughtWorks.QRCode生成二维码

    一.项目添加ThoughtWorks.QRCode.dll和System.Drawing.dll的引用 二.创建二维码公共处理类(QRCodeHandler.cs) /// <summary&g ...

  5. excel处理经纬度

    =LEFT(A1,FIND("°",A1)-1)*1+MID(A1,FIND("°",A1)+1,2)/60+MID(A1,FIND("′" ...

  6. HDU - 6025 Coprime Sequence(前缀gcd+后缀gcd)

    题意:去除数列中的一个数字,使去除后数列中所有数字的gcd尽可能大. 分析:这个题所谓的Coprime Sequence,就是个例子而已嘛,题目中没有任何语句说明给定的数列所有数字gcd一定为1→_→ ...

  7. CGridCtrl显示子控件 及事件

    m_Grid.SetCellType(row, , RUNTIME_CLASS(CGridCell)); m_Grid.SetItemText(row, , _T(")); m_Grid.S ...

  8. 【golang】golang文本处理

    golang文本字符串操作:包含 合并 连接 分割 取索引 前缀后缀检测 消除字符串 消除空格 golang字符串操作需要用到 strings这个包 str := "hello world& ...

  9. 《百面机器学习算法工程师带你去面试》高清PDF及epub+《美团机器学习实践》PDF及思维导图

    http://blog.sina.com.cn/s/blog_ecd882db0102yuek.html <百面机器学习算法工程师带你去面试>高清PDF及epub+<美团机器学习实践 ...

  10. 从GitLab上拉到本地仓库的项目导入到eclipse中

    拉项目 在本地仓库中右键git clone,填写地址 OK, 然后在拉下来的项目上面右键检出创建dev分支. 要将新分支导入到eclipse中, 如果是没有导入过就选第三个,导入过就选第一个. 然后O ...