【RNA folding】RNA折叠算法与生物物理约束

news2024/12/22 13:12:34

文章目录

  • RNA折叠
    • RNA folding representation
    • 1 DP for simple folds
      • 1.1 Nussinov Algorithm objective
      • 1.2 energy constraints
      • 1.3 The key idea of the algorithm
    • 2 DP for stacking and complex folds
    • Stochastic context free grammars

来自Manolis Kellis教授(MIT计算生物学主任)的课
油管链接:6.047/6.878 Lecture 7 - RNA folding, RNA world, RNA structures (Fall 2020)
本节课分为三个部分,本篇笔记是第三部分RNA folding。
本课程探讨RNA的折叠过程及其预测方法。先了解了RNA的表示和Nussinov算法的应用。然后通过动态规划预测复杂的RNA叠加与折叠。最后介绍了随机上下文无关文法,为RNA结构提供了广泛的描述框架。

RNA折叠


RNA折叠是一个过程,其中RNA分子将自己折叠成特定的三维结构,这些结构对于其功能至关重要。

RNA folding representation

  1. 初级结构 (Primary)
  2. 二级结构 (Secondary): 二级结构展示了RNA分子如何在空间中折叠并通过氢键形成基对。tRNA和rRNA就是依赖其二级结构来发挥作用的。
    • 某些RNA的功能区域可能是由其特定的二级结构模式决定的。
  3. 三级结构 (Tertiary): 三级结构描述了RNA分子如何进一步在三维空间中折叠,以形成更复杂的结构。在这一级,分子的不同部分可能会通过疏水相互作用、范德华力和其他非共价相互作用来相互接触。

  1. 能量的覆盖: RNA二级结构占据了折叠过程中的大部分自由能。这意味着RNA的稳定性和形成方式在很大程度上取决于其二级结构。
  2. 生化粗粒化: RNA的二级结构为我们提供了一个粗略的、生化上有意义的3D结构表示。这使得研究人员可以更容易地理解RNA的空间排布和功能性质。
  3. 折叠的中间态: 在形成其完整的三维结构之前,RNA首先会形成一个稳定的二级结构。这是RNA折叠成其最终功能形态的关键步骤。
  4. 进化上的保守性: 在进化过程中,RNA的二级结构往往是保守的。这意味着相似的二级结构在不同的生物中可能具有相似的功能。
  5. 易于计算处理: 与RNA的完整三维结构相比,其二级结构相对简单,因此更容易在计算机上建模和分析。

这个图展示了RNA二级结构的不同表示方法。以下是每种表示方法的简要解释:

  1. 常规图(Conventional plot): 这种图形展示了RNA分子的实际形状和其碱基配对。

  2. 圆形图(Circle plot/outerplanar graph): 这是RNA二级结构的另一种表示方法,其中RNA序列被放置在一个圆上,碱基配对则由连接线表示。这种方法适用于显示复杂的或交叉的碱基配对关系

  3. 括号表示法(Parenthesis representation): 在这种表示法中,RNA序列从左到右写出,而碱基配对则通过括号表示。匹配的左括号和右括号表示一对碱基配对,而点表示未配对的碱基。这种表示法非常紧凑,适用于计算和算法处理。

  4. 点图(Dot-plot): 点图显示了RNA序列内部所有可能的碱基配对。图上的每个点代表一个特定的碱基配对。这种方法常用于预测RNA二级结构和比较不同结构的相似性。

  5. 山形图(Mountain-plot): 这种表示法通过高度变化来描绘RNA的二级结构。高度的变化反映了RNA结构中的堆叠区域。这提供了一个直观的方式来了解RNA的叠层结构和拓扑形态。

1 DP for simple folds

使用动态规划(Dynamic Programming)来解决RNA折叠问题。RNA折叠是预测RNA分子在三维空间中如何折叠成其稳定的结构的问题。

  • 当RNA分子折叠时,某些碱基对之间会形成氢键,形成了所谓的碱基配对。我们通常希望优化的是整个结构的稳定性,这可以通过计算配对得分来评估
  • 参考我们前面序列对比的动态规划,尝试应用在这里

1.1 Nussinov Algorithm objective

算法目标:预测RNA的二级结构

  • Objective function(目标函数):

    • Nussinov算法的目标是找到具有最大嵌套配对数的RNA结构。所谓的嵌套配对意味着这些配对不与其他配对交叉。
  • Recursive computation(递归计算):

    • Use dynamic programming?
    • How?:具体实施方式涉及建立一个得分矩阵,并通过考虑RNA序列中每个可能的碱基对来填充这个矩阵。每个位置的得分都是基于它可以形成的最佳配对,以及它与其他碱基之间的关系。
  • Similarities to sequence alignment(与序列比对的相似性):

    • 在序列比对中,我们试图找到两个或多个序列之间的最佳对齐方式。对于RNA结构预测,我们试图找到RNA序列内部的最佳对齐方式,即碱基配对方式。

1.2 energy constraints

RNA folding based on biophysical energy constraints(基于生物物理能量约束的RNA折叠)

  1. Scoring scheme(评分方案):

    • 为了决定RNA的最优结构,这里有一个评分系统。在物理上,结构的优化通常是基于最小自由能的。自由能在这里代表稳定性,较低的自由能意味着更稳定的结构。
      • "-1"表示G和U的配对,特殊
    • 为了简化模型,为每对碱基配对分配了一个能量值。例如,A与U的配对有-2的能量值,而C与G的配对有-3的能量值。这些值可能是基于实验数据的。
  2. Does DP apply?(动态规划是否适用?):

    • 考虑到能量分数是可加的。
    • 稍后可能会讨论更复杂的能量模型,但基本的思路是,通过排除某些结构(如伪节点),可以将问题分解为子问题,这使得动态规划变得可行。
  3. Define “matrix”: Eij:

    • 这定义了一个矩阵E,其中Eij表示子序列i到j之间的最小能量。
    • 这个矩阵用于动态规划算法,储存每个子序列的最优解,从而避免重复计算。
  4. Recursion formula(递归公式)Traversal order(遍历顺序)

通过为每对碱基配对分配能量分数,并使用动态规划来找到具有最低总自由能的结构,我们可以获得RNA的预测结构。

1.3 The key idea of the algorithm

右侧的图显示了一个填充了数字的大矩阵。这个矩阵的填充表示算法的动态规划过程。每个矩阵的单元格代表一个RNA子序列的得分。为了找到整个RNA序列的最优二级结构,算法会逐步填充这个矩阵。

  1. 矩阵的对角线:矩阵的对角线上的值都是0,因为一个单独的碱基不能与自己形成配对,所以得分为0。

  2. 填充顺序:可以看到图中的蓝色箭头,这表示填充矩阵的顺序。算法从对角线开始,然后向右上方移动,填充每一个子矩阵。

  3. 碱基配对:在图中,有些地方用线连接了两个点。这表示在那个特定的RNA子序列中,两个碱基形成了配对。

  4. 计算得分:当计算F(i, j)时,我们会查看以下两种情况:

    1. ij配对的得分(如果它们可以配对的话)加上子序列F(i+1, j-1)的得分。
    2. 不考虑ij的配对,而是查看从ij之间所有可能的分割点k,然后取F(i, k)F(k+1, j)的得分之和的最大值。
    3. 下一个遍历是往右上角遍历
  5. 该矩阵的填充反映了RNA序列的所有可能的二级结构。算法通过比较所有这些可能性来找到得分最高的结构。

  1. i , j i,j i,j配对:

    • 在这种情况下,位置 i i i的碱基与位置 j j j的碱基形成了配对,因此它们之间形成了一个碱基对。
    • 同时,子序列 x i + 1 x_{i+1} xi+1 x j − 1 x_{j-1} xj1 可能还有其他的最佳配对,记为 F ( i + 1 , j − 1 ) F(i+1, j-1) F(i+1,j1)
  2. i i i未配对:

    • 在这里,位置 i i i的碱基没有与任何其他碱基配对。
    • 子序列 x i + 1 x_{i+1} xi+1 x j x_j xj 继续寻找其他可能的最佳配对。
  3. j j j未配对:

    • 与“ i i i未配对”的情况类似,这里位置 j j j的碱基没有与任何其他碱基配对。
    • 子序列 x i x_i xi x j − 1 x_{j-1} xj1 继续寻找其他可能的最佳配对。
  4. 分叉:

    • 在这种情况中,序列在某个位置 k k k处被分成了两部分。
    • x i x_i xi x k x_k xk 的子序列和从 x k + 1 x_{k+1} xk+1 x j x_j xj 的子序列分别寻找自己的最佳配对。
    • 这是一个更复杂的情况,因为我们需要考虑从 i i i j j j之间的所有可能的 k k k值,并为每个 k k k值计算其得分 F ( i , k ) + F ( k + 1 , j ) F(i, k) + F(k+1, j) F(i,k)+F(k+1,j)。最后,我们选择使得 F ( i , j ) F(i, j) F(i,j) 得分最大的 k k k值。

2 DP for stacking and complex folds

Nussinov能量模型的局限性

  • 除了单个碱基对外,RNA碱基还倾向于在空间中堆叠,形成堆叠结构。这里显示了一个G-C配对和一个A-U配对的堆叠。堆叠交互是由于相邻碱基对之间的香族环的π-π交互。
  • 堆叠交互为RNA分子提供了额外的稳定性,因此它们对RNA分子的整体自由能有着重要的贡献。

  • 基于环(Loop)的能量模型
  1. 堆叠的碱基(Stacked bases)、发夹环(Hairpin loop)、内部环(Interior loop)、Bulge、以及多环(Multi loop)。这些是RNA二级结构的基本组成部分。

“任何二级结构 ( S ) 都可以被唯一地分解成多个环 ( L )”:这意味着任何RNA的二级结构都可以被唯一地分解为环。

  • “分子的自由能 ( $\Delta G $) 是其环的自由能之和”:整个RNA分子的自由能是由它的各个环的自由能组成的。
  • 这可以用以下公式表示:
    $
    \Delta G(S) = \sum_{L \in S} \Delta G(L)
    $
    这表示分子 ( S ) 的自由能是它包含的所有环 ( L ) 的自由能的总和。

扩展补充:

  • Structural ensemble and base-pairing probability

二维的点图,用于可视化RNA分子中可能的碱基配对的概率

在室温下,RNA不仅形成一个结构,而是存在为一系列可能的结构,称为集合(ensemble)

使用热力学理论来计算特定结构的概率

Stochastic context free grammars

上下文无关文法 (CFG),用于生成回文:
V = { S } , T = { a , b } , P = { S → a S a , S → b S b , S → ϵ } V = \{S\}, \quad T = \{a, b\}, \quad P = \{S \rightarrow aSa, S \rightarrow bSb, S \rightarrow \epsilon\} V={S},T={a,b},P={SaSa,SbSb,Sϵ}
这个CFG可以有效地描述字母表 ({a, b}) 上的所有回文。

RNA文法的例子。这是一个上下文无关文法,旨在模拟RNA的二级结构。RNA分子由四种碱基组成:A(腺苷)、C(鸟苷)、G(鸟嘌呤)和U(尿嘧啶)。
V = { S } , T = { a , c , g , u } , P = { S → a S u , S → c S g , …   } V = \{S\}, \quad T = \{a, c, g, u\}, \quad P = \{S \rightarrow aSu, S \rightarrow cSg, \dots\} V={S},T={a,c,g,u},P={SaSu,ScSg,}

这里的产生规则模拟了RNA的碱基配对,例如A与U配对,C与G配对。

解析树 (Parse Tree) 描述了如何使用给定的文法来派生特定的RNA序列。在这个例子中,给定的RNA序列是 (ACAGGAACUGUACGCUGCACCGC),解析树展示了如何从初始非终结符 (S) 开始,通过多次应用产生规则来得到这个序列。

此外,RNA的二级结构图展示了该序列的配对模式,其中一些碱基通过氢键配对形成稳定的结构。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaSE入门---掌握抽象类和接口

文章目录 抽象类什么是抽象类?抽象类语法抽象类特性 接口什么是接口?接口语法接口使用接口特性实现多个接口接口间的继承 抽象类 VS 接口Java中的 Clonable 接口Java中的 Object 类 抽象类 什么是抽象类? 在面向对象的概念中,所…

Linux编译器-gcc/g++使用函数库

【Linux】系列文章目录 【Linux】基础常见指令:http://t.csdn.cn/hwLPb 【Linux】基本权限:http://t.csdn.cn/faFZg 【Linux】软件包管理器yum与环境开发工具vim:http://t.csdn.cn/LEqkm 目录 【Linux】系列文章目录 前言 一、gcc选项总…

【C语言】malloc()函数详解(动态内存开辟函数)

一.malloc()函数简介 我们先来看一下cplusplus.com - The C Resources Network网站上malloc()函数的基本信息: 1.函数功能 可以看到,malloc()函数的功能是:向内存申请一块连续可用的空间,并返回指向块开头的指针. 2.函数参数 该函数有1个参数,是: void* malloc (…

关于iterm2的美化

iterm2 美化 笔者公司最近给发了一个新 M1 mac pro,所以一些软件需要重新安装。其中比较麻烦就是iterm2的一个美化工程 , 由于每次安装的效果都不尽相同所以这次写一个博客来记录一下 安装的过程 。 全程高能开始: 使用brew 来安装 iterm2 …

26. 通过 cilium pwru了解网络包的来龙去脉

pwru是一种基于eBPF的工具,可跟踪Linux内核中的网络数据包,并具有先进的过滤功能。它允许对内核状态进行细粒度检查,以便通过调试网络连接问题来解决传统工具(如iptables TRACE或tcpdump)难以解决甚至无法解决的问题。在本文中,我将介绍pwru如何在不必事先了解所有内容的…

C++ 模板类编译前需要实例化

在复习list容器的模拟实现,遇到了模板未实例化导致代码报错的问题,list的模拟实现可以看下面这篇文章,这里就不多赘述了,直接切入正题。Clist模拟http://t.csdnimg.cn/N6BGh现在的情况是我们已经模拟实现了list类,想在…

1024 漏洞综合项目演示(第十七课)

1024 漏洞综合项目演示(第十七课) 一 渗透流程 前期交互(Reconnaissance):这是一个信息收集的阶段,黑客或攻击者会收集目标系统或网络的信息,例如域名、IP地址、子网结构、网络拓扑等。 信息收集(Informa…

开源博客项目Blog .NET Core源码学习(4:生成验证码)

开源博客项目Blog中的后台管理登录界面中支持输入验证码(如下图所示),本文学习并记录项目中验证码的生成及调用方式。   博客项目中调用VerifyCode类生成验证码,该类位于App.Framwork项目中,命名空间为App.Framwork…

[Docker]一.Docker 简介与安装

一、Docker简介与为什么要用 Docker 1.1、Docker 介绍 Docker 是一个跨平台的开源的 应用容器引擎 ,诞生于 2013 年初,基于 Go语言 并遵从 Apache2.0 协议开源, Docker 可以把它理解成虚拟机,但是 Docker 和传统虚拟化方式 有所不同 …

玩转视频剪辑全攻略:批量添加上自定义封面的技巧

在进行视频编辑的过程中,我们经常需要为视频添加引人入胜的封面,以吸引观众的注意力。以下是一份详细的全攻略,指导你如何批量添加自定义的视频封面。 首先,你需要在浏览器中搜索并下载“固乔智剪软件”,这是一款功能强…

精通Linux系列第三章:文件系统管理与权限设置(含目录结构思维导图)

文章目录 一、前言二、文件系统概述2.1 文件系统的定义2.2 常见的Linux文件系统2.3 查看当前Linux系统所使用的文件系统2.4 怎么使用特定的文件系统2.5 文件系统的层次结构 三、文件和目录管理3.1 文件和目录的基本概念3.2 创建文件和目录3.3 查看文件和目录信息3.4 复制、移动…

codeforces (C++ Simple Design)

题目&#xff1a; 翻译&#xff1a; 思路&#xff1a; 1、难点在于读题&#xff0c;输入两个数x&#xff0c;k&#xff0c;从x开始递增寻找最小可整除k的数。 代码&#xff1a; #include<iostream> using namespace std; int main() {int x, k;int n;cin >> n;…

使用 OpenGL 渲染会旋转 会变色的三角形(LearnOpenGL P3)

文章目录 前言代码 前言 本文参考文献&#xff0c;侵删&#xff01;LearnOpenGL - 你好&#xff0c;三角形 本文将假设您完成了 OpenGL 的配置&#xff0c;并且使用 VAO、VBO 渲染图形 由于时间问题&#xff0c;代码的详细讲解将在几日内给出~ 代码 #include <glad/glad…

UML类图中各箭头表示总结

UML类图中各箭头表示总结 1、泛化2、实现3、依赖4、关联5、聚合6、组合 在UML类图中&#xff0c;箭头关系是用来表示类之间的关系的。箭头关系的种类有以下几种&#xff1a; 1、泛化 泛化&#xff1a;表示类之间的继承关系。箭头从子类指向父类。箭头&#xff1a;实线空心三角…

【计算机网络】UDP/TCP协议

文章目录 :peach:1 UDP协议:peach:1.1 :apple:UDP协议端格式:apple:1.2 :apple:UDP的特点:apple:1.3 :apple:UDP的缓冲区:apple:1.4 :apple:UDP使用注意事项:apple:1.5 :apple:基于UDP的应用层协议:apple: 2 :peach:TCP协议:peach:2.1 :apple:TCP协议端格式:apple:2.2 :apple:确…

《windows核心编程》第3章 内核对象

一、内核对象简介 1.1 内核对象有哪些 令牌对象 token、事件对象 Event、文件对象 File、文件映射对象 Mapping_File、线程对象 Thread、时钟对象 Timer、线程池对象 ThreadPool、I/O完成端口对象 Completion port、工作对象 job、邮槽对象 mailslot、互斥对象 Mutex、管道对…

Hook原理--逆向开发

今天我们将继续讲解逆向开发工程另一个重要内容--Hook原理讲解。Hook&#xff0c;可以中文译为“挂钩”或者“钩子”&#xff0c;逆向开发中改变程序运行的一种技术。按照如下过程进行讲解 Hook概述Hook技术方式fishhook原理及实例符号表查看函数名称总结 一、Hook概述 在逆…

LeetCode刷题---有效的括号

这里用到了栈的思想 栈(stack)是限定仅在表尾进行插入或者删除的线性表。对于栈来说&#xff0c;表尾端称为栈顶&#xff08;top&#xff09;&#xff0c;表头端称为栈低&#xff08;bottom&#xff09;。不含元素的空表称为空栈。因为栈限定在表尾进行插入或者删除&#xff0c…

生成包含10个随机字母或数字的字符串,然后统计每个字符的出现次数

from random import choices from string import ascii_letters, digitsx .join(choices(ascii_lettersdigits, k10)) d dict() # 创建空字典 for ch in x:d[ch] d.get(ch, 0) 1 # x中有ch字符,个数1,并作为字典的值 print(x) print(d)也可以使用collections模块的defaul…

从车窗升降一探 Android 车机的重要 API:车辆属性 CarProperty

前言 前面我们介绍过 Android 车机 Automotive OS 的几块重要内容&#xff1a; 一文了解 Android 车机如何处理中控的旋钮输入从实体按键看 Android 车机的自定义事件机制深度入门 Android 车机核心 CarService 的构成和链路 本篇文章我们聚焦 Android 车机上最重要、最常用…