16#ifndef _CIRCUIT_FACTORY_H_
17#define _CIRCUIT_FACTORY_H_
36template <
typename Time = Types::time_type>
49 return std::make_shared<Circuit<Time>>(ops);
65 const Types::qubits_vector &qubits = {},
66 const std::vector<bool> &resetTgts = {}) {
67 return std::make_shared<Reset<Time>>(qubits, 0, resetTgts);
81 const std::vector<size_t> &bits = {},
size_t seed = 0) {
82 return std::make_shared<Random<Time>>(bits, seed);
96 const std::vector<std::pair<Types::qubit_t, size_t>> &qs = {}) {
97 return std::make_shared<MeasurementOperation<Time>>(qs);
124 double param1 = 0,
double param2 = 0,
double param3 = 0,
131 std::shared_ptr<IQuantumGate<Time>> gate;
136 gate = std::make_shared<PhaseGate<Time>>(q1, param1);
139 gate = std::make_shared<XGate<Time>>(q1);
142 gate = std::make_shared<YGate<Time>>(q1);
145 gate = std::make_shared<ZGate<Time>>(q1);
148 gate = std::make_shared<HadamardGate<Time>>(q1);
151 gate = std::make_shared<SGate<Time>>(q1);
154 gate = std::make_shared<SdgGate<Time>>(q1);
157 gate = std::make_shared<TGate<Time>>(q1);
160 gate = std::make_shared<TdgGate<Time>>(q1);
163 gate = std::make_shared<SxGate<Time>>(q1);
166 gate = std::make_shared<SxDagGate<Time>>(q1);
169 gate = std::make_shared<KGate<Time>>(q1);
172 gate = std::make_shared<RxGate<Time>>(q1, param1);
175 gate = std::make_shared<RyGate<Time>>(q1, param1);
178 gate = std::make_shared<RzGate<Time>>(q1, param1);
182 std::make_shared<UGate<Time>>(q1, param1, param2, param3, param4);
186 gate = std::make_shared<SwapGate<Time>>(q1, q2);
189 gate = std::make_shared<CXGate<Time>>(q1, q2);
192 gate = std::make_shared<CYGate<Time>>(q1, q2);
195 gate = std::make_shared<CZGate<Time>>(q1, q2);
198 gate = std::make_shared<CPGate<Time>>(q1, q2, param1);
201 gate = std::make_shared<CRxGate<Time>>(q1, q2, param1);
204 gate = std::make_shared<CRyGate<Time>>(q1, q2, param1);
207 gate = std::make_shared<CRzGate<Time>>(q1, q2, param1);
210 gate = std::make_shared<CHGate<Time>>(q1, q2);
213 gate = std::make_shared<CSxGate<Time>>(q1, q2);
216 gate = std::make_shared<CSxDagGate<Time>>(q1, q2);
219 gate = std::make_shared<CUGate<Time>>(q1, q2, param1, param2, param3,
224 gate = std::make_shared<CSwapGate<Time>>(q1, q2, q3);
227 gate = std::make_shared<CCXGate<Time>>(q1, q2, q3);
250 const std::vector<double> ¶ms = {}) {
251 return CreateGate(type, qubits.empty() ? 0 : qubits[0],
252 (qubits.size() < 2) ? 0 : qubits[1],
253 (qubits.size() < 3) ? 0 : qubits[2],
254 params.empty() ? 0. : params[0],
255 (params.size() < 2) ? 0. : params[1],
256 (params.size() < 3) ? 0. : params[2],
257 (params.size() < 4) ? 0. : params[3]);
275 const std::vector<size_t> &ind,
const std::vector<bool> &b) {
276 return std::make_shared<EqualCondition>(ind, b);
296 const std::shared_ptr<ICondition> &condition) {
297 return std::make_shared<ConditionalGate<Time>>(operation, condition);
317 return std::make_shared<ConditionalGate<Time>>(operation, eqcond);
335 const std::shared_ptr<ICondition> &condition) {
336 return std::make_shared<ConditionalMeasurement<Time>>(measurement,
356 const std::shared_ptr<ICondition> &condition) {
357 return std::make_shared<ConditionalRandomGen<Time>>(randomGen, condition);
369 return std::make_shared<NoOperation<Time>>();
385 size_t qbit1,
size_t qbit2,
bool qbit1X =
false,
bool qbit2X =
false) {
390 std::vector<std::shared_ptr<IOperation<Time>>> ops(s);
411 static std::vector<std::shared_ptr<IOperation<Time>>>
413 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
433 size_t qbit1,
size_t qbit2,
size_t qbit3) {
434 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
459 static std::vector<std::shared_ptr<IOperation<Time>>>
461 size_t cbit1,
size_t cbit2) {
462 std::vector<std::shared_ptr<IOperation<Time>>> ops(8);
498 static std::vector<std::shared_ptr<IOperation<Time>>>
500 size_t tgtEntangledQubit,
501 size_t ctrlEntangledMeasureBit) {
502 std::vector<std::shared_ptr<IOperation<Time>>> ops(5);
516 const std::vector<std::pair<Types::qubit_t, size_t>> measureOps{
517 {ctrlEntangledQubit, ctrlEntangledMeasureBit}};
526 ops[4] = std::make_shared<Circuits::ConditionalGate<Time>>(
527 std::make_shared<Circuits::XGate<Time>>(tgtEntangledQubit),
528 std::make_shared<Circuits::EqualCondition>(
529 std::vector<size_t>{ctrlEntangledMeasureBit},
530 std::vector<bool>{
true}));
546 static std::vector<std::shared_ptr<IOperation<Time>>>
548 size_t tgtEntangledMeasureBit) {
549 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
551 ops[0] = std::make_shared<Circuits::HadamardGate<Time>>(tgtEntangledQubit);
552 const std::vector<std::pair<Types::qubit_t, size_t>> measureOps{
553 {tgtEntangledQubit, tgtEntangledMeasureBit}};
554 ops[1] = std::make_shared<Circuits::MeasurementOperation<Time>>(measureOps);
555 ops[2] = std::make_shared<Circuits::ConditionalGate<Time>>(
556 std::make_shared<Circuits::ZGate<Time>>(ctrlQubit),
557 std::make_shared<Circuits::EqualCondition>(
558 std::vector<size_t>{tgtEntangledMeasureBit},
559 std::vector<bool>{
true}));
573 size_t qubit,
size_t cbit) {
574 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
590 size_t qubit,
size_t cbit) {
591 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
608 size_t qubit,
size_t cbit) {
609 std::vector<std::shared_ptr<IOperation<Time>>> ops(1);
624 std::vector<std::shared_ptr<IOperation<Time>>> ops(1);
639 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
655 std::vector<std::shared_ptr<IOperation<Time>>> ops(2);
671 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
688 std::vector<std::shared_ptr<IOperation<Time>>> ops(3);
705 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.