Distance Based Partitioning of the Secondary Structure Space
The secondary structure space is divided into partitions according to the base pair distance to two given reference structures and all relevant properties are calculated for each of the resulting partitions.
See also…
For further details, we refer to Lorenz et al. [2009]
Table of Contents
General
MFE Variants
Compute the minimum free energy (MFE) and secondary structures for a partitioning of the secondary structure space according to the base pair distance to two fixed reference structures basepair distance to two fixed reference structures.
Defines
-
TwoDfold_solution
- #include <ViennaRNA/2Dfold.h>
Functions
-
vrna_sol_TwoD_t *vrna_mfe_TwoD(vrna_fold_compound_t *fc, int distance1, int distance2)
- #include <ViennaRNA/2Dfold.h>
Compute MFE’s and representative for distance partitioning.
This function computes the minimum free energies and a representative secondary structure for each distance class according to the two references specified in the datastructure ‘vars’. The maximum basepair distance to each of both references may be set by the arguments ‘distance1’ and ‘distance2’, respectively. If both distance arguments are set to ‘-1’, no restriction is assumed and the calculation is performed for each distance class possible.
The returned list contains an entry for each distance class. If a maximum basepair distance to either of the references was passed, an entry with k=l=-1 will be appended in the list, denoting the class where all structures exceeding the maximum will be thrown into. The end of the list is denoted by an attribute value of INF in the k-attribute of the list entry.
See also
vrna_fold_compound_TwoD(), vrna_fold_compound_free(), vrna_pf_TwoD() vrna_backtrack5_TwoD(), vrna_sol_TwoD_t, vrna_fold_compound_t
- Parameters
fc – The datastructure containing all precomputed folding attributes
distance1 – maximum distance to reference1 (-1 means no restriction)
distance2 – maximum distance to reference2 (-1 means no restriction)
- Returns
A list of minimum free energies (and corresponding structures) for each distance class
-
char *vrna_backtrack5_TwoD(vrna_fold_compound_t *fc, int k, int l, unsigned int j)
- #include <ViennaRNA/2Dfold.h>
Backtrack a minimum free energy structure from a 5’ section of specified length.
This function allows one to backtrack a secondary structure beginning at the 5’ end, a specified length and residing in a specific distance class. If the argument ‘k’ gets a value of -1, the structure that is backtracked is assumed to reside in the distance class where all structures exceeding the maximum basepair distance specified in vrna_mfe_TwoD() belong to.
See also
Note
The argument ‘vars’ must contain precalculated energy values in the energy matrices, i.e. a call to vrna_mfe_TwoD() preceding this function is mandatory!
- Parameters
fc – The datastructure containing all precomputed folding attributes
j – The length in nucleotides beginning from the 5’ end
k – distance to reference1 (may be -1)
l – distance to reference2
-
TwoDfold_vars *get_TwoDfold_variables(const char *seq, const char *structure1, const char *structure2, int circ)
- #include <ViennaRNA/2Dfold.h>
Get a structure of type TwoDfold_vars prefilled with current global settings.
This function returns a datastructure of type TwoDfold_vars. The data fields inside the TwoDfold_vars are prefilled by global settings and all memory allocations necessary to start a computation are already done for the convenience of the user
- Deprecated:
Use the new API that relies on vrna_fold_compound_t and the corresponding functions vrna_fold_compound_TwoD(), vrna_mfe_TwoD(), and vrna_fold_compound_free() instead!
Note
Make sure that the reference structures are compatible with the sequence according to Watson-Crick- and Wobble-base pairing
- Parameters
seq – The RNA sequence
structure1 – The first reference structure in dot-bracket notation
structure2 – The second reference structure in dot-bracket notation
circ – A switch to indicate the assumption to fold a circular instead of linear RNA (0=OFF, 1=ON)
- Returns
A datastructure prefilled with folding options and allocated memory
-
void destroy_TwoDfold_variables(TwoDfold_vars *our_variables)
- #include <ViennaRNA/2Dfold.h>
Destroy a TwoDfold_vars datastructure without memory loss.
This function free’s all allocated memory that depends on the datastructure given.
- Deprecated:
Use the new API that relies on vrna_fold_compound_t and the corresponding functions vrna_fold_compound_TwoD(), vrna_mfe_TwoD(), and vrna_fold_compound_free() instead!
- Parameters
our_variables – A pointer to the datastructure to be destroyed
-
vrna_sol_TwoD_t *TwoDfoldList(TwoDfold_vars *vars, int distance1, int distance2)
- #include <ViennaRNA/2Dfold.h>
Compute MFE’s and representative for distance partitioning.
This function computes the minimum free energies and a representative secondary structure for each distance class according to the two references specified in the datastructure ‘vars’. The maximum basepair distance to each of both references may be set by the arguments ‘distance1’ and ‘distance2’, respectively. If both distance arguments are set to ‘-1’, no restriction is assumed and the calculation is performed for each distance class possible.
The returned list contains an entry for each distance class. If a maximum basepair distance to either of the references was passed, an entry with k=l=-1 will be appended in the list, denoting the class where all structures exceeding the maximum will be thrown into. The end of the list is denoted by an attribute value of INF in the k-attribute of the list entry.
- Deprecated:
Use the new API that relies on vrna_fold_compound_t and the corresponding functions vrna_fold_compound_TwoD(), vrna_mfe_TwoD(), and vrna_fold_compound_free() instead!
- Parameters
vars – the datastructure containing all predefined folding attributes
distance1 – maximum distance to reference1 (-1 means no restriction)
distance2 – maximum distance to reference2 (-1 means no restriction)
-
char *TwoDfold_backtrack_f5(unsigned int j, int k, int l, TwoDfold_vars *vars)
- #include <ViennaRNA/2Dfold.h>
Backtrack a minimum free energy structure from a 5’ section of specified length.
This function allows one to backtrack a secondary structure beginning at the 5’ end, a specified length and residing in a specific distance class. If the argument ‘k’ gets a value of -1, the structure that is backtracked is assumed to reside in the distance class where all structures exceeding the maximum basepair distance specified in TwoDfold() belong to.
- Deprecated:
Use the new API that relies on vrna_fold_compound_t and the corresponding functions vrna_fold_compound_TwoD(), vrna_mfe_TwoD(), vrna_backtrack5_TwoD(), and vrna_fold_compound_free() instead!
Note
The argument ‘vars’ must contain precalculated energy values in the energy matrices, i.e. a call to TwoDfold() preceding this function is mandatory!
- Parameters
j – The length in nucleotides beginning from the 5’ end
k – distance to reference1 (may be -1)
l – distance to reference2
vars – the datastructure containing all predefined folding attributes
-
vrna_sol_TwoD_t **TwoDfold(TwoDfold_vars *our_variables, int distance1, int distance2)
- #include <ViennaRNA/2Dfold.h>
-
struct vrna_sol_TwoD_t
- #include <ViennaRNA/2Dfold.h>
Solution element returned from vrna_mfe_TwoD()
This element contains free energy and structure for the appropriate kappa (k), lambda (l) neighborhood The datastructure contains two integer attributes ‘k’ and ‘l’ as well as an attribute ‘en’ of type float representing the free energy in kcal/mol and an attribute ‘s’ of type char* containg the secondary structure representative,
A value of INF in k denotes the end of a list
See also
-
struct TwoDfold_vars
- #include <ViennaRNA/2Dfold.h>
Variables compound for 2Dfold MFE folding.
- Deprecated:
This data structure will be removed from the library soon! Use vrna_fold_compound_t and the corresponding functions vrna_fold_compound_TwoD(), vrna_mfe_TwoD(), and vrna_fold_compound_free() instead!
Public Members
-
vrna_param_t *P
Precomputed energy parameters and model details.
-
int do_backtrack
Flag whether to do backtracing of the structure(s) or not.
-
char *ptype
Precomputed array of pair types.
-
char *sequence
The input sequence
-
short *S
-
short *S1
The input sequences in numeric form.
-
unsigned int maxD1
Maximum allowed base pair distance to first reference.
-
unsigned int maxD2
Maximum allowed base pair distance to second reference.
-
unsigned int *mm1
Maximum matching matrix, reference struct 1 disallowed.
-
unsigned int *mm2
Maximum matching matrix, reference struct 2 disallowed.
-
int *my_iindx
Index for moving in quadratic distancy dimensions.
-
double temperature
-
unsigned int *referenceBPs1
Matrix containing number of basepairs of reference structure1 in interval [i,j].
-
unsigned int *referenceBPs2
Matrix containing number of basepairs of reference structure2 in interval [i,j].
-
unsigned int *bpdist
Matrix containing base pair distance of reference structure 1 and 2 on interval [i,j].
-
short *reference_pt1
-
short *reference_pt2
-
int circ
-
int dangles
-
unsigned int seq_length
-
int ***E_F5
-
int ***E_F3
-
int ***E_C
-
int ***E_M
-
int ***E_M1
-
int ***E_M2
-
int **E_Fc
-
int **E_FcH
-
int **E_FcI
-
int **E_FcM
-
int **l_min_values
-
int **l_max_values
-
int *k_min_values
-
int *k_max_values
-
int **l_min_values_m
-
int **l_max_values_m
-
int *k_min_values_m
-
int *k_max_values_m
-
int **l_min_values_m1
-
int **l_max_values_m1
-
int *k_min_values_m1
-
int *k_max_values_m1
-
int **l_min_values_f
-
int **l_max_values_f
-
int *k_min_values_f
-
int *k_max_values_f
-
int **l_min_values_f3
-
int **l_max_values_f3
-
int *k_min_values_f3
-
int *k_max_values_f3
-
int **l_min_values_m2
-
int **l_max_values_m2
-
int *k_min_values_m2
-
int *k_max_values_m2
-
int *l_min_values_fc
-
int *l_max_values_fc
-
int k_min_values_fc
-
int k_max_values_fc
-
int *l_min_values_fcH
-
int *l_max_values_fcH
-
int k_min_values_fcH
-
int k_max_values_fcH
-
int *l_min_values_fcI
-
int *l_max_values_fcI
-
int k_min_values_fcI
-
int k_max_values_fcI
-
int *l_min_values_fcM
-
int *l_max_values_fcM
-
int k_min_values_fcM
-
int k_max_values_fcM
-
int *E_F5_rem
-
int *E_F3_rem
-
int *E_C_rem
-
int *E_M_rem
-
int *E_M1_rem
-
int *E_M2_rem
-
int E_Fc_rem
-
int E_FcH_rem
-
int E_FcI_rem
-
int E_FcM_rem
-
vrna_fold_compound_t *compatibility
-
TwoDfold_solution
Partition Function Variants
Compute the partition function and stochastically sample secondary structures for a partitioning of the secondary structure space according to the base pair distance to two fixed reference structures.
Functions
-
vrna_sol_TwoD_pf_t *vrna_pf_TwoD(vrna_fold_compound_t *fc, int maxDistance1, int maxDistance2)
- #include <ViennaRNA/2Dpfold.h>
Compute the partition function for all distance classes.
This function computes the partition functions for all distance classes according the two reference structures specified in the datastructure ‘vars’. Similar to vrna_mfe_TwoD() the arguments maxDistance1 and maxDistance2 specify the maximum distance to both reference structures. A value of ‘-1’ in either of them makes the appropriate distance restrictionless, i.e. all basepair distancies to the reference are taken into account during computation. In case there is a restriction, the returned solution contains an entry where the attribute k=l=-1 contains the partition function for all structures exceeding the restriction. A value of INF in the attribute ‘k’ of the returned list denotes the end of the list
See also
vrna_fold_compound_TwoD(), vrna_fold_compound_free(), vrna_fold_compound vrna_sol_TwoD_pf_t
- Parameters
fc – The datastructure containing all necessary folding attributes and matrices
maxDistance1 – The maximum basepair distance to reference1 (may be -1)
maxDistance2 – The maximum basepair distance to reference2 (may be -1)
- Returns
A list of partition funtions for the corresponding distance classes
-
struct vrna_sol_TwoD_pf_t
- #include <ViennaRNA/2Dpfold.h>
Solution element returned from vrna_pf_TwoD()
This element contains the partition function for the appropriate kappa (k), lambda (l) neighborhood The datastructure contains two integer attributes ‘k’ and ‘l’ as well as an attribute ‘q’ of type FLT_OR_DBL
A value of INF in k denotes the end of a list
See also
Public Members
-
int k
Distance to first reference.
-
int l
Distance to second reference.
-
FLT_OR_DBL q
partition function
-
int k
-
vrna_sol_TwoD_pf_t *vrna_pf_TwoD(vrna_fold_compound_t *fc, int maxDistance1, int maxDistance2)
Stochastic Backtracking
Functions related to stochastic backtracking from a specified distance class.
Functions
-
char *vrna_pbacktrack_TwoD(vrna_fold_compound_t *fc, int d1, int d2)
- #include <ViennaRNA/2Dpfold.h>
Sample secondary structure representatives from a set of distance classes according to their Boltzmann probability.
If the argument ‘d1’ is set to ‘-1’, the structure will be backtracked in the distance class where all structures exceeding the maximum basepair distance to either of the references reside.
See also
- Parameters
fc – [inout] The vrna_fold_compound_t datastructure containing all necessary folding attributes and matrices
d1 – [in] The distance to reference1 (may be -1)
d2 – [in] The distance to reference2
- Pre
The argument ‘vars’ must contain precalculated partition function matrices, i.e. a call to vrna_pf_TwoD() preceding this function is mandatory!
- Returns
A sampled secondary structure in dot-bracket notation
-
char *vrna_pbacktrack5_TwoD(vrna_fold_compound_t *fc, int d1, int d2, unsigned int length)
- #include <ViennaRNA/2Dpfold.h>
Sample secondary structure representatives with a specified length from a set of distance classes according to their Boltzmann probability.
This function does essentially the same as vrna_pbacktrack_TwoD() with the only difference that partial structures, i.e. structures beginning from the 5’ end with a specified length of the sequence, are backtracked
See also
Note
This function does not work (since it makes no sense) for circular RNA sequences!
- Parameters
fc – [inout] The vrna_fold_compound_t datastructure containing all necessary folding attributes and matrices
d1 – [in] The distance to reference1 (may be -1)
d2 – [in] The distance to reference2
length – [in] The length of the structure beginning from the 5’ end
- Pre
The argument ‘vars’ must contain precalculated partition function matrices, i.e. a call to vrna_pf_TwoD() preceding this function is mandatory!
- Returns
A sampled secondary structure in dot-bracket notation
-
char *vrna_pbacktrack_TwoD(vrna_fold_compound_t *fc, int d1, int d2)