Test pattern generation is an electronic design automation tool that attempts to find an input (or test) sequence that, when applied to a digital circuit, enables one to distinguish between the correct circuit behavior and the faulty behavior caused by particular faults. The effectiveness of this classical method is measured by the fault coverage achieved for the fault model and the number of generated vectors, which should be directly proportional to test application time. This work address the quantum process validation problem by considering the quantum mechanical adaptation of test pattern generation methods used to test classical circuits. We found that quantum mechanics allows one to execute multiple test vectors concurrently, making each gate realized in the process act on a complete set of characteristic states in space/time complexity that breaks classical testability lower bounds.
Introduction
Classically, both the fault models considered and the test inputs are localized (not entangled). Form this fact and other reasons, it is not immediately apparent how methods developed in classical test theory could be put to use when testing quantum mechanical switching networks. Here ones views a quantum circuit as being a description of the actions on, and the interactions between qubits. To avoid brute force testing, a method to test these time dependent connections as well as the logical operation of each gate realized in a process is presented. This is done by considering a logical set of failure models designed to drive a switching network to it's bounds of operation and assure main aspects of individual gate functionality.
It is theoretically interesting to combine classical test theory with quantum effects such as entanglement. For instance, quantum states can be designed to execute multiple test vectors concurrently. In addition quantum systems are reversible and any reversible system preserves information. This means that a reversible system preserves the probability that additional information may be present [9] . The additional information present could be used to detect the presence of a fault. In a faulty reversible circuit, the probability of detection for quantum fault f observable withÂ is solely related to the probability of f 's presence (see § 2). For instance, one may develop a test set, consisting of input vectors and corresponding observables, that separates a circuit from all considered faults. Based on the information conservative properties of reversible systems [9] , this test set can be applied multiple times to detect the probabilistic version of the considered faults.
We consider extending methods developed to test classical circuits, and so present tests designed to separate an oracle from one containing a given set of considered faults [7] . Classically, the testability of the circuit class comprising the oracle has already received much attention after the 1972 paper by Sudhakar M. Reddy [2] . This paper presents a quantum mechanical generalization of this and several other classical methods [1, 2, 10] .
Structure of the paper: Sec. 1.1 gives an introduction to oracle construction. Sec. 2 discusses the quantum fault models used in this study. The Quantum Test Algorithm is presented in Sec. 3 followed by the conclusion in Sec. 4. 
Constructing Quantum Oracle Search Spaces
Any Boolean equation may be uniquely expanded to the Positive Polarity Reed-Muller Form (PPRM) [2] as:
f (x 1 , x 2 , ..., x k ) = c 0 ⊕ c 1 x 
where selection variable σ i ∈ {0, 1}, literal x σi i represents a variable or its negation and any c term labeled c 0 through c j is a binary constant 0 or 1.
Example:
Each term in the expansion of Eqn. 2 is called a product term [8] , and each variable x i a literal. For example, x 3 · x 4 is a product term, with literals x 3 and x 4 (constant 1 is not considered to be a product term). Each product term for a given PPRM expansion is realized by an arbitrary quantum controlled-NOT gate (k−CN) given in Fig. 1 . Repeating this procedure for each product term in Eqn. 2 and sequencing the gates leads to the network realization given in Fig. 2 . Above each gate is the label p i , p refers to a product term in the expansion of Eqn. 2, and i the index used to label the seven products. This example will be used again so it is stated explicitly that p 0 corresponds to x 1 , p 1 to x 2 , p 3 to x 3 , p 3 to x 3 x 4 , p 4 to x 1 x 3 x 4 , p 5 to x 1 x 2 x 3 and finally p 6 to x 2 x 3 x 4 .
In many quantum algorithms, after Boolean function f is constructed by means of a k−CN network it is placed in a black box oracle (O). The bottom (k + 1) th bit contains the realization of f to be read at the box's right. The top k inputs to the box begin in state |0 and the (k + 1) th input (target) qubit starts in state |1 . The Hadamard operation H ⊗(k+1) is applied placing the input query in a superposition of all 2 (k+1) classical states. Generally the black box takes as input:
Inside the black box all of the targets act on state |− (an eigenvector of the k−CN gate) and the top k qubits remain in a superposition. The true minterms are inputs that make a Boolean function evaluate to 1 where false minterms evaluate to 0. Each term in the superposition on the top k bits representing a true minterm in the switching function f realized in the oracle will be appended with a negative (relative) phase. The phase of states that do not represent true minterms are left invariant. This is seen by examining the truth table from Fig. 3 . The action of an oracle O, 1 realizing a binary function f (x 1 , x 2 , ..., x k ), is represented by the transform:
Gate Level Quantum Fault Models
Consider the single stage circuit shown in Fig. 4 . The numbered locations of possible gate external faults are illustrated by placing an "×" on the line representing a qubits time traversal and here, the gate, initial states (|i 0 , |i 1 , |i 2 ) and measurements (m 0 , m 1 , m 2 ) may also contain errors.
Definition 1 Error/Fault Location: The wire locations between stages as well as any node, gate initial state or measurement in a given network (see Fig. 4 ).
p0 p1 p2 p3 p4 p5 p6 x1
Figure 2: Quantum Network Realization of Eqn. 2 built from arbitrary k-CN gates as shown in Fig. 1 . The truth table of this oracle is given in Fig. 3 .
Figure 3: Oracle Truth Table for Eqn. 2 implemented by the network in Fig. 2 : Boolean function f is implemented quantum mechanically. Each of the 2 k terms in a superposition input that evaluate to logic-one will be marked with a negative phase (also shown in Eqn. 12, in Sec. 3).
Definition 2 Quantum Single Fault Model: For simplification the "quantum single fault model" is assumed in this work. In the single fault model, test plans are optimized for all considered faults assuming that only a single failure perturbs the quantum circuit exclusively. Multiple faults will accumulate and be detected, but the single fault model makes it much easier to develop test plans.
Conjecture 1 A test set designed to detect all considered single errors will detect and sample the accumulated impact of multiple errors at multiple locations.
The following definitions are used to define some of the fault types considered in this work. Complete fault coverage occurs after a test set has determined that the considered fault(s) are not present in a given circuit.
Definition 3 Pauli Fault Model: The addition of an unwanted Pauli matrix in a quantum network, at any error location and with placement probability p. The Pauli matrices are given in Eqn. 5, 6 and 7.
Definition 4 Initialization Error: A qubit that statistically favors correct preparation in one basis state over the other.
Definition 5 Measurement Fault Model: A single functional measurement gate is replaced with a faulty measurement gate that statistically favors returning logic-zero or a logic-one. 
Conclusions based on the Gate Level Fault Models
In practice, the choice of the fault model will be determined by a particular quantum circuit technology, as well as how the circuit will be used. In this work the functional use of k−CN networks are oracle search spaces. In this setting, any k−CN gate exhibits twelve, functionally distinct actions.
Theorem 1 A quantum k−CN gate is capable of four characteristic classical operations. (By characteristic it is meant that all other operations are variants of this basic set.)
Proof 1
The gate is able to act on a |0 and a |1 state when all controls are set. The two remaining functions are simply to act on |0 and |1 when one or more control(s) is addressed with a non-activating state. There are 2 k −1 input states that do not activate the gate, but these inputs all probe the off function. Similarly, each control has two logical functions. The first is to be addressed with a logical |0 and the second is to be addressed with a |1 . Provided the state of the top k bits is some equal superposition and the target of the gate acts on a state with the following form: |0 + e ±iϕ |1 . Under this condition, the inputs to a k−CN gate are expressed as:
where w x = e ±iφ . Similarly, as in the case of Theorem 1, certain operations define the gate's function. The arbitrary quantum superposition state defined in Eqn. 8 allows one to consider each input as a separate state. In the column denoted minterm from Fig. 6 , |true minterms activate the gate while |f alse terms do not. Under this consideration the following holds:
Theorem 2 A k−CN gate is capable of eight characteristic quantum operations. (We consider quantum operations as those that manipulate quantum phase and non-classical superposition states; characteristic has the same meaning as in Theorem 1.)
Proof 2 The proof is constructive:
Case 1: When activated, quantum gates exhibit phase kickback when the state of the target is |0 + e −iϕ |1 . The activating state can have a phase of +w x or −w x . Furthermore, a non-activating state can have a phase of +w x or −w x and of course, nothing should happen when acted on by the k−CN gate.
Case 2: (The opposite of Case 1.) The alternative case is that the target acts on state |0 + e +iϕ |1 . As before, the activating and non-activating states can have phases of +w x or −w x . Nothing should happen under the case of both an activating and a non-activating state. This functionality is probed in four additional tests.
We draw the readers attention now to the table in Fig. 6 for the illustration of Case 1 and Case 2. Variables φ and ϕ are set to create states that are operated on by the k−CN gate, these are the combinations of actions considered. The Proof is concluded by mentioning that, all the quantum functions of the k−CN gate represent one variant of these eight cases when used in a phase oracle.
Thus according to Theorems 1 and 2 in total we need 4 + 8 = 12 non-entangled tests to identify the function of any k−CN gate.
The Fault Detection Algorithm
Tests T 1 , T 2 , T 5 and T 6 verify all classical degrees of freedom. Tests T 3 and T 4 verify the phase kickback features of the oracle. As a proof of concept the introduced method holds the test set size to constant six, increasing the complexity of added stages for tests T 3 and T 4 . This approach helps better tie classical ideas with quantum test set generation. This is due to the fact that classically, circuits realizing linear functions are easy to test due to their high level of controllability.
Definition 6 Quantum Build In Self Test Circuit ( QBIST):
A quantum circuit designed to test a second quantum circuit; the quantum circuit under test ( QCUT). A QBIST circuit may be built at the input and/or output terminals of the QCUT, and the QBIST stage is always assumed to contain no errors.
Consider the example circuit presented in Fig. 2 . The analysis given in the coming subsections begins by generating an input state that turns all the gates in the network on and off concurrently. Denote these tests as T 1 and T 2 , and their general form on a k variable function follows:
The classical equivalent of tests T 1 and T 2 was given in Fig. 5 (where T 1 corresponded to vectors v 0 and v 2 , and T 2 corresponded to both v 1 and v 3 ). Together tests T 1 and T 2 will be shown to satisfy Requirements 1, 3, 6, 7 and 8 in Sec. 3.1 and 3.2. Sec. 3.3 considers tests T 5 and T 6 . These tests are shown to satisfy Requirement 5 by using the following states as oracle inputs: |+ ⊗k ⊗ |+ and |− ⊗k ⊗ |+ . In both tests, the state at the controls will not impact the state at the target, leaving all qubits-ideally-unchanged (since no net entanglement is generated).
Sec. 3.4 and 3.5 investigate the ability of the network to both attach a relative phase to each activating term in the superposition and to leave non-activating states unaltered. This in general is a complex procedure, that in the first case can be done in two tests denoted as T 3 and T 4 . Test T 3 utilizes state |+ ⊗k ⊗ |− and test T 4 utilizes state |− ⊗k ⊗ |− as input to the oracle. However, additional "designfor-test" stages must be added to the end of the circuit, thereby leading to a deterministic measurement. Tests T 3 and T 4 are shown to satisfy Requirement 4.
Test
In test T 1 , all qubits are initialized as: |0000 ⊗ |0 . The action of the first QBIST 11 stage (from Fig. 8 ) creates the following oracle input state:
The left half of the entangled test sequence is |0000 ⊗ |0 . It is clear that for a "gold circuit " not one gate turns on, and the target qubit will be left untouched. For the right half of the entangled test vector, each gate in the circuit turns on, and this cycles the (k + 1) th qubit initially starting in |0 back and forth between basis states. The state of the last qubit after the oracle is |0 . 2 The purpose of QBIST 12 is simply to remove the phase induced entanglement experienced on the top k qubits. The intermittent states at each stage of the circuit under test T 1 are shown in Fig. 7 . The final step in the QBIST 12 circuit applies a Hadamard gate to the top qubit, resulting back in the starting state, |0000 ⊗ |0 , thereby completing test T 1 . The complexity of the added CN and H gates needed for test T 1 is 2(k − 1)CN+2H. 2 If an an even number of gates were present a slight modification to the final half of the QBIST 12 circuit must be made. This modification is the removal of the first CN gate at the start of the QBIST 12 acting on the (k + 1) th qubit and controlled by the k th qubit. In general for an odd number of gates in a quantum network prior to the final QBIST 12 stage the circuit will be in state |0 ⊗k |0 ± |1 ⊗k |1 . The addition of a CN k,k+1 gate removes unwanted entanglement so that the final qubit will be left in a product state.
QBIST11
Circuit Under Test QBIST12 Figure 8 : Tests T 1 and T 2 (GHZ states): In Test T 1 , a = 0 so the circuit starts off in state: |0000 . QBIST 11 maps this state to the oracle's input as: (|0000 + |1111 ) ⊗ |0 . In Test T 2 , a = 1 and the input to the oracle is: (|0000 − |1111 ) ⊗ |1 . QBIST 12 removes entanglement and returns the system to a product state.
Test
No physical change is made to the circuit from Fig. 8 , however the qubits are now initialized to state |1111 ⊗ |1 . The outcome is similar to test T 1 , the bottom qubit is toggled a total of seven times resulting in the final state of |1 . (Each gate that acted on |0 in test T 1 now acts on |1 thereby exhaustively probing every classical input combination of each k−CN gate, seen in Fig. 8 .) The QBIST 12 again disentangles the test responses, resulting back in the initial state of |1111 ⊗ |1 . In tests T 1 and T 2 each node is addressed with both activating and non-activating states. Furthermore, each qubit is initialized and measured in both basis states. Tests T 1 and T 2 have an added CN and H gate complexity of 4(k − 1)CN+4H. The following Theorems prove which faults have been detected with tests T 1 and tests T 2 and are general for n bit oracles:
Theorem 3 Either test T 1 or test T 2 will detect σ x and σ y bit flips at any error location, thus satisfying Requirement 1.
Proof 3 Tests T 1 and T 2 both satisfy Requirement 1. The proof in this section is given for test T 1 and is nearly identical to the steps taken for test T 2 . Consider now test T 1 :
Case 1: The top (1 st ) qubit is flipped: QBIST 12 receives state (|1 |0 ⊗(k−1) ± |0 |1 ⊗(k−1) ) as input. After successive applications of CN i−1,i from i = k to i = 2 the state will be (|11 |0
. Thus, a bit flip impacting the 1 st bit is detectable on the 2 nd bit. Given a bit flip impacting any other qubit q, th bit. This is detectable based on p, the probability that a bit flip occurred in the computational basis in the first place, satisfying Requirement 1. This is the only fault that, when deterministically present interjects a probabilistic outcome in observability.
Theorem 4 Together tests T 1 and T 2 initialize each qubit in both basis states so that Requirement 3 is satisfied.
Proof 4 In test T 1 the initial state of the register is |0
⊗k ⊗|0 and in test T 2 the initial state is |1 ⊗k ⊗|1 , therefore Requirement 3 is satisfied.
Theorem 5 Taken together tests T 1 and T 2 activate all controls concurrently and each control is addressed with a non-activating state while the target is separately in basis state |0 and next |1 satisfying Requirement 6. Proof 8 In both tests T 5 and T 6 the state of the target qubit is |+ . Any gate that was activated by a state with an eigenvalue +1 in test T 5 will be activated by a state with an eigenvalue −1 in test T 6 . Relative phase will not change under arbitrary non-activating and activating states since the target state has an eigenvalue of +1, satisfying Requirement 5.
Theorem 9 Either one of tests T 5 or T 6 detects σ z or σ y phase flips and therefore satisfies Requirement 2.
Proof 9
Here the Proof is done considering test T 5 , however the steps are the same as those needed for test T 6 . Consider state |+ ⊗k ⊗ |+ , this is a product state that may be expanded as: |+ ⊗ · · · ⊗ |+ ⊗ |+ ⊗ |+ ⊗ · · · ⊗ |+ . The state of the target is |+ and therefore phase will not make the state non-local (with an exception of a phase flip on the (k + 1) th bit, in that case the bottom bit will deterministically reveal the presence of an error). Given a σ z fault impacting any qubit, the state becomes |+ ⊗ · · · ⊗ |+ ⊗ |− ⊗ |+ ⊗ · · · ⊗ |+ . In the final stage of QBIST 52 a Hadamard operation H ⊗(k+1) is applied to the register:
Since the σ z bit flip impacts the global state of a qubit, it will be seen as a bit flip in the measured state of T 5 satisfying Requirement 2. The proof is concluded mentioning that this result coincides with observations drawn in [7] , (Theorem 2, § 4).
Any σx or σy bit flips occurring?
Any σz phase flips occurring?
Is initialization into |0 and |1 O.K.?
With |− at target is phase kickback O.K.?
Any phase problems with |+ at the target?
Are the controls activated with |0 and |1 ?
Gate acts on basis |0 and |1 O.K.?
Is measurement in |0 and |1 O.K.? The controllability of a circuit represents an ability to propagate a specific input vector through a network, such that it will map a state to a specific fault location. This represents an added challenge in the case of quantum circuits, since inputs will become entangled. However, after a discussion of the upper bounds of tests T 3 and T 4 in Sec. 3.6 more controllable test input vectors are proposed (Sec. 3.7) replacing the added complexity of these tests with a linear increase in the number of experiments needed.
Test
The goal of test T 3 is to verify that phase traverses correctly amongst all gates. For test T 3 the Hadamard gates at the left of Fig. 10 are used to prepare the following superposition state input on the top k bits:
Observe that Eqn. 12 is like a truth table where all the true minterms of the function have phase factors of −1, (see Fig. 3 ). This often results in phase induced entanglement as shown in Eqn. 12.
=⇒ |0000 + |0001 − |0010 + |0011 − |0100 − |0101
In general, a product (local ) superposition state may be written as:
where any a i term is either +1 or −1. For the state in Eqn. 12 to be expressible as a product state, Eqn. 14 must be satisfied:
Given Eqn. 14, any one of 2 i (0 ≤ i < k) possible choices for a i results in a local description of the quantum state (the implications of which will be discussed in Sec. 3.6). The general expansion of Eqn. 14 leads directly to the generic state:
Comparing Eqns. 12 and 15 for the considered circuit, the system of arithmetic equations given in Eqn. 16 is obtained. This system is clearly not specifying a product state since Eqns. 12 and 15 matched with Eqn. 16 are inconsistent. The interfering terms a 0 · a 1 · a 2 and a 2 · a 3 could be changed for the system to return to a local, product state description. This may be done by inserting the QBIST 32 circuit given in Fig. 10 . QBIST 32 inverts the phase on terms |1110 and |0011 to +1, making the state factorable as Figure 10 : Circuit Under Test T 3 and T 4 : Test T 3 −→ |+ ⊗k ⊗ |− is first generated (a = 0, T 3 ) and next
. Nodes activated with |0 are denoted as (•). QBIST 32 removes entanglement returning the system to a product state and has the same form in both tests.
is an exact dual to test T 3 and therefore, the needed QBIST 42 stage will have the exact same structure as the QBIST 32 already used. Now the register is initialized into state |1111 ⊗ |1 (by setting a = 1 in Fig. 10 ). The Hadamard operators map this initial state as follows:
and this acts as input to the oracle. The phase of each term is now opposite when compared with T 3 . QBIST 42 inverts the phase on term |1110 and |0011 to −1, making the state factorable and resulting in this local state description (|0 − |1 )(|0 − |1 )(|0 − |1 )(|0 + |1 ) ⊗ |− . Theorem 10 proves that test T 3 combined with test T 4 satisfy Requirement 4. Tests T 3 and T 4 have a worst case added gate complexity of at most Θ(N − k) + 4kH, where Θ is a function of the number of controls needed in the disentanglement stage and the linearity of the oracle. Proof 10 In tests T 3 and T 4 the state of the target is |− . Any gate that was activated by a state with eigenvalues ±1 during test T 3 is activated by a state with eigenvalues ∓1 in test T 4 . Furthermore, both tests T 3 and T 4 contain non-activating terms, each with opposite eigenvalues. Tests T 3 and T 4 therefore satisfy Requirement 4. Table 1 provides a concise illustration of the sets of faults entirely covered by given test(s) (denoted by ×) as well as the sets of faults partially covered by a given test (denoted by •). We have developed a quantum test algorithm that probes the logical function of each k−CN gate in an oracle. Now upper bounds on the extraction technique (QBIST 32 circuit stage) will be derived in Sec. 3.6.
Upper Bounds for QBIST 32 :
The concepts of the presented test algorithm are general and therefore work for any circuit. They do however require the successful design of the QBIST 32 . This design varies between oracles and has an upper bound of added depth complexity that depends on the function realized in the oracle. A f (x 1 , . .., x k ) , on variables x 1 , ..., x k is any function the takes the form
Definition 7 An affine Boolean function
where · is Boolean AND, ⊕ is EXOR (modulo 2 addition), c i ∈ {0, 1} and i = 0, 1, ..., n are indices of coefficients. It is easy to see that there exist 2 k+1 affine functions all of which have checkered cube patterns. A linear function is any one of the 2 k affine functions generated when coefficient c 0 = 0.
We present the following theorem (11) relating state separability to the function being realized by a given oracle.
Theorem 11 Consider oracle O for which test T 3 obtains only separable (local) measurements (requires no disentanglement). O necessarily realizes only affine functions over k variables.
Proof 11
The proof is based on the straightforward generalization of the following example:
Assume input variables (x 1 , x 2 , x 3 ). The expression
corresponds to a classical truth table with a i expressions corresponding to sum-of-product canonical coefficients. Assuming the encoding 
where b i are coefficients of minterms, i.e. b 0 is a coefficient of |000 , b 1 is a coefficient of |001 , etc. The minterms of canonical SOP obtain thus the following encoding (symbol · is arithmetic multiplication)
Applying now the encoding from Eqn. 20 and substituting into the above PPRM one obtains PPRM =
which corresponds to all affine functions on variables x 1 , x 2 , x 3 .
If oracle O contains function f (x 1 , ..., x k ) that is not affine, a modification to any one of the affine functions A i (x 1 , ..., x k ) must be made. This can be done by adding a circuit (such as QBIST 32 (x 1 , ..., x k )) and can be thought of as EXORing it with some function, like this:
Thus, f (x 1 , ...,
The general disentanglement procedure is as follows:
2. BIST i (x 1 , ..., x k ) with the minimum cost is selected.
3. Function BIST i (x 1 , ..., x k ) is added (XORed) after f as QBIST 32 .
Theorem 12
The minimum number of product terms in the ESOP realization of the BIST circuit
where A i is an arbitrary affine function on variables x 1 , ..., x k is equal to p − k where p is the minimal number of product terms in ESOP( BIST(x 1 , ..., x k )).
Proof 12
Given is the minimal ESOP, denoted by ESOP(BIST), of function BIST (x 1 , ..., x k ). Let A be an arbitrary affine function on variables x 1 , x 2 , ..., x k and c 0 ⊕ c 1 · x 1 ⊕ ...c k · x k , where c i ∈ {0, 1}. There are two of these functions that have the maximum number of variables equaling k;
Assuming that ESOP(BIST) has the minimal number of product terms, the following cube pair types must not be included in it:
The only product terms possible in ESOP(BIST) are necessarily
. . x k provided all the best merging cases, then all variables (literals) from A are merged, each of them with some literal from ESOP(BIST), like this: x i ⊕ x i = 0,x i ⊕x i = 0 and x i ⊕x i . Each of these cases will decrease the ESOP cost by one. Merging x i with x i · x j = x i ; x i ⊕ x i · x j = x i ·x j will not change the ESOP cost. All other mergings will increase the cost of the ESOP( BIST⊕A i ) with respect to ESOP(BIST). Thus, the number of terms in the ESOP can be decreased by no more than k. Observe also that the highest decrease of cost is when BIST is already an affine function.
Possible Extensions and Applications
An alternative approach based on the theory outlined in tests T 3 and T 4 utilizes highly controllable test vectors. The growth in additional circuitry is thus replaced with linear growth in the number of experiments needed. The total number of experiments in this second method is (5 + 4⌈k/2⌉). There is little added growth in circuit complexity. Tests T 3 and T 4 are replaced with first repeating the circuitry needed in test T 1 . (All replaced tests of course have state |− at the target.) Next, starting with the top 2 qubits (Fig. 11) , an EPR pair is generated to test the oracle and mirrored with a measurement in the Bell basis. This is then moved down all the top k qubits (Fig. 12 ) a total of 2⌈k/2⌉ times. The EPR generating circuitry is used to create inputs that are products of state |01 ± |10 and |1 . These must be repeated with both positive and negative versions to satisfy Requirement 4. This results in something in classical test known as walking-a-zero [8] (except quantum mechanics allows two zeros to be walked at the same time). This alternative approach however, does not probe the oracle under the types of inputs experienced when used in a Grover search algorithm. It does however illustrate that the algorithm can be modified to reduce the complexity of the stages needed to extract information. Alternative applications of the methods presented in this paper also exist. 
Conclusion
This work reduced the classical test problem by utilizing entanglement as a controllability resource. Classically, the lower bound of this circuit class was found to be (k + 4 + 2n e ) by Reddy [2] (where the 2n e term depends on the function being realized). Quantum effects were used to reduce the test problem to a linear growth of (5 + 4⌈k/2⌉) in experiment count. When testing an oracle, states become non-local due to the phase change undergone by all true minterms as seen in tests T 3 and T 4 in Sec 3.4 and 3.5. It was shown in Sec. 3.6 that all affine oracles generate no net entanglement when used as a search oracle, while an oracle realizing a bent function requires the greatest effort to disentangle the state and return the system to a local product state. Since there are 2 k+1 affine functions, Sec. 3.6 addressed the question of how close an arbitrary state is to a factorable state with phase terms that represent the spectrum of an affine function. The distance in many cases is close, but the upper bound is ∼ Θ(N − k). Linear and Affine functions are very easy to test when realized quantum mechanically. Based on the potential limitations highly controllable test vectors were developed in Sec. 3.7 that do not undergo phase induced entanglement when propagation though a phase oracle occurs. In a correspondence from Agrawal in 1981 [12] , fault detection probability was shown to be the highest when the information output of a circuit is maximized. An information theoretic approach to quantum fault testing might lead to further useful insight into the quantum test problem.
