qiskit 2.0.3__cp39-abi3-manylinux2014_aarch64.manylinux_2_17_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 (690) hide show
  1. qiskit/VERSION.txt +1 -0
  2. qiskit/__init__.py +141 -0
  3. qiskit/_accelerate.abi3.so +0 -0
  4. qiskit/_numpy_compat.py +73 -0
  5. qiskit/circuit/__init__.py +1343 -0
  6. qiskit/circuit/_add_control.py +312 -0
  7. qiskit/circuit/_classical_resource_map.py +150 -0
  8. qiskit/circuit/_standard_gates_commutations.py +3849 -0
  9. qiskit/circuit/_utils.py +167 -0
  10. qiskit/circuit/annotated_operation.py +279 -0
  11. qiskit/circuit/barrier.py +46 -0
  12. qiskit/circuit/classical/__init__.py +41 -0
  13. qiskit/circuit/classical/expr/__init__.py +266 -0
  14. qiskit/circuit/classical/expr/constructors.py +764 -0
  15. qiskit/circuit/classical/expr/expr.py +498 -0
  16. qiskit/circuit/classical/expr/visitors.py +375 -0
  17. qiskit/circuit/classical/types/__init__.py +113 -0
  18. qiskit/circuit/classical/types/ordering.py +229 -0
  19. qiskit/circuit/classical/types/types.py +153 -0
  20. qiskit/circuit/commutation_checker.py +133 -0
  21. qiskit/circuit/commutation_library.py +20 -0
  22. qiskit/circuit/controlflow/__init__.py +59 -0
  23. qiskit/circuit/controlflow/_builder_utils.py +211 -0
  24. qiskit/circuit/controlflow/box.py +163 -0
  25. qiskit/circuit/controlflow/break_loop.py +56 -0
  26. qiskit/circuit/controlflow/builder.py +791 -0
  27. qiskit/circuit/controlflow/continue_loop.py +56 -0
  28. qiskit/circuit/controlflow/control_flow.py +94 -0
  29. qiskit/circuit/controlflow/for_loop.py +218 -0
  30. qiskit/circuit/controlflow/if_else.py +498 -0
  31. qiskit/circuit/controlflow/switch_case.py +411 -0
  32. qiskit/circuit/controlflow/while_loop.py +166 -0
  33. qiskit/circuit/controlledgate.py +274 -0
  34. qiskit/circuit/delay.py +157 -0
  35. qiskit/circuit/duration.py +80 -0
  36. qiskit/circuit/equivalence.py +94 -0
  37. qiskit/circuit/equivalence_library.py +18 -0
  38. qiskit/circuit/exceptions.py +19 -0
  39. qiskit/circuit/gate.py +261 -0
  40. qiskit/circuit/instruction.py +564 -0
  41. qiskit/circuit/instructionset.py +132 -0
  42. qiskit/circuit/library/__init__.py +984 -0
  43. qiskit/circuit/library/arithmetic/__init__.py +40 -0
  44. qiskit/circuit/library/arithmetic/adders/__init__.py +18 -0
  45. qiskit/circuit/library/arithmetic/adders/adder.py +235 -0
  46. qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +123 -0
  47. qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +129 -0
  48. qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +95 -0
  49. qiskit/circuit/library/arithmetic/exact_reciprocal.py +131 -0
  50. qiskit/circuit/library/arithmetic/functional_pauli_rotations.py +114 -0
  51. qiskit/circuit/library/arithmetic/integer_comparator.py +200 -0
  52. qiskit/circuit/library/arithmetic/linear_amplitude_function.py +363 -0
  53. qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +243 -0
  54. qiskit/circuit/library/arithmetic/multipliers/__init__.py +17 -0
  55. qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py +145 -0
  56. qiskit/circuit/library/arithmetic/multipliers/multiplier.py +201 -0
  57. qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +108 -0
  58. qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +502 -0
  59. qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +387 -0
  60. qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +493 -0
  61. qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +389 -0
  62. qiskit/circuit/library/arithmetic/quadratic_form.py +364 -0
  63. qiskit/circuit/library/arithmetic/weighted_adder.py +409 -0
  64. qiskit/circuit/library/basis_change/__init__.py +15 -0
  65. qiskit/circuit/library/basis_change/qft.py +316 -0
  66. qiskit/circuit/library/bit_flip_oracle.py +130 -0
  67. qiskit/circuit/library/blueprintcircuit.py +316 -0
  68. qiskit/circuit/library/boolean_logic/__init__.py +18 -0
  69. qiskit/circuit/library/boolean_logic/inner_product.py +157 -0
  70. qiskit/circuit/library/boolean_logic/quantum_and.py +204 -0
  71. qiskit/circuit/library/boolean_logic/quantum_or.py +206 -0
  72. qiskit/circuit/library/boolean_logic/quantum_xor.py +167 -0
  73. qiskit/circuit/library/data_preparation/__init__.py +57 -0
  74. qiskit/circuit/library/data_preparation/_z_feature_map.py +115 -0
  75. qiskit/circuit/library/data_preparation/_zz_feature_map.py +150 -0
  76. qiskit/circuit/library/data_preparation/initializer.py +107 -0
  77. qiskit/circuit/library/data_preparation/pauli_feature_map.py +656 -0
  78. qiskit/circuit/library/data_preparation/state_preparation.py +336 -0
  79. qiskit/circuit/library/fourier_checking.py +160 -0
  80. qiskit/circuit/library/generalized_gates/__init__.py +30 -0
  81. qiskit/circuit/library/generalized_gates/diagonal.py +159 -0
  82. qiskit/circuit/library/generalized_gates/gms.py +175 -0
  83. qiskit/circuit/library/generalized_gates/gr.py +219 -0
  84. qiskit/circuit/library/generalized_gates/isometry.py +370 -0
  85. qiskit/circuit/library/generalized_gates/linear_function.py +318 -0
  86. qiskit/circuit/library/generalized_gates/mcg_up_to_diagonal.py +143 -0
  87. qiskit/circuit/library/generalized_gates/mcmt.py +316 -0
  88. qiskit/circuit/library/generalized_gates/pauli.py +84 -0
  89. qiskit/circuit/library/generalized_gates/permutation.py +198 -0
  90. qiskit/circuit/library/generalized_gates/rv.py +96 -0
  91. qiskit/circuit/library/generalized_gates/uc.py +303 -0
  92. qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +164 -0
  93. qiskit/circuit/library/generalized_gates/ucrx.py +32 -0
  94. qiskit/circuit/library/generalized_gates/ucry.py +32 -0
  95. qiskit/circuit/library/generalized_gates/ucrz.py +32 -0
  96. qiskit/circuit/library/generalized_gates/unitary.py +217 -0
  97. qiskit/circuit/library/graph_state.py +172 -0
  98. qiskit/circuit/library/grover_operator.py +583 -0
  99. qiskit/circuit/library/hamiltonian_gate.py +142 -0
  100. qiskit/circuit/library/hidden_linear_function.py +163 -0
  101. qiskit/circuit/library/iqp.py +180 -0
  102. qiskit/circuit/library/n_local/__init__.py +45 -0
  103. qiskit/circuit/library/n_local/efficient_su2.py +282 -0
  104. qiskit/circuit/library/n_local/evolved_operator_ansatz.py +520 -0
  105. qiskit/circuit/library/n_local/excitation_preserving.py +303 -0
  106. qiskit/circuit/library/n_local/n_local.py +1477 -0
  107. qiskit/circuit/library/n_local/pauli_two_design.py +246 -0
  108. qiskit/circuit/library/n_local/qaoa_ansatz.py +367 -0
  109. qiskit/circuit/library/n_local/real_amplitudes.py +312 -0
  110. qiskit/circuit/library/n_local/two_local.py +289 -0
  111. qiskit/circuit/library/overlap.py +183 -0
  112. qiskit/circuit/library/pauli_evolution.py +201 -0
  113. qiskit/circuit/library/phase_estimation.py +177 -0
  114. qiskit/circuit/library/phase_oracle.py +239 -0
  115. qiskit/circuit/library/quantum_volume.py +180 -0
  116. qiskit/circuit/library/standard_gates/__init__.py +141 -0
  117. qiskit/circuit/library/standard_gates/dcx.py +77 -0
  118. qiskit/circuit/library/standard_gates/ecr.py +129 -0
  119. qiskit/circuit/library/standard_gates/equivalence_library.py +1800 -0
  120. qiskit/circuit/library/standard_gates/global_phase.py +84 -0
  121. qiskit/circuit/library/standard_gates/h.py +253 -0
  122. qiskit/circuit/library/standard_gates/i.py +76 -0
  123. qiskit/circuit/library/standard_gates/iswap.py +133 -0
  124. qiskit/circuit/library/standard_gates/p.py +422 -0
  125. qiskit/circuit/library/standard_gates/r.py +114 -0
  126. qiskit/circuit/library/standard_gates/rx.py +293 -0
  127. qiskit/circuit/library/standard_gates/rxx.py +180 -0
  128. qiskit/circuit/library/standard_gates/ry.py +286 -0
  129. qiskit/circuit/library/standard_gates/ryy.py +180 -0
  130. qiskit/circuit/library/standard_gates/rz.py +307 -0
  131. qiskit/circuit/library/standard_gates/rzx.py +226 -0
  132. qiskit/circuit/library/standard_gates/rzz.py +193 -0
  133. qiskit/circuit/library/standard_gates/s.py +419 -0
  134. qiskit/circuit/library/standard_gates/swap.py +281 -0
  135. qiskit/circuit/library/standard_gates/sx.py +310 -0
  136. qiskit/circuit/library/standard_gates/t.py +178 -0
  137. qiskit/circuit/library/standard_gates/u.py +395 -0
  138. qiskit/circuit/library/standard_gates/u1.py +490 -0
  139. qiskit/circuit/library/standard_gates/u2.py +145 -0
  140. qiskit/circuit/library/standard_gates/u3.py +428 -0
  141. qiskit/circuit/library/standard_gates/x.py +1481 -0
  142. qiskit/circuit/library/standard_gates/xx_minus_yy.py +202 -0
  143. qiskit/circuit/library/standard_gates/xx_plus_yy.py +236 -0
  144. qiskit/circuit/library/standard_gates/y.py +257 -0
  145. qiskit/circuit/library/standard_gates/z.py +338 -0
  146. qiskit/circuit/library/templates/__init__.py +92 -0
  147. qiskit/circuit/library/templates/clifford/__init__.py +33 -0
  148. qiskit/circuit/library/templates/clifford/clifford_2_1.py +34 -0
  149. qiskit/circuit/library/templates/clifford/clifford_2_2.py +35 -0
  150. qiskit/circuit/library/templates/clifford/clifford_2_3.py +34 -0
  151. qiskit/circuit/library/templates/clifford/clifford_2_4.py +34 -0
  152. qiskit/circuit/library/templates/clifford/clifford_3_1.py +35 -0
  153. qiskit/circuit/library/templates/clifford/clifford_4_1.py +38 -0
  154. qiskit/circuit/library/templates/clifford/clifford_4_2.py +37 -0
  155. qiskit/circuit/library/templates/clifford/clifford_4_3.py +38 -0
  156. qiskit/circuit/library/templates/clifford/clifford_4_4.py +37 -0
  157. qiskit/circuit/library/templates/clifford/clifford_5_1.py +40 -0
  158. qiskit/circuit/library/templates/clifford/clifford_6_1.py +40 -0
  159. qiskit/circuit/library/templates/clifford/clifford_6_2.py +40 -0
  160. qiskit/circuit/library/templates/clifford/clifford_6_3.py +40 -0
  161. qiskit/circuit/library/templates/clifford/clifford_6_4.py +38 -0
  162. qiskit/circuit/library/templates/clifford/clifford_6_5.py +40 -0
  163. qiskit/circuit/library/templates/clifford/clifford_8_1.py +42 -0
  164. qiskit/circuit/library/templates/clifford/clifford_8_2.py +42 -0
  165. qiskit/circuit/library/templates/clifford/clifford_8_3.py +41 -0
  166. qiskit/circuit/library/templates/nct/__init__.py +67 -0
  167. qiskit/circuit/library/templates/nct/template_nct_2a_1.py +34 -0
  168. qiskit/circuit/library/templates/nct/template_nct_2a_2.py +35 -0
  169. qiskit/circuit/library/templates/nct/template_nct_2a_3.py +37 -0
  170. qiskit/circuit/library/templates/nct/template_nct_4a_1.py +43 -0
  171. qiskit/circuit/library/templates/nct/template_nct_4a_2.py +41 -0
  172. qiskit/circuit/library/templates/nct/template_nct_4a_3.py +39 -0
  173. qiskit/circuit/library/templates/nct/template_nct_4b_1.py +41 -0
  174. qiskit/circuit/library/templates/nct/template_nct_4b_2.py +39 -0
  175. qiskit/circuit/library/templates/nct/template_nct_5a_1.py +40 -0
  176. qiskit/circuit/library/templates/nct/template_nct_5a_2.py +40 -0
  177. qiskit/circuit/library/templates/nct/template_nct_5a_3.py +40 -0
  178. qiskit/circuit/library/templates/nct/template_nct_5a_4.py +39 -0
  179. qiskit/circuit/library/templates/nct/template_nct_6a_1.py +40 -0
  180. qiskit/circuit/library/templates/nct/template_nct_6a_2.py +41 -0
  181. qiskit/circuit/library/templates/nct/template_nct_6a_3.py +41 -0
  182. qiskit/circuit/library/templates/nct/template_nct_6a_4.py +41 -0
  183. qiskit/circuit/library/templates/nct/template_nct_6b_1.py +41 -0
  184. qiskit/circuit/library/templates/nct/template_nct_6b_2.py +41 -0
  185. qiskit/circuit/library/templates/nct/template_nct_6c_1.py +41 -0
  186. qiskit/circuit/library/templates/nct/template_nct_7a_1.py +43 -0
  187. qiskit/circuit/library/templates/nct/template_nct_7b_1.py +43 -0
  188. qiskit/circuit/library/templates/nct/template_nct_7c_1.py +43 -0
  189. qiskit/circuit/library/templates/nct/template_nct_7d_1.py +43 -0
  190. qiskit/circuit/library/templates/nct/template_nct_7e_1.py +43 -0
  191. qiskit/circuit/library/templates/nct/template_nct_9a_1.py +45 -0
  192. qiskit/circuit/library/templates/nct/template_nct_9c_1.py +43 -0
  193. qiskit/circuit/library/templates/nct/template_nct_9c_10.py +44 -0
  194. qiskit/circuit/library/templates/nct/template_nct_9c_11.py +44 -0
  195. qiskit/circuit/library/templates/nct/template_nct_9c_12.py +44 -0
  196. qiskit/circuit/library/templates/nct/template_nct_9c_2.py +44 -0
  197. qiskit/circuit/library/templates/nct/template_nct_9c_3.py +44 -0
  198. qiskit/circuit/library/templates/nct/template_nct_9c_4.py +44 -0
  199. qiskit/circuit/library/templates/nct/template_nct_9c_5.py +44 -0
  200. qiskit/circuit/library/templates/nct/template_nct_9c_6.py +44 -0
  201. qiskit/circuit/library/templates/nct/template_nct_9c_7.py +44 -0
  202. qiskit/circuit/library/templates/nct/template_nct_9c_8.py +44 -0
  203. qiskit/circuit/library/templates/nct/template_nct_9c_9.py +44 -0
  204. qiskit/circuit/library/templates/nct/template_nct_9d_1.py +43 -0
  205. qiskit/circuit/library/templates/nct/template_nct_9d_10.py +44 -0
  206. qiskit/circuit/library/templates/nct/template_nct_9d_2.py +44 -0
  207. qiskit/circuit/library/templates/nct/template_nct_9d_3.py +44 -0
  208. qiskit/circuit/library/templates/nct/template_nct_9d_4.py +44 -0
  209. qiskit/circuit/library/templates/nct/template_nct_9d_5.py +44 -0
  210. qiskit/circuit/library/templates/nct/template_nct_9d_6.py +44 -0
  211. qiskit/circuit/library/templates/nct/template_nct_9d_7.py +44 -0
  212. qiskit/circuit/library/templates/nct/template_nct_9d_8.py +44 -0
  213. qiskit/circuit/library/templates/nct/template_nct_9d_9.py +44 -0
  214. qiskit/circuit/library/templates/rzx/__init__.py +25 -0
  215. qiskit/circuit/library/templates/rzx/rzx_cy.py +47 -0
  216. qiskit/circuit/library/templates/rzx/rzx_xz.py +54 -0
  217. qiskit/circuit/library/templates/rzx/rzx_yz.py +45 -0
  218. qiskit/circuit/library/templates/rzx/rzx_zz1.py +69 -0
  219. qiskit/circuit/library/templates/rzx/rzx_zz2.py +59 -0
  220. qiskit/circuit/library/templates/rzx/rzx_zz3.py +59 -0
  221. qiskit/circuit/measure.py +53 -0
  222. qiskit/circuit/operation.py +68 -0
  223. qiskit/circuit/parameter.py +179 -0
  224. qiskit/circuit/parameterexpression.py +703 -0
  225. qiskit/circuit/parametertable.py +119 -0
  226. qiskit/circuit/parametervector.py +140 -0
  227. qiskit/circuit/quantumcircuit.py +7540 -0
  228. qiskit/circuit/quantumcircuitdata.py +136 -0
  229. qiskit/circuit/random/__init__.py +15 -0
  230. qiskit/circuit/random/utils.py +366 -0
  231. qiskit/circuit/reset.py +37 -0
  232. qiskit/circuit/singleton.py +600 -0
  233. qiskit/circuit/store.py +89 -0
  234. qiskit/circuit/tools/__init__.py +16 -0
  235. qiskit/circuit/tools/pi_check.py +193 -0
  236. qiskit/circuit/twirling.py +145 -0
  237. qiskit/compiler/__init__.py +27 -0
  238. qiskit/compiler/transpiler.py +375 -0
  239. qiskit/converters/__init__.py +74 -0
  240. qiskit/converters/circuit_to_dag.py +80 -0
  241. qiskit/converters/circuit_to_dagdependency.py +49 -0
  242. qiskit/converters/circuit_to_dagdependency_v2.py +46 -0
  243. qiskit/converters/circuit_to_gate.py +107 -0
  244. qiskit/converters/circuit_to_instruction.py +142 -0
  245. qiskit/converters/dag_to_circuit.py +79 -0
  246. qiskit/converters/dag_to_dagdependency.py +54 -0
  247. qiskit/converters/dag_to_dagdependency_v2.py +43 -0
  248. qiskit/converters/dagdependency_to_circuit.py +40 -0
  249. qiskit/converters/dagdependency_to_dag.py +48 -0
  250. qiskit/dagcircuit/__init__.py +55 -0
  251. qiskit/dagcircuit/collect_blocks.py +407 -0
  252. qiskit/dagcircuit/dagcircuit.py +24 -0
  253. qiskit/dagcircuit/dagdependency.py +612 -0
  254. qiskit/dagcircuit/dagdependency_v2.py +566 -0
  255. qiskit/dagcircuit/dagdepnode.py +160 -0
  256. qiskit/dagcircuit/dagnode.py +188 -0
  257. qiskit/dagcircuit/exceptions.py +42 -0
  258. qiskit/exceptions.py +153 -0
  259. qiskit/passmanager/__init__.py +258 -0
  260. qiskit/passmanager/base_tasks.py +230 -0
  261. qiskit/passmanager/compilation_status.py +74 -0
  262. qiskit/passmanager/exceptions.py +19 -0
  263. qiskit/passmanager/flow_controllers.py +116 -0
  264. qiskit/passmanager/passmanager.py +353 -0
  265. qiskit/primitives/__init__.py +490 -0
  266. qiskit/primitives/backend_estimator_v2.py +530 -0
  267. qiskit/primitives/backend_sampler_v2.py +339 -0
  268. qiskit/primitives/base/__init__.py +20 -0
  269. qiskit/primitives/base/base_estimator.py +247 -0
  270. qiskit/primitives/base/base_primitive_job.py +78 -0
  271. qiskit/primitives/base/base_primitive_v1.py +45 -0
  272. qiskit/primitives/base/base_result_v1.py +65 -0
  273. qiskit/primitives/base/base_sampler.py +196 -0
  274. qiskit/primitives/base/estimator_result_v1.py +46 -0
  275. qiskit/primitives/base/sampler_result_v1.py +45 -0
  276. qiskit/primitives/base/validation_v1.py +250 -0
  277. qiskit/primitives/containers/__init__.py +26 -0
  278. qiskit/primitives/containers/bindings_array.py +391 -0
  279. qiskit/primitives/containers/bit_array.py +764 -0
  280. qiskit/primitives/containers/data_bin.py +175 -0
  281. qiskit/primitives/containers/estimator_pub.py +222 -0
  282. qiskit/primitives/containers/object_array.py +94 -0
  283. qiskit/primitives/containers/observables_array.py +296 -0
  284. qiskit/primitives/containers/primitive_result.py +53 -0
  285. qiskit/primitives/containers/pub_result.py +51 -0
  286. qiskit/primitives/containers/sampler_pub.py +193 -0
  287. qiskit/primitives/containers/sampler_pub_result.py +74 -0
  288. qiskit/primitives/containers/shape.py +129 -0
  289. qiskit/primitives/primitive_job.py +81 -0
  290. qiskit/primitives/statevector_estimator.py +175 -0
  291. qiskit/primitives/statevector_sampler.py +290 -0
  292. qiskit/primitives/utils.py +72 -0
  293. qiskit/providers/__init__.py +677 -0
  294. qiskit/providers/backend.py +364 -0
  295. qiskit/providers/basic_provider/__init__.py +47 -0
  296. qiskit/providers/basic_provider/basic_provider.py +121 -0
  297. qiskit/providers/basic_provider/basic_provider_job.py +65 -0
  298. qiskit/providers/basic_provider/basic_provider_tools.py +218 -0
  299. qiskit/providers/basic_provider/basic_simulator.py +693 -0
  300. qiskit/providers/basic_provider/exceptions.py +30 -0
  301. qiskit/providers/exceptions.py +33 -0
  302. qiskit/providers/fake_provider/__init__.py +69 -0
  303. qiskit/providers/fake_provider/generic_backend_v2.py +374 -0
  304. qiskit/providers/fake_provider/utils/__init__.py +15 -0
  305. qiskit/providers/job.py +147 -0
  306. qiskit/providers/jobstatus.py +30 -0
  307. qiskit/providers/options.py +273 -0
  308. qiskit/providers/providerutils.py +110 -0
  309. qiskit/qasm/libs/dummy/stdgates.inc +75 -0
  310. qiskit/qasm/libs/qelib1.inc +266 -0
  311. qiskit/qasm/libs/stdgates.inc +82 -0
  312. qiskit/qasm2/__init__.py +669 -0
  313. qiskit/qasm2/exceptions.py +27 -0
  314. qiskit/qasm2/export.py +364 -0
  315. qiskit/qasm2/parse.py +438 -0
  316. qiskit/qasm3/__init__.py +372 -0
  317. qiskit/qasm3/ast.py +782 -0
  318. qiskit/qasm3/exceptions.py +27 -0
  319. qiskit/qasm3/experimental.py +70 -0
  320. qiskit/qasm3/exporter.py +1340 -0
  321. qiskit/qasm3/printer.py +608 -0
  322. qiskit/qpy/__init__.py +1965 -0
  323. qiskit/qpy/binary_io/__init__.py +35 -0
  324. qiskit/qpy/binary_io/circuits.py +1455 -0
  325. qiskit/qpy/binary_io/parse_sympy_repr.py +121 -0
  326. qiskit/qpy/binary_io/schedules.py +308 -0
  327. qiskit/qpy/binary_io/value.py +1165 -0
  328. qiskit/qpy/common.py +353 -0
  329. qiskit/qpy/exceptions.py +53 -0
  330. qiskit/qpy/formats.py +442 -0
  331. qiskit/qpy/interface.py +344 -0
  332. qiskit/qpy/type_keys.py +409 -0
  333. qiskit/quantum_info/__init__.py +162 -0
  334. qiskit/quantum_info/analysis/__init__.py +17 -0
  335. qiskit/quantum_info/analysis/average.py +47 -0
  336. qiskit/quantum_info/analysis/distance.py +104 -0
  337. qiskit/quantum_info/analysis/make_observable.py +44 -0
  338. qiskit/quantum_info/analysis/z2_symmetries.py +484 -0
  339. qiskit/quantum_info/operators/__init__.py +28 -0
  340. qiskit/quantum_info/operators/base_operator.py +145 -0
  341. qiskit/quantum_info/operators/channel/__init__.py +29 -0
  342. qiskit/quantum_info/operators/channel/chi.py +191 -0
  343. qiskit/quantum_info/operators/channel/choi.py +218 -0
  344. qiskit/quantum_info/operators/channel/kraus.py +337 -0
  345. qiskit/quantum_info/operators/channel/ptm.py +204 -0
  346. qiskit/quantum_info/operators/channel/quantum_channel.py +348 -0
  347. qiskit/quantum_info/operators/channel/stinespring.py +296 -0
  348. qiskit/quantum_info/operators/channel/superop.py +373 -0
  349. qiskit/quantum_info/operators/channel/transformations.py +490 -0
  350. qiskit/quantum_info/operators/custom_iterator.py +48 -0
  351. qiskit/quantum_info/operators/dihedral/__init__.py +18 -0
  352. qiskit/quantum_info/operators/dihedral/dihedral.py +511 -0
  353. qiskit/quantum_info/operators/dihedral/dihedral_circuits.py +216 -0
  354. qiskit/quantum_info/operators/dihedral/polynomial.py +313 -0
  355. qiskit/quantum_info/operators/dihedral/random.py +64 -0
  356. qiskit/quantum_info/operators/linear_op.py +25 -0
  357. qiskit/quantum_info/operators/measures.py +418 -0
  358. qiskit/quantum_info/operators/mixins/__init__.py +52 -0
  359. qiskit/quantum_info/operators/mixins/adjoint.py +52 -0
  360. qiskit/quantum_info/operators/mixins/group.py +171 -0
  361. qiskit/quantum_info/operators/mixins/linear.py +84 -0
  362. qiskit/quantum_info/operators/mixins/multiply.py +62 -0
  363. qiskit/quantum_info/operators/mixins/tolerances.py +72 -0
  364. qiskit/quantum_info/operators/op_shape.py +525 -0
  365. qiskit/quantum_info/operators/operator.py +869 -0
  366. qiskit/quantum_info/operators/operator_utils.py +76 -0
  367. qiskit/quantum_info/operators/predicates.py +183 -0
  368. qiskit/quantum_info/operators/random.py +154 -0
  369. qiskit/quantum_info/operators/scalar_op.py +254 -0
  370. qiskit/quantum_info/operators/symplectic/__init__.py +23 -0
  371. qiskit/quantum_info/operators/symplectic/base_pauli.py +719 -0
  372. qiskit/quantum_info/operators/symplectic/clifford.py +1032 -0
  373. qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
  374. qiskit/quantum_info/operators/symplectic/pauli.py +755 -0
  375. qiskit/quantum_info/operators/symplectic/pauli_list.py +1242 -0
  376. qiskit/quantum_info/operators/symplectic/pauli_utils.py +40 -0
  377. qiskit/quantum_info/operators/symplectic/random.py +117 -0
  378. qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +1239 -0
  379. qiskit/quantum_info/operators/utils/__init__.py +20 -0
  380. qiskit/quantum_info/operators/utils/anti_commutator.py +36 -0
  381. qiskit/quantum_info/operators/utils/commutator.py +36 -0
  382. qiskit/quantum_info/operators/utils/double_commutator.py +76 -0
  383. qiskit/quantum_info/quaternion.py +156 -0
  384. qiskit/quantum_info/random.py +26 -0
  385. qiskit/quantum_info/states/__init__.py +28 -0
  386. qiskit/quantum_info/states/densitymatrix.py +857 -0
  387. qiskit/quantum_info/states/measures.py +288 -0
  388. qiskit/quantum_info/states/quantum_state.py +503 -0
  389. qiskit/quantum_info/states/random.py +157 -0
  390. qiskit/quantum_info/states/stabilizerstate.py +805 -0
  391. qiskit/quantum_info/states/statevector.py +977 -0
  392. qiskit/quantum_info/states/utils.py +247 -0
  393. qiskit/result/__init__.py +61 -0
  394. qiskit/result/counts.py +189 -0
  395. qiskit/result/distributions/__init__.py +17 -0
  396. qiskit/result/distributions/probability.py +100 -0
  397. qiskit/result/distributions/quasi.py +154 -0
  398. qiskit/result/exceptions.py +40 -0
  399. qiskit/result/models.py +241 -0
  400. qiskit/result/postprocess.py +239 -0
  401. qiskit/result/result.py +385 -0
  402. qiskit/result/sampled_expval.py +74 -0
  403. qiskit/result/utils.py +294 -0
  404. qiskit/synthesis/__init__.py +240 -0
  405. qiskit/synthesis/arithmetic/__init__.py +18 -0
  406. qiskit/synthesis/arithmetic/adders/__init__.py +17 -0
  407. qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +154 -0
  408. qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +103 -0
  409. qiskit/synthesis/arithmetic/adders/vbe_ripple_carry_adder.py +161 -0
  410. qiskit/synthesis/arithmetic/comparators/__init__.py +16 -0
  411. qiskit/synthesis/arithmetic/comparators/compare_2s.py +112 -0
  412. qiskit/synthesis/arithmetic/comparators/compare_greedy.py +66 -0
  413. qiskit/synthesis/arithmetic/multipliers/__init__.py +16 -0
  414. qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +103 -0
  415. qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +100 -0
  416. qiskit/synthesis/arithmetic/weighted_sum.py +155 -0
  417. qiskit/synthesis/boolean/__init__.py +13 -0
  418. qiskit/synthesis/boolean/boolean_expression.py +231 -0
  419. qiskit/synthesis/boolean/boolean_expression_synth.py +124 -0
  420. qiskit/synthesis/boolean/boolean_expression_visitor.py +96 -0
  421. qiskit/synthesis/clifford/__init__.py +19 -0
  422. qiskit/synthesis/clifford/clifford_decompose_ag.py +178 -0
  423. qiskit/synthesis/clifford/clifford_decompose_bm.py +46 -0
  424. qiskit/synthesis/clifford/clifford_decompose_full.py +64 -0
  425. qiskit/synthesis/clifford/clifford_decompose_greedy.py +58 -0
  426. qiskit/synthesis/clifford/clifford_decompose_layers.py +447 -0
  427. qiskit/synthesis/cnotdihedral/__init__.py +17 -0
  428. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py +52 -0
  429. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py +141 -0
  430. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py +266 -0
  431. qiskit/synthesis/discrete_basis/__init__.py +16 -0
  432. qiskit/synthesis/discrete_basis/commutator_decompose.py +265 -0
  433. qiskit/synthesis/discrete_basis/gate_sequence.py +421 -0
  434. qiskit/synthesis/discrete_basis/generate_basis_approximations.py +165 -0
  435. qiskit/synthesis/discrete_basis/solovay_kitaev.py +240 -0
  436. qiskit/synthesis/evolution/__init__.py +21 -0
  437. qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
  438. qiskit/synthesis/evolution/lie_trotter.py +120 -0
  439. qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
  440. qiskit/synthesis/evolution/pauli_network.py +80 -0
  441. qiskit/synthesis/evolution/product_formula.py +313 -0
  442. qiskit/synthesis/evolution/qdrift.py +130 -0
  443. qiskit/synthesis/evolution/suzuki_trotter.py +224 -0
  444. qiskit/synthesis/linear/__init__.py +26 -0
  445. qiskit/synthesis/linear/cnot_synth.py +69 -0
  446. qiskit/synthesis/linear/linear_circuits_utils.py +128 -0
  447. qiskit/synthesis/linear/linear_depth_lnn.py +61 -0
  448. qiskit/synthesis/linear/linear_matrix_utils.py +27 -0
  449. qiskit/synthesis/linear_phase/__init__.py +17 -0
  450. qiskit/synthesis/linear_phase/cnot_phase_synth.py +206 -0
  451. qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +61 -0
  452. qiskit/synthesis/linear_phase/cz_depth_lnn.py +58 -0
  453. qiskit/synthesis/multi_controlled/__init__.py +25 -0
  454. qiskit/synthesis/multi_controlled/mcmt_vchain.py +52 -0
  455. qiskit/synthesis/multi_controlled/mcx_synthesis.py +359 -0
  456. qiskit/synthesis/multi_controlled/multi_control_rotation_gates.py +206 -0
  457. qiskit/synthesis/one_qubit/__init__.py +15 -0
  458. qiskit/synthesis/one_qubit/one_qubit_decompose.py +288 -0
  459. qiskit/synthesis/permutation/__init__.py +18 -0
  460. qiskit/synthesis/permutation/permutation_full.py +78 -0
  461. qiskit/synthesis/permutation/permutation_lnn.py +54 -0
  462. qiskit/synthesis/permutation/permutation_reverse_lnn.py +93 -0
  463. qiskit/synthesis/permutation/permutation_utils.py +16 -0
  464. qiskit/synthesis/qft/__init__.py +16 -0
  465. qiskit/synthesis/qft/qft_decompose_full.py +97 -0
  466. qiskit/synthesis/qft/qft_decompose_lnn.py +79 -0
  467. qiskit/synthesis/stabilizer/__init__.py +16 -0
  468. qiskit/synthesis/stabilizer/stabilizer_circuit.py +149 -0
  469. qiskit/synthesis/stabilizer/stabilizer_decompose.py +194 -0
  470. qiskit/synthesis/two_qubit/__init__.py +20 -0
  471. qiskit/synthesis/two_qubit/local_invariance.py +63 -0
  472. qiskit/synthesis/two_qubit/two_qubit_decompose.py +583 -0
  473. qiskit/synthesis/two_qubit/xx_decompose/__init__.py +19 -0
  474. qiskit/synthesis/two_qubit/xx_decompose/circuits.py +300 -0
  475. qiskit/synthesis/two_qubit/xx_decompose/decomposer.py +324 -0
  476. qiskit/synthesis/two_qubit/xx_decompose/embodiments.py +163 -0
  477. qiskit/synthesis/two_qubit/xx_decompose/paths.py +412 -0
  478. qiskit/synthesis/two_qubit/xx_decompose/polytopes.py +262 -0
  479. qiskit/synthesis/two_qubit/xx_decompose/utilities.py +40 -0
  480. qiskit/synthesis/two_qubit/xx_decompose/weyl.py +133 -0
  481. qiskit/synthesis/unitary/__init__.py +13 -0
  482. qiskit/synthesis/unitary/aqc/__init__.py +177 -0
  483. qiskit/synthesis/unitary/aqc/approximate.py +116 -0
  484. qiskit/synthesis/unitary/aqc/aqc.py +175 -0
  485. qiskit/synthesis/unitary/aqc/cnot_structures.py +300 -0
  486. qiskit/synthesis/unitary/aqc/cnot_unit_circuit.py +103 -0
  487. qiskit/synthesis/unitary/aqc/cnot_unit_objective.py +299 -0
  488. qiskit/synthesis/unitary/aqc/elementary_operations.py +108 -0
  489. qiskit/synthesis/unitary/aqc/fast_gradient/__init__.py +164 -0
  490. qiskit/synthesis/unitary/aqc/fast_gradient/fast_grad_utils.py +237 -0
  491. qiskit/synthesis/unitary/aqc/fast_gradient/fast_gradient.py +226 -0
  492. qiskit/synthesis/unitary/aqc/fast_gradient/layer.py +370 -0
  493. qiskit/synthesis/unitary/aqc/fast_gradient/pmatrix.py +312 -0
  494. qiskit/synthesis/unitary/qsd.py +288 -0
  495. qiskit/transpiler/__init__.py +1345 -0
  496. qiskit/transpiler/basepasses.py +190 -0
  497. qiskit/transpiler/coupling.py +500 -0
  498. qiskit/transpiler/exceptions.py +59 -0
  499. qiskit/transpiler/instruction_durations.py +281 -0
  500. qiskit/transpiler/layout.py +740 -0
  501. qiskit/transpiler/passes/__init__.py +276 -0
  502. qiskit/transpiler/passes/analysis/__init__.py +23 -0
  503. qiskit/transpiler/passes/analysis/count_ops.py +30 -0
  504. qiskit/transpiler/passes/analysis/count_ops_longest_path.py +26 -0
  505. qiskit/transpiler/passes/analysis/dag_longest_path.py +24 -0
  506. qiskit/transpiler/passes/analysis/depth.py +33 -0
  507. qiskit/transpiler/passes/analysis/num_qubits.py +26 -0
  508. qiskit/transpiler/passes/analysis/num_tensor_factors.py +26 -0
  509. qiskit/transpiler/passes/analysis/resource_estimation.py +41 -0
  510. qiskit/transpiler/passes/analysis/size.py +36 -0
  511. qiskit/transpiler/passes/analysis/width.py +27 -0
  512. qiskit/transpiler/passes/basis/__init__.py +19 -0
  513. qiskit/transpiler/passes/basis/basis_translator.py +138 -0
  514. qiskit/transpiler/passes/basis/decompose.py +137 -0
  515. qiskit/transpiler/passes/basis/translate_parameterized.py +175 -0
  516. qiskit/transpiler/passes/basis/unroll_3q_or_more.py +84 -0
  517. qiskit/transpiler/passes/basis/unroll_custom_definitions.py +110 -0
  518. qiskit/transpiler/passes/layout/__init__.py +26 -0
  519. qiskit/transpiler/passes/layout/_csp_custom_solver.py +65 -0
  520. qiskit/transpiler/passes/layout/apply_layout.py +128 -0
  521. qiskit/transpiler/passes/layout/csp_layout.py +132 -0
  522. qiskit/transpiler/passes/layout/dense_layout.py +177 -0
  523. qiskit/transpiler/passes/layout/disjoint_utils.py +219 -0
  524. qiskit/transpiler/passes/layout/enlarge_with_ancilla.py +49 -0
  525. qiskit/transpiler/passes/layout/full_ancilla_allocation.py +116 -0
  526. qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
  527. qiskit/transpiler/passes/layout/sabre_layout.py +506 -0
  528. qiskit/transpiler/passes/layout/sabre_pre_layout.py +225 -0
  529. qiskit/transpiler/passes/layout/set_layout.py +69 -0
  530. qiskit/transpiler/passes/layout/trivial_layout.py +66 -0
  531. qiskit/transpiler/passes/layout/vf2_layout.py +256 -0
  532. qiskit/transpiler/passes/layout/vf2_post_layout.py +376 -0
  533. qiskit/transpiler/passes/layout/vf2_utils.py +235 -0
  534. qiskit/transpiler/passes/optimization/__init__.py +42 -0
  535. qiskit/transpiler/passes/optimization/_gate_extension.py +80 -0
  536. qiskit/transpiler/passes/optimization/collect_1q_runs.py +31 -0
  537. qiskit/transpiler/passes/optimization/collect_2q_blocks.py +35 -0
  538. qiskit/transpiler/passes/optimization/collect_and_collapse.py +117 -0
  539. qiskit/transpiler/passes/optimization/collect_cliffords.py +109 -0
  540. qiskit/transpiler/passes/optimization/collect_linear_functions.py +85 -0
  541. qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +242 -0
  542. qiskit/transpiler/passes/optimization/commutation_analysis.py +44 -0
  543. qiskit/transpiler/passes/optimization/commutative_cancellation.py +82 -0
  544. qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py +140 -0
  545. qiskit/transpiler/passes/optimization/consolidate_blocks.py +176 -0
  546. qiskit/transpiler/passes/optimization/contract_idle_wires_in_control_flow.py +104 -0
  547. qiskit/transpiler/passes/optimization/elide_permutations.py +91 -0
  548. qiskit/transpiler/passes/optimization/hoare_opt.py +420 -0
  549. qiskit/transpiler/passes/optimization/inverse_cancellation.py +95 -0
  550. qiskit/transpiler/passes/optimization/light_cone.py +135 -0
  551. qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +267 -0
  552. qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +250 -0
  553. qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
  554. qiskit/transpiler/passes/optimization/optimize_annotated.py +449 -0
  555. qiskit/transpiler/passes/optimization/optimize_cliffords.py +89 -0
  556. qiskit/transpiler/passes/optimization/optimize_swap_before_measure.py +71 -0
  557. qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py +41 -0
  558. qiskit/transpiler/passes/optimization/remove_final_reset.py +37 -0
  559. qiskit/transpiler/passes/optimization/remove_identity_equiv.py +70 -0
  560. qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
  561. qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +50 -0
  562. qiskit/transpiler/passes/optimization/split_2q_unitaries.py +63 -0
  563. qiskit/transpiler/passes/optimization/template_matching/__init__.py +19 -0
  564. qiskit/transpiler/passes/optimization/template_matching/backward_match.py +749 -0
  565. qiskit/transpiler/passes/optimization/template_matching/forward_match.py +452 -0
  566. qiskit/transpiler/passes/optimization/template_matching/maximal_matches.py +77 -0
  567. qiskit/transpiler/passes/optimization/template_matching/template_matching.py +370 -0
  568. qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +639 -0
  569. qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
  570. qiskit/transpiler/passes/routing/__init__.py +21 -0
  571. qiskit/transpiler/passes/routing/algorithms/__init__.py +33 -0
  572. qiskit/transpiler/passes/routing/algorithms/token_swapper.py +105 -0
  573. qiskit/transpiler/passes/routing/algorithms/types.py +46 -0
  574. qiskit/transpiler/passes/routing/algorithms/util.py +103 -0
  575. qiskit/transpiler/passes/routing/basic_swap.py +166 -0
  576. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/__init__.py +25 -0
  577. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_block.py +60 -0
  578. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +397 -0
  579. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/pauli_2q_evolution_commutation.py +145 -0
  580. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/swap_strategy.py +306 -0
  581. qiskit/transpiler/passes/routing/layout_transformation.py +119 -0
  582. qiskit/transpiler/passes/routing/lookahead_swap.py +390 -0
  583. qiskit/transpiler/passes/routing/sabre_swap.py +463 -0
  584. qiskit/transpiler/passes/routing/star_prerouting.py +408 -0
  585. qiskit/transpiler/passes/routing/utils.py +35 -0
  586. qiskit/transpiler/passes/scheduling/__init__.py +21 -0
  587. qiskit/transpiler/passes/scheduling/alignments/__init__.py +79 -0
  588. qiskit/transpiler/passes/scheduling/alignments/check_durations.py +70 -0
  589. qiskit/transpiler/passes/scheduling/alignments/reschedule.py +251 -0
  590. qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
  591. qiskit/transpiler/passes/scheduling/padding/base_padding.py +284 -0
  592. qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +415 -0
  593. qiskit/transpiler/passes/scheduling/padding/pad_delay.py +90 -0
  594. qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
  595. qiskit/transpiler/passes/scheduling/scheduling/alap.py +93 -0
  596. qiskit/transpiler/passes/scheduling/scheduling/asap.py +100 -0
  597. qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +88 -0
  598. qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
  599. qiskit/transpiler/passes/scheduling/time_unit_conversion.py +237 -0
  600. qiskit/transpiler/passes/synthesis/__init__.py +20 -0
  601. qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
  602. qiskit/transpiler/passes/synthesis/default_unitary_synth_plugin.py +653 -0
  603. qiskit/transpiler/passes/synthesis/high_level_synthesis.py +429 -0
  604. qiskit/transpiler/passes/synthesis/hls_plugins.py +1963 -0
  605. qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +41 -0
  606. qiskit/transpiler/passes/synthesis/plugin.py +738 -0
  607. qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +313 -0
  608. qiskit/transpiler/passes/synthesis/unitary_synthesis.py +425 -0
  609. qiskit/transpiler/passes/utils/__init__.py +32 -0
  610. qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +41 -0
  611. qiskit/transpiler/passes/utils/check_gate_direction.py +60 -0
  612. qiskit/transpiler/passes/utils/check_map.py +78 -0
  613. qiskit/transpiler/passes/utils/contains_instruction.py +45 -0
  614. qiskit/transpiler/passes/utils/control_flow.py +61 -0
  615. qiskit/transpiler/passes/utils/dag_fixed_point.py +36 -0
  616. qiskit/transpiler/passes/utils/error.py +69 -0
  617. qiskit/transpiler/passes/utils/filter_op_nodes.py +66 -0
  618. qiskit/transpiler/passes/utils/fixed_point.py +48 -0
  619. qiskit/transpiler/passes/utils/gate_direction.py +93 -0
  620. qiskit/transpiler/passes/utils/gates_basis.py +51 -0
  621. qiskit/transpiler/passes/utils/merge_adjacent_barriers.py +163 -0
  622. qiskit/transpiler/passes/utils/minimum_point.py +118 -0
  623. qiskit/transpiler/passes/utils/remove_barriers.py +50 -0
  624. qiskit/transpiler/passes/utils/remove_final_measurements.py +121 -0
  625. qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
  626. qiskit/transpiler/passmanager.py +503 -0
  627. qiskit/transpiler/passmanager_config.py +151 -0
  628. qiskit/transpiler/preset_passmanagers/__init__.py +93 -0
  629. qiskit/transpiler/preset_passmanagers/builtin_plugins.py +993 -0
  630. qiskit/transpiler/preset_passmanagers/common.py +672 -0
  631. qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +437 -0
  632. qiskit/transpiler/preset_passmanagers/level0.py +104 -0
  633. qiskit/transpiler/preset_passmanagers/level1.py +108 -0
  634. qiskit/transpiler/preset_passmanagers/level2.py +109 -0
  635. qiskit/transpiler/preset_passmanagers/level3.py +110 -0
  636. qiskit/transpiler/preset_passmanagers/plugin.py +346 -0
  637. qiskit/transpiler/target.py +905 -0
  638. qiskit/transpiler/timing_constraints.py +59 -0
  639. qiskit/user_config.py +266 -0
  640. qiskit/utils/__init__.py +90 -0
  641. qiskit/utils/classtools.py +146 -0
  642. qiskit/utils/deprecation.py +382 -0
  643. qiskit/utils/lazy_tester.py +363 -0
  644. qiskit/utils/optionals.py +354 -0
  645. qiskit/utils/parallel.py +318 -0
  646. qiskit/utils/units.py +146 -0
  647. qiskit/version.py +84 -0
  648. qiskit/visualization/__init__.py +290 -0
  649. qiskit/visualization/array.py +207 -0
  650. qiskit/visualization/bloch.py +778 -0
  651. qiskit/visualization/circuit/__init__.py +15 -0
  652. qiskit/visualization/circuit/_utils.py +675 -0
  653. qiskit/visualization/circuit/circuit_visualization.py +735 -0
  654. qiskit/visualization/circuit/latex.py +661 -0
  655. qiskit/visualization/circuit/matplotlib.py +2019 -0
  656. qiskit/visualization/circuit/qcstyle.py +278 -0
  657. qiskit/visualization/circuit/styles/__init__.py +13 -0
  658. qiskit/visualization/circuit/styles/bw.json +202 -0
  659. qiskit/visualization/circuit/styles/clifford.json +202 -0
  660. qiskit/visualization/circuit/styles/iqp-dark.json +214 -0
  661. qiskit/visualization/circuit/styles/iqp.json +214 -0
  662. qiskit/visualization/circuit/styles/textbook.json +202 -0
  663. qiskit/visualization/circuit/text.py +1849 -0
  664. qiskit/visualization/circuit_visualization.py +19 -0
  665. qiskit/visualization/counts_visualization.py +487 -0
  666. qiskit/visualization/dag_visualization.py +318 -0
  667. qiskit/visualization/exceptions.py +21 -0
  668. qiskit/visualization/gate_map.py +1424 -0
  669. qiskit/visualization/library.py +40 -0
  670. qiskit/visualization/pass_manager_visualization.py +312 -0
  671. qiskit/visualization/state_visualization.py +1546 -0
  672. qiskit/visualization/timeline/__init__.py +21 -0
  673. qiskit/visualization/timeline/core.py +495 -0
  674. qiskit/visualization/timeline/drawings.py +260 -0
  675. qiskit/visualization/timeline/generators.py +506 -0
  676. qiskit/visualization/timeline/interface.py +444 -0
  677. qiskit/visualization/timeline/layouts.py +115 -0
  678. qiskit/visualization/timeline/plotters/__init__.py +16 -0
  679. qiskit/visualization/timeline/plotters/base_plotter.py +58 -0
  680. qiskit/visualization/timeline/plotters/matplotlib.py +195 -0
  681. qiskit/visualization/timeline/stylesheet.py +301 -0
  682. qiskit/visualization/timeline/types.py +148 -0
  683. qiskit/visualization/transition_visualization.py +369 -0
  684. qiskit/visualization/utils.py +49 -0
  685. qiskit-2.0.3.dist-info/METADATA +220 -0
  686. qiskit-2.0.3.dist-info/RECORD +690 -0
  687. qiskit-2.0.3.dist-info/WHEEL +6 -0
  688. qiskit-2.0.3.dist-info/entry_points.txt +82 -0
  689. qiskit-2.0.3.dist-info/licenses/LICENSE.txt +203 -0
  690. qiskit-2.0.3.dist-info/top_level.txt +1 -0
@@ -0,0 +1,735 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2017, 2018.
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
+ """
14
+ Module for the primary interface to the circuit drawers.
15
+
16
+ This module contains the end user facing API for drawing quantum circuits.
17
+ There are 3 available drawer backends:
18
+
19
+ 0. ASCII art
20
+ 1. LaTeX
21
+ 2. Matplotlib
22
+
23
+ This provides a single function entry point to drawing a circuit object with
24
+ any of the backends.
25
+ """
26
+
27
+ from __future__ import annotations
28
+
29
+ import logging
30
+ import os
31
+ import shutil
32
+ import subprocess
33
+ import tempfile
34
+ import typing
35
+ from warnings import warn
36
+
37
+ from qiskit import user_config
38
+ from qiskit.circuit import ControlFlowOp, Measure
39
+ from qiskit.utils import optionals as _optionals
40
+
41
+ from ..exceptions import VisualizationError
42
+ from ..utils import _trim as trim_image
43
+ from . import _utils
44
+ from . import latex as _latex
45
+ from . import matplotlib as _matplotlib
46
+ from . import text as _text
47
+
48
+ if typing.TYPE_CHECKING:
49
+ from typing import Any
50
+ from qiskit.circuit import QuantumCircuit # pylint: disable=cyclic-import
51
+
52
+
53
+ logger = logging.getLogger(__name__)
54
+
55
+
56
+ def circuit_drawer(
57
+ circuit: QuantumCircuit,
58
+ scale: float | None = None,
59
+ filename: str | None = None,
60
+ style: dict | str | None = None,
61
+ output: str | None = None,
62
+ interactive: bool = False,
63
+ plot_barriers: bool = True,
64
+ reverse_bits: bool | None = None,
65
+ justify: str | None = None,
66
+ vertical_compression: str | None = "medium",
67
+ idle_wires: bool | str | None = None,
68
+ with_layout: bool = True,
69
+ fold: int | None = None,
70
+ # The type of ax is matplotlib.axes.Axes, but this is not a fixed dependency, so cannot be
71
+ # safely forward-referenced.
72
+ ax: Any | None = None,
73
+ initial_state: bool = False,
74
+ cregbundle: bool | None = None,
75
+ wire_order: list[int] | None = None,
76
+ expr_len: int = 30,
77
+ ):
78
+ r"""Draw the quantum circuit. Use the output parameter to choose the drawing format:
79
+
80
+ **text**: ASCII art TextDrawing that can be printed in the console.
81
+
82
+ **mpl**: images with color rendered purely in Python using matplotlib.
83
+
84
+ **latex**: high-quality images compiled via latex.
85
+
86
+ **latex_source**: raw uncompiled latex output.
87
+
88
+ .. warning::
89
+
90
+ Support for :class:`~.expr.Expr` nodes in conditions and :attr:`.SwitchCaseOp.target`
91
+ fields is preliminary and incomplete. The ``text`` and ``mpl`` drawers will make a
92
+ best-effort attempt to show data dependencies, but the LaTeX-based drawers will skip
93
+ these completely.
94
+
95
+ Args:
96
+ circuit: The circuit to visualize.
97
+ scale: Scale of image to draw (shrink if ``< 1.0``). Only used by
98
+ the ``mpl``, ``latex`` and ``latex_source`` outputs. Defaults to ``1.0``.
99
+ filename: File path to save image to. Defaults to ``None`` (result not saved in a file).
100
+ style: Style name, file name of style JSON file, or a dictionary specifying the style.
101
+
102
+ * The supported style names are ``"iqp"`` (default), ``"iqp-dark"``, ``"clifford"``,
103
+ ``"textbook"`` and ``"bw"``.
104
+ * If given a JSON file, e.g. ``my_style.json`` or ``my_style`` (the ``.json``
105
+ extension may be omitted), this function attempts to load the style dictionary
106
+ from that location. Note, that the JSON file must completely specify the
107
+ visualization specifications. The file is searched for in
108
+ ``qiskit/visualization/circuit/styles``, the current working directory, and
109
+ the location specified in ``~/.qiskit/settings.conf``.
110
+ * If a dictionary, every entry overrides the default configuration. If the
111
+ ``"name"`` key is given, the default configuration is given by that style.
112
+ For example, ``{"name": "textbook", "subfontsize": 5}`` loads the ``"texbook"``
113
+ style and sets the subfontsize (e.g. the gate angles) to ``5``.
114
+ * If ``None`` the default style ``"iqp"`` is used or, if given, the default style
115
+ specified in ``~/.qiskit/settings.conf``.
116
+
117
+ output: Select the output method to use for drawing the circuit.
118
+ Valid choices are ``text``, ``mpl``, ``latex``, ``latex_source``.
119
+ By default, the ``text`` drawer is used unless the user config file
120
+ (usually ``~/.qiskit/settings.conf``) has an alternative backend set
121
+ as the default. For example, ``circuit_drawer = latex``. If the output
122
+ kwarg is set, that backend will always be used over the default in
123
+ the user config file.
124
+ interactive: When set to ``True``, show the circuit in a new window
125
+ (for ``mpl`` this depends on the matplotlib backend being used
126
+ supporting this). Note when used with either the `text` or the
127
+ ``latex_source`` output type this has no effect and will be silently
128
+ ignored. Defaults to ``False``.
129
+ reverse_bits: When set to ``True``, reverse the bit order inside
130
+ registers for the output visualization. Defaults to ``False`` unless the
131
+ user config file (usually ``~/.qiskit/settings.conf``) has an
132
+ alternative value set. For example, ``circuit_reverse_bits = True``.
133
+ plot_barriers: Enable/disable drawing barriers in the output
134
+ circuit. Defaults to ``True``.
135
+ justify: Options are ``"left"``, ``"right"`` or ``"none"`` (str).
136
+ If anything else is supplied, left justified will be used instead.
137
+ It refers to where gates should be placed in the output circuit if
138
+ there is an option. ``none`` results in each gate being placed in
139
+ its own column. Defaults to ``left``.
140
+ vertical_compression: ``high``, ``medium`` or ``low``. It
141
+ merges the lines generated by the `text` output so the drawing
142
+ will take less vertical room. Default is ``medium``. Only used by
143
+ the ``text`` output, will be silently ignored otherwise.
144
+ idle_wires: Include (or not) idle wires (wires with no circuit elements)
145
+ in output visualization. The string ``"auto"`` is also possible, in which
146
+ case idle wires are show except that the circuit has a layout attached.
147
+ Default is ``"auto"`` unless the
148
+ user config file (usually ``~/.qiskit/settings.conf``) has an
149
+ alternative value set. For example, ``circuit_idle_wires = False``.
150
+ with_layout: Include layout information, with labels on the
151
+ physical layout. Default is ``True``.
152
+ fold: Sets pagination. It can be disabled using -1. In ``text``,
153
+ sets the length of the lines. This is useful when the drawing does
154
+ not fit in the console. If None (default), it will try to guess the
155
+ console width using ``shutil.get_terminal_size()``. However, if
156
+ running in jupyter, the default line length is set to 80 characters.
157
+ In ``mpl``, it is the number of (visual) layers before folding.
158
+ Default is 25.
159
+ ax: Only used by the `mpl` backend. An optional ``matplotlib.axes.Axes``
160
+ object to be used for the visualization output. If none is
161
+ specified, a new matplotlib Figure will be created and used.
162
+ Additionally, if specified there will be no returned Figure since
163
+ it is redundant.
164
+ initial_state: Adds :math:`|0\rangle` in the beginning of the qubit wires and
165
+ :math:`0` to classical wires. Default is ``False``.
166
+ cregbundle: If set to ``True``, bundle classical registers.
167
+ Default is ``True``, except for when ``output`` is set to ``"text"``.
168
+ wire_order: A list of integers used to reorder the display
169
+ of the bits. The list must have an entry for every bit with the bits
170
+ in the range 0 to (``num_qubits`` + ``num_clbits``).
171
+ expr_len: The number of characters to display if an :class:`~.expr.Expr`
172
+ is used for the condition in a :class:`.ControlFlowOp`. If this number is exceeded,
173
+ the string will be truncated at that number and '...' added to the end.
174
+
175
+ Returns:
176
+ :class:`.TextDrawing` or :class:`matplotlib.figure` or :class:`PIL.Image` or
177
+ :class:`str`:
178
+
179
+ * ``TextDrawing`` (if ``output='text'``)
180
+ A drawing that can be printed as ascii art.
181
+ * ``matplotlib.figure.Figure`` (if ``output='mpl'``)
182
+ A matplotlib figure object for the circuit diagram.
183
+ * ``PIL.Image`` (if ``output='latex``')
184
+ An in-memory representation of the image of the circuit diagram.
185
+ * ``str`` (if ``output='latex_source'``)
186
+ The LaTeX source code for visualizing the circuit diagram.
187
+
188
+ Raises:
189
+ VisualizationError: when an invalid output method is selected
190
+ ImportError: when the output methods requires non-installed libraries.
191
+
192
+ Example:
193
+ .. plot::
194
+ :alt: Circuit diagram output by the previous code.
195
+ :include-source:
196
+
197
+ from qiskit import QuantumCircuit
198
+ from qiskit.visualization import circuit_drawer
199
+ qc = QuantumCircuit(1, 1)
200
+ qc.h(0)
201
+ qc.measure(0, 0)
202
+ circuit_drawer(qc, output="mpl", style={"backgroundcolor": "#EEEEEE"})
203
+ """
204
+ image = None
205
+ expr_len = max(expr_len, 0)
206
+ config = user_config.get_config()
207
+ # Get default from config file else use text
208
+ default_output = "text"
209
+ default_reverse_bits = False
210
+ default_idle_wires = config.get("circuit_idle_wires", "auto")
211
+ if config:
212
+ default_output = config.get("circuit_drawer", "text")
213
+ if default_output == "auto":
214
+ if _optionals.HAS_MATPLOTLIB:
215
+ default_output = "mpl"
216
+ else:
217
+ default_output = "text"
218
+ if wire_order is None:
219
+ default_reverse_bits = config.get("circuit_reverse_bits", False)
220
+ if output is None:
221
+ output = default_output
222
+
223
+ if reverse_bits is None:
224
+ reverse_bits = default_reverse_bits
225
+
226
+ if idle_wires is None:
227
+ idle_wires = default_idle_wires
228
+ if isinstance(idle_wires, str):
229
+ if idle_wires == "auto":
230
+ idle_wires = hasattr(circuit, "_layout") and circuit._layout is None
231
+ else:
232
+ raise VisualizationError(f"Parameter idle_wires={idle_wires} unrecognized.")
233
+
234
+ if wire_order is not None and reverse_bits:
235
+ raise VisualizationError(
236
+ "The wire_order option cannot be set when the reverse_bits option is True."
237
+ )
238
+
239
+ complete_wire_order = wire_order
240
+ if wire_order is not None:
241
+ wire_order_len = len(wire_order)
242
+ total_wire_len = circuit.num_qubits + circuit.num_clbits
243
+ if wire_order_len not in [circuit.num_qubits, total_wire_len]:
244
+ raise VisualizationError(
245
+ f"The wire_order list (length {wire_order_len}) should as long as "
246
+ f"the number of qubits ({circuit.num_qubits}) or the "
247
+ f"total numbers of qubits and classical bits {total_wire_len}."
248
+ )
249
+
250
+ if len(set(wire_order)) != len(wire_order):
251
+ raise VisualizationError("The wire_order list should not have repeated elements.")
252
+
253
+ if wire_order_len == circuit.num_qubits:
254
+ complete_wire_order = wire_order + list(range(circuit.num_qubits, total_wire_len))
255
+
256
+ if (
257
+ circuit.clbits
258
+ and (reverse_bits or wire_order is not None)
259
+ and not set(wire_order or []).issubset(set(range(circuit.num_qubits)))
260
+ ):
261
+ if cregbundle:
262
+ warn(
263
+ "cregbundle set to False since either reverse_bits or wire_order "
264
+ "(over classical bit) has been set.",
265
+ RuntimeWarning,
266
+ 2,
267
+ )
268
+ cregbundle = False
269
+
270
+ def check_clbit_in_inst(circuit, cregbundle):
271
+ if cregbundle is False:
272
+ return False
273
+ for inst in circuit.data:
274
+ if isinstance(inst.operation, ControlFlowOp):
275
+ for block in inst.operation.blocks:
276
+ if check_clbit_in_inst(block, cregbundle) is False:
277
+ return False
278
+ elif inst.clbits and not isinstance(inst.operation, Measure):
279
+ if cregbundle is not False:
280
+ warn(
281
+ "Cregbundle set to False since an instruction needs to refer"
282
+ " to individual classical wire",
283
+ RuntimeWarning,
284
+ 3,
285
+ )
286
+ return False
287
+
288
+ return True
289
+
290
+ cregbundle = check_clbit_in_inst(circuit, cregbundle)
291
+
292
+ if output == "text":
293
+ return _text_circuit_drawer(
294
+ circuit,
295
+ filename=filename,
296
+ reverse_bits=reverse_bits,
297
+ plot_barriers=plot_barriers,
298
+ justify=justify,
299
+ vertical_compression=vertical_compression,
300
+ idle_wires=idle_wires,
301
+ with_layout=with_layout,
302
+ fold=fold,
303
+ initial_state=initial_state,
304
+ cregbundle=cregbundle,
305
+ wire_order=complete_wire_order,
306
+ expr_len=expr_len,
307
+ )
308
+ elif output == "latex":
309
+ image = _latex_circuit_drawer(
310
+ circuit,
311
+ filename=filename,
312
+ scale=scale,
313
+ style=style,
314
+ plot_barriers=plot_barriers,
315
+ reverse_bits=reverse_bits,
316
+ justify=justify,
317
+ idle_wires=idle_wires,
318
+ with_layout=with_layout,
319
+ initial_state=initial_state,
320
+ cregbundle=cregbundle,
321
+ wire_order=complete_wire_order,
322
+ )
323
+ elif output == "latex_source":
324
+ return _generate_latex_source(
325
+ circuit,
326
+ filename=filename,
327
+ scale=scale,
328
+ style=style,
329
+ plot_barriers=plot_barriers,
330
+ reverse_bits=reverse_bits,
331
+ justify=justify,
332
+ idle_wires=idle_wires,
333
+ with_layout=with_layout,
334
+ initial_state=initial_state,
335
+ cregbundle=cregbundle,
336
+ wire_order=complete_wire_order,
337
+ )
338
+ elif output == "mpl":
339
+ image = _matplotlib_circuit_drawer(
340
+ circuit,
341
+ scale=scale,
342
+ filename=filename,
343
+ style=style,
344
+ plot_barriers=plot_barriers,
345
+ reverse_bits=reverse_bits,
346
+ justify=justify,
347
+ idle_wires=idle_wires,
348
+ with_layout=with_layout,
349
+ fold=fold,
350
+ ax=ax,
351
+ initial_state=initial_state,
352
+ cregbundle=cregbundle,
353
+ wire_order=complete_wire_order,
354
+ expr_len=expr_len,
355
+ )
356
+ else:
357
+ raise VisualizationError(
358
+ f"Invalid output type {output} selected. The only valid choices "
359
+ "are text, latex, latex_source, and mpl"
360
+ )
361
+ if image and interactive:
362
+ image.show()
363
+ return image
364
+
365
+
366
+ # -----------------------------------------------------------------------------
367
+ # _text_circuit_drawer
368
+ # -----------------------------------------------------------------------------
369
+
370
+
371
+ def _text_circuit_drawer(
372
+ circuit,
373
+ filename=None,
374
+ reverse_bits=False,
375
+ plot_barriers=True,
376
+ justify=None,
377
+ vertical_compression="high",
378
+ idle_wires=True,
379
+ with_layout=True,
380
+ fold=None,
381
+ initial_state=True,
382
+ cregbundle=None,
383
+ encoding=None,
384
+ wire_order=None,
385
+ expr_len=30,
386
+ ):
387
+ """Draws a circuit using ascii art.
388
+
389
+ Args:
390
+ circuit (QuantumCircuit): Input circuit
391
+ filename (str): Optional filename to write the result
392
+ reverse_bits (bool): Rearrange the bits in reverse order.
393
+ plot_barriers (bool): Draws the barriers when they are there.
394
+ justify (str) : `left`, `right` or `none`. Defaults to `left`. Says how
395
+ the circuit should be justified.
396
+ vertical_compression (string): `high`, `medium`, or `low`. It merges the
397
+ lines so the drawing will take less vertical room. Default is `high`.
398
+ idle_wires (bool): Include idle wires. Default is True.
399
+ with_layout (bool): Include layout information with labels on the physical
400
+ layout. Default: True
401
+ fold (int): Optional. Breaks the circuit drawing to this length. This
402
+ is useful when the drawing does not fit in the console. If
403
+ None (default), it will try to guess the console width using
404
+ `shutil.get_terminal_size()`. If you don't want pagination
405
+ at all, set `fold=-1`.
406
+ initial_state (bool): Optional. Adds |0> in the beginning of the line.
407
+ Default: `False`.
408
+ cregbundle (bool): Optional. If set True, bundle classical registers.
409
+ Default: ``True``.
410
+ encoding (str): Optional. Sets the encoding preference of the output.
411
+ Default: ``sys.stdout.encoding``.
412
+ wire_order (list): Optional. A list of integers used to reorder the display
413
+ of the bits. The list must have an entry for every bit with the bits
414
+ in the range 0 to (num_qubits + num_clbits).
415
+ expr_len (int): Optional. The number of characters to display if an :class:`~.expr.Expr`
416
+ is used for the condition in a :class:`.ControlFlowOp`. If this number is exceeded,
417
+ the string will be truncated at that number and '...' added to the end.
418
+
419
+ Returns:
420
+ TextDrawing: An instance that, when printed, draws the circuit in ascii art.
421
+
422
+ Raises:
423
+ VisualizationError: When the filename extension is not .txt.
424
+ """
425
+ qubits, clbits, nodes = _utils._get_layered_instructions(
426
+ circuit,
427
+ reverse_bits=reverse_bits,
428
+ justify=justify,
429
+ idle_wires=idle_wires,
430
+ wire_order=wire_order,
431
+ )
432
+ text_drawing = _text.TextDrawing(
433
+ qubits,
434
+ clbits,
435
+ nodes,
436
+ circuit,
437
+ reverse_bits=reverse_bits,
438
+ initial_state=initial_state,
439
+ cregbundle=cregbundle,
440
+ encoding=encoding,
441
+ with_layout=with_layout,
442
+ expr_len=expr_len,
443
+ )
444
+ text_drawing.plotbarriers = plot_barriers
445
+ text_drawing.line_length = fold
446
+ text_drawing.vertical_compression = vertical_compression
447
+
448
+ if filename:
449
+ text_drawing.dump(filename, encoding=encoding)
450
+ return text_drawing
451
+
452
+
453
+ # -----------------------------------------------------------------------------
454
+ # latex_circuit_drawer
455
+ # -----------------------------------------------------------------------------
456
+
457
+
458
+ @_optionals.HAS_PDFLATEX.require_in_call("LaTeX circuit drawing")
459
+ @_optionals.HAS_PDFTOCAIRO.require_in_call("LaTeX circuit drawing")
460
+ @_optionals.HAS_PIL.require_in_call("LaTeX circuit drawing")
461
+ def _latex_circuit_drawer(
462
+ circuit,
463
+ scale=0.7,
464
+ style=None,
465
+ filename=None,
466
+ plot_barriers=True,
467
+ reverse_bits=False,
468
+ justify=None,
469
+ idle_wires=True,
470
+ with_layout=True,
471
+ initial_state=False,
472
+ cregbundle=None,
473
+ wire_order=None,
474
+ ):
475
+ """Draw a quantum circuit based on latex (Qcircuit package)
476
+
477
+ Requires version >=2.6.0 of the qcircuit LaTeX package.
478
+
479
+ Args:
480
+ circuit (QuantumCircuit): a quantum circuit
481
+ scale (float): scaling factor
482
+ style (dict or str): dictionary of style or file name of style file
483
+ filename (str): file path to save image to
484
+ reverse_bits (bool): When set to True reverse the bit order inside
485
+ registers for the output visualization.
486
+ plot_barriers (bool): Enable/disable drawing barriers in the output
487
+ circuit. Defaults to True.
488
+ justify (str) : `left`, `right` or `none`. Defaults to `left`. Says how
489
+ the circuit should be justified.
490
+ idle_wires (bool): Include idle wires. Default is True.
491
+ with_layout (bool): Include layout information, with labels on the physical
492
+ layout. Default: True
493
+ initial_state (bool): Optional. Adds |0> in the beginning of the line.
494
+ Default: `False`.
495
+ cregbundle (bool): Optional. If set True, bundle classical registers. On by default, if
496
+ this is possible for the given circuit, otherwise off.
497
+ wire_order (list): Optional. A list of integers used to reorder the display
498
+ of the bits. The list must have an entry for every bit with the bits
499
+ in the range 0 to (num_qubits + num_clbits).
500
+
501
+ Returns:
502
+ PIL.Image: an in-memory representation of the circuit diagram
503
+
504
+ Raises:
505
+ MissingOptionalLibraryError: if pillow, pdflatex, or poppler are not installed
506
+ VisualizationError: if one of the conversion utilities failed for some internal or
507
+ file-access reason.
508
+ """
509
+ from PIL import Image
510
+
511
+ tmpfilename = "circuit"
512
+ with tempfile.TemporaryDirectory() as tmpdirname:
513
+ tmppath = os.path.join(tmpdirname, tmpfilename + ".tex")
514
+ _generate_latex_source(
515
+ circuit,
516
+ filename=tmppath,
517
+ scale=scale,
518
+ style=style,
519
+ plot_barriers=plot_barriers,
520
+ reverse_bits=reverse_bits,
521
+ justify=justify,
522
+ idle_wires=idle_wires,
523
+ with_layout=with_layout,
524
+ initial_state=initial_state,
525
+ cregbundle=cregbundle,
526
+ wire_order=wire_order,
527
+ )
528
+
529
+ try:
530
+ subprocess.run(
531
+ [
532
+ "pdflatex",
533
+ "-halt-on-error",
534
+ f"-output-directory={tmpdirname}",
535
+ f"{tmpfilename + '.tex'}",
536
+ ],
537
+ stdout=subprocess.PIPE,
538
+ stderr=subprocess.DEVNULL,
539
+ check=True,
540
+ )
541
+ except OSError as exc:
542
+ # OSError should generally not occur, because it's usually only triggered if `pdflatex`
543
+ # doesn't exist as a command, but we've already checked that.
544
+ raise VisualizationError("`pdflatex` command could not be run.") from exc
545
+ except subprocess.CalledProcessError as exc:
546
+ with open("latex_error.log", "wb") as error_file:
547
+ error_file.write(exc.stdout)
548
+ logger.warning(
549
+ "Unable to compile LaTeX. Perhaps you are missing the `qcircuit` package."
550
+ " The output from the `pdflatex` command is in `latex_error.log`."
551
+ )
552
+ raise VisualizationError(
553
+ "`pdflatex` call did not succeed: see `latex_error.log`."
554
+ ) from exc
555
+ base = os.path.join(tmpdirname, tmpfilename)
556
+ try:
557
+ subprocess.run(
558
+ ["pdftocairo", "-singlefile", "-png", "-q", base + ".pdf", base],
559
+ check=True,
560
+ )
561
+ except (OSError, subprocess.CalledProcessError) as exc:
562
+ message = "`pdftocairo` failed to produce an image."
563
+ logger.warning(message)
564
+ raise VisualizationError(message) from exc
565
+ image = Image.open(base + ".png")
566
+ image = trim_image(image)
567
+ if filename:
568
+ if filename.endswith(".pdf"):
569
+ shutil.move(base + ".pdf", filename)
570
+ else:
571
+ try:
572
+ image.save(filename)
573
+ except (ValueError, OSError) as exc:
574
+ raise VisualizationError(
575
+ f"Pillow could not write the image file '{filename}'."
576
+ ) from exc
577
+ return image
578
+
579
+
580
+ def _generate_latex_source(
581
+ circuit,
582
+ filename=None,
583
+ scale=0.7,
584
+ style=None,
585
+ reverse_bits=False,
586
+ plot_barriers=True,
587
+ justify=None,
588
+ idle_wires=True,
589
+ with_layout=True,
590
+ initial_state=False,
591
+ cregbundle=None,
592
+ wire_order=None,
593
+ ):
594
+ """Convert QuantumCircuit to LaTeX string.
595
+
596
+ Args:
597
+ circuit (QuantumCircuit): a quantum circuit
598
+ scale (float): scaling factor
599
+ style (dict or str): dictionary of style or file name of style file
600
+ filename (str): optional filename to write latex
601
+ reverse_bits (bool): When set to True reverse the bit order inside
602
+ registers for the output visualization.
603
+ plot_barriers (bool): Enable/disable drawing barriers in the output
604
+ circuit. Defaults to True.
605
+ justify (str) : `left`, `right` or `none`. Defaults to `left`. Says how
606
+ the circuit should be justified.
607
+ idle_wires (bool): Include idle wires. Default is True.
608
+ with_layout (bool): Include layout information, with labels on the physical
609
+ layout. Default: True
610
+ initial_state (bool): Optional. Adds |0> in the beginning of the line.
611
+ Default: `False`.
612
+ cregbundle (bool): Optional. If set True, bundle classical registers.
613
+ wire_order (list): Optional. A list of integers used to reorder the display
614
+ of the bits. The list must have an entry for every bit with the bits
615
+ in the range 0 to (num_qubits + num_clbits).
616
+
617
+ Returns:
618
+ str: Latex string appropriate for writing to file.
619
+ """
620
+ qubits, clbits, nodes = _utils._get_layered_instructions(
621
+ circuit,
622
+ reverse_bits=reverse_bits,
623
+ justify=justify,
624
+ idle_wires=idle_wires,
625
+ wire_order=wire_order,
626
+ )
627
+ qcimg = _latex.QCircuitImage(
628
+ qubits,
629
+ clbits,
630
+ nodes,
631
+ scale,
632
+ style=style,
633
+ reverse_bits=reverse_bits,
634
+ plot_barriers=plot_barriers,
635
+ initial_state=initial_state,
636
+ cregbundle=cregbundle,
637
+ with_layout=with_layout,
638
+ circuit=circuit,
639
+ )
640
+ latex = qcimg.latex()
641
+ if filename:
642
+ with open(filename, "w") as latex_file:
643
+ latex_file.write(latex)
644
+
645
+ return latex
646
+
647
+
648
+ # -----------------------------------------------------------------------------
649
+ # matplotlib_circuit_drawer
650
+ # -----------------------------------------------------------------------------
651
+
652
+
653
+ def _matplotlib_circuit_drawer(
654
+ circuit,
655
+ scale=None,
656
+ filename=None,
657
+ style=None,
658
+ plot_barriers=True,
659
+ reverse_bits=False,
660
+ justify=None,
661
+ idle_wires=True,
662
+ with_layout=True,
663
+ fold=None,
664
+ ax=None,
665
+ initial_state=False,
666
+ cregbundle=None,
667
+ wire_order=None,
668
+ expr_len=30,
669
+ ):
670
+ """Draw a quantum circuit based on matplotlib.
671
+ If `%matplotlib inline` is invoked in a Jupyter notebook, it visualizes a circuit inline.
672
+ We recommend `%config InlineBackend.figure_format = 'svg'` for the inline visualization.
673
+
674
+ Args:
675
+ circuit (QuantumCircuit): a quantum circuit
676
+ scale (float): scaling factor
677
+ filename (str): file path to save image to
678
+ style (dict or str): dictionary of style or file name of style file
679
+ reverse_bits (bool): When set to True, reverse the bit order inside
680
+ registers for the output visualization.
681
+ plot_barriers (bool): Enable/disable drawing barriers in the output
682
+ circuit. Defaults to True.
683
+ justify (str): `left`, `right` or `none`. Defaults to `left`. Says how
684
+ the circuit should be justified.
685
+ idle_wires (bool): Include idle wires. Default is True.
686
+ with_layout (bool): Include layout information, with labels on the physical
687
+ layout. Default: True.
688
+ fold (int): Number of vertical layers allowed before folding. Default is 25.
689
+ ax (matplotlib.axes.Axes): An optional Axes object to be used for
690
+ the visualization output. If none is specified, a new matplotlib
691
+ Figure will be created and used. Additionally, if specified there
692
+ will be no returned Figure since it is redundant.
693
+ initial_state (bool): Optional. Adds |0> in the beginning of the line.
694
+ Default: `False`.
695
+ cregbundle (bool): Optional. If set True bundle classical registers.
696
+ Default: ``True``.
697
+ wire_order (list): Optional. A list of integers used to reorder the display
698
+ of the bits. The list must have an entry for every bit with the bits
699
+ in the range 0 to (num_qubits + num_clbits).
700
+ expr_len (int): Optional. The number of characters to display if an :class:`~.expr.Expr`
701
+ is used for the condition in a :class:`.ControlFlowOp`. If this number is exceeded,
702
+ the string will be truncated at that number and '...' added to the end.
703
+
704
+ Returns:
705
+ matplotlib.figure: a matplotlib figure object for the circuit diagram
706
+ if the ``ax`` kwarg is not set.
707
+ """
708
+
709
+ qubits, clbits, nodes = _utils._get_layered_instructions(
710
+ circuit,
711
+ reverse_bits=reverse_bits,
712
+ justify=justify,
713
+ idle_wires=idle_wires,
714
+ wire_order=wire_order,
715
+ )
716
+ if fold is None:
717
+ fold = 25
718
+
719
+ qcd = _matplotlib.MatplotlibDrawer(
720
+ qubits,
721
+ clbits,
722
+ nodes,
723
+ circuit,
724
+ scale=scale,
725
+ style=style,
726
+ reverse_bits=reverse_bits,
727
+ plot_barriers=plot_barriers,
728
+ fold=fold,
729
+ ax=ax,
730
+ initial_state=initial_state,
731
+ cregbundle=cregbundle,
732
+ with_layout=with_layout,
733
+ expr_len=expr_len,
734
+ )
735
+ return qcd.draw(filename)