RNAlib-2.2.7
|
This module covers all functions and variables related to the problem of incorporating secondary structure constraints into the folding recursions. More...
Modules | |
Hard Constraints | |
This module covers all functionality for hard constraints in secondary structure prediction. | |
Soft Constraints | |
Functions and data structures for secondary structure soft constraints. | |
Incorporating SHAPE reactivity data | |
Incorporate SHAPE reactivity structure probing data into the folding recursions by means of soft constraints. | |
Incorporating ligands binding to specific sequence/structure motifs | |
This module covers functions that enable the incorporation of ligand binding free energies to specific hairpin/interior loop motifs by means of generic soft constraints. | |
Generate soft constraints from data | |
Find a vector of perturbation energies that minimizes the discripancies between predicted and observed pairing probabilities and the amount of neccessary adjustments. | |
Files | |
file | constraints.h |
Functions and data structures for constraining secondary structure predictions and evaluation. | |
Macros | |
#define | VRNA_CONSTRAINT_FILE 0 |
Flag for vrna_constraints_add() to indicate that constraints are present in a text file. More... | |
#define | VRNA_CONSTRAINT_SOFT_MFE 0 |
Indicate generation of constraints for MFE folding. More... | |
#define | VRNA_CONSTRAINT_SOFT_PF VRNA_OPTION_PF |
Indicate generation of constraints for partition function computation. More... | |
#define | VRNA_DECOMP_PAIR_HP 1 |
Flag passed to generic softt constraints callback to indicate hairpin loop decomposition step. More... | |
#define | VRNA_DECOMP_PAIR_IL 2 |
Indicator for interior loop decomposition step. More... | |
#define | VRNA_DECOMP_PAIR_ML 3 |
Indicator for multibranch loop decomposition step. More... | |
#define | VRNA_DECOMP_ML_ML_ML 5 |
Indicator for decomposition of multibranch loop part. More... | |
#define | VRNA_DECOMP_ML_STEM 4 |
Indicator for decomposition of multibranch loop part. More... | |
#define | VRNA_DECOMP_ML_ML 6 |
Indicator for decomposition of multibranch loop part. More... | |
#define | VRNA_DECOMP_ML_UP 11 |
Indicator for decomposition of multibranch loop part. More... | |
#define | VRNA_DECOMP_ML_ML_STEM 20 |
Indicator for decomposition of multibranch loop part. More... | |
#define | VRNA_DECOMP_ML_COAXIAL 13 |
Indicator for decomposition of multibranch loop part. More... | |
#define | VRNA_DECOMP_EXT_EXT 9 |
Indicator for decomposition of exterior loop part. More... | |
#define | VRNA_DECOMP_EXT_UP 8 |
Indicator for decomposition of exterior loop part. More... | |
#define | VRNA_DECOMP_EXT_STEM 14 |
Indicator for decomposition of exterior loop part. More... | |
#define | VRNA_DECOMP_EXT_EXT_EXT 15 |
Indicator for decomposition of exterior loop part. More... | |
#define | VRNA_DECOMP_EXT_STEM_EXT 16 |
Indicator for decomposition of exterior loop part. More... | |
#define | VRNA_DECOMP_EXT_STEM_OUTSIDE 17 |
Indicator for decomposition of exterior loop part. | |
#define | VRNA_DECOMP_EXT_EXT_STEM 18 |
Indicator for decomposition of exterior loop part. More... | |
#define | VRNA_DECOMP_EXT_EXT_STEM1 19 |
Indicator for decomposition of exterior loop part. More... | |
Functions | |
void | vrna_constraints_add (vrna_fold_compound_t *vc, const char *constraint, unsigned int options) |
Add constraints to a vrna_fold_compound_t data structure. More... | |
void | vrna_message_constraint_options (unsigned int option) |
Print a help message for pseudo dot-bracket structure constraint characters to stdout. (constraint support is specified by option parameter) More... | |
void | vrna_message_constraint_options_all (void) |
Print structure constraint characters to stdout (full constraint support) More... | |
This module covers all functions and variables related to the problem of incorporating secondary structure constraints into the folding recursions.
This module provides general functions that allow for an easy control of constrained secondary structure prediction and evaluation. Secondary Structure constraints can be subdivided into two groups:
While Hard-Constraints directly influence the production rules used in the folding recursions by allowing, disallowing, or enforcing certain decomposition steps, Soft-constraints on the other hand are used to change position specific contributions in the recursions by adding bonuses/penalties in form of pseudo free energies to certain loop configurations.
Secondary structure constraints are always applied at decomposition level, i.e. in each step of the recursive structure decomposition, for instance during MFE prediction. Below is a visualization of the decomposition scheme
For Hard Constraints the following option flags may be used to constrain the pairing behavior of single, or pairs of nucleotides:
However, for Soft Constraints we do not allow for simple loop type dependent constraining. But soft constraints are equipped with generic constraint support. This enables the user to pass arbitrary callback functions that return auxiliary energy contributions for evaluation the avaluation of any decomposition.
The callback will then always be notified about the type of decomposition that is happening, and the corresponding delimiting sequence positions. The following decomposition steps are distinguished, and should be captured by the user's implementation of the callback:
Simplified interfaces to the soft constraints framework can be obtained by the implementations in the submodules
An implementation that generates soft constraints for unpaired nucleotides by minimizing the discrepancy between their predicted and expected pairing probability is available in submodule Generate soft constraints from data.
#define VRNA_CONSTRAINT_FILE 0 |
#include <ViennaRNA/constraints.h>
Flag for vrna_constraints_add() to indicate that constraints are present in a text file.
#define VRNA_CONSTRAINT_SOFT_MFE 0 |
#include <ViennaRNA/constraints.h>
Indicate generation of constraints for MFE folding.
#define VRNA_CONSTRAINT_SOFT_PF VRNA_OPTION_PF |
#include <ViennaRNA/constraints.h>
Indicate generation of constraints for partition function computation.
#define VRNA_DECOMP_PAIR_HP 1 |
#include <ViennaRNA/constraints.h>
Flag passed to generic softt constraints callback to indicate hairpin loop decomposition step.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a hairpin loop enclosed by the base pair .
#define VRNA_DECOMP_PAIR_IL 2 |
#include <ViennaRNA/constraints.h>
Indicator for interior loop decomposition step.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an interior loop enclosed by the base pair , and enclosing the base pair
.
#define VRNA_DECOMP_PAIR_ML 3 |
#include <ViennaRNA/constraints.h>
Indicator for multibranch loop decomposition step.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop enclosed by the base pair , and consisting of some enclosed multi loop content from k to l.
#define VRNA_DECOMP_ML_ML_ML 5 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of multibranch loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop part in the interval , which will be decomposed into two multibranch loop parts
, and
.
#define VRNA_DECOMP_ML_STEM 4 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of multibranch loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop part in the interval , which will be considered a single stem branching off with base pair
.
#define VRNA_DECOMP_ML_ML 6 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of multibranch loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop part in the interval , which will be decomposed into a (usually) smaller multibranch loop part
.
#define VRNA_DECOMP_ML_UP 11 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of multibranch loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop part in the interval , which will be considered a multibranch loop part that only consists of unpaired nucleotides.
#define VRNA_DECOMP_ML_ML_STEM 20 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of multibranch loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop part in the interval , which will decomposed into a multibranch loop part
, and a stem with enclosing base pair
.
#define VRNA_DECOMP_ML_COAXIAL 13 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of multibranch loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates a multibranch loop part in the interval , where two stems with enclosing pairs
and
are coaxially stacking onto each other.
#define VRNA_DECOMP_EXT_EXT 9 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be decomposed into a (usually) smaller exterior loop part
.
#define VRNA_DECOMP_EXT_UP 8 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be considered as an exterior loop component consisting of only unpaired nucleotides.
#define VRNA_DECOMP_EXT_STEM 14 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be considered a stem with enclosing pair
.
#define VRNA_DECOMP_EXT_EXT_EXT 15 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be decomposed into two exterior loop parts
and
.
#define VRNA_DECOMP_EXT_STEM_EXT 16 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be decomposed into a stem branching off with base pair
, and an exterior loop part
.
#define VRNA_DECOMP_EXT_EXT_STEM 18 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be decomposed into an exterior loop part
, and a stem branching off with base pair
.
#define VRNA_DECOMP_EXT_EXT_STEM1 19 |
#include <ViennaRNA/constraints.h>
Indicator for decomposition of exterior loop part.
This flag notifies the soft or hard constraint callback function that the current decomposition step evaluates an exterior loop part in the interval , which will be decomposed into an exterior loop part
, and a stem branching off with base pair
.
void vrna_constraints_add | ( | vrna_fold_compound_t * | vc, |
const char * | constraint, | ||
unsigned int | options | ||
) |
#include <ViennaRNA/constraints.h>
Add constraints to a vrna_fold_compound_t data structure.
Use this function to add/update the hard/soft constraints The function allows for passing a string 'constraint' that can either be a filename that points to a constraints definition file or it may be a pseudo dot-bracket notation indicating hard constraints. For the latter, the user has to pass the VRNA_CONSTRAINT_DB option. Also, the user has to specify, which characters are allowed to be interpreted as constraints by passing the corresponding options via the third parameter.
The following is an example for adding hard constraints given in pseudo dot-bracket notation. Here, vc
is the vrna_fold_compound_t object, structure
is a char array with the hard constraint in dot-bracket notation, and enforceConstraints
is a flag indicating whether or not constraints for base pairs should be enforced instead of just doing a removal of base pair that conflict with the constraint.
In constrat to the above, constraints may also be read from file:
vc | The fold compound |
constraint | A string with either the filename of the constraint definitions or a pseudo dot-bracket notation of the hard constraint. May be NULL. |
options | The option flags |
void vrna_message_constraint_options | ( | unsigned int | option | ) |
#include <ViennaRNA/constraints_hard.h>
Print a help message for pseudo dot-bracket structure constraint characters to stdout. (constraint support is specified by option parameter)
Currently available options are:
VRNA_CONSTRAINT_DB_PIPE (paired with another base)
VRNA_CONSTRAINT_DB_DOT (no constraint at all)
VRNA_CONSTRAINT_DB_X (base must not pair)
VRNA_CONSTRAINT_DB_ANG_BRACK (paired downstream/upstream)
VRNA_CONSTRAINT_DB_RND_BRACK (base i pairs base j)
pass a collection of options as one value like this:
vrna_message_constraints(option_1 | option_2 | option_n)
option | Option switch that tells which constraint help will be printed |
void vrna_message_constraint_options_all | ( | void | ) |
#include <ViennaRNA/constraints_hard.h>
Print structure constraint characters to stdout (full constraint support)