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,661 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2017, 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
+ """latex visualization backend."""
14
+
15
+ import io
16
+ import itertools
17
+ import math
18
+ import re
19
+ from warnings import warn
20
+
21
+ import numpy as np
22
+ from qiskit.circuit import Clbit, Qubit, ClassicalRegister
23
+ from qiskit.circuit.classical import expr
24
+ from qiskit.circuit.controlledgate import ControlledGate
25
+ from qiskit.circuit.library.standard_gates import SwapGate, XGate, ZGate, RZZGate, U1Gate, PhaseGate
26
+ from qiskit.circuit.measure import Measure
27
+ from qiskit.circuit.tools.pi_check import pi_check
28
+
29
+
30
+ from .qcstyle import load_style
31
+ from ._utils import (
32
+ get_gate_ctrl_text,
33
+ get_param_str,
34
+ get_wire_map,
35
+ get_bit_register,
36
+ get_bit_reg_index,
37
+ get_wire_label,
38
+ generate_latex_label,
39
+ get_condition_label_val,
40
+ )
41
+
42
+
43
+ class QCircuitImage:
44
+ """This class contains methods to create \\LaTeX circuit images.
45
+
46
+ The class targets the \\LaTeX package Q-circuit
47
+ (https://arxiv.org/pdf/quant-ph/0406003).
48
+
49
+ Thanks to Eric Sabo for the initial implementation for Qiskit.
50
+ """
51
+
52
+ def __init__( # pylint: disable=bad-docstring-quotes
53
+ self,
54
+ qubits,
55
+ clbits,
56
+ nodes,
57
+ scale,
58
+ style=None,
59
+ reverse_bits=False,
60
+ plot_barriers=True,
61
+ initial_state=False,
62
+ cregbundle=None,
63
+ with_layout=False,
64
+ circuit=None,
65
+ ):
66
+ """QCircuitImage initializer.
67
+
68
+ Args:
69
+ qubits (list[Qubit]): list of qubits
70
+ clbits (list[Clbit]): list of clbits
71
+ nodes (list[list[DAGNode]]): list of circuit instructions, grouped by layer
72
+ scale (float): image scaling
73
+ style (dict or str): dictionary of style or file name of style file
74
+ reverse_bits (bool): when True, reverse the bit ordering of the registers
75
+ plot_barriers (bool): Enable/disable drawing barriers in the output
76
+ circuit. Defaults to True.
77
+ initial_state (bool): Optional. Adds |0> in the beginning of the line. Default: `False`.
78
+ cregbundle (bool): Optional. If set True bundle classical registers.
79
+ circuit (QuantumCircuit): the circuit that's being displayed
80
+ Raises:
81
+ ImportError: If pylatexenc is not installed
82
+ """
83
+
84
+ self._circuit = circuit
85
+ self._qubits = qubits
86
+ self._clbits = clbits
87
+
88
+ # list of lists corresponding to layers of the circuit
89
+ self._nodes = nodes
90
+
91
+ # image scaling
92
+ self._scale = 1.0 if scale is None else scale
93
+
94
+ # Map of cregs to sizes
95
+ self._cregs = {}
96
+
97
+ # Array to hold the \\LaTeX commands to generate a circuit image.
98
+ self._latex = []
99
+
100
+ # Variable to hold image depth (width)
101
+ self._img_depth = 0
102
+
103
+ # Variable to hold image width (height)
104
+ self._img_width = 0
105
+
106
+ # Variable to hold total circuit depth
107
+ self._sum_column_widths = 0
108
+
109
+ # Variable to hold total circuit width
110
+ self._sum_wire_heights = 0
111
+
112
+ # em points of separation between circuit columns
113
+ self._column_separation = 1
114
+
115
+ # em points of separation between circuit wire
116
+ self._wire_separation = 0
117
+
118
+ # presence of "box" or "target" determines wire spacing
119
+ self._has_box = False
120
+ self._has_target = False
121
+
122
+ self._plot_barriers = plot_barriers
123
+ self._reverse_bits = reverse_bits
124
+ if with_layout:
125
+ if self._circuit._layout:
126
+ self._layout = self._circuit._layout.initial_layout
127
+ else:
128
+ self._layout = None
129
+ else:
130
+ self._layout = None
131
+
132
+ self._initial_state = initial_state
133
+ self._global_phase = circuit.global_phase
134
+
135
+ # If there is any custom instruction that uses classical bits
136
+ # then cregbundle is forced to be False.
137
+ for node in itertools.chain.from_iterable(self._nodes):
138
+ if node.cargs and node.op.name != "measure":
139
+ if cregbundle:
140
+ warn(
141
+ "Cregbundle set to False since an instruction needs to refer"
142
+ " to individual classical wire",
143
+ RuntimeWarning,
144
+ 2,
145
+ )
146
+ self._cregbundle = False
147
+ break
148
+ else:
149
+ self._cregbundle = True if cregbundle is None else cregbundle
150
+
151
+ self._wire_map = get_wire_map(circuit, qubits + clbits, self._cregbundle)
152
+ self._img_width = len(self._wire_map)
153
+
154
+ self._style, _ = load_style(style)
155
+
156
+ def latex(self):
157
+ """Return LaTeX string representation of circuit."""
158
+
159
+ self._initialize_latex_array()
160
+ self._build_latex_array()
161
+ header_1 = r"\documentclass[border=2px]{standalone}" + "\n"
162
+
163
+ header_2 = r"""
164
+ \usepackage[braket, qm]{qcircuit}
165
+ \usepackage{graphicx}
166
+
167
+ \begin{document}
168
+ """
169
+ header_scale = f"\\scalebox{{{self._scale}}}" + "{"
170
+
171
+ qcircuit_line = r"""
172
+ \Qcircuit @C=%.1fem @R=%.1fem @!R { \\
173
+ """
174
+ output = io.StringIO()
175
+ output.write(header_1)
176
+ output.write(header_2)
177
+ output.write(header_scale)
178
+ if self._global_phase:
179
+ output.write(
180
+ r"""{$\mathrm{%s} \mathrm{%s}$}"""
181
+ % ("global\\,phase:\\,", pi_check(self._global_phase, output="latex"))
182
+ )
183
+ output.write(qcircuit_line % (self._column_separation, self._wire_separation))
184
+ for i in range(self._img_width):
185
+ output.write("\t \t")
186
+ for j in range(self._img_depth + 1):
187
+ output.write(self._latex[i][j])
188
+ if j != self._img_depth:
189
+ output.write(" & ")
190
+ else:
191
+ output.write(r"\\" + "\n")
192
+ output.write(r"\\ " + "}}\n")
193
+ output.write("\\end{document}")
194
+ contents = output.getvalue()
195
+ output.close()
196
+ return contents
197
+
198
+ def _initialize_latex_array(self):
199
+ """Initialize qubit and clbit labels and set wire separation"""
200
+ self._img_depth, self._sum_column_widths = self._get_image_depth()
201
+ self._sum_wire_heights = self._img_width
202
+ # choose the most compact wire spacing, while not squashing them
203
+ if self._has_box:
204
+ self._wire_separation = 0.2
205
+ elif self._has_target:
206
+ self._wire_separation = 0.8
207
+ else:
208
+ self._wire_separation = 1.0
209
+ self._latex = [
210
+ ["\\qw" if isinstance(wire, Qubit) else "\\cw" for _ in range(self._img_depth + 1)]
211
+ for wire in self._wire_map
212
+ ]
213
+ self._latex.append([" "] * (self._img_depth + 1))
214
+
215
+ # display the bit/register labels
216
+ for wire, index in self._wire_map.items():
217
+ if isinstance(wire, ClassicalRegister):
218
+ register = wire
219
+ wire_label = get_wire_label(
220
+ "latex", register, index, layout=self._layout, cregbundle=self._cregbundle
221
+ )
222
+ else:
223
+ register, bit_index, reg_index = get_bit_reg_index(self._circuit, wire)
224
+ wire_label = get_wire_label(
225
+ "latex",
226
+ register,
227
+ bit_index if register is None else reg_index,
228
+ layout=self._layout,
229
+ cregbundle=self._cregbundle,
230
+ )
231
+
232
+ wire_label += " : "
233
+ if self._initial_state:
234
+ wire_label += "\\ket{{0}}" if isinstance(wire, Qubit) else "0"
235
+ wire_label += " }"
236
+
237
+ if not isinstance(wire, (Qubit)) and self._cregbundle and register is not None:
238
+ pos = self._wire_map[register]
239
+ self._latex[pos][1] = "\\lstick{/_{_{" + str(register.size) + "}}} \\cw"
240
+ wire_label = f"\\mathrm{{{wire_label}}}"
241
+ else:
242
+ pos = index
243
+ self._latex[pos][0] = "\\nghost{" + wire_label + " & " + "\\lstick{" + wire_label
244
+
245
+ def _get_image_depth(self):
246
+ """Get depth information for the circuit."""
247
+
248
+ # wires in the beginning and end
249
+ columns = 2
250
+ if self._cregbundle and (
251
+ self._nodes
252
+ and self._nodes[0]
253
+ and (
254
+ self._nodes[0][0].op.name == "measure"
255
+ or getattr(self._nodes[0][0].op, "condition", None)
256
+ )
257
+ ):
258
+ columns += 1
259
+
260
+ # Determine wire spacing before image depth
261
+ max_column_widths = []
262
+ for layer in self._nodes:
263
+ column_width = 1
264
+ current_max = 0
265
+ for node in layer:
266
+ op = node.op
267
+ # useful information for determining wire spacing
268
+ boxed_gates = [
269
+ "u1",
270
+ "u2",
271
+ "u3",
272
+ "u",
273
+ "p",
274
+ "x",
275
+ "y",
276
+ "z",
277
+ "h",
278
+ "s",
279
+ "sdg",
280
+ "t",
281
+ "tdg",
282
+ "sx",
283
+ "sxdg",
284
+ "rx",
285
+ "ry",
286
+ "rz",
287
+ "ch",
288
+ "cy",
289
+ "crz",
290
+ "cu2",
291
+ "cu3",
292
+ "cu",
293
+ "id",
294
+ ]
295
+ target_gates = ["cx", "ccx", "cu1", "cp", "rzz"]
296
+ if op.name in boxed_gates:
297
+ self._has_box = True
298
+ elif op.name in target_gates:
299
+ self._has_target = True
300
+ elif isinstance(op, ControlledGate):
301
+ self._has_box = True
302
+
303
+ arg_str_len = 0
304
+ # the wide gates
305
+ for arg in op.params:
306
+ if not any(isinstance(param, np.ndarray) for param in op.params):
307
+ arg_str = re.sub(r"[-+]?\d*\.\d{2,}|\d{2,}", self._truncate_float, str(arg))
308
+ arg_str_len += len(arg_str)
309
+
310
+ # the width of the column is the max of all the gates in the column
311
+ current_max = max(arg_str_len, current_max)
312
+
313
+ # all gates take up 1 column except from those with side labels (ie cu1, cp, rzz)
314
+ # which take 4 columns
315
+ base_type = None if not hasattr(op, "base_gate") else op.base_gate
316
+ if isinstance(op, RZZGate) or isinstance(base_type, (U1Gate, PhaseGate, RZZGate)):
317
+ column_width = 4
318
+ max_column_widths.append(current_max)
319
+ columns += column_width
320
+
321
+ # every 3 characters is roughly one extra 'unit' of width in the cell
322
+ # the gate name is 1 extra 'unit'
323
+ # the qubit/cbit labels plus initial states is 2 more
324
+ # the wires poking out at the ends is 2 more
325
+ sum_column_widths = sum(1 + v / 3 for v in max_column_widths)
326
+
327
+ max_wire_name = 3
328
+ for wire in self._wire_map:
329
+ if isinstance(wire, (Qubit, Clbit)):
330
+ register = get_bit_register(self._circuit, wire)
331
+ name = register.name if register is not None else ""
332
+ else:
333
+ name = wire.name
334
+ max_wire_name = max(max_wire_name, len(name))
335
+
336
+ sum_column_widths += 5 + max_wire_name / 3
337
+
338
+ # could be a fraction so ceil
339
+ return columns, math.ceil(sum_column_widths)
340
+
341
+ def _get_beamer_page(self):
342
+ """Get height, width & scale attributes for the beamer page."""
343
+
344
+ # PIL python package limits image size to around a quarter gigabyte
345
+ # this means the beamer image should be limited to < 50000
346
+ # if you want to avoid a "warning" too, set it to < 25000
347
+ pil_limit = 40000
348
+
349
+ # the beamer latex template limits each dimension to < 19 feet
350
+ # (i.e. 575cm)
351
+ beamer_limit = 550
352
+
353
+ # columns are roughly twice as big as wires
354
+ aspect_ratio = self._sum_wire_heights / self._sum_column_widths
355
+
356
+ # choose a page margin so circuit is not cropped
357
+ margin_factor = 1.5
358
+ height = min(self._sum_wire_heights * margin_factor, beamer_limit)
359
+ width = min(self._sum_column_widths * margin_factor, beamer_limit)
360
+
361
+ # if too large, make it fit
362
+ if height * width > pil_limit:
363
+ height = min(np.sqrt(pil_limit * aspect_ratio), beamer_limit)
364
+ width = min(np.sqrt(pil_limit / aspect_ratio), beamer_limit)
365
+
366
+ # if too small, give it a minimum size
367
+ height = max(height, 10)
368
+ width = max(width, 10)
369
+
370
+ return (height, width, self._scale)
371
+
372
+ def _build_latex_array(self):
373
+ """Returns an array of strings containing \\LaTeX for this circuit."""
374
+
375
+ column = 1
376
+ # Leave a column to display number of classical registers if needed
377
+ if self._cregbundle and (
378
+ self._nodes
379
+ and self._nodes[0]
380
+ and (
381
+ self._nodes[0][0].op.name == "measure"
382
+ or getattr(self._nodes[0][0].op, "condition", None)
383
+ )
384
+ ):
385
+ column += 1
386
+
387
+ for layer in self._nodes:
388
+ num_cols_layer = 1
389
+
390
+ for node in layer:
391
+ op = node.op
392
+ num_cols_op = 1
393
+ wire_list = [self._wire_map[qarg] for qarg in node.qargs if qarg in self._qubits]
394
+ if getattr(op, "condition", None):
395
+ if isinstance(op.condition, expr.Expr):
396
+ warn("ignoring expression condition, which is not supported yet")
397
+ else:
398
+ self._add_condition(op, wire_list, column)
399
+
400
+ if isinstance(op, Measure):
401
+ self._build_measure(node, column)
402
+
403
+ elif getattr(op, "_directive", False): # barrier, snapshot, etc.
404
+ self._build_barrier(node, column)
405
+
406
+ else:
407
+ gate_text, _, _ = get_gate_ctrl_text(op, "latex", style=self._style)
408
+ gate_text += get_param_str(op, "latex", ndigits=4)
409
+ gate_text = generate_latex_label(gate_text)
410
+ if node.cargs:
411
+ cwire_list = [
412
+ self._wire_map[carg] for carg in node.cargs if carg in self._clbits
413
+ ]
414
+ else:
415
+ cwire_list = []
416
+
417
+ if len(wire_list) == 1 and not node.cargs:
418
+ self._latex[wire_list[0]][column] = f"\\gate{{{gate_text}}}"
419
+
420
+ elif isinstance(op, ControlledGate):
421
+ num_cols_op = self._build_ctrl_gate(op, gate_text, wire_list, column)
422
+ else:
423
+ num_cols_op = self._build_multi_gate(
424
+ op, gate_text, wire_list, cwire_list, column
425
+ )
426
+
427
+ num_cols_layer = max(num_cols_layer, num_cols_op)
428
+
429
+ column += num_cols_layer
430
+
431
+ def _build_multi_gate(self, op, gate_text, wire_list, cwire_list, col):
432
+ """Add a multiple wire gate to the _latex list"""
433
+ cwire_start = len(self._qubits)
434
+ num_cols_op = 1
435
+ if isinstance(op, (SwapGate, RZZGate)):
436
+ num_cols_op = self._build_symmetric_gate(op, gate_text, wire_list, col)
437
+ else:
438
+ wire_min = min(wire_list)
439
+ wire_max = max(wire_list)
440
+ if cwire_list and not self._cregbundle:
441
+ wire_max = max(cwire_list)
442
+ wire_ind = wire_list.index(wire_min)
443
+ self._latex[wire_min][col] = (
444
+ f"\\multigate{{{wire_max - wire_min}}}{{{gate_text}}}_"
445
+ + "<" * (len(str(wire_ind)) + 2)
446
+ + f"{{{wire_ind}}}"
447
+ )
448
+ for wire in range(wire_min + 1, wire_max + 1):
449
+ if wire < cwire_start:
450
+ ghost_box = f"\\ghost{{{gate_text}}}"
451
+ if wire in wire_list:
452
+ wire_ind = wire_list.index(wire)
453
+ else:
454
+ ghost_box = f"\\cghost{{{gate_text}}}"
455
+ if wire in cwire_list:
456
+ wire_ind = cwire_list.index(wire)
457
+ if wire in wire_list + cwire_list:
458
+ self._latex[wire][col] = (
459
+ ghost_box + "_" + "<" * (len(str(wire_ind)) + 2) + f"{{{wire_ind}}}"
460
+ )
461
+ else:
462
+ self._latex[wire][col] = ghost_box
463
+ return num_cols_op
464
+
465
+ def _build_ctrl_gate(self, op, gate_text, wire_list, col):
466
+ """Add a gate with multiple controls to the _latex list"""
467
+ num_cols_op = 1
468
+ num_ctrl_qubits = op.num_ctrl_qubits
469
+ wireqargs = wire_list[num_ctrl_qubits:]
470
+ ctrlqargs = wire_list[:num_ctrl_qubits]
471
+ wire_min = min(wireqargs)
472
+ wire_max = max(wireqargs)
473
+ ctrl_state = f"{op.ctrl_state:b}".rjust(num_ctrl_qubits, "0")[::-1]
474
+
475
+ # First do single qubit target gates
476
+ if len(wireqargs) == 1:
477
+ self._add_controls(wire_list, ctrlqargs, ctrl_state, col)
478
+
479
+ # Check for cx, cz, cu1 and cp first, then do standard gate
480
+ if isinstance(op.base_gate, XGate):
481
+ self._latex[wireqargs[0]][col] = "\\targ"
482
+ elif isinstance(op.base_gate, ZGate):
483
+ self._latex[wireqargs[0]][col] = "\\control\\qw"
484
+ elif isinstance(op.base_gate, (U1Gate, PhaseGate)):
485
+ num_cols_op = self._build_symmetric_gate(op, gate_text, wire_list, col)
486
+ else:
487
+ self._latex[wireqargs[0]][col] = f"\\gate{{{gate_text}}}"
488
+ else:
489
+ # Treat special cases of swap and rzz gates
490
+ if isinstance(op.base_gate, (SwapGate, RZZGate)):
491
+ self._add_controls(wire_list, ctrlqargs, ctrl_state, col)
492
+ num_cols_op = self._build_symmetric_gate(op, gate_text, wire_list, col)
493
+ else:
494
+ # If any controls appear in the span of the multiqubit
495
+ # gate just treat the whole thing as a big gate
496
+ for ctrl in ctrlqargs:
497
+ if ctrl in range(wire_min, wire_max):
498
+ wireqargs = wire_list
499
+ break
500
+ else:
501
+ self._add_controls(wire_list, ctrlqargs, ctrl_state, col)
502
+
503
+ self._build_multi_gate(op, gate_text, wireqargs, [], col)
504
+ return num_cols_op
505
+
506
+ def _build_symmetric_gate(self, op, gate_text, wire_list, col):
507
+ """Add symmetric gates for cu1, cp, swap, and rzz"""
508
+ wire_max = max(wire_list)
509
+ # The last and next to last in the wire list are the gate wires without added controls
510
+ wire_next_last = wire_list[-2]
511
+ wire_last = wire_list[-1]
512
+ base_op = None if not hasattr(op, "base_gate") else op.base_gate
513
+
514
+ if isinstance(op, SwapGate) or (base_op and isinstance(base_op, SwapGate)):
515
+ self._latex[wire_next_last][col] = "\\qswap"
516
+ self._latex[wire_last][col] = "\\qswap \\qwx[" + str(wire_next_last - wire_last) + "]"
517
+ return 1 # num_cols
518
+
519
+ if isinstance(op, RZZGate) or (base_op and isinstance(base_op, RZZGate)):
520
+ ctrl_bit = "1"
521
+ else:
522
+ ctrl_bit = f"{op.ctrl_state:b}".rjust(1, "0")[::-1]
523
+
524
+ control = "\\ctrlo" if ctrl_bit == "0" else "\\ctrl"
525
+ self._latex[wire_next_last][col] = f"{control}" + (
526
+ "{" + str(wire_last - wire_next_last) + "}"
527
+ )
528
+ self._latex[wire_last][col] = "\\control \\qw"
529
+ # Put side text to the right between bottom wire in wire_list and the one above it
530
+ self._latex[wire_max - 1][col + 1] = f"\\dstick{{\\hspace{{2.0em}}{gate_text}}} \\qw"
531
+ return 4 # num_cols for side text gates
532
+
533
+ def _build_measure(self, node, col):
534
+ """Build a meter and the lines to the creg"""
535
+ wire1 = self._wire_map[node.qargs[0]]
536
+ self._latex[wire1][col] = "\\meter"
537
+
538
+ idx_str = ""
539
+ cond_offset = 1.5 if getattr(node.op, "condition", None) else 0.0
540
+ if self._cregbundle:
541
+ register = get_bit_register(self._circuit, node.cargs[0])
542
+ if register is not None:
543
+ wire2 = self._wire_map[register]
544
+ idx_str = str(self._circuit.find_bit(node.cargs[0]).registers[0][1])
545
+ else:
546
+ wire2 = self._wire_map[node.cargs[0]]
547
+ self._latex[wire2][col] = (
548
+ f"\\dstick{{_{{_{{\\hspace{{{cond_offset}em}}{idx_str}}}}}}} "
549
+ f"\\cw \\ar @{{<=}} [-{str(wire2 - wire1)},0]"
550
+ )
551
+ else:
552
+ wire2 = self._wire_map[node.cargs[0]]
553
+ self._latex[wire2][col] = "\\cw \\ar @{<=} [-" + str(wire2 - wire1) + ",0]"
554
+
555
+ def _build_barrier(self, node, col):
556
+ """Build a partial or full barrier if plot_barriers set"""
557
+ if self._plot_barriers:
558
+ indexes = [self._wire_map[qarg] for qarg in node.qargs if qarg in self._qubits]
559
+ indexes.sort()
560
+ first = last = indexes[0]
561
+ for index in indexes[1:]:
562
+ if index - 1 == last:
563
+ last = index
564
+ else:
565
+ pos = self._wire_map[self._qubits[first]]
566
+ self._latex[pos][col - 1] += " \\barrier[0em]{" + str(last - first) + "}"
567
+ self._latex[pos][col] = "\\qw"
568
+ first = last = index
569
+ pos = self._wire_map[self._qubits[first]]
570
+ self._latex[pos][col - 1] += " \\barrier[0em]{" + str(last - first) + "}"
571
+ if node.op.label is not None:
572
+ pos = indexes[0]
573
+ label = node.op.label.replace(" ", "\\,")
574
+ self._latex[pos][col] = f"\\cds{{0}}{{^{{\\mathrm{{{label}}}}}}}"
575
+
576
+ def _add_controls(self, wire_list, ctrlqargs, ctrl_state, col):
577
+ """Add one or more controls to a gate"""
578
+ for index, ctrl_item in enumerate(zip(ctrlqargs, ctrl_state)):
579
+ pos = ctrl_item[0]
580
+ nxt = wire_list[index]
581
+ if wire_list[index] > wire_list[-1]:
582
+ nxt -= 1
583
+ while nxt not in wire_list:
584
+ nxt -= 1
585
+ else:
586
+ nxt += 1
587
+ while nxt not in wire_list:
588
+ nxt += 1
589
+
590
+ # ctrl_item[1] is ctrl_state for this bit
591
+ control = "\\ctrlo" if ctrl_item[1] == "0" else "\\ctrl"
592
+ self._latex[pos][col] = f"{control}" + "{" + str(nxt - wire_list[index]) + "}"
593
+
594
+ def _add_condition(self, op, wire_list, col):
595
+ """Add a condition to the _latex list"""
596
+ # cwire - the wire number for the first wire for the condition register
597
+ # or if cregbundle, wire number of the condition register itself
598
+ # gap - the number of wires from cwire to the bottom gate qubit
599
+ label, val_bits = get_condition_label_val(op.condition, self._circuit, self._cregbundle)
600
+ cond_is_bit = isinstance(op.condition[0], Clbit)
601
+ cond_reg = op.condition[0]
602
+ if cond_is_bit:
603
+ register = get_bit_register(self._circuit, op.condition[0])
604
+ if register is not None:
605
+ cond_reg = register
606
+ meas_offset = -0.3 if isinstance(op, Measure) else 0.0
607
+
608
+ # If condition is a bit or cregbundle true, print the condition value
609
+ # at the bottom and put bullet on creg line
610
+ if cond_is_bit or self._cregbundle:
611
+ cwire = (
612
+ self._wire_map[cond_reg] if self._cregbundle else self._wire_map[op.condition[0]]
613
+ )
614
+ gap = cwire - max(wire_list)
615
+ control = "\\control" if op.condition[1] else "\\controlo"
616
+ self._latex[cwire][
617
+ col
618
+ ] = f"{control} \\cw^({meas_offset}){{^{{\\mathtt{{{label}}}}}}} \\cwx[-{str(gap)}]"
619
+
620
+ # If condition is a register and cregbundle is false
621
+ else:
622
+ # First sort the val_bits in the order of the register bits in the circuit
623
+ cond_wires = []
624
+ cond_bits = []
625
+ for wire, index in self._wire_map.items():
626
+ reg, _, reg_index = get_bit_reg_index(self._circuit, wire)
627
+ if reg == cond_reg:
628
+ cond_bits.append(reg_index)
629
+ cond_wires.append(index)
630
+
631
+ gap = cond_wires[0] - max(wire_list)
632
+ prev_wire = cond_wires[0]
633
+ val_bits_sorted = [bit for _, bit in sorted(zip(cond_bits, val_bits))]
634
+
635
+ # Iterate over the wire values for the bits in the register
636
+ for i, wire in enumerate(cond_wires[:-1]):
637
+ if i > 0:
638
+ gap = wire - prev_wire
639
+ control = "\\control" if val_bits_sorted[i] == "1" else "\\controlo"
640
+ self._latex[wire][col] = f"{control} \\cw \\cwx[-" + str(gap) + "]"
641
+ prev_wire = wire
642
+
643
+ # Add (hex condition value) below the last cwire
644
+ if len(cond_wires) == 1: # Only one bit in register
645
+ gap = cond_wires[0] - max(wire_list)
646
+ else:
647
+ gap = cond_wires[-1] - prev_wire
648
+ control = "\\control" if val_bits_sorted[len(cond_wires) - 1] == "1" else "\\controlo"
649
+ self._latex[cond_wires[-1]][col] = (
650
+ f"{control}" + " \\cw^(%s){^{\\mathtt{%s}}} \\cwx[-%s]"
651
+ ) % (
652
+ meas_offset,
653
+ label,
654
+ str(gap),
655
+ )
656
+
657
+ def _truncate_float(self, matchobj, ndigits=4):
658
+ """Truncate long floats."""
659
+ if matchobj.group(0):
660
+ return f"%.{ndigits}g" % float(matchobj.group(0))
661
+ return ""