qiskit 1.0.0b1__cp38-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1095) hide show
  1. qiskit/VERSION.txt +1 -0
  2. qiskit/__init__.py +195 -0
  3. qiskit/_accelerate.abi3.so +0 -0
  4. qiskit/_qasm2.abi3.so +0 -0
  5. qiskit/assembler/__init__.py +47 -0
  6. qiskit/assembler/assemble_circuits.py +408 -0
  7. qiskit/assembler/assemble_schedules.py +372 -0
  8. qiskit/assembler/disassemble.py +318 -0
  9. qiskit/assembler/run_config.py +77 -0
  10. qiskit/circuit/__init__.py +425 -0
  11. qiskit/circuit/_classical_resource_map.py +144 -0
  12. qiskit/circuit/_utils.py +170 -0
  13. qiskit/circuit/add_control.py +274 -0
  14. qiskit/circuit/annotated_operation.py +188 -0
  15. qiskit/circuit/barrier.py +51 -0
  16. qiskit/circuit/bit.py +142 -0
  17. qiskit/circuit/classical/__init__.py +41 -0
  18. qiskit/circuit/classical/expr/__init__.py +218 -0
  19. qiskit/circuit/classical/expr/constructors.py +473 -0
  20. qiskit/circuit/classical/expr/expr.py +356 -0
  21. qiskit/circuit/classical/expr/visitors.py +280 -0
  22. qiskit/circuit/classical/types/__init__.py +108 -0
  23. qiskit/circuit/classical/types/ordering.py +222 -0
  24. qiskit/circuit/classical/types/types.py +117 -0
  25. qiskit/circuit/classicalfunction/__init__.py +131 -0
  26. qiskit/circuit/classicalfunction/boolean_expression.py +129 -0
  27. qiskit/circuit/classicalfunction/classical_element.py +54 -0
  28. qiskit/circuit/classicalfunction/classical_function_visitor.py +155 -0
  29. qiskit/circuit/classicalfunction/classicalfunction.py +173 -0
  30. qiskit/circuit/classicalfunction/exceptions.py +35 -0
  31. qiskit/circuit/classicalfunction/types.py +18 -0
  32. qiskit/circuit/classicalfunction/utils.py +91 -0
  33. qiskit/circuit/classicalregister.py +71 -0
  34. qiskit/circuit/commutation_checker.py +176 -0
  35. qiskit/circuit/controlflow/__init__.py +27 -0
  36. qiskit/circuit/controlflow/_builder_utils.py +199 -0
  37. qiskit/circuit/controlflow/break_loop.py +70 -0
  38. qiskit/circuit/controlflow/builder.py +651 -0
  39. qiskit/circuit/controlflow/continue_loop.py +72 -0
  40. qiskit/circuit/controlflow/control_flow.py +52 -0
  41. qiskit/circuit/controlflow/for_loop.py +232 -0
  42. qiskit/circuit/controlflow/if_else.py +517 -0
  43. qiskit/circuit/controlflow/switch_case.py +424 -0
  44. qiskit/circuit/controlflow/while_loop.py +177 -0
  45. qiskit/circuit/controlledgate.py +271 -0
  46. qiskit/circuit/delay.py +104 -0
  47. qiskit/circuit/duration.py +88 -0
  48. qiskit/circuit/equivalence.py +291 -0
  49. qiskit/circuit/equivalence_library.py +18 -0
  50. qiskit/circuit/exceptions.py +19 -0
  51. qiskit/circuit/gate.py +245 -0
  52. qiskit/circuit/instruction.py +655 -0
  53. qiskit/circuit/instructionset.py +191 -0
  54. qiskit/circuit/library/__init__.py +581 -0
  55. qiskit/circuit/library/arithmetic/__init__.py +27 -0
  56. qiskit/circuit/library/arithmetic/adders/__init__.py +17 -0
  57. qiskit/circuit/library/arithmetic/adders/adder.py +58 -0
  58. qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +159 -0
  59. qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +116 -0
  60. qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +165 -0
  61. qiskit/circuit/library/arithmetic/exact_reciprocal.py +88 -0
  62. qiskit/circuit/library/arithmetic/functional_pauli_rotations.py +114 -0
  63. qiskit/circuit/library/arithmetic/integer_comparator.py +243 -0
  64. qiskit/circuit/library/arithmetic/linear_amplitude_function.py +196 -0
  65. qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +189 -0
  66. qiskit/circuit/library/arithmetic/multipliers/__init__.py +16 -0
  67. qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py +138 -0
  68. qiskit/circuit/library/arithmetic/multipliers/multiplier.py +101 -0
  69. qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +101 -0
  70. qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +353 -0
  71. qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +277 -0
  72. qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +317 -0
  73. qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +335 -0
  74. qiskit/circuit/library/arithmetic/quadratic_form.py +197 -0
  75. qiskit/circuit/library/arithmetic/weighted_adder.py +337 -0
  76. qiskit/circuit/library/basis_change/__init__.py +15 -0
  77. qiskit/circuit/library/basis_change/qft.py +289 -0
  78. qiskit/circuit/library/blueprintcircuit.py +186 -0
  79. qiskit/circuit/library/boolean_logic/__init__.py +18 -0
  80. qiskit/circuit/library/boolean_logic/inner_product.py +78 -0
  81. qiskit/circuit/library/boolean_logic/quantum_and.py +97 -0
  82. qiskit/circuit/library/boolean_logic/quantum_or.py +98 -0
  83. qiskit/circuit/library/boolean_logic/quantum_xor.py +71 -0
  84. qiskit/circuit/library/data_preparation/__init__.py +47 -0
  85. qiskit/circuit/library/data_preparation/initializer.py +96 -0
  86. qiskit/circuit/library/data_preparation/pauli_feature_map.py +296 -0
  87. qiskit/circuit/library/data_preparation/state_preparation.py +526 -0
  88. qiskit/circuit/library/data_preparation/z_feature_map.py +104 -0
  89. qiskit/circuit/library/data_preparation/zz_feature_map.py +114 -0
  90. qiskit/circuit/library/evolved_operator_ansatz.py +245 -0
  91. qiskit/circuit/library/fourier_checking.py +97 -0
  92. qiskit/circuit/library/generalized_gates/__init__.py +30 -0
  93. qiskit/circuit/library/generalized_gates/diagonal.py +164 -0
  94. qiskit/circuit/library/generalized_gates/gms.py +121 -0
  95. qiskit/circuit/library/generalized_gates/gr.py +215 -0
  96. qiskit/circuit/library/generalized_gates/isometry.py +573 -0
  97. qiskit/circuit/library/generalized_gates/linear_function.py +302 -0
  98. qiskit/circuit/library/generalized_gates/mcg_up_to_diagonal.py +138 -0
  99. qiskit/circuit/library/generalized_gates/mcmt.py +254 -0
  100. qiskit/circuit/library/generalized_gates/pauli.py +85 -0
  101. qiskit/circuit/library/generalized_gates/permutation.py +190 -0
  102. qiskit/circuit/library/generalized_gates/rv.py +93 -0
  103. qiskit/circuit/library/generalized_gates/uc.py +304 -0
  104. qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +164 -0
  105. qiskit/circuit/library/generalized_gates/ucrx.py +32 -0
  106. qiskit/circuit/library/generalized_gates/ucry.py +32 -0
  107. qiskit/circuit/library/generalized_gates/ucrz.py +32 -0
  108. qiskit/circuit/library/generalized_gates/unitary.py +198 -0
  109. qiskit/circuit/library/graph_state.py +86 -0
  110. qiskit/circuit/library/grover_operator.py +311 -0
  111. qiskit/circuit/library/hamiltonian_gate.py +146 -0
  112. qiskit/circuit/library/hidden_linear_function.py +98 -0
  113. qiskit/circuit/library/iqp.py +96 -0
  114. qiskit/circuit/library/n_local/__init__.py +31 -0
  115. qiskit/circuit/library/n_local/efficient_su2.py +162 -0
  116. qiskit/circuit/library/n_local/excitation_preserving.py +176 -0
  117. qiskit/circuit/library/n_local/n_local.py +1044 -0
  118. qiskit/circuit/library/n_local/pauli_two_design.py +131 -0
  119. qiskit/circuit/library/n_local/qaoa_ansatz.py +288 -0
  120. qiskit/circuit/library/n_local/real_amplitudes.py +189 -0
  121. qiskit/circuit/library/n_local/two_local.py +334 -0
  122. qiskit/circuit/library/overlap.py +111 -0
  123. qiskit/circuit/library/pauli_evolution.py +180 -0
  124. qiskit/circuit/library/phase_estimation.py +99 -0
  125. qiskit/circuit/library/phase_oracle.py +153 -0
  126. qiskit/circuit/library/quantum_volume.py +114 -0
  127. qiskit/circuit/library/standard_gates/__init__.py +116 -0
  128. qiskit/circuit/library/standard_gates/dcx.py +71 -0
  129. qiskit/circuit/library/standard_gates/ecr.py +114 -0
  130. qiskit/circuit/library/standard_gates/equivalence_library.py +1677 -0
  131. qiskit/circuit/library/standard_gates/global_phase.py +63 -0
  132. qiskit/circuit/library/standard_gates/h.py +224 -0
  133. qiskit/circuit/library/standard_gates/i.py +60 -0
  134. qiskit/circuit/library/standard_gates/iswap.py +129 -0
  135. qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +390 -0
  136. qiskit/circuit/library/standard_gates/p.py +364 -0
  137. qiskit/circuit/library/standard_gates/r.py +101 -0
  138. qiskit/circuit/library/standard_gates/rx.py +246 -0
  139. qiskit/circuit/library/standard_gates/rxx.py +128 -0
  140. qiskit/circuit/library/standard_gates/ry.py +241 -0
  141. qiskit/circuit/library/standard_gates/ryy.py +128 -0
  142. qiskit/circuit/library/standard_gates/rz.py +261 -0
  143. qiskit/circuit/library/standard_gates/rzx.py +174 -0
  144. qiskit/circuit/library/standard_gates/rzz.py +141 -0
  145. qiskit/circuit/library/standard_gates/s.py +303 -0
  146. qiskit/circuit/library/standard_gates/swap.py +246 -0
  147. qiskit/circuit/library/standard_gates/sx.py +268 -0
  148. qiskit/circuit/library/standard_gates/t.py +150 -0
  149. qiskit/circuit/library/standard_gates/u.py +338 -0
  150. qiskit/circuit/library/standard_gates/u1.py +383 -0
  151. qiskit/circuit/library/standard_gates/u2.py +132 -0
  152. qiskit/circuit/library/standard_gates/u3.py +358 -0
  153. qiskit/circuit/library/standard_gates/x.py +1370 -0
  154. qiskit/circuit/library/standard_gates/xx_minus_yy.py +179 -0
  155. qiskit/circuit/library/standard_gates/xx_plus_yy.py +180 -0
  156. qiskit/circuit/library/standard_gates/y.py +221 -0
  157. qiskit/circuit/library/standard_gates/z.py +294 -0
  158. qiskit/circuit/library/templates/__init__.py +92 -0
  159. qiskit/circuit/library/templates/clifford/__init__.py +33 -0
  160. qiskit/circuit/library/templates/clifford/clifford_2_1.py +33 -0
  161. qiskit/circuit/library/templates/clifford/clifford_2_2.py +34 -0
  162. qiskit/circuit/library/templates/clifford/clifford_2_3.py +32 -0
  163. qiskit/circuit/library/templates/clifford/clifford_2_4.py +33 -0
  164. qiskit/circuit/library/templates/clifford/clifford_3_1.py +34 -0
  165. qiskit/circuit/library/templates/clifford/clifford_4_1.py +37 -0
  166. qiskit/circuit/library/templates/clifford/clifford_4_2.py +36 -0
  167. qiskit/circuit/library/templates/clifford/clifford_4_3.py +37 -0
  168. qiskit/circuit/library/templates/clifford/clifford_4_4.py +36 -0
  169. qiskit/circuit/library/templates/clifford/clifford_5_1.py +39 -0
  170. qiskit/circuit/library/templates/clifford/clifford_6_1.py +39 -0
  171. qiskit/circuit/library/templates/clifford/clifford_6_2.py +39 -0
  172. qiskit/circuit/library/templates/clifford/clifford_6_3.py +39 -0
  173. qiskit/circuit/library/templates/clifford/clifford_6_4.py +37 -0
  174. qiskit/circuit/library/templates/clifford/clifford_6_5.py +39 -0
  175. qiskit/circuit/library/templates/clifford/clifford_8_1.py +41 -0
  176. qiskit/circuit/library/templates/clifford/clifford_8_2.py +41 -0
  177. qiskit/circuit/library/templates/clifford/clifford_8_3.py +40 -0
  178. qiskit/circuit/library/templates/nct/__init__.py +67 -0
  179. qiskit/circuit/library/templates/nct/template_nct_2a_1.py +32 -0
  180. qiskit/circuit/library/templates/nct/template_nct_2a_2.py +33 -0
  181. qiskit/circuit/library/templates/nct/template_nct_2a_3.py +35 -0
  182. qiskit/circuit/library/templates/nct/template_nct_4a_1.py +41 -0
  183. qiskit/circuit/library/templates/nct/template_nct_4a_2.py +39 -0
  184. qiskit/circuit/library/templates/nct/template_nct_4a_3.py +37 -0
  185. qiskit/circuit/library/templates/nct/template_nct_4b_1.py +39 -0
  186. qiskit/circuit/library/templates/nct/template_nct_4b_2.py +37 -0
  187. qiskit/circuit/library/templates/nct/template_nct_5a_1.py +38 -0
  188. qiskit/circuit/library/templates/nct/template_nct_5a_2.py +38 -0
  189. qiskit/circuit/library/templates/nct/template_nct_5a_3.py +38 -0
  190. qiskit/circuit/library/templates/nct/template_nct_5a_4.py +37 -0
  191. qiskit/circuit/library/templates/nct/template_nct_6a_1.py +38 -0
  192. qiskit/circuit/library/templates/nct/template_nct_6a_2.py +39 -0
  193. qiskit/circuit/library/templates/nct/template_nct_6a_3.py +39 -0
  194. qiskit/circuit/library/templates/nct/template_nct_6a_4.py +39 -0
  195. qiskit/circuit/library/templates/nct/template_nct_6b_1.py +39 -0
  196. qiskit/circuit/library/templates/nct/template_nct_6b_2.py +39 -0
  197. qiskit/circuit/library/templates/nct/template_nct_6c_1.py +39 -0
  198. qiskit/circuit/library/templates/nct/template_nct_7a_1.py +41 -0
  199. qiskit/circuit/library/templates/nct/template_nct_7b_1.py +41 -0
  200. qiskit/circuit/library/templates/nct/template_nct_7c_1.py +41 -0
  201. qiskit/circuit/library/templates/nct/template_nct_7d_1.py +41 -0
  202. qiskit/circuit/library/templates/nct/template_nct_7e_1.py +41 -0
  203. qiskit/circuit/library/templates/nct/template_nct_9a_1.py +43 -0
  204. qiskit/circuit/library/templates/nct/template_nct_9c_1.py +41 -0
  205. qiskit/circuit/library/templates/nct/template_nct_9c_10.py +42 -0
  206. qiskit/circuit/library/templates/nct/template_nct_9c_11.py +42 -0
  207. qiskit/circuit/library/templates/nct/template_nct_9c_12.py +42 -0
  208. qiskit/circuit/library/templates/nct/template_nct_9c_2.py +42 -0
  209. qiskit/circuit/library/templates/nct/template_nct_9c_3.py +42 -0
  210. qiskit/circuit/library/templates/nct/template_nct_9c_4.py +42 -0
  211. qiskit/circuit/library/templates/nct/template_nct_9c_5.py +42 -0
  212. qiskit/circuit/library/templates/nct/template_nct_9c_6.py +42 -0
  213. qiskit/circuit/library/templates/nct/template_nct_9c_7.py +42 -0
  214. qiskit/circuit/library/templates/nct/template_nct_9c_8.py +42 -0
  215. qiskit/circuit/library/templates/nct/template_nct_9c_9.py +42 -0
  216. qiskit/circuit/library/templates/nct/template_nct_9d_1.py +41 -0
  217. qiskit/circuit/library/templates/nct/template_nct_9d_10.py +42 -0
  218. qiskit/circuit/library/templates/nct/template_nct_9d_2.py +42 -0
  219. qiskit/circuit/library/templates/nct/template_nct_9d_3.py +42 -0
  220. qiskit/circuit/library/templates/nct/template_nct_9d_4.py +42 -0
  221. qiskit/circuit/library/templates/nct/template_nct_9d_5.py +42 -0
  222. qiskit/circuit/library/templates/nct/template_nct_9d_6.py +42 -0
  223. qiskit/circuit/library/templates/nct/template_nct_9d_7.py +42 -0
  224. qiskit/circuit/library/templates/nct/template_nct_9d_8.py +42 -0
  225. qiskit/circuit/library/templates/nct/template_nct_9d_9.py +42 -0
  226. qiskit/circuit/library/templates/rzx/__init__.py +25 -0
  227. qiskit/circuit/library/templates/rzx/rzx_cy.py +46 -0
  228. qiskit/circuit/library/templates/rzx/rzx_xz.py +53 -0
  229. qiskit/circuit/library/templates/rzx/rzx_yz.py +43 -0
  230. qiskit/circuit/library/templates/rzx/rzx_zz1.py +67 -0
  231. qiskit/circuit/library/templates/rzx/rzx_zz2.py +58 -0
  232. qiskit/circuit/library/templates/rzx/rzx_zz3.py +57 -0
  233. qiskit/circuit/measure.py +41 -0
  234. qiskit/circuit/operation.py +62 -0
  235. qiskit/circuit/parameter.py +160 -0
  236. qiskit/circuit/parameterexpression.py +515 -0
  237. qiskit/circuit/parametertable.py +263 -0
  238. qiskit/circuit/parametervector.py +114 -0
  239. qiskit/circuit/qpy_serialization.py +28 -0
  240. qiskit/circuit/quantumcircuit.py +6074 -0
  241. qiskit/circuit/quantumcircuitdata.py +138 -0
  242. qiskit/circuit/quantumregister.py +90 -0
  243. qiskit/circuit/random/__init__.py +15 -0
  244. qiskit/circuit/random/utils.py +209 -0
  245. qiskit/circuit/register.py +256 -0
  246. qiskit/circuit/reset.py +31 -0
  247. qiskit/circuit/singleton.py +604 -0
  248. qiskit/circuit/store.py +87 -0
  249. qiskit/circuit/tools/__init__.py +16 -0
  250. qiskit/circuit/tools/pi_check.py +190 -0
  251. qiskit/compiler/__init__.py +33 -0
  252. qiskit/compiler/assembler.py +597 -0
  253. qiskit/compiler/scheduler.py +107 -0
  254. qiskit/compiler/sequencer.py +69 -0
  255. qiskit/compiler/transpiler.py +613 -0
  256. qiskit/converters/__init__.py +59 -0
  257. qiskit/converters/circuit_to_dag.py +96 -0
  258. qiskit/converters/circuit_to_dagdependency.py +51 -0
  259. qiskit/converters/circuit_to_gate.py +109 -0
  260. qiskit/converters/circuit_to_instruction.py +131 -0
  261. qiskit/converters/dag_to_circuit.py +77 -0
  262. qiskit/converters/dag_to_dagdependency.py +55 -0
  263. qiskit/converters/dagdependency_to_circuit.py +42 -0
  264. qiskit/converters/dagdependency_to_dag.py +49 -0
  265. qiskit/dagcircuit/__init__.py +44 -0
  266. qiskit/dagcircuit/collect_blocks.py +386 -0
  267. qiskit/dagcircuit/dagcircuit.py +2105 -0
  268. qiskit/dagcircuit/dagdependency.py +626 -0
  269. qiskit/dagcircuit/dagdepnode.py +157 -0
  270. qiskit/dagcircuit/dagnode.py +322 -0
  271. qiskit/dagcircuit/exceptions.py +42 -0
  272. qiskit/exceptions.py +97 -0
  273. qiskit/execute_function.py +354 -0
  274. qiskit/extensions/__init__.py +70 -0
  275. qiskit/extensions/exceptions.py +31 -0
  276. qiskit/extensions/quantum_initializer/__init__.py +26 -0
  277. qiskit/extensions/quantum_initializer/squ.py +163 -0
  278. qiskit/extensions/simulator/__init__.py +15 -0
  279. qiskit/extensions/simulator/snapshot.py +70 -0
  280. qiskit/namespace.py +76 -0
  281. qiskit/passmanager/__init__.py +242 -0
  282. qiskit/passmanager/base_tasks.py +230 -0
  283. qiskit/passmanager/compilation_status.py +74 -0
  284. qiskit/passmanager/exceptions.py +19 -0
  285. qiskit/passmanager/flow_controllers.py +336 -0
  286. qiskit/passmanager/passmanager.py +317 -0
  287. qiskit/primitives/__init__.py +62 -0
  288. qiskit/primitives/backend_estimator.py +473 -0
  289. qiskit/primitives/backend_sampler.py +209 -0
  290. qiskit/primitives/base/__init__.py +20 -0
  291. qiskit/primitives/base/base_estimator.py +256 -0
  292. qiskit/primitives/base/base_primitive.py +74 -0
  293. qiskit/primitives/base/base_result.py +87 -0
  294. qiskit/primitives/base/base_sampler.py +202 -0
  295. qiskit/primitives/base/estimator_result.py +46 -0
  296. qiskit/primitives/base/sampler_result.py +45 -0
  297. qiskit/primitives/base/validation.py +231 -0
  298. qiskit/primitives/estimator.py +158 -0
  299. qiskit/primitives/primitive_job.py +73 -0
  300. qiskit/primitives/sampler.py +155 -0
  301. qiskit/primitives/utils.py +216 -0
  302. qiskit/providers/__init__.py +773 -0
  303. qiskit/providers/backend.py +653 -0
  304. qiskit/providers/backend_compat.py +347 -0
  305. qiskit/providers/basicaer/__init__.py +73 -0
  306. qiskit/providers/basicaer/basicaerjob.py +65 -0
  307. qiskit/providers/basicaer/basicaerprovider.py +127 -0
  308. qiskit/providers/basicaer/basicaertools.py +186 -0
  309. qiskit/providers/basicaer/exceptions.py +30 -0
  310. qiskit/providers/basicaer/qasm_simulator.py +678 -0
  311. qiskit/providers/basicaer/statevector_simulator.py +121 -0
  312. qiskit/providers/basicaer/unitary_simulator.py +395 -0
  313. qiskit/providers/exceptions.py +45 -0
  314. qiskit/providers/fake_provider/__init__.py +267 -0
  315. qiskit/providers/fake_provider/backends/__init__.py +110 -0
  316. qiskit/providers/fake_provider/backends/almaden/__init__.py +16 -0
  317. qiskit/providers/fake_provider/backends/almaden/conf_almaden.json +1 -0
  318. qiskit/providers/fake_provider/backends/almaden/fake_almaden.py +58 -0
  319. qiskit/providers/fake_provider/backends/almaden/props_almaden.json +1 -0
  320. qiskit/providers/fake_provider/backends/armonk/__init__.py +16 -0
  321. qiskit/providers/fake_provider/backends/armonk/conf_armonk.json +1 -0
  322. qiskit/providers/fake_provider/backends/armonk/defs_armonk.json +1 -0
  323. qiskit/providers/fake_provider/backends/armonk/fake_armonk.py +48 -0
  324. qiskit/providers/fake_provider/backends/armonk/props_armonk.json +1 -0
  325. qiskit/providers/fake_provider/backends/athens/__init__.py +16 -0
  326. qiskit/providers/fake_provider/backends/athens/conf_athens.json +1 -0
  327. qiskit/providers/fake_provider/backends/athens/defs_athens.json +1 -0
  328. qiskit/providers/fake_provider/backends/athens/fake_athens.py +38 -0
  329. qiskit/providers/fake_provider/backends/athens/props_athens.json +1 -0
  330. qiskit/providers/fake_provider/backends/auckland/__init__.py +15 -0
  331. qiskit/providers/fake_provider/backends/auckland/conf_auckland.json +1 -0
  332. qiskit/providers/fake_provider/backends/auckland/defs_auckland.json +1 -0
  333. qiskit/providers/fake_provider/backends/auckland/fake_auckland.py +29 -0
  334. qiskit/providers/fake_provider/backends/auckland/props_auckland.json +1 -0
  335. qiskit/providers/fake_provider/backends/belem/__init__.py +16 -0
  336. qiskit/providers/fake_provider/backends/belem/conf_belem.json +1 -0
  337. qiskit/providers/fake_provider/backends/belem/defs_belem.json +1 -0
  338. qiskit/providers/fake_provider/backends/belem/fake_belem.py +38 -0
  339. qiskit/providers/fake_provider/backends/belem/props_belem.json +1 -0
  340. qiskit/providers/fake_provider/backends/boeblingen/__init__.py +16 -0
  341. qiskit/providers/fake_provider/backends/boeblingen/conf_boeblingen.json +1 -0
  342. qiskit/providers/fake_provider/backends/boeblingen/defs_boeblingen.json +1 -0
  343. qiskit/providers/fake_provider/backends/boeblingen/fake_boeblingen.py +60 -0
  344. qiskit/providers/fake_provider/backends/boeblingen/props_boeblingen.json +1 -0
  345. qiskit/providers/fake_provider/backends/bogota/__init__.py +16 -0
  346. qiskit/providers/fake_provider/backends/bogota/conf_bogota.json +1 -0
  347. qiskit/providers/fake_provider/backends/bogota/defs_bogota.json +1 -0
  348. qiskit/providers/fake_provider/backends/bogota/fake_bogota.py +38 -0
  349. qiskit/providers/fake_provider/backends/bogota/props_bogota.json +1 -0
  350. qiskit/providers/fake_provider/backends/brooklyn/__init__.py +16 -0
  351. qiskit/providers/fake_provider/backends/brooklyn/conf_brooklyn.json +1 -0
  352. qiskit/providers/fake_provider/backends/brooklyn/defs_brooklyn.json +1 -0
  353. qiskit/providers/fake_provider/backends/brooklyn/fake_brooklyn.py +38 -0
  354. qiskit/providers/fake_provider/backends/brooklyn/props_brooklyn.json +1 -0
  355. qiskit/providers/fake_provider/backends/burlington/__init__.py +16 -0
  356. qiskit/providers/fake_provider/backends/burlington/conf_burlington.json +1 -0
  357. qiskit/providers/fake_provider/backends/burlington/fake_burlington.py +50 -0
  358. qiskit/providers/fake_provider/backends/burlington/props_burlington.json +1 -0
  359. qiskit/providers/fake_provider/backends/cairo/__init__.py +16 -0
  360. qiskit/providers/fake_provider/backends/cairo/conf_cairo.json +1 -0
  361. qiskit/providers/fake_provider/backends/cairo/defs_cairo.json +1 -0
  362. qiskit/providers/fake_provider/backends/cairo/fake_cairo.py +38 -0
  363. qiskit/providers/fake_provider/backends/cairo/props_cairo.json +1 -0
  364. qiskit/providers/fake_provider/backends/cambridge/__init__.py +17 -0
  365. qiskit/providers/fake_provider/backends/cambridge/conf_cambridge.json +1 -0
  366. qiskit/providers/fake_provider/backends/cambridge/fake_cambridge.py +72 -0
  367. qiskit/providers/fake_provider/backends/cambridge/props_cambridge.json +1 -0
  368. qiskit/providers/fake_provider/backends/cambridge/props_cambridge_alt.json +1 -0
  369. qiskit/providers/fake_provider/backends/casablanca/__init__.py +16 -0
  370. qiskit/providers/fake_provider/backends/casablanca/conf_casablanca.json +1 -0
  371. qiskit/providers/fake_provider/backends/casablanca/defs_casablanca.json +1 -0
  372. qiskit/providers/fake_provider/backends/casablanca/fake_casablanca.py +38 -0
  373. qiskit/providers/fake_provider/backends/casablanca/props_casablanca.json +1 -0
  374. qiskit/providers/fake_provider/backends/essex/__init__.py +16 -0
  375. qiskit/providers/fake_provider/backends/essex/conf_essex.json +1 -0
  376. qiskit/providers/fake_provider/backends/essex/fake_essex.py +54 -0
  377. qiskit/providers/fake_provider/backends/essex/props_essex.json +1 -0
  378. qiskit/providers/fake_provider/backends/geneva/__init__.py +15 -0
  379. qiskit/providers/fake_provider/backends/geneva/conf_geneva.json +1 -0
  380. qiskit/providers/fake_provider/backends/geneva/defs_geneva.json +1 -0
  381. qiskit/providers/fake_provider/backends/geneva/fake_geneva.py +29 -0
  382. qiskit/providers/fake_provider/backends/geneva/props_geneva.json +1 -0
  383. qiskit/providers/fake_provider/backends/guadalupe/__init__.py +16 -0
  384. qiskit/providers/fake_provider/backends/guadalupe/conf_guadalupe.json +1 -0
  385. qiskit/providers/fake_provider/backends/guadalupe/defs_guadalupe.json +1 -0
  386. qiskit/providers/fake_provider/backends/guadalupe/fake_guadalupe.py +39 -0
  387. qiskit/providers/fake_provider/backends/guadalupe/props_guadalupe.json +1 -0
  388. qiskit/providers/fake_provider/backends/hanoi/__init__.py +16 -0
  389. qiskit/providers/fake_provider/backends/hanoi/conf_hanoi.json +1 -0
  390. qiskit/providers/fake_provider/backends/hanoi/defs_hanoi.json +1 -0
  391. qiskit/providers/fake_provider/backends/hanoi/fake_hanoi.py +38 -0
  392. qiskit/providers/fake_provider/backends/hanoi/props_hanoi.json +1 -0
  393. qiskit/providers/fake_provider/backends/jakarta/__init__.py +16 -0
  394. qiskit/providers/fake_provider/backends/jakarta/conf_jakarta.json +1 -0
  395. qiskit/providers/fake_provider/backends/jakarta/defs_jakarta.json +1 -0
  396. qiskit/providers/fake_provider/backends/jakarta/fake_jakarta.py +38 -0
  397. qiskit/providers/fake_provider/backends/jakarta/props_jakarta.json +1 -0
  398. qiskit/providers/fake_provider/backends/johannesburg/__init__.py +16 -0
  399. qiskit/providers/fake_provider/backends/johannesburg/conf_johannesburg.json +1 -0
  400. qiskit/providers/fake_provider/backends/johannesburg/fake_johannesburg.py +58 -0
  401. qiskit/providers/fake_provider/backends/johannesburg/props_johannesburg.json +1 -0
  402. qiskit/providers/fake_provider/backends/kolkata/__init__.py +16 -0
  403. qiskit/providers/fake_provider/backends/kolkata/conf_kolkata.json +1 -0
  404. qiskit/providers/fake_provider/backends/kolkata/defs_kolkata.json +1 -0
  405. qiskit/providers/fake_provider/backends/kolkata/fake_kolkata.py +38 -0
  406. qiskit/providers/fake_provider/backends/kolkata/props_kolkata.json +1 -0
  407. qiskit/providers/fake_provider/backends/lagos/__init__.py +16 -0
  408. qiskit/providers/fake_provider/backends/lagos/conf_lagos.json +1 -0
  409. qiskit/providers/fake_provider/backends/lagos/defs_lagos.json +1 -0
  410. qiskit/providers/fake_provider/backends/lagos/fake_lagos.py +38 -0
  411. qiskit/providers/fake_provider/backends/lagos/props_lagos.json +1 -0
  412. qiskit/providers/fake_provider/backends/lima/__init__.py +16 -0
  413. qiskit/providers/fake_provider/backends/lima/conf_lima.json +1 -0
  414. qiskit/providers/fake_provider/backends/lima/defs_lima.json +1 -0
  415. qiskit/providers/fake_provider/backends/lima/fake_lima.py +38 -0
  416. qiskit/providers/fake_provider/backends/lima/props_lima.json +1 -0
  417. qiskit/providers/fake_provider/backends/london/__init__.py +16 -0
  418. qiskit/providers/fake_provider/backends/london/conf_london.json +1 -0
  419. qiskit/providers/fake_provider/backends/london/fake_london.py +54 -0
  420. qiskit/providers/fake_provider/backends/london/props_london.json +1 -0
  421. qiskit/providers/fake_provider/backends/manhattan/__init__.py +16 -0
  422. qiskit/providers/fake_provider/backends/manhattan/conf_manhattan.json +1 -0
  423. qiskit/providers/fake_provider/backends/manhattan/defs_manhattan.json +1 -0
  424. qiskit/providers/fake_provider/backends/manhattan/fake_manhattan.py +38 -0
  425. qiskit/providers/fake_provider/backends/manhattan/props_manhattan.json +1 -0
  426. qiskit/providers/fake_provider/backends/manila/__init__.py +16 -0
  427. qiskit/providers/fake_provider/backends/manila/conf_manila.json +1 -0
  428. qiskit/providers/fake_provider/backends/manila/defs_manila.json +1 -0
  429. qiskit/providers/fake_provider/backends/manila/fake_manila.py +38 -0
  430. qiskit/providers/fake_provider/backends/manila/props_manila.json +1 -0
  431. qiskit/providers/fake_provider/backends/melbourne/__init__.py +16 -0
  432. qiskit/providers/fake_provider/backends/melbourne/conf_melbourne.json +1 -0
  433. qiskit/providers/fake_provider/backends/melbourne/fake_melbourne.py +91 -0
  434. qiskit/providers/fake_provider/backends/melbourne/props_melbourne.json +1 -0
  435. qiskit/providers/fake_provider/backends/montreal/__init__.py +16 -0
  436. qiskit/providers/fake_provider/backends/montreal/conf_montreal.json +1 -0
  437. qiskit/providers/fake_provider/backends/montreal/defs_montreal.json +1 -0
  438. qiskit/providers/fake_provider/backends/montreal/fake_montreal.py +38 -0
  439. qiskit/providers/fake_provider/backends/montreal/props_montreal.json +1 -0
  440. qiskit/providers/fake_provider/backends/mumbai/__init__.py +16 -0
  441. qiskit/providers/fake_provider/backends/mumbai/conf_mumbai.json +1 -0
  442. qiskit/providers/fake_provider/backends/mumbai/defs_mumbai.json +1 -0
  443. qiskit/providers/fake_provider/backends/mumbai/fake_mumbai.py +38 -0
  444. qiskit/providers/fake_provider/backends/mumbai/props_mumbai.json +1 -0
  445. qiskit/providers/fake_provider/backends/nairobi/__init__.py +16 -0
  446. qiskit/providers/fake_provider/backends/nairobi/conf_nairobi.json +1 -0
  447. qiskit/providers/fake_provider/backends/nairobi/defs_nairobi.json +1 -0
  448. qiskit/providers/fake_provider/backends/nairobi/fake_nairobi.py +38 -0
  449. qiskit/providers/fake_provider/backends/nairobi/props_nairobi.json +1 -0
  450. qiskit/providers/fake_provider/backends/oslo/__init__.py +15 -0
  451. qiskit/providers/fake_provider/backends/oslo/conf_oslo.json +1 -0
  452. qiskit/providers/fake_provider/backends/oslo/defs_oslo.json +1 -0
  453. qiskit/providers/fake_provider/backends/oslo/fake_oslo.py +29 -0
  454. qiskit/providers/fake_provider/backends/oslo/props_oslo.json +1 -0
  455. qiskit/providers/fake_provider/backends/ourense/__init__.py +16 -0
  456. qiskit/providers/fake_provider/backends/ourense/conf_ourense.json +1 -0
  457. qiskit/providers/fake_provider/backends/ourense/fake_ourense.py +50 -0
  458. qiskit/providers/fake_provider/backends/ourense/props_ourense.json +1 -0
  459. qiskit/providers/fake_provider/backends/paris/__init__.py +16 -0
  460. qiskit/providers/fake_provider/backends/paris/conf_paris.json +1 -0
  461. qiskit/providers/fake_provider/backends/paris/defs_paris.json +1 -0
  462. qiskit/providers/fake_provider/backends/paris/fake_paris.py +64 -0
  463. qiskit/providers/fake_provider/backends/paris/props_paris.json +1 -0
  464. qiskit/providers/fake_provider/backends/perth/__init__.py +15 -0
  465. qiskit/providers/fake_provider/backends/perth/conf_perth.json +1 -0
  466. qiskit/providers/fake_provider/backends/perth/defs_perth.json +1 -0
  467. qiskit/providers/fake_provider/backends/perth/fake_perth.py +29 -0
  468. qiskit/providers/fake_provider/backends/perth/props_perth.json +1 -0
  469. qiskit/providers/fake_provider/backends/poughkeepsie/__init__.py +16 -0
  470. qiskit/providers/fake_provider/backends/poughkeepsie/conf_poughkeepsie.json +1 -0
  471. qiskit/providers/fake_provider/backends/poughkeepsie/defs_poughkeepsie.json +1 -0
  472. qiskit/providers/fake_provider/backends/poughkeepsie/fake_poughkeepsie.py +124 -0
  473. qiskit/providers/fake_provider/backends/poughkeepsie/props_poughkeepsie.json +1 -0
  474. qiskit/providers/fake_provider/backends/prague/__init__.py +15 -0
  475. qiskit/providers/fake_provider/backends/prague/conf_prague.json +1 -0
  476. qiskit/providers/fake_provider/backends/prague/fake_prague.py +28 -0
  477. qiskit/providers/fake_provider/backends/prague/props_prague.json +1 -0
  478. qiskit/providers/fake_provider/backends/quito/__init__.py +16 -0
  479. qiskit/providers/fake_provider/backends/quito/conf_quito.json +1 -0
  480. qiskit/providers/fake_provider/backends/quito/defs_quito.json +1 -0
  481. qiskit/providers/fake_provider/backends/quito/fake_quito.py +38 -0
  482. qiskit/providers/fake_provider/backends/quito/props_quito.json +1 -0
  483. qiskit/providers/fake_provider/backends/rochester/__init__.py +16 -0
  484. qiskit/providers/fake_provider/backends/rochester/conf_rochester.json +1 -0
  485. qiskit/providers/fake_provider/backends/rochester/fake_rochester.py +36 -0
  486. qiskit/providers/fake_provider/backends/rochester/props_rochester.json +1 -0
  487. qiskit/providers/fake_provider/backends/rome/__init__.py +16 -0
  488. qiskit/providers/fake_provider/backends/rome/conf_rome.json +1 -0
  489. qiskit/providers/fake_provider/backends/rome/defs_rome.json +1 -0
  490. qiskit/providers/fake_provider/backends/rome/fake_rome.py +38 -0
  491. qiskit/providers/fake_provider/backends/rome/props_rome.json +1 -0
  492. qiskit/providers/fake_provider/backends/rueschlikon/__init__.py +15 -0
  493. qiskit/providers/fake_provider/backends/rueschlikon/fake_rueschlikon.py +74 -0
  494. qiskit/providers/fake_provider/backends/santiago/__init__.py +16 -0
  495. qiskit/providers/fake_provider/backends/santiago/conf_santiago.json +1 -0
  496. qiskit/providers/fake_provider/backends/santiago/defs_santiago.json +1 -0
  497. qiskit/providers/fake_provider/backends/santiago/fake_santiago.py +38 -0
  498. qiskit/providers/fake_provider/backends/santiago/props_santiago.json +1 -0
  499. qiskit/providers/fake_provider/backends/sherbrooke/__init__.py +17 -0
  500. qiskit/providers/fake_provider/backends/sherbrooke/conf_sherbrooke.json +1 -0
  501. qiskit/providers/fake_provider/backends/sherbrooke/defs_sherbrooke.json +1 -0
  502. qiskit/providers/fake_provider/backends/sherbrooke/fake_sherbrooke.py +28 -0
  503. qiskit/providers/fake_provider/backends/sherbrooke/props_sherbrooke.json +1 -0
  504. qiskit/providers/fake_provider/backends/singapore/__init__.py +16 -0
  505. qiskit/providers/fake_provider/backends/singapore/conf_singapore.json +1 -0
  506. qiskit/providers/fake_provider/backends/singapore/fake_singapore.py +58 -0
  507. qiskit/providers/fake_provider/backends/singapore/props_singapore.json +1 -0
  508. qiskit/providers/fake_provider/backends/sydney/__init__.py +16 -0
  509. qiskit/providers/fake_provider/backends/sydney/conf_sydney.json +1 -0
  510. qiskit/providers/fake_provider/backends/sydney/defs_sydney.json +1 -0
  511. qiskit/providers/fake_provider/backends/sydney/fake_sydney.py +38 -0
  512. qiskit/providers/fake_provider/backends/sydney/props_sydney.json +1 -0
  513. qiskit/providers/fake_provider/backends/tenerife/__init__.py +15 -0
  514. qiskit/providers/fake_provider/backends/tenerife/fake_tenerife.py +64 -0
  515. qiskit/providers/fake_provider/backends/tenerife/props_tenerife.json +1 -0
  516. qiskit/providers/fake_provider/backends/tokyo/__init__.py +15 -0
  517. qiskit/providers/fake_provider/backends/tokyo/fake_tokyo.py +137 -0
  518. qiskit/providers/fake_provider/backends/tokyo/props_tokyo.json +1 -0
  519. qiskit/providers/fake_provider/backends/toronto/__init__.py +16 -0
  520. qiskit/providers/fake_provider/backends/toronto/conf_toronto.json +1 -0
  521. qiskit/providers/fake_provider/backends/toronto/defs_toronto.json +1 -0
  522. qiskit/providers/fake_provider/backends/toronto/fake_toronto.py +38 -0
  523. qiskit/providers/fake_provider/backends/toronto/props_toronto.json +1 -0
  524. qiskit/providers/fake_provider/backends/valencia/__init__.py +16 -0
  525. qiskit/providers/fake_provider/backends/valencia/conf_valencia.json +1 -0
  526. qiskit/providers/fake_provider/backends/valencia/defs_valencia.json +1 -0
  527. qiskit/providers/fake_provider/backends/valencia/fake_valencia.py +38 -0
  528. qiskit/providers/fake_provider/backends/valencia/props_valencia.json +1 -0
  529. qiskit/providers/fake_provider/backends/vigo/__init__.py +16 -0
  530. qiskit/providers/fake_provider/backends/vigo/conf_vigo.json +1 -0
  531. qiskit/providers/fake_provider/backends/vigo/fake_vigo.py +50 -0
  532. qiskit/providers/fake_provider/backends/vigo/props_vigo.json +1 -0
  533. qiskit/providers/fake_provider/backends/washington/__init__.py +18 -0
  534. qiskit/providers/fake_provider/backends/washington/conf_washington.json +1 -0
  535. qiskit/providers/fake_provider/backends/washington/defs_washington.json +1 -0
  536. qiskit/providers/fake_provider/backends/washington/fake_washington.py +38 -0
  537. qiskit/providers/fake_provider/backends/washington/props_washington.json +1 -0
  538. qiskit/providers/fake_provider/backends/yorktown/__init__.py +16 -0
  539. qiskit/providers/fake_provider/backends/yorktown/conf_yorktown.json +1 -0
  540. qiskit/providers/fake_provider/backends/yorktown/fake_yorktown.py +54 -0
  541. qiskit/providers/fake_provider/backends/yorktown/props_yorktown.json +1 -0
  542. qiskit/providers/fake_provider/fake_1q.py +91 -0
  543. qiskit/providers/fake_provider/fake_backend.py +572 -0
  544. qiskit/providers/fake_provider/fake_backend_v2.py +217 -0
  545. qiskit/providers/fake_provider/fake_job.py +81 -0
  546. qiskit/providers/fake_provider/fake_mumbai_v2.py +637 -0
  547. qiskit/providers/fake_provider/fake_openpulse_2q.py +342 -0
  548. qiskit/providers/fake_provider/fake_openpulse_3q.py +332 -0
  549. qiskit/providers/fake_provider/fake_provider.py +214 -0
  550. qiskit/providers/fake_provider/fake_pulse_backend.py +43 -0
  551. qiskit/providers/fake_provider/fake_qasm_backend.py +72 -0
  552. qiskit/providers/fake_provider/fake_qasm_simulator.py +48 -0
  553. qiskit/providers/fake_provider/fake_qobj.py +44 -0
  554. qiskit/providers/fake_provider/utils/__init__.py +15 -0
  555. qiskit/providers/fake_provider/utils/backend_converter.py +150 -0
  556. qiskit/providers/fake_provider/utils/configurable_backend.py +360 -0
  557. qiskit/providers/fake_provider/utils/json_decoder.py +109 -0
  558. qiskit/providers/job.py +142 -0
  559. qiskit/providers/jobstatus.py +30 -0
  560. qiskit/providers/models/__init__.py +52 -0
  561. qiskit/providers/models/backendconfiguration.py +994 -0
  562. qiskit/providers/models/backendproperties.py +490 -0
  563. qiskit/providers/models/backendstatus.py +94 -0
  564. qiskit/providers/models/jobstatus.py +66 -0
  565. qiskit/providers/models/pulsedefaults.py +304 -0
  566. qiskit/providers/options.py +273 -0
  567. qiskit/providers/provider.py +79 -0
  568. qiskit/providers/providerutils.py +99 -0
  569. qiskit/pulse/__init__.py +170 -0
  570. qiskit/pulse/builder.py +2733 -0
  571. qiskit/pulse/calibration_entries.py +357 -0
  572. qiskit/pulse/channels.py +221 -0
  573. qiskit/pulse/configuration.py +244 -0
  574. qiskit/pulse/exceptions.py +43 -0
  575. qiskit/pulse/filters.py +302 -0
  576. qiskit/pulse/instruction_schedule_map.py +406 -0
  577. qiskit/pulse/instructions/__init__.py +69 -0
  578. qiskit/pulse/instructions/acquire.py +150 -0
  579. qiskit/pulse/instructions/call.py +176 -0
  580. qiskit/pulse/instructions/delay.py +69 -0
  581. qiskit/pulse/instructions/directives.py +145 -0
  582. qiskit/pulse/instructions/frequency.py +132 -0
  583. qiskit/pulse/instructions/instruction.py +266 -0
  584. qiskit/pulse/instructions/phase.py +149 -0
  585. qiskit/pulse/instructions/play.py +96 -0
  586. qiskit/pulse/instructions/reference.py +99 -0
  587. qiskit/pulse/instructions/snapshot.py +80 -0
  588. qiskit/pulse/library/__init__.py +99 -0
  589. qiskit/pulse/library/continuous.py +430 -0
  590. qiskit/pulse/library/parametric_pulses.py +629 -0
  591. qiskit/pulse/library/pulse.py +137 -0
  592. qiskit/pulse/library/samplers/__init__.py +15 -0
  593. qiskit/pulse/library/samplers/decorators.py +299 -0
  594. qiskit/pulse/library/samplers/strategies.py +71 -0
  595. qiskit/pulse/library/symbolic_pulses.py +1962 -0
  596. qiskit/pulse/library/waveform.py +134 -0
  597. qiskit/pulse/macros.py +256 -0
  598. qiskit/pulse/parameter_manager.py +432 -0
  599. qiskit/pulse/parser.py +314 -0
  600. qiskit/pulse/reference_manager.py +58 -0
  601. qiskit/pulse/schedule.py +2002 -0
  602. qiskit/pulse/transforms/__init__.py +106 -0
  603. qiskit/pulse/transforms/alignments.py +406 -0
  604. qiskit/pulse/transforms/base_transforms.py +71 -0
  605. qiskit/pulse/transforms/canonicalization.py +514 -0
  606. qiskit/pulse/transforms/dag.py +107 -0
  607. qiskit/pulse/utils.py +109 -0
  608. qiskit/qasm/libs/qelib1.inc +266 -0
  609. qiskit/qasm/libs/stdgates.inc +75 -0
  610. qiskit/qasm2/__init__.py +658 -0
  611. qiskit/qasm2/exceptions.py +27 -0
  612. qiskit/qasm2/export.py +374 -0
  613. qiskit/qasm2/parse.py +403 -0
  614. qiskit/qasm3/__init__.py +255 -0
  615. qiskit/qasm3/ast.py +606 -0
  616. qiskit/qasm3/exceptions.py +27 -0
  617. qiskit/qasm3/experimental.py +30 -0
  618. qiskit/qasm3/exporter.py +1079 -0
  619. qiskit/qasm3/printer.py +545 -0
  620. qiskit/qobj/__init__.py +75 -0
  621. qiskit/qobj/common.py +71 -0
  622. qiskit/qobj/converters/__init__.py +18 -0
  623. qiskit/qobj/converters/lo_config.py +168 -0
  624. qiskit/qobj/converters/pulse_instruction.py +1070 -0
  625. qiskit/qobj/pulse_qobj.py +655 -0
  626. qiskit/qobj/qasm_qobj.py +656 -0
  627. qiskit/qobj/utils.py +37 -0
  628. qiskit/qpy/__init__.py +1348 -0
  629. qiskit/qpy/binary_io/__init__.py +36 -0
  630. qiskit/qpy/binary_io/circuits.py +1212 -0
  631. qiskit/qpy/binary_io/schedules.py +619 -0
  632. qiskit/qpy/binary_io/value.py +549 -0
  633. qiskit/qpy/common.py +305 -0
  634. qiskit/qpy/exceptions.py +28 -0
  635. qiskit/qpy/formats.py +360 -0
  636. qiskit/qpy/interface.py +308 -0
  637. qiskit/qpy/type_keys.py +544 -0
  638. qiskit/quantum_info/__init__.py +173 -0
  639. qiskit/quantum_info/analysis/__init__.py +17 -0
  640. qiskit/quantum_info/analysis/average.py +47 -0
  641. qiskit/quantum_info/analysis/distance.py +101 -0
  642. qiskit/quantum_info/analysis/make_observable.py +43 -0
  643. qiskit/quantum_info/analysis/z2_symmetries.py +483 -0
  644. qiskit/quantum_info/operators/__init__.py +28 -0
  645. qiskit/quantum_info/operators/base_operator.py +145 -0
  646. qiskit/quantum_info/operators/channel/__init__.py +29 -0
  647. qiskit/quantum_info/operators/channel/chi.py +190 -0
  648. qiskit/quantum_info/operators/channel/choi.py +217 -0
  649. qiskit/quantum_info/operators/channel/kraus.py +336 -0
  650. qiskit/quantum_info/operators/channel/ptm.py +203 -0
  651. qiskit/quantum_info/operators/channel/quantum_channel.py +350 -0
  652. qiskit/quantum_info/operators/channel/stinespring.py +295 -0
  653. qiskit/quantum_info/operators/channel/superop.py +376 -0
  654. qiskit/quantum_info/operators/channel/transformations.py +467 -0
  655. qiskit/quantum_info/operators/custom_iterator.py +48 -0
  656. qiskit/quantum_info/operators/dihedral/__init__.py +18 -0
  657. qiskit/quantum_info/operators/dihedral/dihedral.py +508 -0
  658. qiskit/quantum_info/operators/dihedral/dihedral_circuits.py +218 -0
  659. qiskit/quantum_info/operators/dihedral/polynomial.py +313 -0
  660. qiskit/quantum_info/operators/dihedral/random.py +61 -0
  661. qiskit/quantum_info/operators/linear_op.py +25 -0
  662. qiskit/quantum_info/operators/measures.py +423 -0
  663. qiskit/quantum_info/operators/mixins/__init__.py +52 -0
  664. qiskit/quantum_info/operators/mixins/adjoint.py +52 -0
  665. qiskit/quantum_info/operators/mixins/group.py +171 -0
  666. qiskit/quantum_info/operators/mixins/linear.py +84 -0
  667. qiskit/quantum_info/operators/mixins/multiply.py +62 -0
  668. qiskit/quantum_info/operators/mixins/tolerances.py +72 -0
  669. qiskit/quantum_info/operators/op_shape.py +533 -0
  670. qiskit/quantum_info/operators/operator.py +778 -0
  671. qiskit/quantum_info/operators/predicates.py +170 -0
  672. qiskit/quantum_info/operators/random.py +154 -0
  673. qiskit/quantum_info/operators/scalar_op.py +253 -0
  674. qiskit/quantum_info/operators/symplectic/__init__.py +23 -0
  675. qiskit/quantum_info/operators/symplectic/base_pauli.py +720 -0
  676. qiskit/quantum_info/operators/symplectic/clifford.py +1022 -0
  677. qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
  678. qiskit/quantum_info/operators/symplectic/pauli.py +699 -0
  679. qiskit/quantum_info/operators/symplectic/pauli_list.py +1209 -0
  680. qiskit/quantum_info/operators/symplectic/pauli_utils.py +40 -0
  681. qiskit/quantum_info/operators/symplectic/random.py +264 -0
  682. qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +1156 -0
  683. qiskit/quantum_info/operators/utils/__init__.py +20 -0
  684. qiskit/quantum_info/operators/utils/anti_commutator.py +36 -0
  685. qiskit/quantum_info/operators/utils/commutator.py +36 -0
  686. qiskit/quantum_info/operators/utils/double_commutator.py +76 -0
  687. qiskit/quantum_info/random.py +26 -0
  688. qiskit/quantum_info/states/__init__.py +28 -0
  689. qiskit/quantum_info/states/densitymatrix.py +848 -0
  690. qiskit/quantum_info/states/measures.py +288 -0
  691. qiskit/quantum_info/states/quantum_state.py +503 -0
  692. qiskit/quantum_info/states/random.py +157 -0
  693. qiskit/quantum_info/states/stabilizerstate.py +638 -0
  694. qiskit/quantum_info/states/statevector.py +961 -0
  695. qiskit/quantum_info/states/utils.py +245 -0
  696. qiskit/quantum_info/synthesis/__init__.py +20 -0
  697. qiskit/quantum_info/synthesis/clifford_decompose.py +69 -0
  698. qiskit/quantum_info/synthesis/cnotdihedral_decompose.py +50 -0
  699. qiskit/quantum_info/synthesis/ion_decompose.py +55 -0
  700. qiskit/quantum_info/synthesis/local_invariance.py +93 -0
  701. qiskit/quantum_info/synthesis/one_qubit_decompose.py +284 -0
  702. qiskit/quantum_info/synthesis/qsd.py +269 -0
  703. qiskit/quantum_info/synthesis/quaternion.py +156 -0
  704. qiskit/quantum_info/synthesis/two_qubit_decompose.py +1567 -0
  705. qiskit/quantum_info/synthesis/weyl.py +98 -0
  706. qiskit/quantum_info/synthesis/xx_decompose/__init__.py +19 -0
  707. qiskit/quantum_info/synthesis/xx_decompose/circuits.py +299 -0
  708. qiskit/quantum_info/synthesis/xx_decompose/decomposer.py +314 -0
  709. qiskit/quantum_info/synthesis/xx_decompose/embodiments.py +163 -0
  710. qiskit/quantum_info/synthesis/xx_decompose/paths.py +412 -0
  711. qiskit/quantum_info/synthesis/xx_decompose/polytopes.py +264 -0
  712. qiskit/quantum_info/synthesis/xx_decompose/utilities.py +40 -0
  713. qiskit/quantum_info/synthesis/xx_decompose/weyl.py +133 -0
  714. qiskit/result/__init__.py +67 -0
  715. qiskit/result/counts.py +189 -0
  716. qiskit/result/distributions/__init__.py +17 -0
  717. qiskit/result/distributions/probability.py +100 -0
  718. qiskit/result/distributions/quasi.py +154 -0
  719. qiskit/result/exceptions.py +40 -0
  720. qiskit/result/mitigation/__init__.py +13 -0
  721. qiskit/result/mitigation/base_readout_mitigator.py +79 -0
  722. qiskit/result/mitigation/correlated_readout_mitigator.py +268 -0
  723. qiskit/result/mitigation/local_readout_mitigator.py +319 -0
  724. qiskit/result/mitigation/utils.py +161 -0
  725. qiskit/result/models.py +233 -0
  726. qiskit/result/postprocess.py +239 -0
  727. qiskit/result/result.py +397 -0
  728. qiskit/result/sampled_expval.py +75 -0
  729. qiskit/result/utils.py +295 -0
  730. qiskit/scheduler/__init__.py +31 -0
  731. qiskit/scheduler/config.py +35 -0
  732. qiskit/scheduler/lowering.py +187 -0
  733. qiskit/scheduler/methods/__init__.py +22 -0
  734. qiskit/scheduler/methods/basic.py +137 -0
  735. qiskit/scheduler/schedule_circuit.py +67 -0
  736. qiskit/scheduler/sequence.py +102 -0
  737. qiskit/synthesis/__init__.py +122 -0
  738. qiskit/synthesis/clifford/__init__.py +19 -0
  739. qiskit/synthesis/clifford/clifford_decompose_ag.py +176 -0
  740. qiskit/synthesis/clifford/clifford_decompose_bm.py +276 -0
  741. qiskit/synthesis/clifford/clifford_decompose_full.py +61 -0
  742. qiskit/synthesis/clifford/clifford_decompose_greedy.py +347 -0
  743. qiskit/synthesis/clifford/clifford_decompose_layers.py +443 -0
  744. qiskit/synthesis/cnotdihedral/__init__.py +17 -0
  745. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py +46 -0
  746. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py +140 -0
  747. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py +264 -0
  748. qiskit/synthesis/discrete_basis/__init__.py +16 -0
  749. qiskit/synthesis/discrete_basis/commutator_decompose.py +241 -0
  750. qiskit/synthesis/discrete_basis/gate_sequence.py +415 -0
  751. qiskit/synthesis/discrete_basis/generate_basis_approximations.py +163 -0
  752. qiskit/synthesis/discrete_basis/solovay_kitaev.py +207 -0
  753. qiskit/synthesis/evolution/__init__.py +20 -0
  754. qiskit/synthesis/evolution/evolution_synthesis.py +46 -0
  755. qiskit/synthesis/evolution/lie_trotter.py +123 -0
  756. qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
  757. qiskit/synthesis/evolution/product_formula.py +328 -0
  758. qiskit/synthesis/evolution/qdrift.py +102 -0
  759. qiskit/synthesis/evolution/suzuki_trotter.py +145 -0
  760. qiskit/synthesis/linear/__init__.py +25 -0
  761. qiskit/synthesis/linear/cnot_synth.py +141 -0
  762. qiskit/synthesis/linear/linear_circuits_utils.py +127 -0
  763. qiskit/synthesis/linear/linear_depth_lnn.py +275 -0
  764. qiskit/synthesis/linear/linear_matrix_utils.py +175 -0
  765. qiskit/synthesis/linear_phase/__init__.py +17 -0
  766. qiskit/synthesis/linear_phase/cnot_phase_synth.py +203 -0
  767. qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +262 -0
  768. qiskit/synthesis/linear_phase/cz_depth_lnn.py +206 -0
  769. qiskit/synthesis/permutation/__init__.py +17 -0
  770. qiskit/synthesis/permutation/permutation_full.py +90 -0
  771. qiskit/synthesis/permutation/permutation_lnn.py +68 -0
  772. qiskit/synthesis/permutation/permutation_utils.py +73 -0
  773. qiskit/synthesis/stabilizer/__init__.py +15 -0
  774. qiskit/synthesis/stabilizer/stabilizer_decompose.py +188 -0
  775. qiskit/test/__init__.py +18 -0
  776. qiskit/test/_canonical.py +125 -0
  777. qiskit/test/base.py +331 -0
  778. qiskit/test/decorators.py +308 -0
  779. qiskit/test/ibmq_mock.py +45 -0
  780. qiskit/test/mock/__init__.py +40 -0
  781. qiskit/test/mock/backends/__init__.py +32 -0
  782. qiskit/test/mock/backends/almaden/__init__.py +32 -0
  783. qiskit/test/mock/backends/armonk/__init__.py +32 -0
  784. qiskit/test/mock/backends/athens/__init__.py +32 -0
  785. qiskit/test/mock/backends/belem/__init__.py +32 -0
  786. qiskit/test/mock/backends/boeblingen/__init__.py +32 -0
  787. qiskit/test/mock/backends/bogota/__init__.py +32 -0
  788. qiskit/test/mock/backends/brooklyn/__init__.py +32 -0
  789. qiskit/test/mock/backends/burlington/__init__.py +32 -0
  790. qiskit/test/mock/backends/cairo/__init__.py +32 -0
  791. qiskit/test/mock/backends/cambridge/__init__.py +32 -0
  792. qiskit/test/mock/backends/casablanca/__init__.py +32 -0
  793. qiskit/test/mock/backends/essex/__init__.py +32 -0
  794. qiskit/test/mock/backends/guadalupe/__init__.py +32 -0
  795. qiskit/test/mock/backends/hanoi/__init__.py +32 -0
  796. qiskit/test/mock/backends/jakarta/__init__.py +32 -0
  797. qiskit/test/mock/backends/johannesburg/__init__.py +32 -0
  798. qiskit/test/mock/backends/kolkata/__init__.py +32 -0
  799. qiskit/test/mock/backends/lagos/__init__.py +32 -0
  800. qiskit/test/mock/backends/lima/__init__.py +32 -0
  801. qiskit/test/mock/backends/london/__init__.py +32 -0
  802. qiskit/test/mock/backends/manhattan/__init__.py +32 -0
  803. qiskit/test/mock/backends/manila/__init__.py +32 -0
  804. qiskit/test/mock/backends/melbourne/__init__.py +32 -0
  805. qiskit/test/mock/backends/montreal/__init__.py +32 -0
  806. qiskit/test/mock/backends/mumbai/__init__.py +32 -0
  807. qiskit/test/mock/backends/nairobi/__init__.py +32 -0
  808. qiskit/test/mock/backends/ourense/__init__.py +32 -0
  809. qiskit/test/mock/backends/paris/__init__.py +32 -0
  810. qiskit/test/mock/backends/poughkeepsie/__init__.py +32 -0
  811. qiskit/test/mock/backends/quito/__init__.py +32 -0
  812. qiskit/test/mock/backends/rochester/__init__.py +32 -0
  813. qiskit/test/mock/backends/rome/__init__.py +32 -0
  814. qiskit/test/mock/backends/rueschlikon/__init__.py +32 -0
  815. qiskit/test/mock/backends/santiago/__init__.py +32 -0
  816. qiskit/test/mock/backends/singapore/__init__.py +32 -0
  817. qiskit/test/mock/backends/sydney/__init__.py +32 -0
  818. qiskit/test/mock/backends/tenerife/__init__.py +32 -0
  819. qiskit/test/mock/backends/tokyo/__init__.py +32 -0
  820. qiskit/test/mock/backends/toronto/__init__.py +32 -0
  821. qiskit/test/mock/backends/valencia/__init__.py +32 -0
  822. qiskit/test/mock/backends/vigo/__init__.py +32 -0
  823. qiskit/test/mock/backends/washington/__init__.py +32 -0
  824. qiskit/test/mock/backends/yorktown/__init__.py +32 -0
  825. qiskit/test/providers/__init__.py +16 -0
  826. qiskit/test/providers/backend.py +75 -0
  827. qiskit/test/providers/provider.py +59 -0
  828. qiskit/test/reference_circuits.py +41 -0
  829. qiskit/test/testing_options.py +93 -0
  830. qiskit/test/utils.py +87 -0
  831. qiskit/tools/__init__.py +44 -0
  832. qiskit/tools/events/__init__.py +25 -0
  833. qiskit/tools/events/progressbar.py +195 -0
  834. qiskit/tools/events/pubsub.py +158 -0
  835. qiskit/tools/jupyter/__init__.py +138 -0
  836. qiskit/tools/jupyter/backend_monitor.py +588 -0
  837. qiskit/tools/jupyter/backend_overview.py +322 -0
  838. qiskit/tools/jupyter/copyright.py +42 -0
  839. qiskit/tools/jupyter/job_watcher.py +167 -0
  840. qiskit/tools/jupyter/job_widgets.py +160 -0
  841. qiskit/tools/jupyter/jupyter_magics.py +190 -0
  842. qiskit/tools/jupyter/library.py +189 -0
  843. qiskit/tools/jupyter/monospace.py +29 -0
  844. qiskit/tools/jupyter/progressbar.py +122 -0
  845. qiskit/tools/jupyter/version_table.py +67 -0
  846. qiskit/tools/jupyter/watcher_monitor.py +74 -0
  847. qiskit/tools/monitor/__init__.py +16 -0
  848. qiskit/tools/monitor/job_monitor.py +107 -0
  849. qiskit/tools/monitor/overview.py +247 -0
  850. qiskit/tools/parallel.py +198 -0
  851. qiskit/tools/visualization.py +16 -0
  852. qiskit/transpiler/__init__.py +1287 -0
  853. qiskit/transpiler/basepasses.py +221 -0
  854. qiskit/transpiler/coupling.py +500 -0
  855. qiskit/transpiler/exceptions.py +55 -0
  856. qiskit/transpiler/fencedobjs.py +78 -0
  857. qiskit/transpiler/instruction_durations.py +278 -0
  858. qiskit/transpiler/layout.py +658 -0
  859. qiskit/transpiler/passes/__init__.py +296 -0
  860. qiskit/transpiler/passes/analysis/__init__.py +23 -0
  861. qiskit/transpiler/passes/analysis/count_ops.py +30 -0
  862. qiskit/transpiler/passes/analysis/count_ops_longest_path.py +26 -0
  863. qiskit/transpiler/passes/analysis/dag_longest_path.py +24 -0
  864. qiskit/transpiler/passes/analysis/depth.py +33 -0
  865. qiskit/transpiler/passes/analysis/num_qubits.py +26 -0
  866. qiskit/transpiler/passes/analysis/num_tensor_factors.py +26 -0
  867. qiskit/transpiler/passes/analysis/resource_estimation.py +41 -0
  868. qiskit/transpiler/passes/analysis/size.py +36 -0
  869. qiskit/transpiler/passes/analysis/width.py +27 -0
  870. qiskit/transpiler/passes/basis/__init__.py +20 -0
  871. qiskit/transpiler/passes/basis/basis_translator.py +697 -0
  872. qiskit/transpiler/passes/basis/decompose.py +98 -0
  873. qiskit/transpiler/passes/basis/translate_parameterized.py +177 -0
  874. qiskit/transpiler/passes/basis/unroll_3q_or_more.py +86 -0
  875. qiskit/transpiler/passes/basis/unroll_custom_definitions.py +107 -0
  876. qiskit/transpiler/passes/basis/unroller.py +145 -0
  877. qiskit/transpiler/passes/calibration/__init__.py +17 -0
  878. qiskit/transpiler/passes/calibration/base_builder.py +79 -0
  879. qiskit/transpiler/passes/calibration/builders.py +20 -0
  880. qiskit/transpiler/passes/calibration/exceptions.py +22 -0
  881. qiskit/transpiler/passes/calibration/pulse_gate.py +98 -0
  882. qiskit/transpiler/passes/calibration/rx_builder.py +160 -0
  883. qiskit/transpiler/passes/calibration/rzx_builder.py +394 -0
  884. qiskit/transpiler/passes/calibration/rzx_templates.py +51 -0
  885. qiskit/transpiler/passes/layout/__init__.py +27 -0
  886. qiskit/transpiler/passes/layout/_csp_custom_solver.py +65 -0
  887. qiskit/transpiler/passes/layout/apply_layout.py +108 -0
  888. qiskit/transpiler/passes/layout/csp_layout.py +132 -0
  889. qiskit/transpiler/passes/layout/dense_layout.py +202 -0
  890. qiskit/transpiler/passes/layout/disjoint_utils.py +205 -0
  891. qiskit/transpiler/passes/layout/enlarge_with_ancilla.py +49 -0
  892. qiskit/transpiler/passes/layout/full_ancilla_allocation.py +117 -0
  893. qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
  894. qiskit/transpiler/passes/layout/noise_adaptive_layout.py +311 -0
  895. qiskit/transpiler/passes/layout/sabre_layout.py +468 -0
  896. qiskit/transpiler/passes/layout/sabre_pre_layout.py +217 -0
  897. qiskit/transpiler/passes/layout/set_layout.py +64 -0
  898. qiskit/transpiler/passes/layout/trivial_layout.py +66 -0
  899. qiskit/transpiler/passes/layout/vf2_layout.py +257 -0
  900. qiskit/transpiler/passes/layout/vf2_post_layout.py +419 -0
  901. qiskit/transpiler/passes/layout/vf2_utils.py +260 -0
  902. qiskit/transpiler/passes/optimization/__init__.py +38 -0
  903. qiskit/transpiler/passes/optimization/_gate_extension.py +80 -0
  904. qiskit/transpiler/passes/optimization/collect_1q_runs.py +31 -0
  905. qiskit/transpiler/passes/optimization/collect_2q_blocks.py +35 -0
  906. qiskit/transpiler/passes/optimization/collect_and_collapse.py +115 -0
  907. qiskit/transpiler/passes/optimization/collect_cliffords.py +97 -0
  908. qiskit/transpiler/passes/optimization/collect_linear_functions.py +80 -0
  909. qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +227 -0
  910. qiskit/transpiler/passes/optimization/commutation_analysis.py +93 -0
  911. qiskit/transpiler/passes/optimization/commutative_cancellation.py +207 -0
  912. qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py +97 -0
  913. qiskit/transpiler/passes/optimization/consolidate_blocks.py +219 -0
  914. qiskit/transpiler/passes/optimization/crosstalk_adaptive_schedule.py +732 -0
  915. qiskit/transpiler/passes/optimization/cx_cancellation.py +55 -0
  916. qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +160 -0
  917. qiskit/transpiler/passes/optimization/hoare_opt.py +416 -0
  918. qiskit/transpiler/passes/optimization/inverse_cancellation.py +177 -0
  919. qiskit/transpiler/passes/optimization/normalize_rx_angle.py +149 -0
  920. qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +268 -0
  921. qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +263 -0
  922. qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
  923. qiskit/transpiler/passes/optimization/optimize_cliffords.py +89 -0
  924. qiskit/transpiler/passes/optimization/optimize_swap_before_measure.py +71 -0
  925. qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py +69 -0
  926. qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
  927. qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +47 -0
  928. qiskit/transpiler/passes/optimization/template_matching/__init__.py +19 -0
  929. qiskit/transpiler/passes/optimization/template_matching/backward_match.py +749 -0
  930. qiskit/transpiler/passes/optimization/template_matching/forward_match.py +454 -0
  931. qiskit/transpiler/passes/optimization/template_matching/maximal_matches.py +77 -0
  932. qiskit/transpiler/passes/optimization/template_matching/template_matching.py +370 -0
  933. qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +629 -0
  934. qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
  935. qiskit/transpiler/passes/routing/__init__.py +21 -0
  936. qiskit/transpiler/passes/routing/algorithms/__init__.py +33 -0
  937. qiskit/transpiler/passes/routing/algorithms/token_swapper.py +105 -0
  938. qiskit/transpiler/passes/routing/algorithms/types.py +46 -0
  939. qiskit/transpiler/passes/routing/algorithms/util.py +103 -0
  940. qiskit/transpiler/passes/routing/basic_swap.py +155 -0
  941. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/__init__.py +25 -0
  942. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_block.py +60 -0
  943. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +387 -0
  944. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/pauli_2q_evolution_commutation.py +141 -0
  945. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/swap_strategy.py +306 -0
  946. qiskit/transpiler/passes/routing/layout_transformation.py +118 -0
  947. qiskit/transpiler/passes/routing/lookahead_swap.py +384 -0
  948. qiskit/transpiler/passes/routing/sabre_swap.py +430 -0
  949. qiskit/transpiler/passes/routing/stochastic_swap.py +512 -0
  950. qiskit/transpiler/passes/routing/utils.py +35 -0
  951. qiskit/transpiler/passes/scheduling/__init__.py +27 -0
  952. qiskit/transpiler/passes/scheduling/alap.py +155 -0
  953. qiskit/transpiler/passes/scheduling/alignments/__init__.py +81 -0
  954. qiskit/transpiler/passes/scheduling/alignments/align_measures.py +256 -0
  955. qiskit/transpiler/passes/scheduling/alignments/check_durations.py +75 -0
  956. qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +97 -0
  957. qiskit/transpiler/passes/scheduling/alignments/reschedule.py +241 -0
  958. qiskit/transpiler/passes/scheduling/asap.py +177 -0
  959. qiskit/transpiler/passes/scheduling/base_scheduler.py +289 -0
  960. qiskit/transpiler/passes/scheduling/calibration_creators.py +27 -0
  961. qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +285 -0
  962. qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
  963. qiskit/transpiler/passes/scheduling/padding/base_padding.py +256 -0
  964. qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +408 -0
  965. qiskit/transpiler/passes/scheduling/padding/pad_delay.py +79 -0
  966. qiskit/transpiler/passes/scheduling/rzx_templates.py +28 -0
  967. qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
  968. qiskit/transpiler/passes/scheduling/scheduling/alap.py +127 -0
  969. qiskit/transpiler/passes/scheduling/scheduling/asap.py +131 -0
  970. qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +89 -0
  971. qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
  972. qiskit/transpiler/passes/scheduling/time_unit_conversion.py +135 -0
  973. qiskit/transpiler/passes/synthesis/__init__.py +19 -0
  974. qiskit/transpiler/passes/synthesis/high_level_synthesis.py +637 -0
  975. qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +63 -0
  976. qiskit/transpiler/passes/synthesis/plugin.py +597 -0
  977. qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +289 -0
  978. qiskit/transpiler/passes/synthesis/unitary_synthesis.py +895 -0
  979. qiskit/transpiler/passes/utils/__init__.py +34 -0
  980. qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +95 -0
  981. qiskit/transpiler/passes/utils/block_to_matrix.py +47 -0
  982. qiskit/transpiler/passes/utils/check_gate_direction.py +87 -0
  983. qiskit/transpiler/passes/utils/check_map.py +94 -0
  984. qiskit/transpiler/passes/utils/contains_instruction.py +45 -0
  985. qiskit/transpiler/passes/utils/control_flow.py +61 -0
  986. qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +89 -0
  987. qiskit/transpiler/passes/utils/dag_fixed_point.py +36 -0
  988. qiskit/transpiler/passes/utils/error.py +69 -0
  989. qiskit/transpiler/passes/utils/filter_op_nodes.py +65 -0
  990. qiskit/transpiler/passes/utils/fixed_point.py +48 -0
  991. qiskit/transpiler/passes/utils/gate_direction.py +347 -0
  992. qiskit/transpiler/passes/utils/gates_basis.py +75 -0
  993. qiskit/transpiler/passes/utils/merge_adjacent_barriers.py +162 -0
  994. qiskit/transpiler/passes/utils/minimum_point.py +118 -0
  995. qiskit/transpiler/passes/utils/remove_barriers.py +49 -0
  996. qiskit/transpiler/passes/utils/remove_final_measurements.py +114 -0
  997. qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
  998. qiskit/transpiler/passmanager.py +617 -0
  999. qiskit/transpiler/passmanager_config.py +193 -0
  1000. qiskit/transpiler/preset_passmanagers/__init__.py +280 -0
  1001. qiskit/transpiler/preset_passmanagers/builtin_plugins.py +971 -0
  1002. qiskit/transpiler/preset_passmanagers/common.py +651 -0
  1003. qiskit/transpiler/preset_passmanagers/level0.py +113 -0
  1004. qiskit/transpiler/preset_passmanagers/level1.py +120 -0
  1005. qiskit/transpiler/preset_passmanagers/level2.py +119 -0
  1006. qiskit/transpiler/preset_passmanagers/level3.py +119 -0
  1007. qiskit/transpiler/preset_passmanagers/plugin.py +345 -0
  1008. qiskit/transpiler/propertyset.py +19 -0
  1009. qiskit/transpiler/runningpassmanager.py +174 -0
  1010. qiskit/transpiler/synthesis/__init__.py +16 -0
  1011. qiskit/transpiler/synthesis/aqc/__init__.py +178 -0
  1012. qiskit/transpiler/synthesis/aqc/approximate.py +116 -0
  1013. qiskit/transpiler/synthesis/aqc/aqc.py +170 -0
  1014. qiskit/transpiler/synthesis/aqc/aqc_plugin.py +146 -0
  1015. qiskit/transpiler/synthesis/aqc/cnot_structures.py +299 -0
  1016. qiskit/transpiler/synthesis/aqc/cnot_unit_circuit.py +103 -0
  1017. qiskit/transpiler/synthesis/aqc/cnot_unit_objective.py +299 -0
  1018. qiskit/transpiler/synthesis/aqc/elementary_operations.py +108 -0
  1019. qiskit/transpiler/synthesis/aqc/fast_gradient/__init__.py +164 -0
  1020. qiskit/transpiler/synthesis/aqc/fast_gradient/fast_grad_utils.py +237 -0
  1021. qiskit/transpiler/synthesis/aqc/fast_gradient/fast_gradient.py +225 -0
  1022. qiskit/transpiler/synthesis/aqc/fast_gradient/layer.py +370 -0
  1023. qiskit/transpiler/synthesis/aqc/fast_gradient/pmatrix.py +312 -0
  1024. qiskit/transpiler/synthesis/graysynth.py +114 -0
  1025. qiskit/transpiler/target.py +1540 -0
  1026. qiskit/transpiler/timing_constraints.py +59 -0
  1027. qiskit/user_config.py +239 -0
  1028. qiskit/utils/__init__.py +66 -0
  1029. qiskit/utils/classtools.py +146 -0
  1030. qiskit/utils/deprecation.py +489 -0
  1031. qiskit/utils/lazy_tester.py +334 -0
  1032. qiskit/utils/multiprocessing.py +48 -0
  1033. qiskit/utils/optionals.py +320 -0
  1034. qiskit/utils/units.py +143 -0
  1035. qiskit/version.py +84 -0
  1036. qiskit/visualization/__init__.py +289 -0
  1037. qiskit/visualization/array.py +204 -0
  1038. qiskit/visualization/bloch.py +741 -0
  1039. qiskit/visualization/circuit/__init__.py +15 -0
  1040. qiskit/visualization/circuit/_utils.py +633 -0
  1041. qiskit/visualization/circuit/circuit_visualization.py +717 -0
  1042. qiskit/visualization/circuit/latex.py +659 -0
  1043. qiskit/visualization/circuit/matplotlib.py +1975 -0
  1044. qiskit/visualization/circuit/qcstyle.py +420 -0
  1045. qiskit/visualization/circuit/styles/bw.json +202 -0
  1046. qiskit/visualization/circuit/styles/clifford.json +202 -0
  1047. qiskit/visualization/circuit/styles/iqp-dark.json +214 -0
  1048. qiskit/visualization/circuit/styles/iqp.json +214 -0
  1049. qiskit/visualization/circuit/styles/textbook.json +202 -0
  1050. qiskit/visualization/circuit/text.py +1802 -0
  1051. qiskit/visualization/circuit_visualization.py +19 -0
  1052. qiskit/visualization/counts_visualization.py +496 -0
  1053. qiskit/visualization/dag_visualization.py +224 -0
  1054. qiskit/visualization/exceptions.py +21 -0
  1055. qiskit/visualization/gate_map.py +1461 -0
  1056. qiskit/visualization/pass_manager_visualization.py +281 -0
  1057. qiskit/visualization/pulse_v2/__init__.py +21 -0
  1058. qiskit/visualization/pulse_v2/core.py +905 -0
  1059. qiskit/visualization/pulse_v2/device_info.py +146 -0
  1060. qiskit/visualization/pulse_v2/drawings.py +253 -0
  1061. qiskit/visualization/pulse_v2/events.py +254 -0
  1062. qiskit/visualization/pulse_v2/generators/__init__.py +40 -0
  1063. qiskit/visualization/pulse_v2/generators/barrier.py +76 -0
  1064. qiskit/visualization/pulse_v2/generators/chart.py +208 -0
  1065. qiskit/visualization/pulse_v2/generators/frame.py +437 -0
  1066. qiskit/visualization/pulse_v2/generators/snapshot.py +133 -0
  1067. qiskit/visualization/pulse_v2/generators/waveform.py +649 -0
  1068. qiskit/visualization/pulse_v2/interface.py +452 -0
  1069. qiskit/visualization/pulse_v2/layouts.py +395 -0
  1070. qiskit/visualization/pulse_v2/plotters/__init__.py +17 -0
  1071. qiskit/visualization/pulse_v2/plotters/base_plotter.py +53 -0
  1072. qiskit/visualization/pulse_v2/plotters/matplotlib.py +202 -0
  1073. qiskit/visualization/pulse_v2/stylesheet.py +322 -0
  1074. qiskit/visualization/pulse_v2/types.py +242 -0
  1075. qiskit/visualization/qcstyle.py +17 -0
  1076. qiskit/visualization/state_visualization.py +1518 -0
  1077. qiskit/visualization/timeline/__init__.py +21 -0
  1078. qiskit/visualization/timeline/core.py +457 -0
  1079. qiskit/visualization/timeline/drawings.py +260 -0
  1080. qiskit/visualization/timeline/generators.py +506 -0
  1081. qiskit/visualization/timeline/interface.py +414 -0
  1082. qiskit/visualization/timeline/layouts.py +115 -0
  1083. qiskit/visualization/timeline/plotters/__init__.py +16 -0
  1084. qiskit/visualization/timeline/plotters/base_plotter.py +58 -0
  1085. qiskit/visualization/timeline/plotters/matplotlib.py +193 -0
  1086. qiskit/visualization/timeline/stylesheet.py +311 -0
  1087. qiskit/visualization/timeline/types.py +148 -0
  1088. qiskit/visualization/transition_visualization.py +364 -0
  1089. qiskit/visualization/utils.py +49 -0
  1090. qiskit-1.0.0b1.dist-info/LICENSE.txt +203 -0
  1091. qiskit-1.0.0b1.dist-info/METADATA +430 -0
  1092. qiskit-1.0.0b1.dist-info/RECORD +1095 -0
  1093. qiskit-1.0.0b1.dist-info/WHEEL +6 -0
  1094. qiskit-1.0.0b1.dist-info/entry_points.txt +49 -0
  1095. qiskit-1.0.0b1.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1212 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2021.
4
+ #
5
+ # This code is licensed under the Apache License, Version 2.0. You may
6
+ # obtain a copy of this license in the LICENSE.txt file in the root directory
7
+ # of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
8
+ #
9
+ # Any modifications or derivative works of this code must retain this
10
+ # copyright notice, and modified files need to carry a notice indicating
11
+ # that they have been altered from the originals.
12
+
13
+ # pylint: disable=invalid-name
14
+
15
+ """Binary IO for circuit objects."""
16
+
17
+ from collections import defaultdict
18
+ import io
19
+ import json
20
+ import struct
21
+ import uuid
22
+ import warnings
23
+
24
+ import numpy as np
25
+
26
+ from qiskit import circuit as circuit_mod
27
+ from qiskit import extensions
28
+ from qiskit.circuit import library, controlflow, CircuitInstruction, ControlFlowOp
29
+ from qiskit.circuit.classical import expr
30
+ from qiskit.circuit.classicalregister import ClassicalRegister, Clbit
31
+ from qiskit.circuit.gate import Gate
32
+ from qiskit.circuit.singleton import SingletonInstruction, SingletonGate
33
+ from qiskit.circuit.controlledgate import ControlledGate
34
+ from qiskit.circuit.instruction import Instruction
35
+ from qiskit.circuit.quantumcircuit import QuantumCircuit
36
+ from qiskit.circuit.quantumregister import QuantumRegister, Qubit
37
+ from qiskit.extensions import quantum_initializer
38
+ from qiskit.qpy import common, formats, type_keys
39
+ from qiskit.qpy.binary_io import value, schedules
40
+ from qiskit.quantum_info.operators import SparsePauliOp
41
+ from qiskit.synthesis import evolution as evo_synth
42
+ from qiskit.transpiler.layout import Layout, TranspileLayout
43
+
44
+
45
+ def _read_header_v2(file_obj, version, vectors, metadata_deserializer=None):
46
+
47
+ data = formats.CIRCUIT_HEADER_V2._make(
48
+ struct.unpack(
49
+ formats.CIRCUIT_HEADER_V2_PACK,
50
+ file_obj.read(formats.CIRCUIT_HEADER_V2_SIZE),
51
+ )
52
+ )
53
+
54
+ name = file_obj.read(data.name_size).decode(common.ENCODE)
55
+ global_phase = value.loads_value(
56
+ data.global_phase_type,
57
+ file_obj.read(data.global_phase_size),
58
+ version=version,
59
+ vectors=vectors,
60
+ )
61
+ header = {
62
+ "global_phase": global_phase,
63
+ "num_qubits": data.num_qubits,
64
+ "num_clbits": data.num_clbits,
65
+ "num_registers": data.num_registers,
66
+ "num_instructions": data.num_instructions,
67
+ }
68
+
69
+ metadata_raw = file_obj.read(data.metadata_size)
70
+ metadata = json.loads(metadata_raw, cls=metadata_deserializer)
71
+ return header, name, metadata
72
+
73
+
74
+ def _read_header(file_obj, metadata_deserializer=None):
75
+ data = formats.CIRCUIT_HEADER._make(
76
+ struct.unpack(formats.CIRCUIT_HEADER_PACK, file_obj.read(formats.CIRCUIT_HEADER_SIZE))
77
+ )
78
+ name = file_obj.read(data.name_size).decode(common.ENCODE)
79
+ header = {
80
+ "global_phase": data.global_phase,
81
+ "num_qubits": data.num_qubits,
82
+ "num_clbits": data.num_clbits,
83
+ "num_registers": data.num_registers,
84
+ "num_instructions": data.num_instructions,
85
+ }
86
+ metadata_raw = file_obj.read(data.metadata_size)
87
+ metadata = json.loads(metadata_raw, cls=metadata_deserializer)
88
+ return header, name, metadata
89
+
90
+
91
+ def _read_registers_v4(file_obj, num_registers):
92
+ registers = {"q": {}, "c": {}}
93
+ for _reg in range(num_registers):
94
+ data = formats.REGISTER_V4._make(
95
+ struct.unpack(
96
+ formats.REGISTER_V4_PACK,
97
+ file_obj.read(formats.REGISTER_V4_SIZE),
98
+ )
99
+ )
100
+ name = file_obj.read(data.name_size).decode("utf8")
101
+ REGISTER_ARRAY_PACK = "!%sq" % data.size
102
+ bit_indices_raw = file_obj.read(struct.calcsize(REGISTER_ARRAY_PACK))
103
+ bit_indices = list(struct.unpack(REGISTER_ARRAY_PACK, bit_indices_raw))
104
+ if data.type.decode("utf8") == "q":
105
+ registers["q"][name] = (data.standalone, bit_indices, data.in_circuit)
106
+ else:
107
+ registers["c"][name] = (data.standalone, bit_indices, data.in_circuit)
108
+ return registers
109
+
110
+
111
+ def _read_registers(file_obj, num_registers):
112
+ registers = {"q": {}, "c": {}}
113
+ for _reg in range(num_registers):
114
+ data = formats.REGISTER._make(
115
+ struct.unpack(
116
+ formats.REGISTER_PACK,
117
+ file_obj.read(formats.REGISTER_SIZE),
118
+ )
119
+ )
120
+ name = file_obj.read(data.name_size).decode("utf8")
121
+ REGISTER_ARRAY_PACK = "!%sI" % data.size
122
+ bit_indices_raw = file_obj.read(struct.calcsize(REGISTER_ARRAY_PACK))
123
+ bit_indices = list(struct.unpack(REGISTER_ARRAY_PACK, bit_indices_raw))
124
+ if data.type.decode("utf8") == "q":
125
+ registers["q"][name] = (data.standalone, bit_indices, True)
126
+ else:
127
+ registers["c"][name] = (data.standalone, bit_indices, True)
128
+ return registers
129
+
130
+
131
+ def _loads_instruction_parameter(
132
+ type_key, data_bytes, version, vectors, registers, circuit, use_symengine
133
+ ):
134
+ if type_key == type_keys.Program.CIRCUIT:
135
+ param = common.data_from_binary(data_bytes, read_circuit, version=version)
136
+ elif type_key == type_keys.Container.RANGE:
137
+ data = formats.RANGE._make(struct.unpack(formats.RANGE_PACK, data_bytes))
138
+ param = range(data.start, data.stop, data.step)
139
+ elif type_key == type_keys.Container.TUPLE:
140
+ param = tuple(
141
+ common.sequence_from_binary(
142
+ data_bytes,
143
+ _loads_instruction_parameter,
144
+ version=version,
145
+ vectors=vectors,
146
+ registers=registers,
147
+ circuit=circuit,
148
+ use_symengine=use_symengine,
149
+ )
150
+ )
151
+ elif type_key == type_keys.Value.INTEGER:
152
+ # TODO This uses little endian. Should be fixed in the next QPY version.
153
+ param = struct.unpack("<q", data_bytes)[0]
154
+ elif type_key == type_keys.Value.FLOAT:
155
+ # TODO This uses little endian. Should be fixed in the next QPY version.
156
+ param = struct.unpack("<d", data_bytes)[0]
157
+ elif type_key == type_keys.Value.REGISTER:
158
+ param = _loads_register_param(data_bytes.decode(common.ENCODE), circuit, registers)
159
+ else:
160
+ clbits = circuit.clbits if circuit is not None else ()
161
+ param = value.loads_value(
162
+ type_key,
163
+ data_bytes,
164
+ version,
165
+ vectors,
166
+ clbits=clbits,
167
+ cregs=registers["c"],
168
+ use_symengine=use_symengine,
169
+ )
170
+
171
+ return param
172
+
173
+
174
+ def _loads_register_param(data_bytes, circuit, registers):
175
+ # If register name prefixed with null character it's a clbit index for single bit condition.
176
+ if data_bytes[0] == "\x00":
177
+ conditional_bit = int(data_bytes[1:])
178
+ return circuit.clbits[conditional_bit]
179
+ return registers["c"][data_bytes]
180
+
181
+
182
+ def _read_instruction(
183
+ file_obj, circuit, registers, custom_operations, version, vectors, use_symengine
184
+ ):
185
+ if version < 5:
186
+ instruction = formats.CIRCUIT_INSTRUCTION._make(
187
+ struct.unpack(
188
+ formats.CIRCUIT_INSTRUCTION_PACK,
189
+ file_obj.read(formats.CIRCUIT_INSTRUCTION_SIZE),
190
+ )
191
+ )
192
+ else:
193
+ instruction = formats.CIRCUIT_INSTRUCTION_V2._make(
194
+ struct.unpack(
195
+ formats.CIRCUIT_INSTRUCTION_V2_PACK,
196
+ file_obj.read(formats.CIRCUIT_INSTRUCTION_V2_SIZE),
197
+ )
198
+ )
199
+ gate_name = file_obj.read(instruction.name_size).decode(common.ENCODE)
200
+ label = file_obj.read(instruction.label_size).decode(common.ENCODE)
201
+ condition_register = file_obj.read(instruction.condition_register_size).decode(common.ENCODE)
202
+ qargs = []
203
+ cargs = []
204
+ params = []
205
+ condition = None
206
+ if (version < 5 and instruction.has_condition) or (
207
+ version >= 5 and instruction.conditional_key == type_keys.Condition.TWO_TUPLE
208
+ ):
209
+ condition = (
210
+ _loads_register_param(condition_register, circuit, registers),
211
+ instruction.condition_value,
212
+ )
213
+ elif version >= 5 and instruction.conditional_key == type_keys.Condition.EXPRESSION:
214
+ condition = value.read_value(
215
+ file_obj,
216
+ version,
217
+ vectors,
218
+ clbits=circuit.clbits,
219
+ cregs=registers["c"],
220
+ use_symengine=use_symengine,
221
+ )
222
+ if circuit is not None:
223
+ qubit_indices = dict(enumerate(circuit.qubits))
224
+ clbit_indices = dict(enumerate(circuit.clbits))
225
+ else:
226
+ qubit_indices = {}
227
+ clbit_indices = {}
228
+
229
+ # Load Arguments
230
+ if circuit is not None:
231
+ for _qarg in range(instruction.num_qargs):
232
+ qarg = formats.CIRCUIT_INSTRUCTION_ARG._make(
233
+ struct.unpack(
234
+ formats.CIRCUIT_INSTRUCTION_ARG_PACK,
235
+ file_obj.read(formats.CIRCUIT_INSTRUCTION_ARG_SIZE),
236
+ )
237
+ )
238
+ if qarg.type.decode(common.ENCODE) == "c":
239
+ raise TypeError("Invalid input carg prior to all qargs")
240
+ qargs.append(qubit_indices[qarg.size])
241
+ for _carg in range(instruction.num_cargs):
242
+ carg = formats.CIRCUIT_INSTRUCTION_ARG._make(
243
+ struct.unpack(
244
+ formats.CIRCUIT_INSTRUCTION_ARG_PACK,
245
+ file_obj.read(formats.CIRCUIT_INSTRUCTION_ARG_SIZE),
246
+ )
247
+ )
248
+ if carg.type.decode(common.ENCODE) == "q":
249
+ raise TypeError("Invalid input qarg after all qargs")
250
+ cargs.append(clbit_indices[carg.size])
251
+
252
+ # Load Parameters
253
+ for _param in range(instruction.num_parameters):
254
+ type_key, data_bytes = common.read_generic_typed_data(file_obj)
255
+ param = _loads_instruction_parameter(
256
+ type_key, data_bytes, version, vectors, registers, circuit, use_symengine
257
+ )
258
+ params.append(param)
259
+
260
+ # Load Gate object
261
+ if gate_name in {"Gate", "Instruction", "ControlledGate"}:
262
+ inst_obj = _parse_custom_operation(
263
+ custom_operations, gate_name, params, version, vectors, registers, use_symengine
264
+ )
265
+ inst_obj.condition = condition
266
+ if instruction.label_size > 0:
267
+ inst_obj.label = label
268
+ if circuit is None:
269
+ return inst_obj
270
+ circuit._append(inst_obj, qargs, cargs)
271
+ return None
272
+ elif gate_name in custom_operations:
273
+ inst_obj = _parse_custom_operation(
274
+ custom_operations, gate_name, params, version, vectors, registers, use_symengine
275
+ )
276
+ inst_obj.condition = condition
277
+ if instruction.label_size > 0:
278
+ inst_obj.label = label
279
+ if circuit is None:
280
+ return inst_obj
281
+ circuit._append(inst_obj, qargs, cargs)
282
+ return None
283
+ elif hasattr(library, gate_name):
284
+ gate_class = getattr(library, gate_name)
285
+ elif hasattr(circuit_mod, gate_name):
286
+ gate_class = getattr(circuit_mod, gate_name)
287
+ elif hasattr(extensions, gate_name):
288
+ gate_class = getattr(extensions, gate_name)
289
+ elif hasattr(quantum_initializer, gate_name):
290
+ gate_class = getattr(quantum_initializer, gate_name)
291
+ elif hasattr(controlflow, gate_name):
292
+ gate_class = getattr(controlflow, gate_name)
293
+ else:
294
+ raise AttributeError("Invalid instruction type: %s" % gate_name)
295
+
296
+ if instruction.label_size <= 0:
297
+ label = None
298
+ if gate_name in {"IfElseOp", "WhileLoopOp"}:
299
+ gate = gate_class(condition, *params, label=label)
300
+ elif version >= 5 and issubclass(gate_class, ControlledGate):
301
+ if gate_name in {
302
+ "MCPhaseGate",
303
+ "MCU1Gate",
304
+ "MCXGrayCode",
305
+ "MCXGate",
306
+ "MCXRecursive",
307
+ "MCXVChain",
308
+ }:
309
+ gate = gate_class(*params, instruction.num_ctrl_qubits, label=label)
310
+ else:
311
+ gate = gate_class(*params, label=label)
312
+ if (
313
+ gate.num_ctrl_qubits != instruction.num_ctrl_qubits
314
+ or gate.ctrl_state != instruction.ctrl_state
315
+ ):
316
+ gate = gate.to_mutable()
317
+ gate.num_ctrl_qubits = instruction.num_ctrl_qubits
318
+ gate.ctrl_state = instruction.ctrl_state
319
+ if condition:
320
+ gate = gate.c_if(*condition)
321
+ else:
322
+ if gate_name in {"Initialize", "StatePreparation"}:
323
+ if isinstance(params[0], str):
324
+ # the params are the labels of the initial state
325
+ gate = gate_class("".join(label for label in params))
326
+ elif instruction.num_parameters == 1:
327
+ # the params is the integer indicating which qubits to initialize
328
+ gate = gate_class(int(params[0].real), instruction.num_qargs)
329
+ else:
330
+ # the params represent a list of complex amplitudes
331
+ gate = gate_class(params)
332
+ elif gate_name in {
333
+ "UCRXGate",
334
+ "UCRYGate",
335
+ "UCRZGate",
336
+ "DiagonalGate",
337
+ }:
338
+ gate = gate_class(params)
339
+ else:
340
+ if gate_name == "Barrier":
341
+ params = [len(qargs)]
342
+ elif gate_name in {"BreakLoopOp", "ContinueLoopOp"}:
343
+ params = [len(qargs), len(cargs)]
344
+ if label is not None:
345
+ if issubclass(gate_class, (SingletonInstruction, SingletonGate)):
346
+ gate = gate_class(*params, label=label)
347
+ else:
348
+ gate = gate_class(*params)
349
+ gate.label = label
350
+ else:
351
+ gate = gate_class(*params)
352
+ if condition:
353
+ if not isinstance(gate, ControlFlowOp):
354
+ gate = gate.c_if(*condition)
355
+ else:
356
+ gate.condition = condition
357
+ if circuit is None:
358
+ return gate
359
+ if not isinstance(gate, Instruction):
360
+ circuit.append(gate, qargs, cargs)
361
+ else:
362
+ circuit._append(CircuitInstruction(gate, qargs, cargs))
363
+ return None
364
+
365
+
366
+ def _parse_custom_operation(
367
+ custom_operations, gate_name, params, version, vectors, registers, use_symengine
368
+ ):
369
+ if version >= 5:
370
+ (
371
+ type_str,
372
+ num_qubits,
373
+ num_clbits,
374
+ definition,
375
+ num_ctrl_qubits,
376
+ ctrl_state,
377
+ base_gate_raw,
378
+ ) = custom_operations[gate_name]
379
+ else:
380
+ type_str, num_qubits, num_clbits, definition = custom_operations[gate_name]
381
+ type_key = type_keys.CircuitInstruction(type_str)
382
+
383
+ if type_key == type_keys.CircuitInstruction.INSTRUCTION:
384
+ inst_obj = Instruction(gate_name, num_qubits, num_clbits, params)
385
+ if definition is not None:
386
+ inst_obj.definition = definition
387
+ return inst_obj
388
+
389
+ if type_key == type_keys.CircuitInstruction.GATE:
390
+ inst_obj = Gate(gate_name, num_qubits, params)
391
+ inst_obj.definition = definition
392
+ return inst_obj
393
+
394
+ if version >= 5 and type_key == type_keys.CircuitInstruction.CONTROLLED_GATE:
395
+ with io.BytesIO(base_gate_raw) as base_gate_obj:
396
+ base_gate = _read_instruction(
397
+ base_gate_obj, None, registers, custom_operations, version, vectors, use_symengine
398
+ )
399
+ if ctrl_state < 2**num_ctrl_qubits - 1:
400
+ # If open controls, we need to discard the control suffix when setting the name.
401
+ gate_name = gate_name.rsplit("_", 1)[0]
402
+ inst_obj = ControlledGate(
403
+ gate_name,
404
+ num_qubits,
405
+ params,
406
+ num_ctrl_qubits=num_ctrl_qubits,
407
+ ctrl_state=ctrl_state,
408
+ base_gate=base_gate,
409
+ )
410
+ inst_obj.definition = definition
411
+ return inst_obj
412
+
413
+ if type_key == type_keys.CircuitInstruction.PAULI_EVOL_GATE:
414
+ return definition
415
+
416
+ raise ValueError("Invalid custom instruction type '%s'" % type_str)
417
+
418
+
419
+ def _read_pauli_evolution_gate(file_obj, version, vectors):
420
+ pauli_evolution_def = formats.PAULI_EVOLUTION_DEF._make(
421
+ struct.unpack(
422
+ formats.PAULI_EVOLUTION_DEF_PACK, file_obj.read(formats.PAULI_EVOLUTION_DEF_SIZE)
423
+ )
424
+ )
425
+ if pauli_evolution_def.operator_size != 1 and pauli_evolution_def.standalone_op:
426
+ raise ValueError(
427
+ "Can't have a standalone operator with {pauli_evolution_raw[0]} operators in the payload"
428
+ )
429
+
430
+ operator_list = []
431
+ for _ in range(pauli_evolution_def.operator_size):
432
+ op_elem = formats.SPARSE_PAULI_OP_LIST_ELEM._make(
433
+ struct.unpack(
434
+ formats.SPARSE_PAULI_OP_LIST_ELEM_PACK,
435
+ file_obj.read(formats.SPARSE_PAULI_OP_LIST_ELEM_SIZE),
436
+ )
437
+ )
438
+ op_raw_data = common.data_from_binary(file_obj.read(op_elem.size), np.load)
439
+ operator_list.append(SparsePauliOp.from_list(op_raw_data))
440
+
441
+ if pauli_evolution_def.standalone_op:
442
+ pauli_op = operator_list[0]
443
+ else:
444
+ pauli_op = operator_list
445
+
446
+ time = value.loads_value(
447
+ pauli_evolution_def.time_type,
448
+ file_obj.read(pauli_evolution_def.time_size),
449
+ version=version,
450
+ vectors=vectors,
451
+ )
452
+ synth_data = json.loads(file_obj.read(pauli_evolution_def.synth_method_size))
453
+ synthesis = getattr(evo_synth, synth_data["class"])(**synth_data["settings"])
454
+ return_gate = library.PauliEvolutionGate(pauli_op, time=time, synthesis=synthesis)
455
+ return return_gate
456
+
457
+
458
+ def _read_custom_operations(file_obj, version, vectors):
459
+ custom_operations = {}
460
+ custom_definition_header = formats.CUSTOM_CIRCUIT_DEF_HEADER._make(
461
+ struct.unpack(
462
+ formats.CUSTOM_CIRCUIT_DEF_HEADER_PACK,
463
+ file_obj.read(formats.CUSTOM_CIRCUIT_DEF_HEADER_SIZE),
464
+ )
465
+ )
466
+ if custom_definition_header.size > 0:
467
+ for _ in range(custom_definition_header.size):
468
+ if version < 5:
469
+ data = formats.CUSTOM_CIRCUIT_INST_DEF._make(
470
+ struct.unpack(
471
+ formats.CUSTOM_CIRCUIT_INST_DEF_PACK,
472
+ file_obj.read(formats.CUSTOM_CIRCUIT_INST_DEF_SIZE),
473
+ )
474
+ )
475
+ else:
476
+ data = formats.CUSTOM_CIRCUIT_INST_DEF_V2._make(
477
+ struct.unpack(
478
+ formats.CUSTOM_CIRCUIT_INST_DEF_V2_PACK,
479
+ file_obj.read(formats.CUSTOM_CIRCUIT_INST_DEF_V2_SIZE),
480
+ )
481
+ )
482
+
483
+ name = file_obj.read(data.gate_name_size).decode(common.ENCODE)
484
+ type_str = data.type
485
+ definition_circuit = None
486
+ if data.custom_definition:
487
+ def_binary = file_obj.read(data.size)
488
+ if version < 3 or not name.startswith(r"###PauliEvolutionGate_"):
489
+ definition_circuit = common.data_from_binary(
490
+ def_binary, read_circuit, version=version
491
+ )
492
+ elif name.startswith(r"###PauliEvolutionGate_"):
493
+ definition_circuit = common.data_from_binary(
494
+ def_binary, _read_pauli_evolution_gate, version=version, vectors=vectors
495
+ )
496
+ if version < 5:
497
+ data_payload = (type_str, data.num_qubits, data.num_clbits, definition_circuit)
498
+ else:
499
+ base_gate = file_obj.read(data.base_gate_size)
500
+ data_payload = (
501
+ type_str,
502
+ data.num_qubits,
503
+ data.num_clbits,
504
+ definition_circuit,
505
+ data.num_ctrl_qubits,
506
+ data.ctrl_state,
507
+ base_gate,
508
+ )
509
+ custom_operations[name] = data_payload
510
+ return custom_operations
511
+
512
+
513
+ def _read_calibrations(file_obj, version, vectors, metadata_deserializer):
514
+ calibrations = {}
515
+
516
+ header = formats.CALIBRATION._make(
517
+ struct.unpack(formats.CALIBRATION_PACK, file_obj.read(formats.CALIBRATION_SIZE))
518
+ )
519
+ for _ in range(header.num_cals):
520
+ defheader = formats.CALIBRATION_DEF._make(
521
+ struct.unpack(formats.CALIBRATION_DEF_PACK, file_obj.read(formats.CALIBRATION_DEF_SIZE))
522
+ )
523
+ name = file_obj.read(defheader.name_size).decode(common.ENCODE)
524
+ qubits = tuple(
525
+ struct.unpack("!q", file_obj.read(struct.calcsize("!q")))[0]
526
+ for _ in range(defheader.num_qubits)
527
+ )
528
+ params = tuple(
529
+ value.read_value(file_obj, version, vectors) for _ in range(defheader.num_params)
530
+ )
531
+ schedule = schedules.read_schedule_block(file_obj, version, metadata_deserializer)
532
+
533
+ if name not in calibrations:
534
+ calibrations[name] = {(qubits, params): schedule}
535
+ else:
536
+ calibrations[name][(qubits, params)] = schedule
537
+
538
+ return calibrations
539
+
540
+
541
+ def _dumps_register(register, index_map):
542
+ if isinstance(register, ClassicalRegister):
543
+ return register.name.encode(common.ENCODE)
544
+ # Clbit.
545
+ return b"\x00" + str(index_map["c"][register]).encode(common.ENCODE)
546
+
547
+
548
+ def _dumps_instruction_parameter(param, index_map, use_symengine):
549
+ if isinstance(param, QuantumCircuit):
550
+ type_key = type_keys.Program.CIRCUIT
551
+ data_bytes = common.data_to_binary(param, write_circuit)
552
+ elif isinstance(param, range):
553
+ type_key = type_keys.Container.RANGE
554
+ data_bytes = struct.pack(formats.RANGE_PACK, param.start, param.stop, param.step)
555
+ elif isinstance(param, tuple):
556
+ type_key = type_keys.Container.TUPLE
557
+ data_bytes = common.sequence_to_binary(
558
+ param, _dumps_instruction_parameter, index_map=index_map, use_symengine=use_symengine
559
+ )
560
+ elif isinstance(param, int):
561
+ # TODO This uses little endian. This should be fixed in next QPY version.
562
+ type_key = type_keys.Value.INTEGER
563
+ data_bytes = struct.pack("<q", param)
564
+ elif isinstance(param, float):
565
+ # TODO This uses little endian. This should be fixed in next QPY version.
566
+ type_key = type_keys.Value.FLOAT
567
+ data_bytes = struct.pack("<d", param)
568
+ elif isinstance(param, (Clbit, ClassicalRegister)):
569
+ type_key = type_keys.Value.REGISTER
570
+ data_bytes = _dumps_register(param, index_map)
571
+ else:
572
+ type_key, data_bytes = value.dumps_value(
573
+ param, index_map=index_map, use_symengine=use_symengine
574
+ )
575
+
576
+ return type_key, data_bytes
577
+
578
+
579
+ # pylint: disable=too-many-boolean-expressions
580
+ def _write_instruction(file_obj, instruction, custom_operations, index_map, use_symengine):
581
+ gate_class_name = instruction.operation.base_class.__name__
582
+ custom_operations_list = []
583
+ if (
584
+ (
585
+ not hasattr(library, gate_class_name)
586
+ and not hasattr(circuit_mod, gate_class_name)
587
+ and not hasattr(extensions, gate_class_name)
588
+ and not hasattr(quantum_initializer, gate_class_name)
589
+ and not hasattr(controlflow, gate_class_name)
590
+ )
591
+ or gate_class_name == "Gate"
592
+ or gate_class_name == "Instruction"
593
+ or isinstance(instruction.operation, library.BlueprintCircuit)
594
+ ):
595
+ gate_class_name = instruction.operation.name
596
+ # ucr*_dg gates can have different numbers of parameters,
597
+ # the uuid is appended to avoid storing a single definition
598
+ # in circuits with multiple ucr*_dg gates.
599
+ if instruction.operation.name in ["ucrx_dg", "ucry_dg", "ucrz_dg"]:
600
+ gate_class_name += "_" + str(uuid.uuid4())
601
+
602
+ if gate_class_name not in custom_operations:
603
+ custom_operations[gate_class_name] = instruction.operation
604
+ custom_operations_list.append(gate_class_name)
605
+
606
+ elif gate_class_name == "ControlledGate":
607
+ # controlled gates can have the same name but different parameter
608
+ # values, the uuid is appended to avoid storing a single definition
609
+ # in circuits with multiple controlled gates.
610
+ gate_class_name = instruction.operation.name + "_" + str(uuid.uuid4())
611
+ custom_operations[gate_class_name] = instruction.operation
612
+ custom_operations_list.append(gate_class_name)
613
+
614
+ elif isinstance(instruction.operation, library.PauliEvolutionGate):
615
+ gate_class_name = r"###PauliEvolutionGate_" + str(uuid.uuid4())
616
+ custom_operations[gate_class_name] = instruction.operation
617
+ custom_operations_list.append(gate_class_name)
618
+
619
+ condition_type = type_keys.Condition.NONE
620
+ condition_register = b""
621
+ condition_value = 0
622
+ if (op_condition := getattr(instruction.operation, "condition", None)) is not None:
623
+ if isinstance(op_condition, expr.Expr):
624
+ condition_type = type_keys.Condition.EXPRESSION
625
+ else:
626
+ condition_type = type_keys.Condition.TWO_TUPLE
627
+ condition_register = _dumps_register(instruction.operation.condition[0], index_map)
628
+ condition_value = int(instruction.operation.condition[1])
629
+
630
+ gate_class_name = gate_class_name.encode(common.ENCODE)
631
+ label = getattr(instruction.operation, "label")
632
+ if label:
633
+ label_raw = label.encode(common.ENCODE)
634
+ else:
635
+ label_raw = b""
636
+
637
+ # The instruction params we store are about being able to reconstruct the objects; they don't
638
+ # necessarily need to match one-to-one to the `params` field.
639
+ if isinstance(instruction.operation, controlflow.SwitchCaseOp):
640
+ instruction_params = [
641
+ instruction.operation.target,
642
+ tuple(instruction.operation.cases_specifier()),
643
+ ]
644
+ else:
645
+ instruction_params = instruction.operation.params
646
+
647
+ num_ctrl_qubits = getattr(instruction.operation, "num_ctrl_qubits", 0)
648
+ ctrl_state = getattr(instruction.operation, "ctrl_state", 0)
649
+ instruction_raw = struct.pack(
650
+ formats.CIRCUIT_INSTRUCTION_V2_PACK,
651
+ len(gate_class_name),
652
+ len(label_raw),
653
+ len(instruction_params),
654
+ instruction.operation.num_qubits,
655
+ instruction.operation.num_clbits,
656
+ condition_type.value,
657
+ len(condition_register),
658
+ condition_value,
659
+ num_ctrl_qubits,
660
+ ctrl_state,
661
+ )
662
+ file_obj.write(instruction_raw)
663
+ file_obj.write(gate_class_name)
664
+ file_obj.write(label_raw)
665
+ if condition_type is type_keys.Condition.EXPRESSION:
666
+ value.write_value(file_obj, op_condition, index_map=index_map)
667
+ else:
668
+ file_obj.write(condition_register)
669
+ # Encode instruction args
670
+ for qbit in instruction.qubits:
671
+ instruction_arg_raw = struct.pack(
672
+ formats.CIRCUIT_INSTRUCTION_ARG_PACK, b"q", index_map["q"][qbit]
673
+ )
674
+ file_obj.write(instruction_arg_raw)
675
+ for clbit in instruction.clbits:
676
+ instruction_arg_raw = struct.pack(
677
+ formats.CIRCUIT_INSTRUCTION_ARG_PACK, b"c", index_map["c"][clbit]
678
+ )
679
+ file_obj.write(instruction_arg_raw)
680
+ # Encode instruction params
681
+ for param in instruction_params:
682
+ type_key, data_bytes = _dumps_instruction_parameter(param, index_map, use_symengine)
683
+ common.write_generic_typed_data(file_obj, type_key, data_bytes)
684
+ return custom_operations_list
685
+
686
+
687
+ def _write_pauli_evolution_gate(file_obj, evolution_gate):
688
+ operator_list = evolution_gate.operator
689
+ standalone = False
690
+ if not isinstance(operator_list, list):
691
+ operator_list = [operator_list]
692
+ standalone = True
693
+ num_operators = len(operator_list)
694
+
695
+ def _write_elem(buffer, op):
696
+ elem_data = common.data_to_binary(op.to_list(array=True), np.save)
697
+ elem_metadata = struct.pack(formats.SPARSE_PAULI_OP_LIST_ELEM_PACK, len(elem_data))
698
+ buffer.write(elem_metadata)
699
+ buffer.write(elem_data)
700
+
701
+ pauli_data_buf = io.BytesIO()
702
+ for operator in operator_list:
703
+ data = common.data_to_binary(operator, _write_elem)
704
+ pauli_data_buf.write(data)
705
+
706
+ time_type, time_data = value.dumps_value(evolution_gate.time)
707
+ time_size = len(time_data)
708
+ synth_class = str(type(evolution_gate.synthesis).__name__)
709
+ settings_dict = evolution_gate.synthesis.settings
710
+ synth_data = json.dumps({"class": synth_class, "settings": settings_dict}).encode(common.ENCODE)
711
+ synth_size = len(synth_data)
712
+ pauli_evolution_raw = struct.pack(
713
+ formats.PAULI_EVOLUTION_DEF_PACK,
714
+ num_operators,
715
+ standalone,
716
+ time_type,
717
+ time_size,
718
+ synth_size,
719
+ )
720
+ file_obj.write(pauli_evolution_raw)
721
+ file_obj.write(pauli_data_buf.getvalue())
722
+ pauli_data_buf.close()
723
+ file_obj.write(time_data)
724
+ file_obj.write(synth_data)
725
+
726
+
727
+ def _write_custom_operation(file_obj, name, operation, custom_operations, use_symengine):
728
+ type_key = type_keys.CircuitInstruction.assign(operation)
729
+ has_definition = False
730
+ size = 0
731
+ data = None
732
+ num_qubits = operation.num_qubits
733
+ num_clbits = operation.num_clbits
734
+ ctrl_state = 0
735
+ num_ctrl_qubits = 0
736
+ base_gate = None
737
+ new_custom_instruction = []
738
+
739
+ if type_key == type_keys.CircuitInstruction.PAULI_EVOL_GATE:
740
+ has_definition = True
741
+ data = common.data_to_binary(operation, _write_pauli_evolution_gate)
742
+ size = len(data)
743
+ elif type_key == type_keys.CircuitInstruction.CONTROLLED_GATE:
744
+ # For ControlledGate, we have to access and store the private `_definition` rather than the
745
+ # public one, because the public one is mutated to include additional logic if the control
746
+ # state is open, and the definition setter (during a subsequent read) uses the "fully
747
+ # excited" control definition only.
748
+ has_definition = True
749
+ # Build internal definition to support overloaded subclasses by
750
+ # calling definition getter on object
751
+ operation.definition # pylint: disable=pointless-statement
752
+ data = common.data_to_binary(operation._definition, write_circuit)
753
+ size = len(data)
754
+ num_ctrl_qubits = operation.num_ctrl_qubits
755
+ ctrl_state = operation.ctrl_state
756
+ base_gate = operation.base_gate
757
+ elif operation.definition is not None:
758
+ has_definition = True
759
+ data = common.data_to_binary(operation.definition, write_circuit)
760
+ size = len(data)
761
+ if base_gate is None:
762
+ base_gate_raw = b""
763
+ else:
764
+ with io.BytesIO() as base_gate_buffer:
765
+ new_custom_instruction = _write_instruction(
766
+ base_gate_buffer,
767
+ CircuitInstruction(base_gate, (), ()),
768
+ custom_operations,
769
+ {},
770
+ use_symengine,
771
+ )
772
+ base_gate_raw = base_gate_buffer.getvalue()
773
+ name_raw = name.encode(common.ENCODE)
774
+ custom_operation_raw = struct.pack(
775
+ formats.CUSTOM_CIRCUIT_INST_DEF_V2_PACK,
776
+ len(name_raw),
777
+ type_key,
778
+ num_qubits,
779
+ num_clbits,
780
+ has_definition,
781
+ size,
782
+ num_ctrl_qubits,
783
+ ctrl_state,
784
+ len(base_gate_raw),
785
+ )
786
+ file_obj.write(custom_operation_raw)
787
+ file_obj.write(name_raw)
788
+ if data:
789
+ file_obj.write(data)
790
+ file_obj.write(base_gate_raw)
791
+ return new_custom_instruction
792
+
793
+
794
+ def _write_calibrations(file_obj, calibrations, metadata_serializer):
795
+ flatten_dict = {}
796
+ for gate, caldef in calibrations.items():
797
+ for (qubits, params), schedule in caldef.items():
798
+ key = (gate, qubits, params)
799
+ flatten_dict[key] = schedule
800
+ header = struct.pack(formats.CALIBRATION_PACK, len(flatten_dict))
801
+ file_obj.write(header)
802
+ for (name, qubits, params), schedule in flatten_dict.items():
803
+ # In principle ScheduleBlock and Schedule can be supported.
804
+ # As of version 5 only ScheduleBlock is supported.
805
+ name_bytes = name.encode(common.ENCODE)
806
+ defheader = struct.pack(
807
+ formats.CALIBRATION_DEF_PACK,
808
+ len(name_bytes),
809
+ len(qubits),
810
+ len(params),
811
+ type_keys.Program.assign(schedule),
812
+ )
813
+ file_obj.write(defheader)
814
+ file_obj.write(name_bytes)
815
+ for qubit in qubits:
816
+ file_obj.write(struct.pack("!q", qubit))
817
+ for param in params:
818
+ value.write_value(file_obj, param)
819
+ schedules.write_schedule_block(file_obj, schedule, metadata_serializer)
820
+
821
+
822
+ def _write_registers(file_obj, in_circ_regs, full_bits):
823
+ bitmap = {bit: index for index, bit in enumerate(full_bits)}
824
+
825
+ out_circ_regs = set()
826
+ for bit in full_bits:
827
+ if bit._register is not None and bit._register not in in_circ_regs:
828
+ out_circ_regs.add(bit._register)
829
+
830
+ for regs, is_in_circuit in [(in_circ_regs, True), (out_circ_regs, False)]:
831
+ for reg in regs:
832
+ standalone = all(bit._register is reg for bit in reg)
833
+ reg_name = reg.name.encode(common.ENCODE)
834
+ reg_type = reg.prefix.encode(common.ENCODE)
835
+ file_obj.write(
836
+ struct.pack(
837
+ formats.REGISTER_V4_PACK,
838
+ reg_type,
839
+ standalone,
840
+ reg.size,
841
+ len(reg_name),
842
+ is_in_circuit,
843
+ )
844
+ )
845
+ file_obj.write(reg_name)
846
+ REGISTER_ARRAY_PACK = "!%sq" % reg.size
847
+ bit_indices = []
848
+ for bit in reg:
849
+ bit_indices.append(bitmap.get(bit, -1))
850
+ file_obj.write(struct.pack(REGISTER_ARRAY_PACK, *bit_indices))
851
+
852
+ return len(in_circ_regs) + len(out_circ_regs)
853
+
854
+
855
+ def _write_layout(file_obj, circuit):
856
+ if circuit.layout is None:
857
+ # Write a null header if there is no layout present
858
+ file_obj.write(struct.pack(formats.LAYOUT_V2_PACK, False, -1, -1, -1, 0, 0))
859
+ return
860
+ initial_size = -1
861
+ input_qubit_mapping = {}
862
+ initial_layout_array = []
863
+ extra_registers = defaultdict(list)
864
+ if circuit.layout.initial_layout is not None:
865
+ initial_size = len(circuit.layout.initial_layout)
866
+ layout_mapping = circuit.layout.initial_layout.get_physical_bits()
867
+ for i in range(circuit.num_qubits):
868
+ qubit = layout_mapping[i]
869
+ input_qubit_mapping[qubit] = i
870
+ if qubit._register is not None or qubit._index is not None:
871
+ if qubit._register not in circuit.qregs:
872
+ extra_registers[qubit._register].append(qubit)
873
+ initial_layout_array.append((qubit._index, qubit._register))
874
+ else:
875
+ initial_layout_array.append((None, None))
876
+ input_qubit_size = -1
877
+ input_qubit_mapping_array = []
878
+ if circuit.layout.input_qubit_mapping is not None:
879
+ input_qubit_size = len(circuit.layout.input_qubit_mapping)
880
+ input_qubit_mapping_array = [None] * input_qubit_size
881
+ layout_mapping = circuit.layout.initial_layout.get_virtual_bits()
882
+ for qubit, index in circuit.layout.input_qubit_mapping.items():
883
+ if (
884
+ getattr(qubit, "_register", None) is not None
885
+ and getattr(qubit, "_index", None) is not None
886
+ ):
887
+ if qubit._register not in circuit.qregs:
888
+ extra_registers[qubit._register].append(qubit)
889
+ input_qubit_mapping_array[index] = layout_mapping[qubit]
890
+ else:
891
+ input_qubit_mapping_array[index] = layout_mapping[qubit]
892
+ final_layout_size = -1
893
+ final_layout_array = []
894
+ if circuit.layout.final_layout is not None:
895
+ final_layout_size = len(circuit.layout.final_layout)
896
+ final_layout_physical = circuit.layout.final_layout.get_physical_bits()
897
+ for i in range(circuit.num_qubits):
898
+ virtual_bit = final_layout_physical[i]
899
+ final_layout_array.append(circuit.find_bit(virtual_bit).index)
900
+
901
+ input_qubit_count = circuit._layout._input_qubit_count
902
+ if input_qubit_count is None:
903
+ input_qubit_count = -1
904
+ file_obj.write(
905
+ struct.pack(
906
+ formats.LAYOUT_V2_PACK,
907
+ True,
908
+ initial_size,
909
+ input_qubit_size,
910
+ final_layout_size,
911
+ len(extra_registers),
912
+ input_qubit_count,
913
+ )
914
+ )
915
+ _write_registers(
916
+ file_obj, list(extra_registers), [x for bits in extra_registers.values() for x in bits]
917
+ )
918
+ for index, register in initial_layout_array:
919
+ reg_name_bytes = None if register is None else register.name.encode(common.ENCODE)
920
+ file_obj.write(
921
+ struct.pack(
922
+ formats.INITIAL_LAYOUT_BIT_PACK,
923
+ -1 if index is None else index,
924
+ -1 if reg_name_bytes is None else len(reg_name_bytes),
925
+ )
926
+ )
927
+ if reg_name_bytes is not None:
928
+ file_obj.write(reg_name_bytes)
929
+ for i in input_qubit_mapping_array:
930
+ file_obj.write(struct.pack("!I", i))
931
+ for i in final_layout_array:
932
+ file_obj.write(struct.pack("!I", i))
933
+
934
+
935
+ def _read_layout(file_obj, circuit):
936
+ header = formats.LAYOUT._make(
937
+ struct.unpack(formats.LAYOUT_PACK, file_obj.read(formats.LAYOUT_SIZE))
938
+ )
939
+ if not header.exists:
940
+ return
941
+ _read_common_layout(file_obj, header, circuit)
942
+
943
+
944
+ def _read_common_layout(file_obj, header, circuit):
945
+ registers = {
946
+ name: QuantumRegister(len(v[1]), name)
947
+ for name, v in _read_registers_v4(file_obj, header.extra_registers)["q"].items()
948
+ }
949
+ initial_layout = None
950
+ initial_layout_virtual_bits = []
951
+ for _ in range(header.initial_layout_size):
952
+ virtual_bit = formats.INITIAL_LAYOUT_BIT._make(
953
+ struct.unpack(
954
+ formats.INITIAL_LAYOUT_BIT_PACK,
955
+ file_obj.read(formats.INITIAL_LAYOUT_BIT_SIZE),
956
+ )
957
+ )
958
+ if virtual_bit.index == -1 and virtual_bit.register_size == -1:
959
+ qubit = Qubit()
960
+ else:
961
+ register_name = file_obj.read(virtual_bit.register_size).decode(common.ENCODE)
962
+ if register_name in registers:
963
+ qubit = registers[register_name][virtual_bit.index]
964
+ else:
965
+ register = next(filter(lambda x, name=register_name: x.name == name, circuit.qregs))
966
+ qubit = register[virtual_bit.index]
967
+ initial_layout_virtual_bits.append(qubit)
968
+ if initial_layout_virtual_bits:
969
+ initial_layout = Layout.from_qubit_list(initial_layout_virtual_bits)
970
+ input_qubit_mapping = None
971
+ input_qubit_mapping_array = []
972
+ for _ in range(header.input_mapping_size):
973
+ input_qubit_mapping_array.append(
974
+ struct.unpack("!I", file_obj.read(struct.calcsize("!I")))[0]
975
+ )
976
+ if input_qubit_mapping_array:
977
+ input_qubit_mapping = {}
978
+ physical_bits = initial_layout.get_physical_bits()
979
+ for index, bit in enumerate(input_qubit_mapping_array):
980
+ input_qubit_mapping[physical_bits[bit]] = index
981
+ final_layout = None
982
+ final_layout_array = []
983
+ for _ in range(header.final_layout_size):
984
+ final_layout_array.append(struct.unpack("!I", file_obj.read(struct.calcsize("!I")))[0])
985
+
986
+ if final_layout_array:
987
+ layout_dict = {circuit.qubits[bit]: index for index, bit in enumerate(final_layout_array)}
988
+ final_layout = Layout(layout_dict)
989
+
990
+ circuit._layout = TranspileLayout(initial_layout, input_qubit_mapping, final_layout)
991
+
992
+
993
+ def _read_layout_v2(file_obj, circuit):
994
+ header = formats.LAYOUT_V2._make(
995
+ struct.unpack(formats.LAYOUT_V2_PACK, file_obj.read(formats.LAYOUT_V2_SIZE))
996
+ )
997
+ if not header.exists:
998
+ return
999
+ _read_common_layout(file_obj, header, circuit)
1000
+ if header.input_qubit_count >= 0:
1001
+ circuit._layout._input_qubit_count = header.input_qubit_count
1002
+ circuit._layout._output_qubit_list = circuit.qubits
1003
+
1004
+
1005
+ def write_circuit(file_obj, circuit, metadata_serializer=None, use_symengine=False):
1006
+ """Write a single QuantumCircuit object in the file like object.
1007
+
1008
+ Args:
1009
+ file_obj (FILE): The file like object to write the circuit data in.
1010
+ circuit (QuantumCircuit): The circuit data to write.
1011
+ metadata_serializer (JSONEncoder): An optional JSONEncoder class that
1012
+ will be passed the :attr:`.QuantumCircuit.metadata` dictionary for
1013
+ ``circuit`` and will be used as the ``cls`` kwarg
1014
+ on the ``json.dump()`` call to JSON serialize that dictionary.
1015
+ use_symengine (bool): If True, symbolic objects will be serialized using symengine's
1016
+ native mechanism. This is a faster serialization alternative, but not supported in all
1017
+ platforms. Please check that your target platform is supported by the symengine library
1018
+ before setting this option, as it will be required by qpy to deserialize the payload.
1019
+ """
1020
+ metadata_raw = json.dumps(
1021
+ circuit.metadata, separators=(",", ":"), cls=metadata_serializer
1022
+ ).encode(common.ENCODE)
1023
+ metadata_size = len(metadata_raw)
1024
+ num_instructions = len(circuit)
1025
+ circuit_name = circuit.name.encode(common.ENCODE)
1026
+ global_phase_type, global_phase_data = value.dumps_value(circuit.global_phase)
1027
+
1028
+ with io.BytesIO() as reg_buf:
1029
+ num_qregs = _write_registers(reg_buf, circuit.qregs, circuit.qubits)
1030
+ num_cregs = _write_registers(reg_buf, circuit.cregs, circuit.clbits)
1031
+ registers_raw = reg_buf.getvalue()
1032
+ num_registers = num_qregs + num_cregs
1033
+
1034
+ # Write circuit header
1035
+ header_raw = formats.CIRCUIT_HEADER_V2(
1036
+ name_size=len(circuit_name),
1037
+ global_phase_type=global_phase_type,
1038
+ global_phase_size=len(global_phase_data),
1039
+ num_qubits=circuit.num_qubits,
1040
+ num_clbits=circuit.num_clbits,
1041
+ metadata_size=metadata_size,
1042
+ num_registers=num_registers,
1043
+ num_instructions=num_instructions,
1044
+ )
1045
+ header = struct.pack(formats.CIRCUIT_HEADER_V2_PACK, *header_raw)
1046
+ file_obj.write(header)
1047
+ file_obj.write(circuit_name)
1048
+ file_obj.write(global_phase_data)
1049
+ file_obj.write(metadata_raw)
1050
+ # Write header payload
1051
+ file_obj.write(registers_raw)
1052
+ instruction_buffer = io.BytesIO()
1053
+ custom_operations = {}
1054
+ index_map = {}
1055
+ index_map["q"] = {bit: index for index, bit in enumerate(circuit.qubits)}
1056
+ index_map["c"] = {bit: index for index, bit in enumerate(circuit.clbits)}
1057
+ for instruction in circuit.data:
1058
+ _write_instruction(
1059
+ instruction_buffer, instruction, custom_operations, index_map, use_symengine
1060
+ )
1061
+
1062
+ with io.BytesIO() as custom_operations_buffer:
1063
+ new_custom_operations = list(custom_operations.keys())
1064
+ while new_custom_operations:
1065
+ operations_to_serialize = new_custom_operations.copy()
1066
+ new_custom_operations = []
1067
+ for name in operations_to_serialize:
1068
+ operation = custom_operations[name]
1069
+ new_custom_operations.extend(
1070
+ _write_custom_operation(
1071
+ custom_operations_buffer, name, operation, custom_operations, use_symengine
1072
+ )
1073
+ )
1074
+
1075
+ file_obj.write(struct.pack(formats.CUSTOM_CIRCUIT_DEF_HEADER_PACK, len(custom_operations)))
1076
+ file_obj.write(custom_operations_buffer.getvalue())
1077
+
1078
+ file_obj.write(instruction_buffer.getvalue())
1079
+ instruction_buffer.close()
1080
+
1081
+ # Write calibrations
1082
+ _write_calibrations(file_obj, circuit.calibrations, metadata_serializer)
1083
+ _write_layout(file_obj, circuit)
1084
+
1085
+
1086
+ def read_circuit(file_obj, version, metadata_deserializer=None, use_symengine=False):
1087
+ """Read a single QuantumCircuit object from the file like object.
1088
+
1089
+ Args:
1090
+ file_obj (FILE): The file like object to read the circuit data from.
1091
+ version (int): QPY version.
1092
+ metadata_deserializer (JSONDecoder): An optional JSONDecoder class
1093
+ that will be used for the ``cls`` kwarg on the internal
1094
+ ``json.load`` call used to deserialize the JSON payload used for
1095
+ the :attr:`.QuantumCircuit.metadata` attribute for a circuit
1096
+ in the file-like object. If this is not specified the circuit metadata will
1097
+ be parsed as JSON with the stdlib ``json.load()`` function using
1098
+ the default ``JSONDecoder`` class.
1099
+ use_symengine (bool): If True, symbolic objects will be de-serialized using
1100
+ symengine's native mechanism. This is a faster serialization alternative, but not
1101
+ supported in all platforms. Please check that your target platform is supported by
1102
+ the symengine library before setting this option, as it will be required by qpy to
1103
+ deserialize the payload.
1104
+ Returns:
1105
+ QuantumCircuit: The circuit object from the file.
1106
+
1107
+ Raises:
1108
+ QpyError: Invalid register.
1109
+ """
1110
+ vectors = {}
1111
+ if version < 2:
1112
+ header, name, metadata = _read_header(file_obj, metadata_deserializer=metadata_deserializer)
1113
+ else:
1114
+ header, name, metadata = _read_header_v2(
1115
+ file_obj, version, vectors, metadata_deserializer=metadata_deserializer
1116
+ )
1117
+
1118
+ global_phase = header["global_phase"]
1119
+ num_qubits = header["num_qubits"]
1120
+ num_clbits = header["num_clbits"]
1121
+ num_registers = header["num_registers"]
1122
+ num_instructions = header["num_instructions"]
1123
+ # `out_registers` is two "name: register" maps segregated by type for the rest of QPY, and
1124
+ # `all_registers` is the complete ordered list used to construct the `QuantumCircuit`.
1125
+ out_registers = {"q": {}, "c": {}}
1126
+ all_registers = []
1127
+ out_bits = {"q": [None] * num_qubits, "c": [None] * num_clbits}
1128
+ if num_registers > 0:
1129
+ if version < 4:
1130
+ registers = _read_registers(file_obj, num_registers)
1131
+ else:
1132
+ registers = _read_registers_v4(file_obj, num_registers)
1133
+ for bit_type_label, bit_type, reg_type in [
1134
+ ("q", Qubit, QuantumRegister),
1135
+ ("c", Clbit, ClassicalRegister),
1136
+ ]:
1137
+ # This does two passes through the registers. In the first, we're actually just
1138
+ # constructing the `Bit` instances: any register that is `standalone` "owns" all its
1139
+ # bits in the old Qiskit data model, so we have to construct those by creating the
1140
+ # register and taking the bits from them. That's the case even if that register isn't
1141
+ # actually in the circuit, which is why we stored them (with `in_circuit=False`) in QPY.
1142
+ #
1143
+ # Since there's no guarantees in QPY about the ordering of registers, we have to pass
1144
+ # through all registers to create the bits first, because we can't reliably know if a
1145
+ # non-standalone register contains bits from a standalone one until we've seen all
1146
+ # standalone registers.
1147
+ typed_bits = out_bits[bit_type_label]
1148
+ typed_registers = registers[bit_type_label]
1149
+ for register_name, (standalone, indices, _incircuit) in typed_registers.items():
1150
+ if not standalone:
1151
+ continue
1152
+ register = reg_type(len(indices), register_name)
1153
+ out_registers[bit_type_label][register_name] = register
1154
+ for owned, index in zip(register, indices):
1155
+ # Negative indices are for bits that aren't in the circuit.
1156
+ if index >= 0:
1157
+ typed_bits[index] = owned
1158
+ # Any remaining unset bits aren't owned, so we can construct them in the standard way.
1159
+ typed_bits = [bit if bit is not None else bit_type() for bit in typed_bits]
1160
+ # Finally _properly_ construct all the registers. Bits can be in more than one
1161
+ # register, including bits that are old-style "owned" by a register.
1162
+ for register_name, (standalone, indices, in_circuit) in typed_registers.items():
1163
+ if standalone:
1164
+ register = out_registers[bit_type_label][register_name]
1165
+ else:
1166
+ register = reg_type(
1167
+ name=register_name,
1168
+ bits=[typed_bits[x] if x >= 0 else bit_type() for x in indices],
1169
+ )
1170
+ out_registers[bit_type_label][register_name] = register
1171
+ if in_circuit:
1172
+ all_registers.append(register)
1173
+ out_bits[bit_type_label] = typed_bits
1174
+ else:
1175
+ out_bits = {
1176
+ "q": [Qubit() for _ in out_bits["q"]],
1177
+ "c": [Clbit() for _ in out_bits["c"]],
1178
+ }
1179
+ circ = QuantumCircuit(
1180
+ out_bits["q"],
1181
+ out_bits["c"],
1182
+ *all_registers,
1183
+ name=name,
1184
+ global_phase=global_phase,
1185
+ metadata=metadata,
1186
+ )
1187
+ custom_operations = _read_custom_operations(file_obj, version, vectors)
1188
+ for _instruction in range(num_instructions):
1189
+ _read_instruction(
1190
+ file_obj, circ, out_registers, custom_operations, version, vectors, use_symengine
1191
+ )
1192
+
1193
+ # Read calibrations
1194
+ if version >= 5:
1195
+ circ.calibrations = _read_calibrations(file_obj, version, vectors, metadata_deserializer)
1196
+
1197
+ for vec_name, (vector, initialized_params) in vectors.items():
1198
+ if len(initialized_params) != len(vector):
1199
+ warnings.warn(
1200
+ f"The ParameterVector: '{vec_name}' is not fully identical to its "
1201
+ "pre-serialization state. Elements "
1202
+ f"{', '.join([str(x) for x in set(range(len(vector))) - initialized_params])} "
1203
+ "in the ParameterVector will be not equal to the pre-serialized ParameterVector "
1204
+ f"as they weren't used in the circuit: {circ.name}",
1205
+ UserWarning,
1206
+ )
1207
+ if version >= 8:
1208
+ if version >= 10:
1209
+ _read_layout_v2(file_obj, circ)
1210
+ else:
1211
+ _read_layout(file_obj, circ)
1212
+ return circ