The reversible circuit synthesis problem can be reduced to permutation group. This allows Schreier-Sims Algorithm for the strong generating set-finding problem to be used to find tight bounds on the synthesis of 3-bit reversible circuits using the NFT library. The tight bounds include the maximum and minimum length of 3-bit reversible circuits, the maximum and minimum cost of 3-bit reversible circuits. The analysis shows better results than that found in the literature for the lower bound of the cost. The analysis also shows that there are 1960 universal reversible sub-libraries from the main NFT library.
Introduction
Reversible logic [2, 11] is one of the hot areas of research. It has many applications in quantum computation [14, 23] , low-power CMOS [9, 5] and many more. Synthesis of reversible circuits cannot be done using conventional ways [29] . Synthesis and optimization of Boolean systems on non-standard computers that promise to do computation more powerfully [26] than classical computers, such as quantum computers, is an essential aim in the exploration of the benefits that may be gain from such systems.
A lot of work has been done trying to find an efficient reversible circuit for an arbitrary reversible function. In one of the research directions, it was shown that the process of synthesizing linear reversible circuits can be reduced to a row reduction problem of n × n non-singular matrix [24] . Standard row reduction methods such as Gaussian elimination and LU-decomposition have been proposed [3] . In another research direction, search algorithms and template matching tools using reversible gates libraries have been used [10, 17, 21, 22] . These will work efficiently for small circuits. A method is given in [15] , where a very useful set of transformations for Boolean quantum circuits is shown. In this method, extra auxiliary bits are used in the construction that will increase the hardware cost. In [31] , it was shown that there is a direct correspondence between reversible Boolean operations and certain forms of classical logic known as Reed-Muller expansions. This arises the possibility of handling the problem of synthesis and optimization of reversible Boolean logic within the field of Reed-Muller logic. A lot of work has been done trying to find an efficient reversible circuit for an arbitrary multi-output Boolean functions by using templates [18, 19] and data-structure-based optimization [25] . A method to generate an optimal 4-bit reversible circuits has been proposed [13] . Benchmarks for reversible circuits have been established [20] .
Recently, the study of reversible logic synthesis problem using group theory is gaining more attention. Investigation on the universality of the basic building blocks of reversible circuit has been done [28, 6] . A relation between Young subgroups and the reversible logic synthesis problem has been proposed [7] . A comparison between the decomposition of reversible circuit and quantum circuit using group theory has been shown [8] . A GAP-based algorithms to synthesize reversible circuits for various types of gate with various gate costs has been proposed [30] .
The aim of the paper is to answer the following questions for the synthesis of 3-bit reversible circuits using NFT library: 
Reversible Circuits
To build a reversible circuit with n variables, an n × n reversible circuit is used. C n N OT gate is the main primitive gate that is used to build the circuit since it is shown to be universal for reversible computation [29] . C n N OT gate is defined as follows:
n N OT is a reversible gate denoted as,
with n inputs: x 1 , x 2 ,. . . , x n−1 (known as control bits) and f in (known as target bit), and n outputs: y 1 , y 2 ,. . . , y n−1 and f out . The operation of the C n N OT gate is defined as follows,
i.e. the target bit will be flipped if and only if all the control bits are set to 1. Some special cases of the general C n N OT gate have their own names, C 1 N OT gate with no control bits is called N OT gate as shown in Fig. 1-b , where the bit will be flipped unconditionally. C 2 N OT gate with one control bit is called Feynman gate as shown in Fig. 1 -c. C 3 N OT gate with two control bits is called Toffoli gate as shown in Fig. 1-d. For the sake of readability C 1 N OT , C 2 N OT and C 3 N OT will be written for short as N , F and T respectively where the control and/or target bits will be shown in the subscript of the gate, for example, a 3-bit reversible circuit synthesized using N ,F and T gates can contain 12 possible gates, as shown in Fig.2 , that perform as follows: 
A reversible circuit is a cascade of one or more C n N OT gates, for example, a 3-bit reversible circuit shown in Fig.4 -a can be written for short as (T 123 F 23 N 2 T 132 F 13 F 31 ), where the truth table of this circuit is shown in Fig.4 -b. Another way to write this truth table is (0, 1, 2, 3, 4, 5, 6, 7) → (2, 6, 5, 4, 7, 1, 0, 3), or simply (2, 6, 5, 4, 7, 1, 0, 3) which is called the specification of the circuit.
Quantum Cost
Quantum cost is a term used to refer to the technological cost of building C n N OT gates. The quantum cost of a reversible circuit is subject to optimization as well as the number of C n N OT gates used in the circuit. The quantum cost of a C n N OT gate is based primarily on the number of bits involved in the gate, i.e. the number of elementary operations required to build the C n N OT gate [1] . Figure 3 : Decomposition of T gate as 5 elementary 2-qubit gates.
When implementing a reversible gate circuit on a quantum computer, four elementary quantum gates are used [1] : N gate, F gate, Controlled-V and Controlled-V + gates, where
where I is the identity. The cost of a 2-qubit gate is much larger than that of a 1-qubit gate. In this paper, the cost of N gate is ignored as in [30] to be able to compare results, and assume that the cost of any 2-qubit gate is equal to 1. The cost of a reversible circuit is measured by the number of 2-qubit gates used in its implementation as a quantum circuit, so, the quantum cost of T gate is 5 as shown in Fig.3. 
Basic Notions
In this section, the basic notions for reversible circuit, permutation group, NFT library, the relationship between reversible logic circuits and permutation group theory will be reviewed. Definition 2.2 Let X = {0, 1}. A Boolean function f with n input variables, x 1 , . . . , x n , and n output variables, y 1 , . . . , y n , is a function f : X n → X n , where (x 1 , . . . , x n ) ∈ X n is called the input vector and (y 1 , . . . , y n ) ∈ X n is called the output vector.
Definition 2.3
An n-input n-output Boolean function is reversible (n × n function) if it maps each input vector to a unique output vector, i.e. a one-to-one, onto function (bijection).
There are 2 n ! reversible n × n Boolean functions. For n = 3, there are 40,320 3-input 3-output reversible functions. Definition 2.4 An n-input n-output reversible gate (or circuit) is a gate that realizes an n × n reversible function.
Definition 2.5 A set of reversible gates that can be used to build a reversible circuit is called a gate library L. Definition 2.6 A universal reversible gate library L n is a set of reversible gates that can be used to build any reversible circuit with n-input n-output. Definition 2.7 Consider a finite set A = {1, 2, ..., N } and a bijection σ : A → A, then σ can be written as,
i.e. σ is a permutation of A. Let A be an ordered set, then the top row can be eliminated and σ can be written as,
Any reversible circuit with n-input n-output can be considered as a permutation σ and Eqn.5 is called the specification of this reversible circuit such that N = 2 n .
a. The set of all permutations on A forms a symmetric group on A under composition of mappings [16] , denoted by S N [4] . A permutation group G is a subgroup [16] of the symmetric group S N . A universal reversible gate library L n is called the generators of the group. Another important notation of a permutation is the product of disjoint cycles [4] . For example, 1, 2, 3, 4, 5, 6, 7, 8 3, 2, 5, 4, 6, 1, 8, 7 will be written as (1, 3, 5, 6)(7, 8). The identity mapping "()" is called the unit element in a permutation group. A product p * q of two permutations p and q means applying mapping p then q, which is equivalent to cascading p and q.
The one-to-one correspondence between a n×n reversible circuit and a permutation on A = {1, 2, ..., N } is established as done in [30] . In the permutation group references, A begins from one, instead of zero. Therefore, we have the following relation [30] : < X N , X N −1 , . . . , X 1 > 2 = index(X N , . . . , X 1 ) − 1. Using the integer coding, a permutation is considered as a bijective function f : {1, 2, . . . , N } → {1, 2, . . . , N }.
Cascading two generators is equivalent to multiplying two permutations. In what follows, a n × n reversible gate is not distinguished from a permutation in S N . The set of 12 gates shown in Fig. 2 and performs as shown in Eqn.3 can be re-written as product of disjoint cycles as follows, 
Schreier-Sims Algorithm
Let A be a finite set. The Symmetric group, Sym(A), is the group of all bijections from A to itself.
, and the chain of subgroups,
defined by
A strong generating set for G relative to B, denoted S, is a set S ⊆ G and for every i with 1
holds. This allows the problem of synthesizing a minimal number of gates (generators) to be reduced to a strong generating set-finding problem, that is, given a group G acting faithfully on a finite set A of size N . G is specified by means of a generating set S where each element of S is expressed as a permutation on A.
Schreier-Sims Algorithm is a poly-time algorithm [27] known in computational Group Theory that solves the strong generating set-finding problem and also go further to solve membership testing problem. Schreier-Sims Algorithm keeps computing the generating sets using cosets, by trimming down the size of the generating set at every step using a depth first search approach to keep the size of the generating set from growing too large. An implementation of Schreier-Sims Algorithm on GAP [12] has been used to find the minimal number of generators that generates a specification of a reversible circuit given that the generators of the group can represent that specification .
Given the universal gate library NFT with 12 generators as shown in Eqn.6 and the 40320 specifications for all 3-input 3-output reversible circuits. The aim of the experiment is to answer the questions shown in the aim of the paper. To answer these questions, all sub-libraries of NFT library has been generated, that is 4095 sub-libraries after excluding the identity mapping. Use every sub-library to try to synthesize a reversible circuit for the 40320 specifications, if possible, using Schreier-Sims Algorithm. The term "if possible" here means that if a specification does not belong to the group generated by a sub-library, then it is impossible for this specification to be represented as a reversible circuit using this sub-library. The process of synthesizing all possible 3-bit reversible circuits is shown in Algorithim 1. 
Specification Oriented Results
In this section, the results are organized to show a summary for the specification oriented results in Table  1 . The results related to the bounds on circuits length are shown in Tables 2, 3 , 4 and 5. Then the results related to the bounds on circuits cost are shown in Tables 6, 7, 8 and 9.   #lib  #specs  #lib  #specs  #lib  #specs  1960  29670  2263  108  2468  12  1984  216  2264  24  2496  6  2016  1746  2266  80  2525  24  2044  36  2268  12  2528  27  2080  1170  2274  12  2540  6  2085  1  2284  48  2560  27  2086  559  2287  135  2605  12  2116  540  2311  27  2624  13  2120  96  2320  210  2625  8  2122  2974  2324  24  2636  6  2128  162  2335  9  2676  12  2132  192  2348  12  2688  9  2144  78  2353  24  2689  3  2152  36  2354  12  2705  3  2176  24  2393  45  2732  6  2191  27  2412  72  2816  7  2196  96  2417  27  2880  6  2198  12  2428  24  2944  6  2217  1293  2432  11  2961  3  2218  108  2450  6  3072  3  2220  72  2455  27  3200  3  2246  12  2456  3  3264  6  2249  36  2465  3   Table 1 : There are #specs specifications that can be synthesized by #lib sub-libraries. Table 1 shows the number of sub-libraries that can be used to synthesize a circuit for a specification, for example, there are 1960 sub-libraries that can be used to synthesize a circuit for 29670 specifications. There are 6 popular specifications that can be synthesized by 3264 different sub-libraries. These 6 specifications are the specifications of F 12 , F 13 , F 23 , F 21 , F 32 and F 31 . Fig.5 shows the worst circuit representation for F 31 with 10 gates and cost = 24. This shows that any F gates can be removed from a library and be replaced by another set of generators although there might be an increase in the cost of the circuit. Table 2 shows the maximum length for the 40319 specifications, after excluding the identity. There are 3 specifications with maximum length = 7 gates and 24 specifications with maximum length = 18 gates. The average maximum length is 14.639. Table 3 shows the same results as Table 2 with more details on the cost of the maximum length, for example, there are 3 specifications with maximum length = 7 gates, the cost of two of them is 9, while the third specification has cost =11. Table 4 shows the minimum length for the 40319 specifications, after excluding the identity. There are 12 specifications with minimum length = 1 gate, these are the generators shown in Eqn.6, while there are 577 specifications with minimum length = 8 gates. These results are identical with that shown in [30] . This comes from the fact that all minimum length circuits come from using the gate library that contains all the 12 generators shown in Eqn.6. This is not true when finding a library of gates that synthesize minimum cost circuits as shown later. Table 5 shows the same results as Table 4 with more details on the cost of the minimum length circuit. Table 6 shows the maximum cost for the 40319 specifications, after excluding the identity. There is 1 specification with maximum cost = 18 and 2 specifications with maximum cost = 54. The average maximum cost is 40.759. Table 7 shows the same results as Table 2 with more details on the length of the maximum cost, for example, the length of the only specification with maximum cost = 18 is 6 gates and the length of the two specifications with maximum cost = 54 are 15 gates. Table 8 shows the minimum cost for the 40319 specifications, after excluding the identity. There are 7 specifications with minimum cost = 0, these are the cost of specifications synthesized by circuits contain the gates N 1 , N 2 and N 3 only. There are 7 such circuits starting from a circuit with only one N gate to a circuit consists of the three gates: (N 1 N 2 N 3 ). There are 2049 specifications with minimum cost = 17. The average minimum cost is 11.769. This is better that that shown in [30] , this enhancement comes from considering all sub-libraries. Table 9 shows the same results as Table 8 with more details on the length of the circuits with minimum cost.
Comparing the above results related to the bounds on circuits length with the results related to the bound on circuits cost shows that the cost and the length of a circuit using a library is not correlated if all types of generators are considered, not only the gates used to calculate the cost, e.g. T gate is counted as 1 in circuit length while it is counted 5 in circuit cost. For example, when searching for the best length circuit for the specification ((1, 7)(2, 5) (3, 6, 8, 4) 128  11  19  1  13  36  50  15  25  473  16  39  97  11  21  12  13  37  28  15  26  76  16  40  17  11  22  2  13  38  19  15  27  1364  16  41  34  11  23  14  13  39  20  15  28  3963  16  42  17  11  24  2  13  40  2  15  29  2517  16  43  16  11  26  6  13  41  4  15  30  376  16  44  31  11  27  18  13  43  2  15  31  277  16  45  22  12  14  6  14  16  7  15  32  1653  16  46  14  12  16  8  14  18  110  15  33  2718  16  47  17  12  17  2  14  19  132  15  34  1047  16  48  6  12  18  21  14  20  157  15  35  60  16  49  21  12  21  14  14  21  109  15  36  115  16  50  2  12  22  27  14  22  662  15  37  317  16  51  1  12  23  1  14  23  1735  15  38  361  16  53  2  12  24  7  14  24  1275  15  39  137  17  25  12  12  26  17  14  25  254  15  40  174  17  28  18  12  27  8  14  26  404  15  41  222  17  29  3  12  28  4  14  27  2081  15  42  219  17  32  9  12  29  8  14  28  3115  15  43  195  17  33  12  12  30  2  14  29  976  15  44  238  17  34  63  12  31  6  14  30  129  15  45  98  17  35  66  12  32  10  14  31  493  15  46  63  17  36  6  12  33  4  14  32  1389  15  47  32  17  39  45  12  34  6  14  33  702  15  48  47  17  40  9  12  38  3  14  34  46  15  49  57  18  29  3  13  15  5  14  35  86  15  50  22  18  33  6  13  16  2  14  36  137  15  51  6  18  36  6  13  17  49  14  37  263  15  53  18  18  40  9  13  18  52  14  38  126  16  20  3   Table 3 : There are #specs specifications with maximum length= M axLen and cost = cost. 7  19  226  3  0  1  4  19  2  6  10  253  7  20  101  3  1  18  5  3  75  6  11  833  7  21  28  3  2  117  5  4  375  6  12  3070  7  22  3  3  3  51  5  5  24  6  13  3933  7  23  3  3  5  24  5  6  10  6  14  759  7  24  3  3  6  162  5  7  673  6  15  913  8  9  3  3  7  138  5  8  2041  6  16  1860  8  12  9  3  9  18  5  9  516  6  17  1242  8  13  31  3  10  51  5  10  284  6  18  234  8  14  36  3  11  39  5  11  1181  6  19  142  8  15  22  3  14  5  5  12  1883  6  20  104  8  16  145  3  15  1  5  13  669  6  21  16  8  17  173  4  2  51  5  14  137  6  22  1  8  18  109  4  3  282  5  15  490  7  6  14  8  19  39  4  4  60  5  16  409  7  8  33  8  20  9  4  5  8  5  17  89  7  9  518  8  21  1   Table 5 : There are #specs specifications with minimum length= M inLen and cost = cost. #specs   18  1  31  122  43  5406  19  1  32  314  44  3484  20  1  33  549  45  1652  22  10  34  525  46  883  23  9  35  972  47  687  24  21  36  1816  48  914  25  22  37  3088  49  622  26  18  38  3035  50  96  27  41  39  3769  51  28  28  23  40  4111  52  5  29  37  41  3854  53  68  30  66  42  4067  54  2 9  15  39  14  830  47  12  22  25  8  2  33  10  18  39  15  132  47  13  168  25  9  2  33  11  54  39  16  28  47  14  275  26  7  5  33  12  193  40  10  2  47  15  204  26  8  2  33  13  173  40  11  83  47  16  18  26  9  1  33  14  51  40  12  631  48  13  147  26  10  10  33  15  43  40  13  1682  48  14  529  27  7  14  34  8  1  40  14  1437  48  15  230  27  8  2  34  9  1  40  15  261  48  16  8  27  9  5  34  10  16  40  16  15  49  13  1  27  11  18  34  11  88  41  11  58  49  14  296  27  12  2  34  12  186  41  12  378  49  15  303  28  8  8  34  13  168  41  13  1297  49  16  22  28  9  3  34  14  41  41  14  1685  50  13  1  28  10  3  34  15  24  41  15  411  50  14  10  28  11  6  35  9  2  41  16  25  50  15  83  28  12  3  35  10  8  42  11  107  50  16  2  29  7  2  35  11  127  42  12  854  51  14  9  29  8  1  35  12  370  42  13  1391  51  15  18  29  9  4  35  13  406  42  14  1305  51  16  1  29  10  7  35  14  59  42  15  393  52  14  1  29  11  6  36  10  2  42  16  17  52  15  4  29  12  17  36  11  98  43  11  87  53  14  22  30  8  2  36  12  556  43  12  1251  53  15  44  30  9  3  36  13  839  43  13  2241  53  16  2  30  10  38  36  14  292  43  14  1457  54  15  2  30  11  7  36  15  29  43  15  355  30  12  15  37  10  44  43  16  15   Table 7 : There are #specs specifications with maximum cost = M axCost and length = Len. 0  1  3  7  4  615  11  4  261  14  11  13  0  2  3  7  5  820  11  5  962  14  12  2  0  3  1  7  6  362  11  6  1366  15  3  1  1  1  6  7  7  63  11  7  801  15  4  35  1  2  24  7  8  3  11  8  248  15  5  295  1  3  18  8  4  249  11  9  18  15  6  869  2  2  24  8  5  1649  12  4  123  15  7  1111  2  3  117  8  6  1489  12  5  1090  15  8  805  2  4  51  8  7  446  12  6  2738  15  9  383  3  3  51  8  8  48  12  7  2233  15  10  63  3  4  282  8  9  6  12  8  869  16  4  8  3  5  75  9  2  3  12  9  165  16  5  154  4  4  60  9  3  18  12  10  3  16  6  873  4  5  375  9  4  45  13  5  276  16  7  1443  4  6  45  9  5  356  13  6  2244  16  8  1023  5  1  3  9  6  1794  13  7  2158  16  9  591  5  2  15  9  7  600  13  8  875  16  10  109  5  3  30  9  8  97  13  9  381  17  5  26  5  4  30  9  9  2  13  10  113  17  6  290  5  5  39  9  10  1  13  11  12  17  7  548  5  6  171  10  2  3  14  3  5  17  8  332  6  2  24  10  3  39  14  4  41  17  9  347  6  3  132  10  4  180  14  5  141  17  10  338  6  4  222  10  5  363  14  6  360  17  11  155  6  5  150  10  6  391  14  7  473  17  12  13  6  6  50  10  7  295  14  8  247  6  7  14  10  8  28  14  9  125  7  3  99  11  3  27  14  10  58   Table 9 : There are #specs specifications with minimum cost = M inCost and length = Len.
with length = 7 and quantum cost = 18, while searching for the best cost circuit for the same specification, the best cost circuit is (N 2 N 3 T 321 N 2 F 13 T 321 N 2 N 3 F 12 T 321 N 2 N 3 ) with length = 12 and cost = 17.
Library Oriented Results
In this section, the results are organized to show a summary of library oriented results in Table 10 . The results related to the bounds on circuits maximum length synthesized by the sub-libraries are shown in Tables 11, 12 and 13. Then results related to the bounds on circuits maximum cost synthesized by the sub-libraries are shown in Tables 14, 15 Table 10 : There are #Lib sub-libraries that can synthesize a circuit for #specs specifications. Table 10 shows the ability of a sub-library to synthesize a circuit for a specification. It can be seen that there are 1960 sub-libraries that can be used to synthesize a circuit of any specification, i.e. there are 1960 universal reversible sub-libraries from the main library shown in Eqn.6. It is shown in the previous section that the main library is the best library to synthesize a minimum length circuit, while choosing a sub-library to synthesize a minimal cost circuit is not a trivial task.
Max Len #lib
Max Len   #lib   1  12  10  498  2  54  11  498  3  79  12  433  4  148  13  378  5  231  14  255  6  289  15  120  7  223  16  51  8  364  17  6  9  453  18  3   Table 11 : There are #lib sub-libraries that can synthesize circuits with maximum length = M axLen. Table 11 shows the maximum length circuits synthesized by a sub-library. There are 12 sub-libraries that can synthesize a circuit with maximum length = 1. These are the sub-libraries that each of them contain a single generator from the main library shown in Eqn.6, where there are 3 sub-libraries that synthesize a circuit with maximum length = 18. These three sub-libraries are {N 3 , F 32 , F 31 , T 123 },{N 2 , F 23 , F 21 , T 132 } and {N 1 , F 12 , F 13 , T 321 }. These sub-libraries are three examples from the 1960 universal reversible sublibraries. Table 12 continued in Table 13 shows the same results as Table 11 with more details on the cost of the circuits synthesized by these sub-libraries. Table 14 shows the maximum cost circuits synthesized by a sub-library. There are 7 sub-libraries that can synthesize a circuit with maximum cost = 0. These are the sub-libraries that each of them contain a combination of N generators, where there are 2 sub-libraries that synthesize a circuit with maximum cost = 54. These two sub-libraries are {N 1 , N 9  17  40  11  17  54  4  6  12  7  11  12  9  18  49  11  18  20  4  7  17  7  12  4  9  19  37  11  19  47  4  8  7  7  13  22  9  20  20  11  20  42  4  10  12  7  14  6  9  21  41  11  21  89  4  12  11  7  15  17  9  22  14  11  22  6  4  15  4  7  16  5  9  24  13  11  23  24  4  16  2  7  17  13  9  25  9  11  24  20  4  18  1  7  18  2  9  27  3  11  25  21  5  2  11  7  19  27  9  28  7  11  26  18  5  3  43  7  20  4  9  29  19  11  27  39  5  4  39  7  22  4  9  30  2  11  28  22  5  6  4  7  25  4  9  31  8  11  29  20  5  7  5  7  26  3  9  32  4  11  30  11  5  8  18  7  27  4  9  33  2  11  31  5  5  9  10  8  6  32  9  34  4  11  32  3  5  10  34  8  7  10  10  7  7  11  33  3  5  11  23  8  8  5  10  8  14  11  34  1  5  12  19  8  10  59  10  12  17  11  35  1  5  13  5  8  11  2  10  13  3  11  37  1  5  15  12  8  12  5  10  14  4  12  13  1  5  16  6  8  13  25  10  15  20  12  14  5  5  19  1  8  14  9  10  16  30  12  16  2  5  20  1  8  15  28  10  17  18  12  17  4  6  3  11  8  16  24  10  18  36  12  18  11  6  4  76  8  17  15  10  19  83  12  19  3  6  6  7  8  18  45  10  20  78  12  20  12   Table 12 : There are #lib sub-libraries that can synthesize circuits with maximum length = M axLen and cost = cost. 12  21  52  13  27  17  14  28  27  15  36  3  12  22  30  13  28  1  14  29  3  15  38  1  12  23  17  13  29  11  14  30  3  15  39  2  12  24  52  13  30  22  14  31  2  15  41  4  12  25  44  13  31  10  14  32  9  15  42  5  12  26  42  13  32  8  14  34  8  15  43  2  12  27  14  13  33  10  14  35  9  15  44  4  12  28  23  13  34  16  14  36  11  15 2  13  20  8  14  21  2  15  29  10  16  47  3  13  21  15  14  22  1  15  30  1  16  48  1  13  22  17  14  23  21  15  31  9  16  49  2  13  23  36  14  24  48  15  32  16  17  25  2  13  24  10  14  25  15  15  33  9  17  35  4  13  25  55  14  26  8  15  34  1  18  33  1  13  26  19  14  27  21  15  35  1  18 36 2 38  12  13  40  14  3  43  13  9  47  14  5  38  13  4  40  18  3  43  14  4  48  13  1  38  14  3  41  11  2  44  11  1  49  14  3  38  15  14  41  12  12  44  13  10  50  13  1  38  16  3  41  13  13  44  14  1  50  15  3  39  10  1  41  14  6  44  15  2  51  14  2  39  11  15  42  11  19  45  13  4  51  15  1  39  12  27  42  12  18  45  14  3  52  15  1  39  13  13  42  13  10  46  12  1  53  15  2  40  10  6  42  14  2  46  14  2  54  15  2  40  11  9  42  15  2  46  15  2  40  12  14  43  11  6  47  12  2  40 13 2 43 12 6 47 13 3 Table 16 : Table 15 cont.: There are #lib libraries that can synthesize circuits with maximum cost = M axcost and length = Len.
two examples from the 1960 universal reversible sub-libraries. Table 15 continued in Table 16 shows the same results as Table 14 with more details on the cost of the circuits synthesized by these sub-libraries.
The above results show that there are 1960 sub-libraries, each can be used as a universal reversible gate library:
1. The sub-library that synthesize the best maximum length circuits is the main library, Non of the 1960 universal reversible gate libraries can synthesize a circuit with the best maximum cost which is 17 as shown in Table 8 . This best maximum cost comes from sub-libraries that are not universal, for example, the sub-library, is not universal since it can syntheise circuits for 1151 specifications only, where its best maximum cost = 17 with circuit length =7 and the maximum length = 7 gates with cost = 8.
Conclusion
By reducing the representation of the reversible circuit synthesis problem to permutation group, SchreierSims Algorithm for the strong generating set-finding problem is used to put tight bounds on the synthesis of 3-bit reversible circuits using the NFT library. Using group-theory algebraic software GAP shows that, 1. The minimum length of a circuit ranges from 1 to 8 gate(s) with average length = 5.865.
2. The maximum length of a circuit ranges from 7 to 18 gates with average length = 14.639.
3. The minimum cost of a reversible circuit ranges from 1 to 17 with average cost = 11.769.
4.
The maximum cost of a reversible circuit ranges from 18 to 54 with average cost = 40.759.
The analysis shows that there 1960 universal reversible sub-libraries from the NFT library. The upper and lower bounds on the length of the circuits come from using the universal reversible sub-libraries while the upper bound on the cost of the circuits comes from using the universal reversible sub-libraries, while the lower bounds on the cost of the circuits comes from other sub-libraries which are not necessary universal.
The same sort of analysis is applied to other libraries such as NFP, NFFr, NFPT, NFTFr and NFPFr. The tight bounds for these libraries are under preparation.
