17#ifndef _CIRCUIT_FACTORY_H_
18#define _CIRCUIT_FACTORY_H_
37template <
typename Time = Types::time_type>
50 return std::make_shared<Circuit<Time>>(ops);
67 const std::vector<bool> &resetTgts = {}) {
68 return std::make_shared<Reset<Time>>(qubits, 0, resetTgts);
82 const std::vector<size_t> &bits = {},
size_t seed = 0) {
83 return std::make_shared<Random<Time>>(bits, seed);
97 const std::vector<std::pair<Types::qubit_t, size_t>> &qs = {}) {
98 return std::make_shared<MeasurementOperation<Time>>(qs);
125 double param1 = 0,
double param2 = 0,
double param3 = 0,
132 std::shared_ptr<IQuantumGate<Time>> gate;
137 gate = std::make_shared<PhaseGate<Time>>(q1, param1);
140 gate = std::make_shared<XGate<Time>>(q1);
143 gate = std::make_shared<YGate<Time>>(q1);
146 gate = std::make_shared<ZGate<Time>>(q1);
149 gate = std::make_shared<HadamardGate<Time>>(q1);
152 gate = std::make_shared<SGate<Time>>(q1);
155 gate = std::make_shared<SdgGate<Time>>(q1);
158 gate = std::make_shared<TGate<Time>>(q1);
161 gate = std::make_shared<TdgGate<Time>>(q1);
164 gate = std::make_shared<SxGate<Time>>(q1);
167 gate = std::make_shared<SxDagGate<Time>>(q1);
170 gate = std::make_shared<KGate<Time>>(q1);
173 gate = std::make_shared<RxGate<Time>>(q1, param1);
176 gate = std::make_shared<RyGate<Time>>(q1, param1);
179 gate = std::make_shared<RzGate<Time>>(q1, param1);
183 std::make_shared<UGate<Time>>(q1, param1, param2, param3, param4);
187 gate = std::make_shared<SwapGate<Time>>(q1, q2);
190 gate = std::make_shared<CXGate<Time>>(q1, q2);
193 gate = std::make_shared<CYGate<Time>>(q1, q2);
196 gate = std::make_shared<CZGate<Time>>(q1, q2);
199 gate = std::make_shared<CPGate<Time>>(q1, q2, param1);
202 gate = std::make_shared<CRxGate<Time>>(q1, q2, param1);
205 gate = std::make_shared<CRyGate<Time>>(q1, q2, param1);
208 gate = std::make_shared<CRzGate<Time>>(q1, q2, param1);
211 gate = std::make_shared<CHGate<Time>>(q1, q2);
214 gate = std::make_shared<CSxGate<Time>>(q1, q2);
217 gate = std::make_shared<CSxDagGate<Time>>(q1, q2);
220 gate = std::make_shared<CUGate<Time>>(q1, q2, param1, param2, param3,
225 gate = std::make_shared<CSwapGate<Time>>(q1, q2, q3);
228 gate = std::make_shared<CCXGate<Time>>(q1, q2, q3);
251 const std::vector<double> ¶ms = {}) {
252 return CreateGate(type, qubits.empty() ? 0 : qubits[0],
253 (qubits.size() < 2) ? 0 : qubits[1],
254 (qubits.size() < 3) ? 0 : qubits[2],
255 params.empty() ? 0. : params[0],
256 (params.size() < 2) ? 0. : params[1],
257 (params.size() < 3) ? 0. : params[2],
258 (params.size() < 4) ? 0. : params[3]);
276 const std::vector<size_t> &ind,
const std::vector<bool> &b) {
277 return std::make_shared<EqualCondition>(ind, b);
297 const std::shared_ptr<ICondition> &condition) {
298 return std::make_shared<ConditionalGate<Time>>(operation, condition);
318 return std::make_shared<ConditionalGate<Time>>(operation, eqcond);
336 const std::shared_ptr<ICondition> &condition) {
337 return std::make_shared<ConditionalMeasurement<Time>>(measurement,
357 const std::shared_ptr<ICondition> &condition) {
358 return std::make_shared<ConditionalRandomGen<Time>>(randomGen, condition);
370 return std::make_shared<NoOperation<Time>>();
386 size_t qbit1,
size_t qbit2,
bool qbit1X =
false,
bool qbit2X =
false) {
391 std::vector<std::shared_ptr<IOperation<Time>>> ops(s);
412 static std::vector<std::shared_ptr<IOperation<Time>>>
414 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
434 size_t qbit1,
size_t qbit2,
size_t qbit3) {
435 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
460 static std::vector<std::shared_ptr<IOperation<Time>>>
462 size_t cbit1,
size_t cbit2) {
463 std::vector<std::shared_ptr<IOperation<Time>>> ops(8);
499 static std::vector<std::shared_ptr<IOperation<Time>>>
501 size_t tgtEntangledQubit,
502 size_t ctrlEntangledMeasureBit) {
503 std::vector<std::shared_ptr<IOperation<Time>>> ops(5);
517 const std::vector<std::pair<Types::qubit_t, size_t>> measureOps{
518 {ctrlEntangledQubit, ctrlEntangledMeasureBit}};
527 ops[4] = std::make_shared<Circuits::ConditionalGate<Time>>(
528 std::make_shared<Circuits::XGate<Time>>(tgtEntangledQubit),
529 std::make_shared<Circuits::EqualCondition>(
530 std::vector<size_t>{ctrlEntangledMeasureBit},
531 std::vector<bool>{
true}));
547 static std::vector<std::shared_ptr<IOperation<Time>>>
549 size_t tgtEntangledMeasureBit) {
550 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
552 ops[0] = std::make_shared<Circuits::HadamardGate<Time>>(tgtEntangledQubit);
553 const std::vector<std::pair<Types::qubit_t, size_t>> measureOps{
554 {tgtEntangledQubit, tgtEntangledMeasureBit}};
555 ops[1] = std::make_shared<Circuits::MeasurementOperation<Time>>(measureOps);
556 ops[2] = std::make_shared<Circuits::ConditionalGate<Time>>(
557 std::make_shared<Circuits::ZGate<Time>>(ctrlQubit),
558 std::make_shared<Circuits::EqualCondition>(
559 std::vector<size_t>{tgtEntangledMeasureBit},
560 std::vector<bool>{
true}));
574 size_t qubit,
size_t cbit) {
575 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
591 size_t qubit,
size_t cbit) {
592 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
609 size_t qubit,
size_t cbit) {
610 std::vector<std::shared_ptr<IOperation<Time>>> ops(1);
625 std::vector<std::shared_ptr<IOperation<Time>>> ops(1);
640 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
656 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
672 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
689 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
706 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
Factory for quantum gates and other operations.
static std::shared_ptr< IOperation< Time > > CreateSimpleConditionalGate(const std::shared_ptr< IGateOperation< Time > > &operation, const size_t cbit)
Construct a simple conditional gate.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateGZHStateCircuit(size_t qbit1, size_t qbit2, size_t qbit3)
Creates a circuit that prepares three qubits in a GHZ state.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateInitMinusI(size_t qubit)
Creates the circuit for initializing a qubit in the |-i> state.
static std::shared_ptr< IOperation< Time > > CreateNoOp()
Creates a no op.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateInitMinus(size_t qubit)
Creates the circuit for initializing a qubit in the |-> state.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateInitOne(size_t qubit)
Creates the circuit for initializing a qubit in the |1> state.
static const std::shared_ptr< IQuantumGate< Time > > CreateGate(QuantumGateType type, size_t q1, size_t q2=0, size_t q3=0, double param1=0, double param2=0, double param3=0, double param4=0)
Construct a quantum gate.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateInitZero(size_t qubit)
Creates the circuit for initializing a qubit in the |0> state.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateMeasureY(size_t qubit, size_t cbit)
Creates the circuit for measuring a qubit in the Y basis.
static std::shared_ptr< IOperation< Time > > CreateConditionalGate(const std::shared_ptr< IGateOperation< Time > > &operation, const std::shared_ptr< ICondition > &condition)
Construct a conditional gate.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateInitPlusI(size_t qubit)
Creates the circuit for initializing a qubit in the |i> state.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateMeasureZ(size_t qubit, size_t cbit)
Creates the circuit for measuring a qubit in the Z basis.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateMeasureX(size_t qubit, size_t cbit)
Creates the circuit for measuring a qubit in the X basis.
static std::shared_ptr< IOperation< Time > > CreateReset(const Types::qubits_vector &qubits={}, const std::vector< bool > &resetTgts={})
Construct a reset operation.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateStartDistributionCircuit(size_t ctrlQubit, size_t ctrlEntangledQubit, size_t tgtEntangledQubit, size_t ctrlEntangledMeasureBit)
Creates the circuit for distribution start.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateEndDistributionCircuit(size_t ctrlQubit, size_t tgtEntangledQubit, size_t tgtEntangledMeasureBit)
Creates the circuit for distribution end.
static const std::shared_ptr< IOperation< Time > > CreateMeasurement(const std::vector< std::pair< Types::qubit_t, size_t > > &qs={})
Construct a measurement operation.
static std::shared_ptr< Circuit< Time > > CreateCircuit(const std::vector< std::shared_ptr< IOperation< Time > > > &ops={})
Construct a circuit.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateTeleportationCircuit(size_t entqbit1, size_t entqbit2, size_t srcqbit, size_t cbit1, size_t cbit2)
Creates a teleportation circuit.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateBellStateDecoderCircuit(size_t qbit1, size_t qbit2)
Creates a Bell state decoder circuit.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateBellStateCircuit(size_t qbit1, size_t qbit2, bool qbit1X=false, bool qbit2X=false)
Creates a circuit that prepares a qubit pair in a Bell state.
static std::shared_ptr< IOperation< Time > > CreateConditionalRandomGen(const std::shared_ptr< Random< Time > > &randomGen, const std::shared_ptr< ICondition > &condition)
Constructs a conditional random number generator.
static const std::shared_ptr< IOperation< Time > > CreateGateWithVectors(QuantumGateType type, const Types::qubits_vector &qubits, const std::vector< double > ¶ms={})
Construct a quantum gate.
static std::shared_ptr< IOperation< Time > > CreateRandom(const std::vector< size_t > &bits={}, size_t seed=0)
Construct a random operation.
static std::vector< std::shared_ptr< IOperation< Time > > > CreateInitPlus(size_t qubit)
Creates the circuit for initializing a qubit in the |+> state.
static std::shared_ptr< IOperation< Time > > CreateConditionalMeasurement(const std::shared_ptr< MeasurementOperation< Time > > &measurement, const std::shared_ptr< ICondition > &condition)
Constructs a conditional measurement.
static std::shared_ptr< ICondition > CreateEqualCondition(const std::vector< size_t > &ind, const std::vector< bool > &b)
Construct an equality condition.
The gate operation interface.
Measurement operation class.
QuantumGateType
The type of quantum gates.
std::vector< qubit_t > qubits_vector
The type of a vector of qubits.