 Research Article
 Open Access
Algorithms and Complexity Analyses for Control of Singleton Attractors in Boolean Networks
 Morihiro Hayashida^{1},
 Takeyuki Tamura^{1}Email author,
 Tatsuya Akutsu^{1},
 ShuQin Zhang^{2} and
 WaiKi Ching^{3}
https://doi.org/10.1155/2008/521407
© Morihiro Hayashida et al. 2008
 Received: 12 January 2008
 Accepted: 2 June 2008
 Published: 12 June 2008
Abstract
A Boolean network (BN) is a mathematical model of genetic networks. We propose several algorithms for control of singleton attractors in BN. We theoretically estimate the averagecase time complexities of the proposed algorithms, and confirm them by computer experiments. The results suggest the importance of gene ordering. Especially, setting internal nodes ahead yields shorter computational time than setting external nodes ahead in various types of algorithms. We also present a heuristic algorithm which does not look for the optimal solution but for the solution whose computational time is shorter than that of the exact algorithms.
Keywords
 Internal Node
 Boolean Network
 Recursive Call
 Average Computational Time
 External Node
1. Introduction
One of the important challenges of computational systems biology and bioinformatics is to develop a control theory for biological systems [12]. Development of such a control theory is interesting from both a theoretical viewpoint and a practical viewpoint. From a theoretical viewpoint, biological systems are highly nonlinear. For control of linear systems, extensive studies have been done, and rigorous theories and useful methods have been developed. Furthermore, many of these methods have been applied to control various kinds of real systems. However, it is recognized that control of nonlinear systems is far more difficult than control of linear systems. Though there are some established methods for control of nonlinear systems [34], these can only be applied to certain classes/special cases. In particular, it is very difficult to control largescale nonlinear systems. From a practical viewpoint, as Kitano wrote [12], identification of a set of perturbations that induces desired changes in cellular behaviors may be useful for systemsbased drug discovery and cancer treatment. For example, Takahashi (this author along with Morihiro Hayashida contributed equally to this work) and Yamanaka developed induced pluripotent stem cells (iPS cells) by introducing 4 kinds of transcription factors (Oct3/4, Sox2, cMyc, Klf4) into fibroblast cells of mouse [5]. Furthermore, Takahashi et al. [6] and Yu et al. [7] independently succeeded to develop iPS cells by introducing 4 kinds of factors into human cells. It is to be noted that Yamanaka et al. introduced 4 transcription factors of Oct3/4, Sox2, cMyc, and Klf4 into fibroblast cells, whereas Thomson et al. introduced 4 factors of OCT4, SOX2, NANOG, and LIN28 into somatic cells. Though these seminal discoveries were achieved based on their knowledge, experience, and many experiments, systematic methods might help such kind of works. Therefore, we study systematic methods for control of biological systems. In this paper, we focus on control of gene regulatory networks because these networks play a fundamental role in cells and may be efficiently controlled by overexpression and suppression of genes.
Various kinds of mathematical models have been proposed for modeling gene regulatory networks. These models include neural networks, differential equations, Petri nets, Boolean networks, probabilistic Boolean networks (PBNs), and multivariate Markov chain model [8–11]. Among these models, Boolean network (BN) [12–14] has been well studied. BN is a very simple model; each node (e.g., gene) takes either 0 (inactive) or 1 (active), and the states of nodes change synchronously. Although BN is very simple, its dynamic process is complex and can give insight into the global behavior of large genetic regulatory networks [15].
The total number of possible global states for a Boolean network with genes is . However, for any initial condition, the system will eventually evolve into a limited set of stable states called attractors. The set of states that can lead the system to a specific attractor is called the basin of attraction. Each attractor can contain one or many states. An attractor having only one state is called a singleton attractor. Otherwise, it is called a cyclic attractor. Attractors are biologically interpreted so that different attractors correspond to different cell types [14] or different cell states [16].
Motivated by this biological interpretation, extensive studies have been done on the averagecase analysis of the number and length of attractors in randomly generated BNs [1417–19], although there is no conclusive result. Recently, several methods have been developed for efficiently finding or enumerating attractors in BNs [20–23], whereas it is known that finding a singleton attractor (i.e., a fixed point) is NPhard [2425]. Devloo et al. developed a method using transformation to a constraint satisfaction problem [20]. Garg et al. developed a method based on binary decision diagrams (BDDs) [21]. Irons developed a method that makes use of small subnetworks [22]. However, theoretical analysis of the averagecase complexity was not addressed in these works. We recently developed algorithms for identifying singleton attractors and small attractors, and analyzed the averagecase time complexities of these algorithms [23].
Finding a sequence of control actions for BNs is another important topic on BNs. Datta et al. proposed methods for finding control actions for probabilistic Boolean networks (PBNs) [26–28], where a PBN is a probabilistic extension of a BN [29]. In their approach, the control problem is defined as minimization of the total of control cost and the cost of terminal state. The control cost is defined as the cost of applying control inputs in some particular states, and higher terminal costs are usually assigned to those undesirable states. Their approach is based on the theory of controlled Markov chains, and makes use of the theory of probabilistic dynamic programming. They extended their approach for handling contextsensitive PBNs [30] and/or infinitehorizon optimal control [31]. Since BNs are special cases of PBNs, their methods can also be applied to finding control actions for BNs. However, all of these approaches need to handle matrices, which limits application of these approaches only to small size (e.g., less than 20 nodes) networks. Therefore, we studied computational complexity of the control problem on BN and PBN, and proved that finding an optimal control strategy is NPhard for both BN and PBN [32]. In order to break the barrier of computational complexity, an approximate finitehorizon optimal control has been introduced [33] and a heuristic method based on learning algorithm for approximating the optimal infinitehorizon control policy has been proposed [34]. However, application of these approaches is still limited to small networks.
In this paper, we propose a new model for control of BN, that is, control of attractors of BN. Though our model can be extended to cyclic attractors to some extent (as shown in Section 3.9), here we focus on singleton attractors. Since cyclic attractors correspond to cell cycles appearing in such cases as cell division and cell growth whereas singleton attractors correspond to steady states of cells or cell types, it is reasonable to begin with singleton attractors. We assume that a BN and a score function are given as an input, where the score function indicates the closeness of the attractor state to the desired state. We also assume that nodes in a BN are divided into internal nodes and external nodes, where states of external nodes can only be controlled. Then, our objective is to determine 0/1 states of external nodes so that the score of the resulting singleton attractor is maximized. However, if there exist multiple attractors, the attractor into which a BN is evolved depends on an initial state of a BN. Since it is very difficult to know the initial state exactly, we modify the objective so that the minimum score of the singleton attractors is maximized or exceeds a given threshold. In this model, external nodes correspond to candidate genes and/or transcription factors to be added or to be deleted (suppressed), and the objective is to make a cell to go to a preferable state regardless of the current state of the cell.
In order to solve the proposed problem, we develop several algorithms based on our previous work [23]. In [23], we developed a series of algorithms for finding singleton and small attractors in a BN. The most important feature of the algorithms is that the averagecase time complexity was theoretically analyzed and was experimentally corroborated. It was shown that most of these are much faster than if the maximum indegree is bounded by some constant . For example, one of the algorithms works in time and time (in the average case) for and respectively, which are much faster than . Many of the algorithms proposed in this paper have similar properties. For example, it is shown that one of the algorithms works in and times for and respectively, under some reasonable conditions. Though these time complexities are worse than those in [23], the problem considered in this paper is much more difficult than the one in [23]. Therefore, these results are reasonable and are still much faster than . It is to be noted that some of the proposed algorithms are far from straightforward extensions of [23], and novel ideas are introduced in some of the theoretical analyses. Most of the theoretical results are corroborated through computational experiments.
It is to be noted that the statespacebased methods [26–283133] need at least time. Though a learningbased method [34] needs polynomial update time, it seems that an exponential number of repetitions are required to obtain preferable control actions. Our proposed model may be interpreted as a variant of the infinitehorizon control model [31]. However, our developed algorithms are quite different from those in [31]. Though our proposed algorithms are based on [23], the problems to be solved are different from those in [23] and several new ideas are introduced in development of the algorithms. As a related work, Pal et al. studied the problem of generating BNs with a prescribed attractor structure [28]. Though their model has some similarity with our model, applicability of their methods is limited to small size networks.
The organization of the paper is as follows. First, we briefly review BN and then give a formal definition of the problem. Next, we present our proposed algorithms, their theoretical analyses, and the results on computational experiments. Then, we present an approximate but faster heuristic algorithm. Finally, we conclude with future work.
2. Problem of Controlling Singleton Attractors
In this section, we briefly review the Boolean network model, and then formulate the problem explained above. After that we present enumerationbased algorithms and perform theoretical and empirical analyses.
2.1. Boolean Network and Attractor
This rule means that the state of gene at time depends on the states of genes at time , where is called the indegree of . Furthermore, the maximum indegree of a BN is defined as . The number of genes which are directly influenced by gene is called the outdegree of gene . The states of all genes are changed synchronously according to the corresponding Boolean functions. A consecutive sequence of GAPs ( ) is called an attractor with period if . When , an attractor is called a singleton attractor. When , it is called a cyclic attractor.
Example of a truth table of a Boolean network.







0  0  0  1  0  0 
0  0  1  1  0  1 
0  1  0  0  0  0 
0  1  1  0  1  1 
1  0  0  0  1  0 
1  0  1  0  1  1 
1  1  0  1  1  0 
1  1  1  0  1  1 
In this paper, we assume that there are two types of nodes in a BN: external nodes and internal nodes. Let and be external and internal nodes of a BN, respectively. Note that the total number of nodes in a BN is hereafter. When it is not necessary to distinguish internal and external nodes, are used to specify nodes. Furthermore, let and denote and , respectively.
Now, we formulate the main problem of this paper.
2.2. Singleton Attractor Controlling Problem (SACP)
 (i)
Input: a Boolean network which consists of external nodes and internal nodes, and a score function , that is, a function from to real. We assume that Boolean functions are randomly assigned to nodes and that the parent nodes of each node are also randomly determined with .
 (ii)
Output: a 01 assignment to external nodes, which maximizes the minimum score of singleton attractors, where the score of an attractor is given as .
Example of a score function of a Boolean network.


 

0  3  1  2 
1  0  5  4 
If is fixed as 0 in the truth table of Table 1, the following one is obtained.







0  0  0  0  0  0 
0  0  1  0  0  1 
0  1  0  0  0  0 
0  1  1  0  1  1 
If is fixed as 1 in the truth table of Table 1, the following one is obtained.







1  0  0  1  1  0 
1  0  1  1  1  1 
1  1  0  1  1  0 
1  1  1  1  1  1 
For this problem, one of the robust algorithms is to enumerate all singleton attractors and check the score of every singleton attractor. For this strategy, it is reasonable to utilize the basic recursive algorithm [23] as a subroutine. Although algorithms proposed in this paper are to some extent similar to those in [23], further observations and different approaches are necessary to estimate their computational time since [23] does not include the notion of external and internal nodes.
3. EnumerationBased Algorithms
Before presenting enumerationbased algorithms for SACP, we briefly review the basic recursive algorithm in [23]. In this algorithm, partial GAPs are extended one by one towards a complete GAP according to a given gene ordering. If it is found that a partial GAP cannot be extended to a singleton attractor, the next partial GAP is examined. Although all proposed algorithms in this section are based on the same framework which includes the basic recursive algorithm as a subroutine, gene orderings are different from each other. Therefore, we explain only methods of gene ordering for most algorithms although we present the whole pseudocode of the first algorithm.
In what follows, we present algorithms for SACP and estimate their average computational time. Since some approximations are used for these theoretical analyses, each estimated computational time is not exactly the same as the result of the computer experiments shown in Section 3.8.
3.1. Algorithm 1: ExternalAhead
Theoretical Analysis
The number of terms is , and each term will be exponential function of as shown below. The overall average time complexity will only be affected by the largest term in (2) since holds for arbitrary when and is large enough. Similar discussions will also be applied to the other algorithms.
3.2. Algorithm 2: Basic
Algorithm for gene ordering. Nodes are chosen at random.
Theoretical Analysis
Similar to the analysis of the previous algorithm, the average computational time can be estimated as and its maximum values for fixed and are shown in Tables 5 and 7. Note that the range of is different from that of the previous algorithm.
Intuitively, this algorithm is the same as the basic recursive algorithm in [23]. However, the computational time depends on since always holds for an external node. Therefore, assigning an external node always leads to the next recursive loop, and thus the computational time becomes higher than that of the basic recursive algorithm in [23].
3.3. Algorithm 3: ExternalBehind
Algorithm for gene ordering. First all internal nodes are examined (Step 1). After that all external nodes are examined (Step 2).
Theoretical Analysis
It can be confirmed that the maximum values for fixed and are as shown in Tables 5 and 7.
3.4. Algorithm 4: ExternalLastOne
To achieve smaller time complexity, it is necessary to detect a contradiction for the condition of a singleton attractor at early stage. To detect a contradiction from a node, the node and all its parent nodes must be assigned. Therefore, one of the reasonable methods is to find an assigned node for which of parent nodes have already been assigned, and then assign the nonassigned node so that all parent nodes of are assigned. We call such a nonassigned node LastOne node. In the following three algorithms, we utilize the notion of "LastOne." The frameworks of these three algorithms are the same. (i) First, a nonassigned node is randomly chosen. (ii) Second, if there is a "LastOne" node, assign it either 0 or 1. By further restricting (i) and (ii), we developed the following three algorithms as shown in Table 9.
Algorithm for gene ordering. If there is an external node which satisfies the following condition, is chosen to be assigned either 0 or 1. Otherwise, a nonassigned internal node is randomly chosen. and all parent nodes of have already been assigned except .
If there are multiple external nodes and both of them satisfy the condition, one of them is randomly selected to be assigned. Moreover, if some external nodes are still nonassigned when all internal nodes have been assigned, remaining nodes will be randomly chosen one by one.
Example 3.1.
Assume that , , , and have already been assigned either 0 or 1 as shown in Figure 4(a). Furthermore, assume that is an external node and has not been assigned yet. In such a case, we select instead of randomly selecting a nonassigned internal node.
Theoretical Analysis
holds.
It can be confirmed that the maximum values for fixed and are as shown in Tables 5 and 7.
3.5. Algorithm 5: LastOneAny
Algorithm for gene ordering. If there is a node of which all parent nodes have already been assigned except , will be selected to be assigned either 0 or 1. Otherwise, a nonassigned node is randomly chosen to be assigned. If there are multiple nodes and both of which satisfy the above condition, one of them is randomly selected to be assigned.
Example 3.2.
Assume that , , , and have already been assigned either 0 or 1 as shown in Figure 4(c). Furthermore, assume that has not been assigned yet. In such a case, we select instead of randomly selecting a nonassigned node. Note that is not limited to an external node. Moreover, external nodes and internal nodes are not distinguished in this algorithm at all.
Theoretical Analysis
With simple numerical calculations, we can confirm that the maximum values of (30) for fixed and are as shown in Tables 5 and 7.
3.6. LastOne
Algorithm for gene ordering. If there is a node which satisfies the following condition, is chosen to be assigned either 0 or 1. Otherwise, a nonassigned internal node is randomly chosen. and all its parent nodes have been assigned except .
If there are multiple nodes and both of which satisfy the above condition, one of them is randomly selected to be assigned.
Example 3.3.
Assume that , , , and have already been assigned either 0 or 1 as shown in Figure 4(d). Furthermore, assume that has not been assigned yet. In such a case, we select instead of randomly selecting a nonassigned internal node. Note that is not limited to an external node, but external nodes and internal nodes are distinguished when nonassigned nodes are randomly selected.
Theoretical Analysis
holds.
With simple numerical calculations, we can confirm that the maximum values of (36) for fixed and are as shown in Tables 5 and 7.
3.7. OutdLastOne
Empirical time complexities for .
 ExAhead  Basic  ExBehind  ExLastOne  LastOneAny  LastOne  OutdLastOne 

0.10 







0.167 







0.20 







Theoretical time complexities for .
 ExternalAhead  Basic  ExternalBehind  ExternalLastOne  LastOneAny  LastOne 

0.01 






0.02 






0.03 






0.04 






0.05 






0.06 






0.07 






0.08 






0.09 






0.10 






0.167 






0.20 






0.30 






0.333 






Empirical time complexities for .
 ExAhead  Basic  ExBehind  ExLastOne  LastOneAny  LastOne  OutdLastOne 

0.10 







0.167 







0.20 







ExternalLastOne, LastOneAny, and LastOne.
(ii) is applied to only external nodes  (ii) is applied to both external and internal nodes  

(i) is applied to only internal nodes  ExternalLastOne  LastOne 
(i) is applied to both external and internal nodes  LastOneAny 
Algorithm for gene ordering. If there is a node which satisfies the following condition, is chosen to be assigned either 0 or 1. Otherwise, a nonassigned internal node with the highest outdegree is randomly chosen. and all its parent nodes have been assigned except .
If there are multiple nodes and both of which satisfy the above condition, the one with the highest outdegree is randomly selected to be assigned.
Example 3.4.
Assume that , , , and have already been assigned either 0 or 1 as shown in Figure 4(d). Furthermore, assume that has not been assigned yet. In such a case, we select instead of randomly selecting an internal node with the highest outdegree.
3.8. Computer Experiments for EnumerationBased Algorithms
As a result, empirical time complexities for each algorithm with and are shown in Tables 6 and 8. Since some approximations are used in the theoretical analyses, the theoretical time complexities shown in Tables 5 and 7 are not exactly the same as those of empirical time complexities shown in Tables 6 and 8. However, magnitude correlations of these algorithms are the same for each and . Furthermore, differences between theoretical time complexities and empirical time complexities are not very large for each and . Thus, we can say that our estimation of the theoretical time complexity of each algorithm is relatively appropriate although we used several theoretical approximations to estimate them.
3.9. Comparison among Proposed Algorithms
As a result of theoretical and empirical analyses for the proposed algorithms for SACP, if is not large, it is seen that "LastOne LastOneAny ExternalLastOne ExternalBehind Basic ExternalAhead" holds in terms of necessary computational time, where A B means that A is faster than B. One of the reasonable methods for analyzing the above result is to distinguish these algorithms by depending on whether external nodes or internal nodes are assigned first.
Let us classify these algorithms into the following three types. (i) First, assign internal nodes. After that assign external nodes. (ii) First, assign external nodes. After that assign internal nodes. (iii) Do not distinguish internal and external nodes. From " ExternalBehind Basic ExternalAhead", it is seen that (i) (iii) (ii) holds for the most basic type of algorithms. Although the other algorithms utilize the notion of "last one," they can also roughly be classified into the above three types. For example, the only difference between "LastOne" and "LastOneAny" is that "LastOne" randomly selects only internal nodes when there are no special nodes, whereas "LastOneAny" randomly selects nodes from both internal and external nodes in the same condition. Therefore, it is reasonable to regard "LastOne" and "LastOneAny" as (i) and (iii), respectively, when comparing these two and we can confirm that (i) (iii) holds again. On the other hand, the only difference between "ExternalLastOne" and "LastOne" is that the notion of "last one node" is only applied to external nodes in "ExternalLast," whereas the notion is applied to both internal and external nodes in "LastOne". Therefore, it is also reasonable to regard "ExternalLastOne" and "LastOne" as (ii) and (iii), respectively, in this comparison, and we can confirm that (iii) (ii) holds. Note that "LastOne" is classified into (i) in the previous comparison but is classified into (iii) this time. It depends on which two are compared. Thus, we can confirm that (i) (iii) (ii) holds for various types of comparisons. Intuitively, to reduce the computational time, it is necessary to detect a contradiction for the condition of a singleton attractor at early stage. To detect a contradiction from a node, the node and all its parent nodes must be assigned. However, since always holds for an external node, algorithms cannot detect the contradiction from external nodes. That is why assigning internal nodes first reduces the computational time.
However, if cyclic attractors are taken into consideration, the above property does not hold. Now, we formulate the extended version of SACP as follows.
 (i)
Input: a Boolean network which consists of external nodes and internal nodes, and a score function , that is, a function from to real. We assume that Boolean functions are randomly assigned to nodes, and parent nodes of each node are also randomly determined with .
 (ii)
Output: a 01 assignment to external nodes, which maximizes the minimum score of attractors whose periods are , where . The score of an attractor is given as .
Note that the score of a cyclic attractor is defined as the sum of the score of GAP for each , but it can be extended to other definitions such as the sum of the minimum score of each node.
Although our proposed algorithms were introduced for SACP, we extended and implemented them for ACP(2) and ACP(3). A pseudocode of ExternalAhead for ACP is shown in Algorithm 2. Although the main part of each algorithm is the same as that for SACP, the process for checking whether the partial assignments contradict the condition of attractors is different. Let xancestor of be nodes which have a directed path to with length less than or equal to . For SACP, algorithms only check the relationship between the assignment of each node and its parent nodes. However, for ACP , algorithms check the relationship between the assignment of each node and its ancestors.
Empirical time complexities for ACP(2) with .
 ExAhead  Basic  ExBehind  ExLastOne  LastOneAny  LastOne  OutdLastOne 

0.10 







0.167 







0.20 







Empirical time complexities for ACP(3) with .
 ExAhead  Basic  ExBehind  ExLastOne  LastOneAny  LastOne  OutdLastOne 

0.10 







0.167 







0.20 







Algorithm 1: Algorithm for gene ordering. First, all external nodes are examined. After that all internal nodes are examined.
Pseudocode
Input: Boolean network and score function
Output: 01 assignment to external nodes, which maximizes the minimum score of singleton attractors.
Begin
Initialize .
For to do
For to do
the th digit of the binary number representation of .
Initialize ; .
Procedure
If and , then
;
for to do ;
if it is found that for some , then continue;
else ;
if and ,
then ;
for to do
;
if , then return ;
else return null.
End
Algorithm 2: Pseudocode of ExternalAhead for ACP .
Input: a Boolean network and score functions
Output: 01 assignments to external nodes, which maximize the minimum score
of attractors whose periods are , where . The score of an attractor is given as
.
Begin
Define : nodes which have length paths to .
Initialize ;
for to do
for to do
the th digit of the binary number representation of .
Initialize ; .
Procedure
If and , then
;
for to do
for to do
while and do
if every is assigned and then
if then continue;
else ;
if and ,
then ;
for to do
if , then return ;
else return null.
End
3.10. SACP in ScaleFree BN
It is known that gene regulatory networks have the scalefree property; that is, the degree distribution approximately follows the power law [35]. Moreover, it is observed that the outdegree distribution follows the power law and the indegree distribution follows the Poisson distribution [36]. We implemented OutdLastOne for SACP with scalefree networks, where indegrees are 2 and outdegrees are proportional to . (Note that this does not mean indegrees.) The average empirical time complexities of randomly generated 100 BNs are shown in Table 13, and we can confirm that OutdLastOne in scalefree networks is almost as fast as OutdLastOne in random networks examined in Section 3.8. were used for , and similar numbers of nodes were also used for .
4. Heuristic Algorithms for SACP
In the previous section, we analyzed enumerationbased algorithms for SACP. Although these algorithms are guaranteed to output optimal solutions, it may not be necessary to find the rigorous optimal solutions in some practical cases. One of the possible approaches for this purpose is to use a threshold. Based on it, we develop heuristic algorithms by modifying the original algorithms. In the original algorithms, we update the minimum score whenever a new singleton attractor is found. Instead, in the modified algorithms, we compare the score of a new singleton attractor with a given threshold and output the corresponding assignment to external nodes as an approximate solution if the score is greater than . Of course, there may exist multiple attractors for each assignment to external nodes, and the minimum is taken (per assignment to external nodes) in the original algorithms. However, it is known that the expected number of singleton attractors is 1 [3738]. Thus, it is expected that we can obtain a good solution even if we stop the algorithms as soon as a singleton attractor whose score is greater than is found. How to select is also an important issue in these heuristic algorithms. If we know appropriate in advance, we can simply use such . Otherwise, we may examine several values of from lower to upper. For each , we manually inspect the solution and we stop further examinations if the solution is satisfactory.
Since there is no performance guarantee on the proposed heuristic approach, we examined it by means of computational experiments. We implemented one of the proposed heuristic algorithms assuming that is distributed in uniformly. Furthermore, let us call the following property selectivity: When is to be assigned, if holds, is examined in advance of examining . On the other hand, if holds, is examined in advance of examining . Note that the results in Tables 6 and 8 were not with selectivity.
Empirical time complexities of OutdLastOne for with and selectivity.
 Without 




0.1 




0.111 




0.125 




0.143 




0.167 




0.2 




Empirical time complexities of OutdLastOne for SACP in scalefree network.
 OutdLastOne 

0.1 

0.167 

0.2 

Average and standard deviations of by OutdLastOne for SACP with and selectivity.

 Average of  Standard deviation of  The number of all singleton attractors in 100 BNs  The number of singleton attractors whose scores are more than in 100 BNs 

0.1  −0.1  0.0228  0.0245  64  64 
(  0.0  0.0176  0.0242  64  54 
)  0.1  0.0046  0.0124  64  14 
0.111  −0.1  0.0271  0.0216  66  66 
(  0.0  0.0235  0.0217  66  58 
)  0.1  0.0060  0.0133  66  18 
0.125  −0.1  0.0329  0.0323  66  66 
(  0.0  0.0218  0.0281  66  51 
)  0.1  0.0060  0.0195  66  12 
0.143  −0.1  0.0260  0.0252  70  70 
(  0.0  0.0213  0.0235  70  63 
)  0.1  0.0064  0.0164  70  23 
0.167  −0.1  0.0294  0.0278  73  73 
(  0.0  0.0252  0.0272  73  66 
)  0.1  0.0050  0.0118  73  27 
0.2  −0.1  0.0340  0.0347  66  66 
(  0.0  0.0305  0.0325  66  61 
)  0.1  0.0146  0.0236  66  37 
Average and standard deviations of by OutdLastOne for SACP with and selectivity.

 Average of  Standard deviation of  The number of all singleton attractors in 100 BNs  The number of singleton attractors whose scores are more than in 100 BNs 

0.1  −0.1  0.0552  0.0407  94  94 
(  0.0  0.0443  0.0388  94  85 
)  0.1  0.0108  0.0300  94  21 
0.111  −0.1  0.0582  0.0403  95  95 
(  0.0  0.0476  0.0395  95  91 
)  0.1  0.0147  0.0329  95  31 
0.125  −0.1  0.0619  0.0466  93  93 
(  0.0  0.0462  0.0422  93  86 
)  0.1  0.0199  0.0354  93  41 
0.143  −0.1  0.0680  0.0405  94  94 
(  0.0  0.0526  0.0450  94  91 
)  0.1  0.0212  0.0376  94  32 
0.167  −0.1  0.0619  0.0448  94  94 
(  0.0  0.0528  0.0441  94  89 
)  0.1  0.0206  0.0344  94  44 
0.2  −0.1  0.0782  0.0502  96  96 
(  0.0  0.0661  0.0474  96  92 
)  0.1  0.0300  0.0450  96  58 
Empirical time complexities of ExternalAhead for with and selectivity.





0.1 



0.111 



0.125 



0.143 



0.167 



0.2 



5. Conclusion
In this paper, we have presented fast algorithms to find a 01 assignment for external nodes of a BN, which maximizes the minimum score of singleton attractors. We performed theoretical and experimental analyses for these proposed algorithms, which showed good agreements between their theoretical results and empirical results. It was also suggested that assigning internal nodes in advance of external nodes was the fastest. Furthermore, we have implemented some heuristic algorithms although theoretical analysis has not been performed. One of our future works is to extend our algorithms to a problem where it is not given which nodes are external. Furthermore, for practical use, it is important to develop a method for controlling steady states of a continuous model of biological networks. Although BN is not a continuous model, the idea based on combinatorial models may be utilized in the analysis of continuous models as in [38]. Therefore, it is also our important future work to develop a method for extending our model to continuous one.
Declarations
Acknowledgments
WaiKi Ching supports in part by Research HK RCG Grant no. 7017/07P and HKU CRCG grants.
Authors’ Affiliations
References
 Kitano H: Computational systems biology. Nature 2002,420(6912):206210. 10.1038/nature01254View ArticleGoogle Scholar
 Kitano H: Cancer as a robust system: implications for anticancer therapy. Nature Reviews Cancer 2004,4(3):227235. 10.1038/nrc1300MathSciNetView ArticleGoogle Scholar
 Isidori A: Nonlinear Control Systems II. Springer, Berlin, Germany; 1995.View ArticleMATHGoogle Scholar
 Nijmeijer H, van der Schaft AJ: Nonlinear Dynamical Control Systems. Springer, New York, NY, USA; 1990.View ArticleMATHGoogle Scholar
 Takahashi K, Yamanaka S: Induction of pluripotent stem cells from mouse embryonic and adult fibroblast cultures by defined factors. Cell 2006,126(4):663676. 10.1016/j.cell.2006.07.024View ArticleGoogle Scholar
 Takahashi K, Tanabe K, Ohnuki M, et al.: Induction of pluripotent stem cells from adult human fibroblasts by defined factors. Cell 2007,131(5):861872. 10.1016/j.cell.2007.11.019View ArticleGoogle Scholar
 Yu J, Vodyanik MA, SmugaOtto K, et al.: Induced pluripotent stem cell lines derived from human somatic cells. Science 2007,318(5858):19171920. 10.1126/science.1151526View ArticleGoogle Scholar
 Ching WK, Ng MM, Fung ES, Akutsu T: On construction of stochastic genetic networks based on gene expression sequences. International Journal of Neural Systems 2005,15(4):297310. 10.1142/S0129065705000256View ArticleGoogle Scholar
 de Jong H: Modeling and simulation of genetic regulatory systems: a literature review. Journal of Computational Biology 2002,9(1):67103. 10.1089/10665270252833208View ArticleGoogle Scholar
 Smolen P, Baxter DA, Byrne JH: Mathematical modeling of gene networks. Neuron 2000,26(3):567580. 10.1016/S08966273(00)811940View ArticleMATHGoogle Scholar
 Matsuno H, Tanaka Y, Aoshima H, Doi A, Matsui M, Miyano S: Biopathways representation and simulation on hybrid functional Petri net. In Silico Biology 2003,3(3):389404.Google Scholar
 Kauffman SA: Metabolic stability and epigenesis in randomly constructed genetic nets. Journal of Theoretical Biology 1969,22(3):437467. 10.1016/00225193(69)900150View ArticleGoogle Scholar
 Kauffman S: Homeostasis and differentiation in random genetic control networks. Nature 1969,224(5215):177178. 10.1038/224177a0View ArticleGoogle Scholar
 Kauffman SA: The Origins of Order: SelfOrganization and Selection in Evolution. Oxford University Press, New York, NY, USA; 1993.Google Scholar
 Thieffry D, Huerta AM, PérezRueda E, ColladoVides J: From specific gene regulation to genomic networks: a global analysis of transcriptional regulation in Escherichia coli . BioEssays 1998,20(5):433440. 10.1002/(SICI)15211878(199805)20:5<433::AIDBIES10>3.0.CO;22View ArticleGoogle Scholar
 Huang S: Gene expression profiling, genetic networks, and cellular states: an integrating concept for tumorigenesis and drug discovery. Journal of Molecular Medicine 1999,77(6):469480. 10.1007/s001099900023View ArticleGoogle Scholar
 Aldana M: Boolean dynamics of networks with scalefree topology. Physica D 2003,185(1):4566. 10.1016/S01672789(03)00174XMathSciNetView ArticleMATHGoogle Scholar
 Drossel B, Mihaljev T, Greil F: Number and length of attractors in a critical Kauffman model with connectivity one. Physical Review Letters 2005,94(8):4.View ArticleGoogle Scholar
 Samuelsson B, Troein C: Superpolynomial growth in the number of attractors in Kauffman networks. Physical Review Letters 2003,90(9):4.MathSciNetView ArticleMATHGoogle Scholar
 Devloo V, Hansen P, Labbé M: Identification of all steady states in large networks by logical analysis. Bulletin of Mathematical Biology 2003,65(6):10251051. 10.1016/S00928240(03)000612View ArticleGoogle Scholar
 Garg A, Xenarios I, Mendoza L, DeMicheli G: An efficient method for dynamic analysis of gene regulatory networks and in silico gene perturbation experiments. In Proceedings of the 11th Annual International Conference on Research in Computational Molecular Biology (RECOMB '07), vol. 4453 of Lecture Notes in Computer Science, Oakland, Calif, USA, April 2007. Springer; 6276.Google Scholar
 Irons DJ: Improving the efficiency of attractor cycle identification in Boolean networks. Physica D 2006,217(1):721. 10.1016/j.physd.2006.03.006MathSciNetView ArticleMATHGoogle Scholar
 Zhang SQ, Hayashida M, Akutsu T, Ching WK, Ng MK: Algorithms for finding small attractors in Boolean networks. EURASIP Journal on Bioinformatics and Systems Biology 2007, 2007:13.Google Scholar
 Akutsu T, Kuhara S, Maruyama O, Miyano S: A system for identifying genetic networks from gene expression patterns produced by gene disruptions and overexpressions. Genome Informatics 1998, 9: 151160.MATHGoogle Scholar
 Milano M, Roli A: Solving the satisfiability problem through Boolean networks. Proceedings of the 6th Congress of the Italian Association for Artificial Intelligence on Advances in Artificial Intelligence, vol. 1792 of Lecture Notes in Artificial Intelligence, Bologna, Italy, September 2000 7283.Google Scholar
 Datta A, Choudhary A, Bittner ML, Dougherty ER: External control in Markovian genetic regulatory networks. Machine Learning 2003,52(12):169191.View ArticleMATHGoogle Scholar
 Datta A, Choudhary A, Bittner ML, Dougherty ER: External control in Markovian genetic regulatory networks: the imperfect information case. Bioinformatics 2004,20(6):924930. 10.1093/bioinformatics/bth008View ArticleGoogle Scholar
 Pal R, Ivanov I, Datta A, Bittner ML, Dougherty ER: Generating Boolean networks with a prescribed attractor structure. Bioinformatics 2005,21(21):40214025. 10.1093/bioinformatics/bti664View ArticleGoogle Scholar
 Shmulevich I, Dougherty ER, Kim S, Zhang W: Probabilistic Boolean networks: a rulebased uncertainty model for gene regulatory networks. Bioinformatics 2002,18(2):261274. 10.1093/bioinformatics/18.2.261View ArticleGoogle Scholar
 Pal R, Datta A, Bittner ML, Dougherty ER: Intervention in contextsensitive probabilistic Boolean networks. Bioinformatics 2005,21(7):12111218. 10.1093/bioinformatics/bti131View ArticleGoogle Scholar
 Pal R, Datta A, Dougherty ER: Optimal infinitehorizon control for probabilistic Boolean networks. IEEE Transactions on Signal Processing 2006,54(6, part 2):23752387.View ArticleGoogle Scholar
 Akutsu T, Hayashida M, Ching WK, Ng MK: Control of Boolean networks: hardness results and algorithms for tree structured networks. Journal of Theoretical Biology 2007,244(4):670679. 10.1016/j.jtbi.2006.09.023MathSciNetView ArticleGoogle Scholar
 Ng MK, Zhang SQ, Ching WK, Akutsu T: A control model for Markovian genetic regulatory networks. Lecture Notes in Computer Science. In Transactions on Computational Systems Biology V. Volume 4070. Springer, Berlin, Germany; 2006:3648. 10.1007/11790105_4View ArticleGoogle Scholar
 Faryabi B, Datta A, Dougherty ER: On approximate stochastic control in genetic regulatory networks. IET Systems Biology 2007,1(6):361368. 10.1049/ietsyb:20070015View ArticleGoogle Scholar
 Barabási AL, Albert R: Emergence of scaling in random networks. Science 1999,286(5439):509512. 10.1126/science.286.5439.509MathSciNetView ArticleMATHGoogle Scholar
 Guelzim N, Bottani S, Bourgine P, Képès F: Topological and causal structure of the yeast transcriptional regulatory network. Nature Genetics 2002,31(1):6063. 10.1038/ng873View ArticleGoogle Scholar
 Harvey I, Bossomaier T: Time out of joint: attractors in asynchronous random Boolean networks. In Proceedings of the 4th European Conference on Artificial Life (ECAL '97), Brighton, UK, July 1997. MIT Press; 6775.Google Scholar
 Mochizuki A: An analytical study of the number of steady states in gene regulatory networks. Journal of Theoretical Biology 2005,236(3):291310. 10.1016/j.jtbi.2005.03.015MathSciNetView ArticleGoogle Scholar
Copyright
This article is published under license to BioMed Central Ltd. This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.