-
Notifications
You must be signed in to change notification settings - Fork 14
Expand file tree
/
Copy pathparameterized_circuit_test.cpp
More file actions
53 lines (38 loc) · 1.09 KB
/
parameterized_circuit_test.cpp
File metadata and controls
53 lines (38 loc) · 1.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/*
# This code is part of Qiskit.
#
# (C) Copyright IBM 2024. 2026.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
#
# Any modifications or derivative works of this code must retain this
# copyright notice, and modified files need to carry a notice indicating
# that they have been altered from the originals.
*/
// Test parameterized circuit of Qiskit C++
#define _USE_MATH_DEFINES
#include <iostream>
#include <cstdint>
#include <cstdlib>
#include <cmath>
#include "circuit/quantumcircuit.hpp"
using namespace Qiskit::circuit;
int main()
{
QuantumRegister qr(4);
ClassicalRegister cr(4);
QuantumCircuit circ(qr, cr);
Parameter theta("t");
Parameter a = theta + 0.5;
circ.h(0);
circ.rx(a, 1);
circ.measure(qr, cr);
circ.print();
circ.draw();
Parameter p1 = Parameter(M_PI/2.0);
Parameter p2 = Parameter(M_PI/2.0);
std::cout << (p1 == p2) << std::endl;
return 0;
}