Abstract
Computational design of RNA sequences that fold into targeted secondary structures has many applications in biomedicine, nanotechnology and synthetic biology. An RNA molecule is made of different types of secondary structure elements and an important RNA element named pseudoknot plays a key role in stabilizing the functional form of the molecule. However, due to the computational complexities associated with characterizing pseudoknotted RNA structures, most of the existing RNA sequence designer algorithms generally ignore this important structural element and therefore limit their applications. In this paper we present a new algorithm to design RNA sequences for pseudoknotted secondary structures. We use NUPACK as the folding algorithm to compute the equilibrium characteristics of the pseudoknotted RNAs, and describe a new adaptive defect weighted sampling algorithm named Enzymer to design low ensemble defect RNA sequences for targeted secondary structures including pseudoknots. We used a biological data set of 201 pseudoknotted structures from the Pseudobase library to benchmark the performance of our algorithm. We compared the quality characteristics of the RNA sequences we designed by Enzymer with the results obtained from the state of the art MODENA and antaRNA. Our results show our method succeeds more frequently than MODENA and antaRNA do, and generates sequences that have lower ensemble defect, lower probability defect and higher thermostability. Finally by using Enzymer and by constraining the design to a naturally occurring and highly conserved Hammerhead motif, we designed 8 sequences for a pseudoknotted cis-acting Hammerhead ribozyme. Enzymer is available for download at https://bitbucket.org/casraz/enzymer.
Keywords: RNA secondary structure, sequence design algorithm, pseudoknot, hammerhead ribozyme, Pseudobase
1. Introduction
Ribonucleic acid (RNA) molecules play critical roles in various key cellular processes. Other than the messenger RNA (mRNA) (Singer and Leder, 1966) several other classes of RNAs have been discovered to be functional and the pace of discovery has accelerated over the past decade (Stark et al., 2007; Stefani and Slack, 2008; Fu et al., 2013; Roth et al., 2014). Functional RNAs are termed non-coding RNAs (ncRNAs) because they perform their functionality directly and not via their protein products (Mattick and Makunin, 2006). NcRNAs are involved in translation (tRNA) (Giegé et al., 1993), splicing (snRNA) (Matera and Wang, 2014), processing of other RNAs (snoRNA) (Bratkovič and Rogelj, 2014) and other key regulatory processes (Hannon, 2002; Bartel, 2009; Smith et al., 2010; Scarborough et al., 2014).
Due to their diverse range of functionalities, ncRNA are well suited for applications in synthetic biology (Khalil and Collins, 2010; Liang et al., 2011; Rodrigo et al., 2013), therapeutics (Lainé et al., 2011; Burnett and Rossi, 2012; Shum and Rossi, 2013), as well as nanotechnology (Afonin et al., 2013; Geary et al., 2014). The functional form of ncRNAs often requires a specific 3D structure (Shapiro et al., 2007) that is primarily determined by the secondary structure, as well as the sequence composition of the molecule (Leontis and Westhof, 2003; Dieterich and Stadler, 2013). Despite the difficulties of determining the 3D structure of RNAs, secondary structure prediction and secondary structure classification provide a major key in determining the potential functions (Laing and Schlick, 2011) as well as family signature (Griffiths-Jones et al., 2005) of the ncRNA molecules. Hence, developing better methods to design RNA sequences with specified secondary structures is a valuable pursuit as it opens doors to multiple applications.
The problem of designing artificial RNA sequences that fold into a targeted secondary structure is computationally difficult (Schnall-Levin et al., 2008; Haleš et al., 2015) and most of the existing methods resort to heuristics and stochastic local search strategies. The widely used RNA design strategy consists of two steps: first a random seed is generated; next, this seed is iteratively mutated until it adopts the desired folding properties as predicted by a folding algorithm such as RNAfold (Hofacker, 2003), mfold (Zuker, 2003) or CentroidFold (Hamada et al., 2009).
RNAinverse (Hofacker, 2003) is one of the first and most widely used RNA secondary structure design programs. RNAinverse decomposes the given target structure into smaller subunits and attempts to find an RNA sequence by an adaptive local walk, or greedy algorithm. The initial seed sequence is randomly chosen; then sequence positions are iteratively and randomly mutated and mutations are accepted if the objective function improves. In the case of RNAinverse, the objective function reflects the Hamming distance between the predicted minimum free energy (MFE) structure of the design candidate and the target secondary structure. The optimization procedure stops if and when the Hamming distance reaches zero. We note that there is no guarantee for the optimization procedure to find an optimal solution and therefore it is required to specify a cap for the maximum number of iterations allowed.
Subsequent RNA designer methods have demonstrated improved performance compared to RNAinverse. RNA-SSD (Andronescu et al., 2004) and INFO-RNA (Busch and Backofen, 2006) introduced improved seed initialization techniques and stochastic local search strategies to design RNAs with high thermostability. NUPACK (Zadeh et al., 2011) introduced a weighted local sampling strategy to design RNA sequences with low ensemble defect. RNAexinv (Avihoo et al., 2011) used a multi-objective optimization strategy to design RNAs with high thermostability and high mutational robustness. RNAensign (Levin et al., 2012) took a global sampling strategy to design RNAs with high thermostability. Frnakenstein (Lyngsø et al., 2012) utilized a genetic algorithm with local sampling strategy to design RNAs for multiple target structures. RNAiFold (Garcia-Martin et al., 2013) defines the sequence design as a constraint satisfaction problem to design RNAs with targeted GC content and high thermostability. IncaRNAtion (Reinharz et al., 2013) introduces a glocal sampling strategy to design RNAs with targeted GC content and high thermostability.
All above mentioned RNA designer methods ignore a critical structural element called pseudoknot and therefore have limited use. A pseudoknot is typically formed when crossing basepairs occur between the unpaired bases from a loop and other bases outside that loop. Several ncRNA species with regulatory function such as glmS ribozymes (Klein and Ferré-D'Amaré, 2006; Soukup, 2006), Delta ribozymes (Nehdi et al., 2007), SAM II aptamer domain (Gilbert et al., 2008), SAH riboswitch aptamer domain (Edwards et al., 2010), Hammerhead riboyzmes (Perreault et al., 2011) and Twister ribozymes (Roth et al., 2014) contain pseudoknots, where the pseudoknots are known to stabilize the functional form of the structure. Hence, it is of interest to develop RNA designer methods that can handle pseudoknots as well. Computational complexity of designing pseduoknotted RNA secondary structures is characterized by Ponty and Saule (2011).
We identify three reasons why the above mentioned methods can not handle the design of pseudoknotted RNAs. First, in all of the above methods the folding algorithms used to predict the folding properties of the designed sequences are often RNAfold or mfold. Even though both RNAfold and mfold can predict the MFE structure and the partition function (McCaskill, 1989) of a given sequence and a given target structure of length n in O(n3) time and O(n2) space, neither can be used to predict presence of pseudoknots. Second, all above mentioned methods utilize hierarchical structural decomposition methods to speed up the design process. However, the hierarchical structural decomposition methods used by the previous methods can not be generalized to cover pseudoknots and therefore are inapplicable. Third, none of the above methods make any distinction between the different types of base pairs (i.e., nested vs. non-nested) and therefore are not well suited for the cases where the secondary structure includes a pseudoknot motif. In order to include pseudoknots in the design process, it is crucial to address the above mentioned issues.
To our knowledge, there are three algorithmic reports in the literature for the design of pseudoknotted RNAs. antaRNA (Kleinkauf et al., 2015) utilizes an Ant Colony Optimization technique (Dorigo et al., 2006) to design pseudoknotted RNAs that are predicted to fold into the target structure with targeted GC distribution. antaRNA (Kleinkauf et al., 2015) uses pKiss (Janssen and Giegerich, 2015) to predict the MFE structure of the RNA sequences including pseudoknots. MODENA (Taneda, 2012) is a multi-objective genetic algorithm (MOGA) for pseudoknotted RNA sequence design. MODENA attempts to maximize the structural similarity between the target structure and the predicted fold while simultaneously minimizing the free energy of the design candidate sequences. MODENA implements a novel crossover operator to handle pseudoknots and uses IPknot (Sato et al., 2011) as its default folding algorithm. For a given RNA sequence, IPknot can predict the pseudoknotted secondary structure with maximum expected accuracy (MEA) (Lu et al., 2009); hence enabling MODENA to design pseudoknotted RNAs. Note that neither IPknot nor pKiss can not compute the partition function and therefore can not be used to measure important qualitative characteristics such as the ensemble defect and the probability defect of the sequences. The term ensemble defect corresponds the ensemble average of the incorrectly pair nucleotides and the term probability defect corresponds to the sum of the probabilities of all non-target structures in the structural ensemble at thermodynamic equilibrium (Zadeh et al., 2011). INV (Gao et al., 2010) is another RNA designer algorithm to design a restricted class of pseudoknots using a graph decomposition method and a energy minimization criteria. However, as reported by Taneda (2012), the current implementation of INV, does not return any solution for structures larger than 85 nucleotides. It is also worth noting that the benchmark data set of the original article for INV, contains only four structures that are all shorter than 85 nucleotides in length.
In our work, we identify three key choices for the design of pseudoknotted RNAs and devise a new sequence design algorithm. First is the choice for the folding algorithm, which must recognize pseudoknots. Ideally one requires the folding algorithm to compute two key measures: (i) the free energy of the folded molecule, and (ii) the partition function of a single RNA sequence when folded into a target pseudoknotted secondary structure. The free energy is a measure of thermostability, and the partition function makes it possible to characterize the equilibrium base pair qualities by computing the matrix of base pair probabilities. Most of the widely used single sequence folding algorithms such as RNAfold and mfold can not characterize pseudoknots. On the other hand, other existing methods, which can recognize the pseudoknots such as IPknot, Hotknot (Ren et al., 2005), ProbKnot (Bellaousov and Mathews, 2010), pKiss and NanoFolder (Bindewald et al., 2011), can only compute the free energy of the pseudoknotted structures and do not make it possible to compute the partition function. To our knowledge, NUPACK is the only available method, which can be utilized to compute the partition function of a limited but biologically relevant class of pseudoknots (Dirks and Pierce, 2003) and therefore make it possible to compute the matrix of base pair probabilities of a single sequence folding into pseudoknotted target structures. Using the matrix of base pair probabilities, one can compute two other important measures namely ensemble defect and probability defect as well.
The second sequence design choice is the choice an objective function for the optimization algorithm. antaRNA, MODENA and INV utilize energy minimization approaches to design RNA sequences that have the highest similarity to the target structure by favoring design candidates that have lower free energy when folded into the target. However, as described and demonstrated by Dirks et al. (2004) and Zadeh et al. (2011), ensemble defect optimization dominates both of the energy minimization and probability defect minimization approaches. More precisely, ensemble defect minimization leads to design of molecules with folding energies that are as low as those of the molecules designed by energy minimization approaches and also have probability defect values that are as low as those of the molecules designed through probability defect minimization methods. Hence, the ideal choice for the objective function would be the ensemble defect minimization and (Zadeh et al., 2011) provides sufficient evidence to support this claim.
The third sequence design choice is an efficient search strategy which may be realized via iterative sequence mutations. It is desirable for the mutation operators to be able to make distinction between different types of base pairs (i.e., nested base pairs and non-nested base pairs), while efficiently exploring the mutational landscape of the design candidates. To efficiently explore the mutational landscape of the design candidates, the mutation operator must make effective use of the folding attributes, such as the free energy as well as the two different matrices of base pair probabilities, as predicted by the folding algorithm.
In this paper, we follow an ensemble defect optimization strategy to design RNA sequences that fold into a single targeted secondary structure that include pseudoknots. Our method extends the approach previously introduced by Zadeh et al. (2011) to design pseudoknot-free RNA secondary structures such that the pseudoknots can be handled as well. We introduce a new adaptive defect weighted sampling algorithm named Enzymer, and use it to progressively mutate design candidates until the specified stop conditions are reached. We note that the notion of adaptive weighted sampling technique was previously used by Reinharz et al. (2013) in another context. To benchmark our method, we used a biological dataset from the PseudoBase library (Van Batenburg et al., 2000), containing 201 pseudoknotted ncRNAs of length 21–140 nucleotides. We compared our results with the results generated by the state of the art namely MODENA and antaRNA. The data shows that the population of the sequences generated by Enzymer have lower ensemble defect, lower probability defect, higher Boltzmann frequency and higher success rate when compared to MODENA. Our results also show that Enzymer generates sequence populations that have lower ensemble defect, lower probability defect, higher thermostability, higher Boltzmann frequency and higher success rate when compared to the results generated by antaRNA. Finally, we used Enzymer and constrained the design process by using a naturally occurring and highly conserved Hammerhead motif and designed 8 RNA sequences for a pseudoknotted cis-acting Hammerhead ribozyme.
2. Materials and methods
2.1. RNA folding measures at equilibrium
Let ϕ denote an RNA sequence with n nucleotides. Sequence ϕ = ϕ1 … ϕn, can be specified by positional base identities such that ϕi ∈ {A, U, G, C} for i = 1, …, n. Secondary structure τ can be specified by a set of base pairs (ϕi, ϕj) where 1 ≤ i < j ≤ n, such that positions i and j are paired, j ≥ i + 3, and (ϕi, ϕj) ∈ {(A − U), (G − C), (G − U), (U − A), (C − G), (U − G)}. We denote ensemble Γ, as the set of all possible secondary structures of ϕ including pseudoknots. For a sequence ϕ and secondary structure τ ∈ Γ, the free energy ΔG(ϕ, τ) in kcal/mol, is calculated using nearest-neighbor empirical parameters for RNA in 1 M Na+ (Mathews et al., 1999). By calculating the partition function (Dirks and Pierce, 2003) over Γ:
(1) |
one can evaluate the equilibrium probability of ϕ folding into τ:
(2) |
where kB is the Boltzmann constant and T is the temperature in Kelvin. The equilibrium structural features of ensemble Γ are quantified by the base pairing probability matrix P(ϕ) with entries Pi, j ∈ [0, 1] corresponding to the probability:
(3) |
that the base pair i.j forms at equilibrium. Here S(τ) is the structure matrix with entries Si, j ∈ {0, 1}. If structure τ contains pair i.j, then Si, j = 1, otherwise Si, j = 0. To describe unpaired bases, the structure and probability matrices are augmented by an extra column. The entry Si, n+1(τ) is unity if base i is unpaired in structure τ and zero otherwise. The entry Pi, n+1(ϕ) ∈ [0, 1] denotes the equilibrium probability that base i is unpaired over ensemble Γ. Hence, the row sums of the augmented S(τ) and P(ϕ) are unity. The term probability defect (Zadeh et al., 2011) corresponding to the sum of the probabilities of all non-target structures of ensemble Γ can be computed by term:
(4) |
The term ensemble defect (Zadeh et al., 2011) is defined by:
(5) |
where n(ϕ, τ) corresponds to the ensemble average number of incorrectly paired nucleotides at equilibrium over ensemble Γ. Intuitively, the term normalized ensemble defect is given by:
(6) |
We use NUPACK to compute Pi, j as well as two extra matrices: the matrix of nested base-pair probabilities , and the matrix of non-nested base-pair probabilities , all in O(n5) time and O(n4) space. The dynamic programming methods to compute and are described by Dirks and Pierce (2003). Enzymer uses Pi, j to compute the normalized ensemble defect, and uses and to guide the mutation operator.
One can formulate the MFE defect by term:
(7) |
where d(MFEϕ, τ) quantifies the hamming distance between the predicted MFE structure of ϕ and the target structure τ. We call a design successful if d(MFEϕ, τ) = 0. Furthermore, to measure how dominant a structure is in the Boltzmann ensemble, one can compute the Boltzmann frequency by term:
(8) |
Finally, for a set of aligned sequences generated for a single target τ, the term sequence identity (Reinharz et al., 2013) defined by:
(9) |
quantifies the the degree of similarity of the sequences in the corresponding set S. Intuitively, Sid quantifies the diversity of a sequence population. Note that in our case all sequences designed for a given structure have equal length and therefore there are no gaps in the aligned set S.
2.2. Adaptive defect weighted sampling algorithm
Enzymer follows an ensemble defect minimization approach and implements a new adaptive defect weighted sampling algorithm to design pseudoknotted RNAs with a single target secondary structure. In our context, the term adaptive means that the total number of positions to mutate at each iteration, is dynamically chosen at the run-time. The term defect weighted sampling means that at each iteration the probability of mutation of a nucleotide at each position depends on the type of that position (i.e., free, nested pair or non-nested pair), and is also proportional to the positional contribution of that nucleotide to the ensemble defect of the sequence. The positional defect of each position is based on the type of the position and is quantified by Pi, j for free nucleotides, by for nested base pairs, and by for non-nested base pairs.
For a given pseudoknotted target structure τ of size n, our method starts with a randomly generated seed ϕ, and iteratively samples from the low ensemble defect mutational landscape of the seed until it reaches the stop condition. Let fstop denote the maximum value that we accept for N(ϕ, τ). The iterations stop and return ϕ when N(ϕ, τ) ≤ fstop. We note that during each instance of the design trial, there is no guarantee of reaching N(ϕ, τ) ≤ fstop. Hence, we limit the maximum number of the iterations and once the limit is reached, we report the fittest result that was found during the sampling process. Let max_it denote the maximum number of iterations. Then we define the stop condition as the event where either N(ϕ, τ) ≤ fstop or max_it is reached.
Figure 1 presents the key steps of Enzymer. Algorithm 1 describes the complete design approach. Algorithms 2–4, describe the three mutation operators that constitute the adaptive defect weighted sampling process. An Enzymer instance, starts with four input parameters: (i) τ, (ii) fstop, (iii) max_it, and (iv) design template t as defined by string t = t1 … tn, where ti ∈ {A, U, G, C, o} such that the length of t is equal to n. We use t to specify design constrains.
Algorithm 1.
1: // input: target structure, target normalized ensemble defect, maximum iterations and the design template |
2: ϕ ← initialize_seed(τ, t) |
3: iteration_count ← 1 |
4: Cdesign_begin ← current_time() |
5: //compute pair probabilities using NUPACK-pairs |
6: N(ϕ, τ) ← compute_normalized_ensemble_defect(Pi, j, ϕ, τ) |
7: // adaptive defect weighted sampling process starts here |
8: while (N(ϕ, τ) ≥ fstop) OR (iteration_count < max_it) do |
9: iteration_count ← iteration_count+1 |
10: mutation_scheme ← random_integer(1, 3) |
11: if (mutation_scheme = = 1) then |
12: ϕ ← mutate_single_nucleotide(ϕ, τ, Pi, j, t) |
13: end if |
14: if (mutation_scheme = = 2) then |
15: |
16: end if |
17: if (mutation_scheme = = 3) then |
18: m′ ← (length(τ)*N(ϕ, τ))∕5 |
19: m ← floor(absolute_value(normal_distribution(m′, m′∕5))) |
20: if m < 1 then |
21: m = 1 |
22: end if |
23: |
24: end if |
25: |
26: N(ϕ, τ) ← compute_normalized_ensemble_defect(Pi, j, ϕ, τ) |
27: end while |
28: Cdesign_end ← current_time() |
29: Cdesign ← Cdesign_end − Cdesign_begin |
30: Return ϕ, N(ϕ, τ), π(ϕ, τ), ΔG(ϕ, τ), Cdesign |
Algorithm 2.
1: // input: sequence, target structure, matrix of pair probabilities and the design template |
2: mutation ← False |
3: while mutation = = False do |
4: i ← randomly_select_unpaired_position(τ) |
5: if t[i] is not “o” then |
6: continue |
7: end if |
8: random_number ← random_float(0, 1) |
9: probability_of_mutation ← 1−Pi, n+1 |
10: if random_number < probability_of_mutation then |
11: ϕ′ ← mutate_at_position(position = i, ϕ) //replace ϕi with A,G,U or C |
12: if ϕ′ is not ϕ then |
13: ϕ ← ϕ′ |
14: mutation ← True |
15: end if |
16: end if |
17: end while |
18: Return ϕ |
Algorithm 4.
1: // This function mutates exactly m positions. The inputs are the number of positions to mutate, sequence, target structure, pair probabilities, nested pair probabilities, non-nested pair probabilities and the design template, respectively. |
2: mutation_count ← 0 |
3: while mutation_count < m do |
4: i ← random(1, length(τ)) |
5: if ϕi is a free nucleotide OR mutation_count = = (m − 1) then |
6: ϕ ← mutate_single_nucleotide(ϕ, τ, Pi, j, t) |
7: mutation_count ← mutation_count + 1 |
8: end if |
9: if ϕi is not a single nucleotide then |
10: |
11: mutation_count ← mutation_count + 2 |
12: end if |
13: end while |
14: Return ϕ |
First, for target τ we initialize a random RNA seed sequence ϕ that is compatible with the target structure by enforcing base pairing rules (Algorithm 1, line 2). At the seed initialization step, the design template t is used as a mean to specify a set of positional nucleotide constrains on the seed sequence. Once the seed is initialized, we update the seed to match the template such that for i = 1…n, if ti ≠ ”o” then ϕi = ti. Furthermore, t is also used during the sampling process to safeguard the constrained positions against mutations. More precisely, for i = 1…n, the nucleotide ϕi is subject to mutation, if and only if ti = ”o”. Our algorithm allows the user to specify the percentage of the GC content for unconstrained regions of the initial seed sequence and if the GC content is not specified, a random value between of 20 and 80% is used to generate the initial seed sequence.
Second, we use the prob program with -pseudo option from NUPACK, to compute Pi, j, and . We use Pi, j to compute N(ϕ, τ) and use and to guide the sampling step (Algorithm 1, lines 5 and 6).
Third, the algorithm executes the adaptive defect weighted sampling process until it reaches the stop condition (Algorithm 1, line 8). At each iteration the sampling process will uniformly and randomly select from one of the mutation operator (Algorithm 1, line 10) to sample mutants from the low ensemble defect mutational landscape of ϕ. The first mutation operator targets unpaired positions and mutates a single unpaired position. The second mutation operator targets pair positions and mutates a single base pair. Ideally, we would like to mutate multiple positions at each iteration with the aim of reaching the stop criteria with fewer iterations and therefore reducing the running time of the sampling algorithm. Therefore we implemented a third mutation operator to dynamically decide for variable m, which quantifies the total number of positions that have to go under mutation at each iteration. Once the third mutation operator computes m it will make random calls to the first and second mutation operators until precisely m positions are mutated. The details of each of the three mutation operators follows:
single point mutation (algorithm 2): this operator samples a mutant sequence from the mutational landscape of ϕ by mutating a single free nucleotide. For an arbitrary unpaired ϕi, the probability of mutation is computed by (1 − Pi, n+1), which is the measure of positional contribution of ϕi to N(ϕ, τ). The mutation operator scans through ϕ until it selects a single unpaired nucleotide ϕi for mutation.
pair mutation (algorithm 3): this operator samples a mutant sequence from the mutational landscape of ϕ by mutating a single base pair. This operator makes distinction between the two different types of base pairs. For an arbitrary nested base pair (ϕi, ϕj), the probability of pair mutation is proportional to its contribution to N(ϕ, τ) and is computed by the term . For an arbitrary non-nested base pair (ϕi, ϕj), the probability of pair mutation is proportional to its contribution to N(ϕ, τ) and is computed by . The operator continuously scans through all base pairs to select exactly one base pair for mutation.
-
m-mutation (algorithm 4): this operator samples a mutant sequence from the mutational landscape of ϕ by mutating exactly m positions. The value of m will dynamically converge to a value proportional to N(ϕ, τ) and n. Let m′ represent the value that m converges to and be defined by:
(10) where C is an arbitrary constant. In our simulations we set C = 5. Then we compute m using:(11) Once the value of m is determined, the operator will iteratively make uniformly random calls to the single point and pair mutation operators until exactly m positions are mutated. This technique causes the sampling process to choose more positions for mutation when N(ϕ, τ) is large, and to choose fewer positions as N(ϕ, τ) diminishes.
Algorithm 3.
1: //function inputs: sequences, target, nested pair probability, non-nested pair probability, template |
2: mutation ← False |
3: while mutation = = False do |
4: i, j ← randomly_select_a_pair(τ) |
5: if t [i] is not “o” AND t [j] is not “o” then |
6: continue // The entire pair is locked as specified by the design template t |
7: end if |
8: if t [i] is not “o” AND t [j] is “o” then |
9: ϕ′ ← only_mutate_j(j, ϕ) // respecting pair rules, only mutate the unlocked part of the pair |
10: if ϕ′ is not ϕ then |
11: ϕ ← ϕ′ |
12: mutation ← True |
13: end if |
14: Return ϕ |
15: end if |
16: if t [j] is not “o” AND t [i] is “o” then |
17: ϕ′ ← only_mutate_i(i, ϕ) // respecting pair rules, only mutate the unlocked part of the pair |
18: if ϕ′ is not ϕ then |
19: ϕ ← ϕ′ |
20: mutation ← True |
21: end if |
22: Return ϕ |
23: end if |
24: if (i, j) is a nested base pair in τ then |
25: random_number ← random_float(0, 1) |
26: |
27: if random_number < probability_of_mutation then |
28: ϕ′ ← mutate_position_i_j(ϕ, i, j) //replace ϕi, ϕj with A-U, G-C or G-U |
29: if ϕ′ is not ϕ then |
30: ϕ ← ϕ′ |
31: mutation ← True |
32: end if |
33: end if |
34: end if |
35: if (i, j) is a non-nested base pair in τ then |
36: random_number ← random_float(0, 1) |
37: |
38: if random_number < probability_of_mutation then |
39: ϕ′ ← mutate_position_i_j(ϕ, i, j) //replace ϕi, ϕj with A-U,G-C,G-U,U-A,C-G or U-G |
40: if ϕ′ is not ϕ then |
41: ϕ ← ϕ′ |
42: mutation ← True |
43: end if |
44: end if |
45: end if |
46: end while |
47: Return ϕ |
The last step of each iteration is to compute and to decide whether the stop condition is reached or not. Finally, when the sampling process reaches the stop condition, the iterations will stop and ϕ will be returned.
2.3. Characterizing performance of the optimization algorithm
To measure the run-time performance of each Enzymer instance, we count the number of iterations as well as the number of seconds that were required to reach the stop criteria. We emphasize that our algorithm utilizes NUPACK to compute the partition function of each sequence in O(n5) time. Due to the expensive computational costs associated with computation of the partition function at each iteration, it would be ideal to utilize an approach that enables the algorithm to reach the stop criteria in fewer steps. We will discuss in the results section how our third mutation operator (i.e., m − mutation operator) improves the run-time requirement of our adaptive weighted sampling algorithm.
2.4. Dataset
To benchmark the performance of our method we use a non-redundant and diverse biological dataset of pseudoknotted secondary structures prepared by Taneda (2012). We note that the original source of all the target structures in this dataset is the Pseudobase library. The initial dataset was composed of 266 structures. We emphasize that the only existing folding algorithm which enables one to compute P(ϕ, τ), P′(ϕ, τ) and P″(ϕ, τ), is NUPACK and therefore we use it to filter the dataset. Since NUPACK can only recognize a limited class of pseudoknots, our filtering process yields a dataset of 201 pseudoknotted structures of length 21–140 nucleotides. Figure 1 in the Supplementary Material section presents the size distribution of the target structures in the filtered dataset. We will refer to the filtered dataset as Pseudo. Our algorithm accepts secondary structures over the alphabet {[, ], (, ), .} presented in standard dot bracket notation. The Pseudo dataset is available at https://bitbucket.org/casraz/enzymer.
3. Results
3.1. Setup
For each target structure in Pseudo, we ran Enzyner for 30 independent trials. We ran each trial on a dedicated computational core with a CPU speed of 2.0 GHz and 2 GB of RAM. This leads to 30*201 (total of 6030) independent instances of the method. In our setup, we set fstop = 0.01 and max_it = 400. Note max_it = 400 is an arbitrary choice; however as we will discuss, it turned out the 400 is a sufficiently large number of iterations to demonstrate the effectiveness of our approach. Finally, Enzymer returns a single design candidate per trial.
We compare the performance of Enzymer with MODENA and antaRNA. We emphasize that for target structure τ, Enzymer seeks to design sequence ϕ by minimizing the normalized ensemble defect value, where MODENA and antaRNA aim to design sequences with high thermostability. In order to establish a fair basis for comparison with MODENA, we set the maximum number of generations (i.e., max_it) of a MODENA instance to 400. Note that MODENA is a genetic algorithm and is initialized by a population of P independently generated seed sequences and once it reaches the maximum number of generations it returns a population of P candidate solutions. In order to observe a consistent behavior, the author of MODENA (Taneda, 2012) recommends to set the initial population size to be equal to 10% of the total number of generations. Hence, for each target structure we set the P = 40. In the end, for each target structure, we sort the generated sequences based on the corresponding normalized ensemble defect values and select a subset of 30 sequences with the lowest normalized ensemble defect. MODENA generated sequences for all of the 201 target structures. For the case of antaRNA, we ran 30 independent trials and generated 30 sequences for each target structure. Because there is no guarantee that antaRNA reaches the stop condition, we limit the running time to be equal median running time that was required by Enzymer to reach the stop condition for each corresponding target structure. We note that antaRNA failed to recognize 4 of the target structures from the benchmark dataset.
Other than MODENA and antaRNA, the only other reported pseudoknot designer algorithm is INV. As of the date of submission of this article, INV has remained unavailable for benchmarking purposes. However, as reported by Taneda (2012), INV does not return any solution for structures that are larger than 85 nucleotides in length. Furthermore, even for structures that are shorter than 85 nucleotides, MODENA has demonstrated superior performance compared to INV. Therefore comparing Enzymer with MODENA and antaRNA is expected to provide us with sufficient information about the performance of Enzymer.
3.2. Benchmark results
To characterize the quality of a designed sequence ϕ that is predicted to fold into τ, we measure the normalized ensemble defect N(ϕ, τ) (Equation 6), probability defect π(ϕ, τ) (Equation 4), normalized free energy ΔG(ϕ, τ), MFE defect μ(ϕ, τ) (Equation 7), Boltzmann frequency Bf (Equation 8) and sequence identity Sid (Equation 9).
For each of the three methods and for each target structure τk ∈ Pseudo where k = 1, …, 201, we generated 30 sequences ϕls where l = 1, …, 30. For each τk, let fk denote the frequency of reaching N(ϕl, τk) ≤ 0.01. Figure 2 presents the fk values we obtained for each τk from a pool of 30 generated ϕl by each method. In this performance evaluation, we observed fk ≥ 1 in 188, 144, and 24 cases for Enzymer (Figure 2A), for MODENA (Figure 2B) and for antaRNA (Figure 2C) respectively. Furthermore, we observed that there is no single case where the fk of the results generated by Enzymer was lower than that of MODENA or antaRNA.
The number of successful designs where μ(ϕl, τk) = 0 are presented in Figure 3. The results show Enzymer outperformed MODENA and antaRNA in 191 and 194 cases respectively. We also observe MODENA outperformed antaRNA in 127 cases. Respective binomial test statistics with p-values 1.55e−44 and 1.52e−48 suggest Enzymer delivers superior performance compared to MODENA and antaRNA in generating sequences that have their predicted MFE equal to the target structure. Moreover, binomial test statistic with p-value 2.26e−4 also suggests that MODENA delivers superior performance compared to antaRNA.
Figure 4 presents the median normalized ensemble defect values of the sequences generated by each method for each target structure. We observe Enzymer generated sequences with lower normalized ensemble defect and outperformed both MODENA and MODENA in 200 and 201 cases respectively. Furthermore, we also observe MODENA outperformed antaRNA in 155 cases. Respective binomial test statistics with p-values 1.25e−58 and 6.22e−61 suggest that Enzymer delivers superior performance compared to MODENA and antaRNA in generating sequences with lower ensemble defect. Furthermore, binomial test statistic with p-value 5.28e−15 suggests that MODENA delivers superior performance compared to antaRNA as well.
Figure 5 shows median probability defect values of the sequences generated by each method for each target structure. We observe Enzymer outperformed MODENA and antaRNA in 196 and 201 cases respectively. We also observe MODENA outperformed antaRNA in 153 cases. Respective binomial test statistics with p-values 1.66e−51 and 6.22e−61 suggest that Enzymer delivers superior performance compared to MODENA and antaRNA in generating sequences with lower probability defect. Furthermore, binomial test statistic with p-value 5.72e−14 suggests that MODENA delivers superior performance when compared to antaRNA as well.
Figure 6 presents the normalized median free energy values of the sequences generated by each method. We observed Enzymer designed sequences with lower free energy compared to MODENA and antaRNA in 102 and 198 cases respectively. We also observe when compared with antaRNA, MODENA generated sequences with lower free energy in 195 cases. Respective binomial test statistics with with p-value 0.88 suggest Enzymer and MODENA generate sequences with similar free energy. However, respective binomial test statistics with p-values 8.42e−55 and 5.45e−50 suggest that both Enzymer and MODENA deliver superior performance compared to antaRNA in generating sequences that have lower free energy and therefore are thermodynamically more stable.
Figure 7 presents the median Boltzmann frequencies achieved by each of the methods. We observe Enzymer outperformed MODENA and antaRNA in generating sequences with higher Boltzmann frequency in 197 and 201 cases respectively. We also observe MODENA outperformed antaRNA in 153 cases. Respective binomial test statistics with p-values 4.19e−53 and 6.22e−61 suggest that Enzymer delivers superior performance compared to both MODENA and antaRNA in generating sequences that have higher Boltzmann frequency values. Moreover, binomial test statistic with p-value 5.72e−14 suggests that MODENA delivers superior performance compared to antaRNA.
Figure 8 presents median sequence identity for sequence populations generated by each method. We observe antaRNA generated sequences with lower sequence identity in all 201 cases. When we compare Enzymer with MODENA, we observe Enzymer generated sequences with lower sequence identity in 193 cases. Binomial test statistics with p-value 6.22e−61 suggest antaRNA generates solution sets that have lower sequence identity than those sequences generated by Enzymer and MODENA. On the other hand binomial test with p-value 3.72e−47 suggests that MODENA generates solution sets with the lower degree of sequence diversity than the solution sets generated by Enzymer.
Figure 9A compares the run-time performance of Enzymer with MODENA. The y-axis quantifies the logarithm of the median running time required by each of the two methods to reach the corresponding stop criteria. The x-axis represents the size of the target structures in increasing order. As the size of the target structures grow, we observe a rapid rate of growth in the run-time requirement of Enzymer as opposed to a slower growth of run-time requirement for MODENA. The computationaly costly run-time requirement of Enzymer can be related to the expensive task of computing the partition function over the pseudoknotted ensemble in O(n5) time. We have omitted antaRNA from this figure because in our simulations we enforced antaRNA to run for the exact same amount of time it was required by Enzymer to reach the stop condition for each corresponding target structure. We note that the stop criteria for antaRNA is when the MFE defect becomes zero, however as Figure 3 shows there is no guarantee for antaRNA to reach the stop criteria and therefore an artificial cap on the maximum running time allowed must be applied. Figure 9B presents the median value for the number of iterations required for Enzymer to reach the stop criteria. We observe in 179 or 89% of the cases, the stop condition was reached in less than 200 iterations. Both MODENA and antaRNA have been omitted from Figure 9B. MODENA is omitted because it does not stop the optimization process unless it reaches the maximum number of iterations. We also omitted antaRNA because it was not possible to measure the total number iterations before antaRNA reached the stop condition.
The effect of the adding the adaptive sampling technique on normalized ensemble defect and probability defect values are presented in Figure 10. In order to make visual comparison possible, we also added the second degree curve to each dataset. We observe when we enabled the adaptive sampling schema (i.e., the third mutation operator) we reached lower normalized ensemble defect values in 199 out of 201 cases (Figure 10A). We also observe the adaptive sampling technique lowered the probability defect values in 181 out of 201 cases (Figure 10B). Respective binomial test statistics with p-values 1.26e−56 and 1.25e−33 strongly suggest that when the total number of iterations are kept constant (i.e., max_it = 400), the adaptive sampling strategy enables the algorithm to reach lower normalized ensemble defect and lower probability defect values and therefore improve on the run-time requirement of the algorithm.
3.3. Using naturally occurring motif sequences to design a hammerhead ribozyme
Hammerhead ribozymes are small self cleaving RNAs that promote strand scission by internal phosphodiaster transfer. In this section we describe a computational setup for the design of a cis-acting pseudoknotted Hammerhead ribozyme by using a set of naturally occurring and highly conserved nucleotides, which constitute a highly conserved Hammerhead motif. An RNA structural motif is defined as a collection of nucleotides that fold into a stable three dimensional (3D) structure, which can be found in naturally occurring RNAs in unexpected abundance.
Figure 11 shows the secondary structure of a Hammerhead ribozyme from mouse gut metagenome as reported by Perreault et al. (2011) and we will refer to it by HH. The reporting article also identifies the set of highly conserved motif nucleotides with ≥90% rate of conservation throughout the entire phylogenetic family of the ribozyme. Let the design template tHH specify the highly conserved Hammerhead motif for the wild type HH. We adopt the motif specification from Perreault et al. (2011), and use it describe the RNA template sequence for HH by tHH = ooooooooooooooooCCUGAUGAGoooooooooooooooGCGAAAooooooooooooooooooUCGoooooooooooooo. We used tHH as the design template for Enzymer and use HH as the target structure and designed 8 sequences where l = 1…8 for the Hammerhead ribozyme. We also set max_it = 400 and fstop ≤ 0.01.
Table 1 presents the quality of the sequences we generated for HH. The last two rows show the mean and median values of the corresponding columns. Notably fstop was satisfied in neither of the design trials however, the median normalized ensemble defect achieved was as low as 0.04. Interestingly, we observed that the median value for the free energy of the designed sequences is equal to 2.48E + 01 which is equivalent to the free energy of the wild type sequence of the Hammerhead ribozyme. The sequences we generated are presented in Table 1 of the Supplementary Materials section.
Table 1.
Annotation | N(, HH) | π(, HH) | ΔG(, HH) | max_it |
---|---|---|---|---|
4.01E − 02 | 5.41E − 01 | −3.21E + 01 | 400 | |
4.97E − 02 | 6.33E − 01 | −2.13E + 01 | 400 | |
5.02E − 02 | 6.66E − 01 | −2.47E + 01 | 400 | |
4.34E − 02 | 5.85E − 01 | −2.66E + 01 | 400 | |
4.43E − 02 | 5.76E − 01 | −2.33E + 01 | 400 | |
4.99E − 02 | 6.44E − 01 | −2.49E + 01 | 400 | |
4.29E − 02 | 5.73E − 01 | −2.19E + 01 | 400 | |
5.38E − 02 | 7.05E − 01 | −2.65E + 01 | 400 | |
Mean | 4.68E − 02 | 6.16E − 01 | −2.52E + 01 | 400 |
Median | 4.70E − 02 | 6.09E − 01 | −2.48E + 01 | 400 |
4. Discussion
4.1. Summary of contributions
We presented Enzymer, a novel adaptive defect weighted sampling algorithm for the design of pseudoknotted RNA secondary structures. Enzymer (i) uses NUPACK to compute the equilibrium characteristics of RNA sequences, (ii) dynamically adapts the total number of positional mutations at each iteration during the run-time, and (iii) chooses target positions for mutation in respect to their type (free nucleotide, nested base pair or non-nested pair) as well as their positional contribution to ensemble defect of the sequence. To benchmark Enzymer, we used a biological dataset of naturally occurring pseudoknotted secondary structures from the PseudoBase library and compared our results with the state of the art MODENA and antaRNA.
4.2. Summary of results
Our benchmark dataset contains 201 naturally occurring pseudoknotted secondary structures of size 21–140 nucleotides. For each structure, we used Enzymer and generated 30 RNA sequences and compared our results with the results generated by MODENA and antaRNA. We showed that Enzymer efficiently explores the low ensemble defect mutational landscape of the candidate RNAs to design sequences that have lower ensemble defect, lower probability defect and higher Boltzmann frequency than those generated by MODENA and antaRNA. We also showed the sequences designed by our method have similar thermostability when compared to the sequences generated by MODENA but show better thermostability when compared the sequences generated by antaRNA. Furthermore, we showed our method succeeds more often than both MODENA and antaRNA do.
Furthermore, we observed that in 89% of the cases where the size of the target structure is bellow 140 nucleotides, our method can generate sequences with normalized ensemble defect value bellow 0.01 in less than 200 iterations. We also demonstrated that our adaptive sampling strategy causes the algorithm to reach the stop criteria in fewer number of iterations and therefore reduce the computational cost associated with the sampling process. Given our simulation results in respect to the run-time requirement of our approach, we conclude that our method is an excellent choice for the design of pseudoknotted RNA secondary structures of size up to 150 nucleotides. To our knowledge, there exists no other pseudoknotted RNA secondary structure designer algorithm that generates sequences that match the quality characteristics of sequences generated by Enzymer. Further experimentation will allow one to obtain a more accurate estimate about the applicability of Enzymer on larger and more diverse structures.
We emphasize that Enzymer extends the NUPACK design algorithm so that it include pseudoknots. However, if no pseudoknot is present in the target structure, our method will simply call the original NUPACK algorithm to generate sequences for pseudoknot-free targets.
4.3. Constrained sequence design to reengineer a hammerhead ribozyme
We used a naturally occurring Hammerhead motif and used Enzymer to reengineer a cis-acting Hammerhead ribozyme from the mouse gut metagenome. Our method achieved mean and median normalized ensemble defect values of 0.046 and 0.047 respectively. Future in-vitro experimentations will allow us to further analyze applicability of our algorithm as well as the applicability of the particular energy model we used to re-engineer functional cis-acting Hammerhead ribozymes.
4.4. Limitations
We note that the applicability of Enzymer is bound by the ability of NUPACK in recognizing different classes of pseudoknots. NUPACK realizes pseudoknots for single RNA strands such that the search space can be broken into all secondary structures that can be decomposed into two pseudoknot-free structures. Due to this limitation, when we used NUPACK to filter the original dataset, which was provided by Taneda (2012), the number of structures were reduced from 266 to 201. However, to our knowledge NUPACK is the only available computational framework, which can compute the partition function for a limited but biologically relevant class of pseudoknots. Hence, NUPACK is the best choice of the folding algorithm to design pseudoknotted RNAs with low ensemble defect, low probability defect and high thermostability.
4.5. Future work
To our knowledge neither Enzymer nor any other existing sequence designer algorithm exists, which can design RNA sequences for multi-strand and multi-target models such as the trans-acting glmS ribozyme described by Klein and Ferré-D'Amaré (2006) or the oligonucleotide-sensing allosteric ribozyme based logic gates such as the ones described by Penchovsky and Breaker (2005) if pseudoknots are present.
One can use NUPACK to compute the equilibrium characteristics of pseudoknot-free complexes of interacting RNA species (Wolfe and Pierce, 2014), or use NanoFolder (Bindewald et al., 2011) to predict base pairings of pseudoknotted complexes of interacting RNA species. As a future work, we intent to use NUPACK and NanoFolder as folding algorithms to build on our adaptive defect weighted sampling algorithm in order to include the ability to design RNA sequences for multi-strand and multi-target secondary structures where pseudoknots can be present in single stranded forms. Such improvement will open door to design oligonucleotide sensing genetic networks that implement more complex modular interactions such as networks of interacting RNA species where each single stranded RNA species can include pseudoknots.
Author contributions
KZ: Developed the methodology and implemented the software, generated results, conducted the analysis and wrote the manuscript in its entire form. KZ also revised the manuscript to address the issues raised by the reviewers. GB: Provided oversight to the research process, provided comments and corrective remarks regarding the methodology and the analysis. NK: Provided supervision for research process related to this article, monitored the discussion sessions, read and provided corrective remarks about the methodology, implementation and analysis.
Conflict of interest statement
The authors declare that the research was conducted in the absence of any commercial or financial relationships that could be construed as a potential conflict of interest.
Acknowledgments
Computations were made on the supercomputer Guillimin from McGill university, managed by Calcul Qubec and Compute Canada. The operation of this supercomputer is funded by the Canada Foundation for Innovation (CFI), Ministre de l'conomie, de l'Innovation et des Exportations du Qubec (MEIE), RMGA and the Fonds de recherche du Qubec - Nature et technologies (FRQ-NT).
Supplementary material
The Supplementary Material for this article can be found online at: http://journal.frontiersin.org/article/10.3389/fgene.2016.00129
References
- Afonin K. A., Lindsay B., Shapiro B. A. (2013). Engineered RNA nanodesigns for applications in RNA nanotechnology. RNA Nanotechnol. 1, 1–15. 10.2478/rnan-2013-0001 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Andronescu M., Fejes A. P., Hutter F., Hoos H. H., Condon A. (2004). A new algorithm for RNA secondary structure design. J. Mol. Biol. 336, 607–624. 10.1016/j.jmb.2003.12.041 [DOI] [PubMed] [Google Scholar]
- Avihoo A., Churkin A., Barash D. (2011). RNAexinv: an extended inverse RNA folding from shape and physical attributes to sequences. BMC Bioinformatics 12:319. 10.1186/1471-2105-12-319 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Bartel D. P. (2009). MicroRNAs: target recognition and regulatory functions. Cell 136, 215–233. 10.1016/j.cell.2009.01.002 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Bellaousov S., Mathews D. H. (2010). ProbKnot: fast prediction of RNA secondary structure including pseudoknots. RNA 16, 1870–1880. 10.1261/rna.2125310 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Bindewald E., Afonin K., Jaeger L., Shapiro B. A. (2011). Multistrand RNA secondary structure prediction and nanostructure design including pseudoknots. ACS Nano 5, 9542–9551. 10.1021/nn202666w [DOI] [PMC free article] [PubMed] [Google Scholar]
- Bratkovič T., Rogelj B. (2014). The many faces of small nucleolar RNAs. Biochim. Biophys. Acta. 1839, 438–443. 10.1016/j.bbagrm.2014.04.009 [DOI] [PubMed] [Google Scholar]
- Burnett J. C., Rossi J. J. (2012). RNA-based therapeutics: current progress and future prospects. Chem. Biol. 19, 60–71. 10.1016/j.chembiol.2011.12.008 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Busch A., Backofen R. (2006). INFO-RNA a fast approach to inverse RNA folding. Bioinformatics 22, 1823–1831. 10.1093/bioinformatics/btl194 [DOI] [PubMed] [Google Scholar]
- Byun Y., Han K. (2009). PseudoViewer3: generating planar drawings of large-scale RNA structures with pseudoknots. Bioinformatics 25, 1435–1437. 10.1093/bioinformatics/btp252 [DOI] [PubMed] [Google Scholar]
- Dieterich C., Stadler P. F. (2013). Computational biology of RNA interactions. Wiley Interdisc. Rev. 4, 107–120. 10.1002/wrna.1147 [DOI] [PubMed] [Google Scholar]
- Dirks R. M., Lin M., Winfree E., Pierce N. A. (2004). Paradigms for computational nucleic acid design. Nucl. Acids Res. 32, 1392–1403. 10.1093/nar/gkh291 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Dirks R. M., Pierce N. A. (2003). A partition function algorithm for nucleic acid secondary structure including pseudoknots. J. Comput. Chem. 24, 1664–1677. 10.1002/jcc.10296 [DOI] [PubMed] [Google Scholar]
- Dorigo M., Birattari M., Stützle T. (2006). Ant colony optimization. IEEE Comput. Intell. Mag. 1, 28–39. 10.1109/MCI.2006.32969117946638 [DOI] [Google Scholar]
- Edwards A. L., Reyes F. E., Héroux A., Batey R. T. (2010). Structural basis for recognition of S-adenosylhomocysteine by riboswitches. RNA 16, 2144–2155. 10.1261/rna.2341610 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Fu Y., Xu Z., Lu Z. J., Zhao S., Mathews D. H. (2013). 31 Discovery of novel ncRNA by scanning multiple genome alignments. J. Biomol. Struct. Dyn. 31(Suppl 1):19 10.1080/07391102.2013.786463 [DOI] [Google Scholar]
- Gao J. Z. M., Li L. Y. M., Reidys C. M. (2010). Inverse folding of RNA pseudoknot structures. Algorithms Mol. Biol. 5:27. 10.1186/1748-7188-5-27 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Garcia-Martin J. A., Clote P., Dotu I. (2013). RNAifold: a constraint programming algorithm for RNA inverse folding and molecular design. J. Bioinform. Comput. Biol. 11:1350001. 10.1142/s0219720013500017 [DOI] [PubMed] [Google Scholar]
- Geary C., Rothemund P. W., Andersen E. S. (2014). A single-stranded architecture for cotranscriptional folding of RNA nanostructures. Science 345, 799–804. 10.1126/science.1253920 [DOI] [PubMed] [Google Scholar]
- Giegé R., Puglisi J. D., Florentz C. (1993). tRNA structure and aminoacylation efficiency. Prog. Nucl. Acid Res. Mol. Biol. 45, 129–206. 10.1016/S0079-6603(08)60869-7 [DOI] [PubMed] [Google Scholar]
- Gilbert S. D., Rambo R. P., Van Tyne D., Batey R. T. (2008). Structure of the SAM-II riboswitch bound to S-adenosylmethionine. Nat. Struct. Mol. Biol. 15, 177–182. 10.1038/nsmb.1371 [DOI] [PubMed] [Google Scholar]
- Griffiths-Jones S., Moxon S., Marshall M., Khanna A., Eddy S. R., Bateman A. (2005). Rfam: annotating non-coding RNAs in complete genomes. Nucl. Acids Res. 33(Suppl 1):D121–D124. 10.1093/nar/gki081 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Haleš J., Maňuch J., Ponty Y., Stacho L. (2015). Combinatorial RNA design: designability and structure-approximating algorithm, in Combinatorial Pattern Matching eds Cicalese F., Porat El., Vaccaro U. (Springer; ), 231–246. [Google Scholar]
- Hamada M., Kiryu H., Sato K., Mituyama T., Asai K. (2009). Prediction of RNA secondary structure using generalized centroid estimators. Bioinformatics 25, 465–473. 10.1093/bioinformatics/btn601 [DOI] [PubMed] [Google Scholar]
- Hannon G. J. (2002). RNA interference. Nature 418, 244–251. 10.1038/418244a [DOI] [PubMed] [Google Scholar]
- Hofacker I. L. (2003). Vienna RNA secondary structure server. Nucl. Acids Res. 31, 3429–3431. 10.1093/nar/gkg599 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Janssen S., Giegerich R. (2015). The RNA shapes studio. Bioinformatics 31, 423–425. 10.1093/bioinformatics/btu649 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Khalil A. S., Collins J. J. (2010). Synthetic biology: applications come of age. Nat. Rev. Genet. 11, 367–379. 10.1038/nrg2775 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Klein D. J., Ferré-D'Amaré A. R. (2006). Structural basis of glmS ribozyme activation by glucosamine-6-phosphate. Science 313, 1752–1756. 10.1126/science.1129666 [DOI] [PubMed] [Google Scholar]
- Kleinkauf R., Houwaart T., Backofen R., Mann M. (2015). antaRNA–multi-objective inverse folding of pseudoknot RNA using ant-colony optimization. BMC Bioinformatics 16:389. 10.1186/s12859-015-0815-6 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Lainé S., Scarborough R. J., Lévesque D., Didierlaurent L., Soye K. J., Mougel M., et al. (2011). In vitro and in vivo cleavage of HIV-1 RNA by new SOFA-HDV ribozymes and their potential to inhibit viral replication. RNA Biol. 8, 343–353. 10.4161/rna.8.2.15200 [DOI] [PubMed] [Google Scholar]
- Laing C., Schlick T. (2011). Computational approaches to RNA structure prediction, analysis, and design. Curr. Opin. Struct. Biol. 21, 306–318. 10.1016/j.sbi.2011.03.015 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Leontis N. B., Westhof E. (2003). Analysis of RNA motifs. Curr. Opin. Struct. Biol. 13, 300–308. 10.1016/S0959-440X(03)00076-9 [DOI] [PubMed] [Google Scholar]
- Levin A., Lis M., Ponty Y., ODonnell C. W., Devadas S., Berger B., et al. (2012). A global sampling approach to designing and reengineering RNA secondary structures. Nucl. Acids Res. 40, 10041–10052. 10.1093/nar/gks768 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Liang J. C., Bloom R. J., Smolke C. D. (2011). Engineering biological systems with synthetic RNA molecules. Mol. Cell 43, 915–926. 10.1016/j.molcel.2011.08.023 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Lu Z. J., Gloor J. W., Mathews D. H. (2009). Improved RNA secondary structure prediction by maximizing expected pair accuracy. RNA 15, 1805–1813. 10.1261/rna.1643609 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Lyngsø R. B., Anderson J. W., Sizikova E., Badugu A., Hyland T., Hein J. (2012). Frnakenstein: multiple target inverse RNA folding. BMC Bioinformatics 13:260. 10.1186/1471-2105-13-260 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Matera A. G., Wang Z. (2014). A day in the life of the spliceosome. Nat. Rev. Mol. Cell Biol. 15, 108–121. 10.1038/nrm3742 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Mathews D. H., Sabina J., Zuker M., Turner D. H. (1999). Expanded sequence dependence of thermodynamic parameters improves prediction of RNA secondary structure. J. Mol. Biol. 288, 911–940. 10.1006/jmbi.1999.2700 [DOI] [PubMed] [Google Scholar]
- Mattick J. S., Makunin I. V. (2006). Non-coding RNA. Hum. Mol. Genet. 15(Suppl 1):R17–R29. 10.1093/hmg/ddl046 [DOI] [PubMed] [Google Scholar]
- McCaskill J. (1989). The equilibrium partition function and base pair binding probabilities for RNA secondary structure. Biopolymers 29, 1105–1119. 10.1002/bip.360290621 [DOI] [PubMed] [Google Scholar]
- Nehdi A., Perreault J., Beaudoin J.-D., Perreault J.-P. (2007). A novel structural rearrangement of hepatitis delta virus antigenomic ribozyme. Nucl. Acids Res. 35, 6820–6831. 10.1093/nar/gkm674 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Penchovsky R., Breaker R. R. (2005). Computational design and experimental validation of oligonucleotide-sensing allosteric ribozymes. Nat. Biotechnol. 23, 1424–1433. 10.1038/nbt1155 [DOI] [PubMed] [Google Scholar]
- Perreault J., Weinberg Z., Roth A., Popescu O., Chartrand P., Ferbeyre G., et al. (2011). Identification of hammerhead ribozymes in all domains of life reveals novel structural variations. PLoS Comput. Biol. 7:e1002031. 10.1371/journal.pcbi.1002031 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Ponty Y., Saule C. (2011). A combinatorial framework for designing (pseudoknotted) RNA algorithms, in Algorithms in Bioinformatics, eds Przytycka T. M., Sagot M.-F. (Berlin; Heidelberg: Springer; ), 250–269. 10.1007/978-3-642-23038-7_22 [DOI] [Google Scholar]
- Reinharz V., Ponty Y., Waldispühl J. (2013). A weighted sampling algorithm for the design of RNA sequences with targeted secondary structure and nucleotide distribution. Bioinformatics 29, i308–i315. 10.1093/bioinformatics/btt217 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Ren J., Rastegari B., Condon A., Hoos H. H. (2005). HotKnots: heuristic prediction of RNA secondary structures including pseudoknots. RNA 11, 1494–1504. 10.1261/rna.7284905 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Rodrigo G., Landrain T. E., Shen S., Jaramillo A. (2013). A new frontier in synthetic biology: automated design of small RNA devices in bacteria. Trends Genet. 29, 529–536. 10.1016/j.tig.2013.06.005 [DOI] [PubMed] [Google Scholar]
- Roth A., Weinberg Z., Chen A. G., Kim P. B., Ames T. D., Breaker R. R. (2014). A widespread self-cleaving ribozyme class is revealed by bioinformatics. Nat. Chem. Biol. 10, 56–60. 10.1038/nchembio.1386 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Sato K., Kato Y., Hamada M., Akutsu T., Asai K. (2011). IPknot: fast and accurate prediction of RNA secondary structures with pseudoknots using integer programming. Bioinformatics 27, i85–i93. 10.1093/bioinformatics/btr215 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Scarborough R. J., Lévesque M. V., Perreault J.-P., Gatignol A. (2014). Design and evaluation of clinically relevant SOFA-HDV Ribozymes targeting HIV RNA, in Therapeutic Applications of Ribozymes and Riboswitches, eds Lafontaine D., Dubé A. (Springer: ), 31–43. 10.1007/978-1-62703-730-3_3 [DOI] [PubMed] [Google Scholar]
- Schnall-Levin M., Chindelevitch L., Berger B. (2008). Inverting the viterbi algorithm: an abstract framework for structure design, in Proceedings of the 25th international conference on Machine learning (Helsinki: ACM; ), 904–911. 10.1145/1390156.1390270 [DOI] [Google Scholar]
- Shapiro B. A., Yingling Y. G., Kasprzak W., Bindewald E. (2007). Bridging the gap in RNA structure prediction. Curr. Opin. Struct. Biol. 17, 157–165. 10.1016/j.sbi.2007.03.001 [DOI] [PubMed] [Google Scholar]
- Shum K.-T., Rossi J. J. (2013). RNA Nanotechnology approach for targeted delivery of RNA therapeutics using cell-internalizing aptamers, in DNA and RNA Nanobiotechnologies in Medicine: Diagnosis and Treatment of Diseases, eds Erdmann V. A., Barciszewski J. (Berlin; Heidelberg: Springer; ), 395–423. 10.1007/978-3-662-45775-7_16 [DOI] [Google Scholar]
- Singer M. F., Leder P. (1966). Messenger RNA: an evaluation. Ann. Rev. Biochem. 35, 195–230. 10.1146/annurev.bi.35.070166.001211 [DOI] [PubMed] [Google Scholar]
- Smith A. M., Fuchs R. T., Grundy F. J., Henkin T. (2010). Riboswitch RNAs: regulation of gene expression by direct monitoring of a physiological signal. RNA Biol. 7, 104–110. 10.4161/rna.7.1.10757 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Soukup G. A. (2006). Core requirements for glmS ribozyme self-cleavage reveal a putative pseudoknot structure. Nucl. Acids Res. 34, 968–975. 10.1093/nar/gkj497 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Stark A., Lin M. F., Kheradpour P., Pedersen J. S., Parts L., Carlson J. W., et al. (2007). Discovery of functional elements in 12 Drosophila genomes using evolutionary signatures. Nature 450, 219–232. 10.1038/nature06340 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Stefani G., Slack F. J. (2008). Small non-coding RNAs in animal development. Nat. Revi. Mol. Cell Biol. 9, 219–230. 10.1038/nrm2347 [DOI] [PubMed] [Google Scholar]
- Taneda A. (2012). Multi-objective genetic algorithm for pseudoknotted RNA sequence design. Front. Genet. 3:36. 10.3389/fgene.2012.00036 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Van Batenburg F., Gultyaev A. P., Pleij C., Ng J., Oliehoek J. (2000). PseudoBase: a database with RNA pseudoknots. Nucl. Acids Res. 28, 201–204. 10.1093/nar/28.1.201 [DOI] [PMC free article] [PubMed] [Google Scholar]
- Wolfe B. R., Pierce N. A. (2014). Sequence design for a test tube of interacting nucleic acid strands. ACS Syn. Biol. 4, 1086–1100. 10.1021/sb5002196 [DOI] [PubMed] [Google Scholar]
- Zadeh J. N., Wolfe B. R., Pierce N. A. (2011). Nucleic acid sequence design via efficient ensemble defect optimization. J. Comput. Chem. 32, 439–452. 10.1002/jcc.21633 [DOI] [PubMed] [Google Scholar]
- Zuker M. (2003). Mfold web server for nucleic acid folding and hybridization prediction. Nucl. Acids Res. 31, 3406–3415. 10.1093/nar/gkg595 [DOI] [PMC free article] [PubMed] [Google Scholar]
Associated Data
This section collects any data citations, data availability statements, or supplementary materials included in this article.