Sequential Quantum Gate Decomposer  v1.9.3
Powerful decomposition of general unitarias into one- and two-qubit gates gates
CNOT.h
Go to the documentation of this file.
1 /*
2 Created on Fri Jun 26 14:13:26 2020
3 Copyright 2020 Peter Rakyta, Ph.D.
4 
5 Licensed under the Apache License, Version 2.0 (the "License");
6 you may not use this file except in compliance with the License.
7 You may obtain a copy of the License at
8 
9  http://www.apache.org/licenses/LICENSE-2.0
10 
11 Unless required by applicable law or agreed to in writing, software
12 distributed under the License is distributed on an "AS IS" BASIS,
13 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 See the License for the specific language governing permissions and
15 limitations under the License.
16 
17 @author: Peter Rakyta, Ph.D.
18 */
23 #ifndef CNOT_H
24 #define CNOT_H
25 
26 #include "matrix.h"
27 #include "Gate.h"
28 #define _USE_MATH_DEFINES
29 #include <math.h>
30 
31 
35 class CNOT: public Gate {
36 
37 protected:
38 
39 
40 public:
41 
45 CNOT();
46 
47 
54 CNOT(int qbit_num_in, int target_qbit_in, int control_qbit_in);
55 
59 virtual ~CNOT();
60 
67 
73 Matrix get_matrix(int parallel);
74 
80 virtual void apply_to( Matrix& input, int parallel );
81 
82 
87 virtual void apply_from_right( Matrix& input );
88 
89 
94 virtual void set_qbit_num(int qbit_num);
95 
100 virtual void reorder_qubits( std::vector<int> qbit_list);
101 
102 
109 
114 virtual CNOT* clone();
115 
116 };
117 
118 #endif //CNOT
Matrix calc_one_qubit_u3()
Set static values for matrix of the gates.
Definition: CNOT.cpp:211
Header file for a class for the representation of general gate operations.
virtual void apply_to(Matrix &input, int parallel)
Call to apply the gate on the input array/matrix by CNOT*input.
Definition: CNOT.cpp:149
virtual void reorder_qubits(std::vector< int > qbit_list)
Call to reorder the qubits in the matrix of the operation.
Definition: CNOT.cpp:200
Header file of complex array storage array with automatic and thread safe reference counting...
virtual void apply_from_right(Matrix &input)
Call to apply the gate on the input array/matrix by input*CNOT.
Definition: CNOT.cpp:172
virtual CNOT * clone()
Call to create a clone of the present class.
Definition: CNOT.cpp:225
A class representing a CNOT operation.
Definition: CNOT.h:35
virtual void set_qbit_num(int qbit_num)
Call to set the number of qubits spanning the matrix of the operation.
Definition: CNOT.cpp:188
CNOT()
Nullary constructor of the class.
Definition: CNOT.cpp:32
Class to store data of complex arrays and its properties.
Definition: matrix.h:38
Base class for the representation of general gate operations.
Definition: Gate.h:73
virtual ~CNOT()
Destructor of the class.
Definition: CNOT.cpp:110
Matrix get_matrix()
Call to retrieve the operation matrix.
Definition: CNOT.cpp:118
int qbit_num
number of qubits spanning the matrix of the operation
Definition: Gate.h:81