qiskit 1.3.0__cp39-abi3-win32.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 (836) hide show
  1. qiskit/VERSION.txt +1 -0
  2. qiskit/__init__.py +146 -0
  3. qiskit/_accelerate.pyd +0 -0
  4. qiskit/_numpy_compat.py +73 -0
  5. qiskit/assembler/__init__.py +42 -0
  6. qiskit/assembler/assemble_circuits.py +451 -0
  7. qiskit/assembler/assemble_schedules.py +367 -0
  8. qiskit/assembler/disassemble.py +310 -0
  9. qiskit/assembler/run_config.py +77 -0
  10. qiskit/circuit/__init__.py +1313 -0
  11. qiskit/circuit/_classical_resource_map.py +148 -0
  12. qiskit/circuit/_standard_gates_commutations.py +3849 -0
  13. qiskit/circuit/_utils.py +167 -0
  14. qiskit/circuit/add_control.py +274 -0
  15. qiskit/circuit/annotated_operation.py +279 -0
  16. qiskit/circuit/barrier.py +50 -0
  17. qiskit/circuit/bit.py +94 -0
  18. qiskit/circuit/classical/__init__.py +41 -0
  19. qiskit/circuit/classical/expr/__init__.py +238 -0
  20. qiskit/circuit/classical/expr/constructors.py +556 -0
  21. qiskit/circuit/classical/expr/expr.py +397 -0
  22. qiskit/circuit/classical/expr/visitors.py +300 -0
  23. qiskit/circuit/classical/types/__init__.py +109 -0
  24. qiskit/circuit/classical/types/ordering.py +222 -0
  25. qiskit/circuit/classical/types/types.py +117 -0
  26. qiskit/circuit/classicalfunction/__init__.py +140 -0
  27. qiskit/circuit/classicalfunction/boolean_expression.py +129 -0
  28. qiskit/circuit/classicalfunction/classical_element.py +54 -0
  29. qiskit/circuit/classicalfunction/classical_function_visitor.py +155 -0
  30. qiskit/circuit/classicalfunction/classicalfunction.py +173 -0
  31. qiskit/circuit/classicalfunction/exceptions.py +35 -0
  32. qiskit/circuit/classicalfunction/types.py +18 -0
  33. qiskit/circuit/classicalfunction/utils.py +91 -0
  34. qiskit/circuit/classicalregister.py +57 -0
  35. qiskit/circuit/commutation_checker.py +106 -0
  36. qiskit/circuit/commutation_library.py +20 -0
  37. qiskit/circuit/controlflow/__init__.py +28 -0
  38. qiskit/circuit/controlflow/_builder_utils.py +207 -0
  39. qiskit/circuit/controlflow/break_loop.py +56 -0
  40. qiskit/circuit/controlflow/builder.py +691 -0
  41. qiskit/circuit/controlflow/continue_loop.py +58 -0
  42. qiskit/circuit/controlflow/control_flow.py +84 -0
  43. qiskit/circuit/controlflow/for_loop.py +217 -0
  44. qiskit/circuit/controlflow/if_else.py +511 -0
  45. qiskit/circuit/controlflow/switch_case.py +417 -0
  46. qiskit/circuit/controlflow/while_loop.py +171 -0
  47. qiskit/circuit/controlledgate.py +274 -0
  48. qiskit/circuit/delay.py +123 -0
  49. qiskit/circuit/duration.py +95 -0
  50. qiskit/circuit/equivalence.py +94 -0
  51. qiskit/circuit/equivalence_library.py +18 -0
  52. qiskit/circuit/exceptions.py +19 -0
  53. qiskit/circuit/gate.py +263 -0
  54. qiskit/circuit/instruction.py +697 -0
  55. qiskit/circuit/instructionset.py +179 -0
  56. qiskit/circuit/library/__init__.py +668 -0
  57. qiskit/circuit/library/arithmetic/__init__.py +34 -0
  58. qiskit/circuit/library/arithmetic/adders/__init__.py +18 -0
  59. qiskit/circuit/library/arithmetic/adders/adder.py +210 -0
  60. qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +123 -0
  61. qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +129 -0
  62. qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +95 -0
  63. qiskit/circuit/library/arithmetic/exact_reciprocal.py +88 -0
  64. qiskit/circuit/library/arithmetic/functional_pauli_rotations.py +114 -0
  65. qiskit/circuit/library/arithmetic/integer_comparator.py +243 -0
  66. qiskit/circuit/library/arithmetic/linear_amplitude_function.py +196 -0
  67. qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +189 -0
  68. qiskit/circuit/library/arithmetic/multipliers/__init__.py +17 -0
  69. qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py +145 -0
  70. qiskit/circuit/library/arithmetic/multipliers/multiplier.py +192 -0
  71. qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +108 -0
  72. qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +353 -0
  73. qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +277 -0
  74. qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +317 -0
  75. qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +335 -0
  76. qiskit/circuit/library/arithmetic/quadratic_form.py +198 -0
  77. qiskit/circuit/library/arithmetic/weighted_adder.py +337 -0
  78. qiskit/circuit/library/basis_change/__init__.py +15 -0
  79. qiskit/circuit/library/basis_change/qft.py +313 -0
  80. qiskit/circuit/library/blueprintcircuit.py +280 -0
  81. qiskit/circuit/library/boolean_logic/__init__.py +18 -0
  82. qiskit/circuit/library/boolean_logic/inner_product.py +155 -0
  83. qiskit/circuit/library/boolean_logic/quantum_and.py +200 -0
  84. qiskit/circuit/library/boolean_logic/quantum_or.py +202 -0
  85. qiskit/circuit/library/boolean_logic/quantum_xor.py +165 -0
  86. qiskit/circuit/library/data_preparation/__init__.py +57 -0
  87. qiskit/circuit/library/data_preparation/_z_feature_map.py +115 -0
  88. qiskit/circuit/library/data_preparation/_zz_feature_map.py +150 -0
  89. qiskit/circuit/library/data_preparation/initializer.py +107 -0
  90. qiskit/circuit/library/data_preparation/pauli_feature_map.py +656 -0
  91. qiskit/circuit/library/data_preparation/state_preparation.py +336 -0
  92. qiskit/circuit/library/fourier_checking.py +158 -0
  93. qiskit/circuit/library/generalized_gates/__init__.py +30 -0
  94. qiskit/circuit/library/generalized_gates/diagonal.py +159 -0
  95. qiskit/circuit/library/generalized_gates/gms.py +174 -0
  96. qiskit/circuit/library/generalized_gates/gr.py +215 -0
  97. qiskit/circuit/library/generalized_gates/isometry.py +370 -0
  98. qiskit/circuit/library/generalized_gates/linear_function.py +318 -0
  99. qiskit/circuit/library/generalized_gates/mcg_up_to_diagonal.py +143 -0
  100. qiskit/circuit/library/generalized_gates/mcmt.py +316 -0
  101. qiskit/circuit/library/generalized_gates/pauli.py +85 -0
  102. qiskit/circuit/library/generalized_gates/permutation.py +194 -0
  103. qiskit/circuit/library/generalized_gates/rv.py +96 -0
  104. qiskit/circuit/library/generalized_gates/uc.py +213 -0
  105. qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +164 -0
  106. qiskit/circuit/library/generalized_gates/ucrx.py +32 -0
  107. qiskit/circuit/library/generalized_gates/ucry.py +32 -0
  108. qiskit/circuit/library/generalized_gates/ucrz.py +32 -0
  109. qiskit/circuit/library/generalized_gates/unitary.py +215 -0
  110. qiskit/circuit/library/graph_state.py +169 -0
  111. qiskit/circuit/library/grover_operator.py +579 -0
  112. qiskit/circuit/library/hamiltonian_gate.py +142 -0
  113. qiskit/circuit/library/hidden_linear_function.py +161 -0
  114. qiskit/circuit/library/iqp.py +175 -0
  115. qiskit/circuit/library/n_local/__init__.py +45 -0
  116. qiskit/circuit/library/n_local/efficient_su2.py +277 -0
  117. qiskit/circuit/library/n_local/evolved_operator_ansatz.py +515 -0
  118. qiskit/circuit/library/n_local/excitation_preserving.py +297 -0
  119. qiskit/circuit/library/n_local/n_local.py +1472 -0
  120. qiskit/circuit/library/n_local/pauli_two_design.py +243 -0
  121. qiskit/circuit/library/n_local/qaoa_ansatz.py +366 -0
  122. qiskit/circuit/library/n_local/real_amplitudes.py +306 -0
  123. qiskit/circuit/library/n_local/two_local.py +289 -0
  124. qiskit/circuit/library/overlap.py +182 -0
  125. qiskit/circuit/library/pauli_evolution.py +186 -0
  126. qiskit/circuit/library/phase_estimation.py +175 -0
  127. qiskit/circuit/library/phase_oracle.py +153 -0
  128. qiskit/circuit/library/quantum_volume.py +167 -0
  129. qiskit/circuit/library/standard_gates/__init__.py +142 -0
  130. qiskit/circuit/library/standard_gates/dcx.py +78 -0
  131. qiskit/circuit/library/standard_gates/ecr.py +130 -0
  132. qiskit/circuit/library/standard_gates/equivalence_library.py +1800 -0
  133. qiskit/circuit/library/standard_gates/global_phase.py +85 -0
  134. qiskit/circuit/library/standard_gates/h.py +258 -0
  135. qiskit/circuit/library/standard_gates/i.py +76 -0
  136. qiskit/circuit/library/standard_gates/iswap.py +134 -0
  137. qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +405 -0
  138. qiskit/circuit/library/standard_gates/p.py +441 -0
  139. qiskit/circuit/library/standard_gates/r.py +117 -0
  140. qiskit/circuit/library/standard_gates/rx.py +303 -0
  141. qiskit/circuit/library/standard_gates/rxx.py +183 -0
  142. qiskit/circuit/library/standard_gates/ry.py +298 -0
  143. qiskit/circuit/library/standard_gates/ryy.py +183 -0
  144. qiskit/circuit/library/standard_gates/rz.py +319 -0
  145. qiskit/circuit/library/standard_gates/rzx.py +229 -0
  146. qiskit/circuit/library/standard_gates/rzz.py +196 -0
  147. qiskit/circuit/library/standard_gates/s.py +428 -0
  148. qiskit/circuit/library/standard_gates/swap.py +288 -0
  149. qiskit/circuit/library/standard_gates/sx.py +315 -0
  150. qiskit/circuit/library/standard_gates/t.py +179 -0
  151. qiskit/circuit/library/standard_gates/u.py +403 -0
  152. qiskit/circuit/library/standard_gates/u1.py +501 -0
  153. qiskit/circuit/library/standard_gates/u2.py +149 -0
  154. qiskit/circuit/library/standard_gates/u3.py +436 -0
  155. qiskit/circuit/library/standard_gates/x.py +1529 -0
  156. qiskit/circuit/library/standard_gates/xx_minus_yy.py +235 -0
  157. qiskit/circuit/library/standard_gates/xx_plus_yy.py +239 -0
  158. qiskit/circuit/library/standard_gates/y.py +262 -0
  159. qiskit/circuit/library/standard_gates/z.py +348 -0
  160. qiskit/circuit/library/templates/__init__.py +92 -0
  161. qiskit/circuit/library/templates/clifford/__init__.py +33 -0
  162. qiskit/circuit/library/templates/clifford/clifford_2_1.py +34 -0
  163. qiskit/circuit/library/templates/clifford/clifford_2_2.py +35 -0
  164. qiskit/circuit/library/templates/clifford/clifford_2_3.py +34 -0
  165. qiskit/circuit/library/templates/clifford/clifford_2_4.py +34 -0
  166. qiskit/circuit/library/templates/clifford/clifford_3_1.py +35 -0
  167. qiskit/circuit/library/templates/clifford/clifford_4_1.py +38 -0
  168. qiskit/circuit/library/templates/clifford/clifford_4_2.py +37 -0
  169. qiskit/circuit/library/templates/clifford/clifford_4_3.py +38 -0
  170. qiskit/circuit/library/templates/clifford/clifford_4_4.py +37 -0
  171. qiskit/circuit/library/templates/clifford/clifford_5_1.py +40 -0
  172. qiskit/circuit/library/templates/clifford/clifford_6_1.py +40 -0
  173. qiskit/circuit/library/templates/clifford/clifford_6_2.py +40 -0
  174. qiskit/circuit/library/templates/clifford/clifford_6_3.py +40 -0
  175. qiskit/circuit/library/templates/clifford/clifford_6_4.py +38 -0
  176. qiskit/circuit/library/templates/clifford/clifford_6_5.py +40 -0
  177. qiskit/circuit/library/templates/clifford/clifford_8_1.py +42 -0
  178. qiskit/circuit/library/templates/clifford/clifford_8_2.py +42 -0
  179. qiskit/circuit/library/templates/clifford/clifford_8_3.py +41 -0
  180. qiskit/circuit/library/templates/nct/__init__.py +67 -0
  181. qiskit/circuit/library/templates/nct/template_nct_2a_1.py +34 -0
  182. qiskit/circuit/library/templates/nct/template_nct_2a_2.py +35 -0
  183. qiskit/circuit/library/templates/nct/template_nct_2a_3.py +37 -0
  184. qiskit/circuit/library/templates/nct/template_nct_4a_1.py +43 -0
  185. qiskit/circuit/library/templates/nct/template_nct_4a_2.py +41 -0
  186. qiskit/circuit/library/templates/nct/template_nct_4a_3.py +39 -0
  187. qiskit/circuit/library/templates/nct/template_nct_4b_1.py +41 -0
  188. qiskit/circuit/library/templates/nct/template_nct_4b_2.py +39 -0
  189. qiskit/circuit/library/templates/nct/template_nct_5a_1.py +40 -0
  190. qiskit/circuit/library/templates/nct/template_nct_5a_2.py +40 -0
  191. qiskit/circuit/library/templates/nct/template_nct_5a_3.py +40 -0
  192. qiskit/circuit/library/templates/nct/template_nct_5a_4.py +39 -0
  193. qiskit/circuit/library/templates/nct/template_nct_6a_1.py +40 -0
  194. qiskit/circuit/library/templates/nct/template_nct_6a_2.py +41 -0
  195. qiskit/circuit/library/templates/nct/template_nct_6a_3.py +41 -0
  196. qiskit/circuit/library/templates/nct/template_nct_6a_4.py +41 -0
  197. qiskit/circuit/library/templates/nct/template_nct_6b_1.py +41 -0
  198. qiskit/circuit/library/templates/nct/template_nct_6b_2.py +41 -0
  199. qiskit/circuit/library/templates/nct/template_nct_6c_1.py +41 -0
  200. qiskit/circuit/library/templates/nct/template_nct_7a_1.py +43 -0
  201. qiskit/circuit/library/templates/nct/template_nct_7b_1.py +43 -0
  202. qiskit/circuit/library/templates/nct/template_nct_7c_1.py +43 -0
  203. qiskit/circuit/library/templates/nct/template_nct_7d_1.py +43 -0
  204. qiskit/circuit/library/templates/nct/template_nct_7e_1.py +43 -0
  205. qiskit/circuit/library/templates/nct/template_nct_9a_1.py +45 -0
  206. qiskit/circuit/library/templates/nct/template_nct_9c_1.py +43 -0
  207. qiskit/circuit/library/templates/nct/template_nct_9c_10.py +44 -0
  208. qiskit/circuit/library/templates/nct/template_nct_9c_11.py +44 -0
  209. qiskit/circuit/library/templates/nct/template_nct_9c_12.py +44 -0
  210. qiskit/circuit/library/templates/nct/template_nct_9c_2.py +44 -0
  211. qiskit/circuit/library/templates/nct/template_nct_9c_3.py +44 -0
  212. qiskit/circuit/library/templates/nct/template_nct_9c_4.py +44 -0
  213. qiskit/circuit/library/templates/nct/template_nct_9c_5.py +44 -0
  214. qiskit/circuit/library/templates/nct/template_nct_9c_6.py +44 -0
  215. qiskit/circuit/library/templates/nct/template_nct_9c_7.py +44 -0
  216. qiskit/circuit/library/templates/nct/template_nct_9c_8.py +44 -0
  217. qiskit/circuit/library/templates/nct/template_nct_9c_9.py +44 -0
  218. qiskit/circuit/library/templates/nct/template_nct_9d_1.py +43 -0
  219. qiskit/circuit/library/templates/nct/template_nct_9d_10.py +44 -0
  220. qiskit/circuit/library/templates/nct/template_nct_9d_2.py +44 -0
  221. qiskit/circuit/library/templates/nct/template_nct_9d_3.py +44 -0
  222. qiskit/circuit/library/templates/nct/template_nct_9d_4.py +44 -0
  223. qiskit/circuit/library/templates/nct/template_nct_9d_5.py +44 -0
  224. qiskit/circuit/library/templates/nct/template_nct_9d_6.py +44 -0
  225. qiskit/circuit/library/templates/nct/template_nct_9d_7.py +44 -0
  226. qiskit/circuit/library/templates/nct/template_nct_9d_8.py +44 -0
  227. qiskit/circuit/library/templates/nct/template_nct_9d_9.py +44 -0
  228. qiskit/circuit/library/templates/rzx/__init__.py +25 -0
  229. qiskit/circuit/library/templates/rzx/rzx_cy.py +47 -0
  230. qiskit/circuit/library/templates/rzx/rzx_xz.py +54 -0
  231. qiskit/circuit/library/templates/rzx/rzx_yz.py +45 -0
  232. qiskit/circuit/library/templates/rzx/rzx_zz1.py +69 -0
  233. qiskit/circuit/library/templates/rzx/rzx_zz2.py +59 -0
  234. qiskit/circuit/library/templates/rzx/rzx_zz3.py +59 -0
  235. qiskit/circuit/measure.py +44 -0
  236. qiskit/circuit/operation.py +67 -0
  237. qiskit/circuit/parameter.py +178 -0
  238. qiskit/circuit/parameterexpression.py +692 -0
  239. qiskit/circuit/parametertable.py +119 -0
  240. qiskit/circuit/parametervector.py +120 -0
  241. qiskit/circuit/quantumcircuit.py +6829 -0
  242. qiskit/circuit/quantumcircuitdata.py +136 -0
  243. qiskit/circuit/quantumregister.py +75 -0
  244. qiskit/circuit/random/__init__.py +15 -0
  245. qiskit/circuit/random/utils.py +358 -0
  246. qiskit/circuit/register.py +233 -0
  247. qiskit/circuit/reset.py +34 -0
  248. qiskit/circuit/singleton.py +606 -0
  249. qiskit/circuit/store.py +97 -0
  250. qiskit/circuit/tools/__init__.py +16 -0
  251. qiskit/circuit/tools/pi_check.py +190 -0
  252. qiskit/circuit/twirling.py +145 -0
  253. qiskit/compiler/__init__.py +33 -0
  254. qiskit/compiler/assembler.py +681 -0
  255. qiskit/compiler/scheduler.py +109 -0
  256. qiskit/compiler/sequencer.py +71 -0
  257. qiskit/compiler/transpiler.py +533 -0
  258. qiskit/converters/__init__.py +74 -0
  259. qiskit/converters/circuit_to_dag.py +78 -0
  260. qiskit/converters/circuit_to_dagdependency.py +51 -0
  261. qiskit/converters/circuit_to_dagdependency_v2.py +47 -0
  262. qiskit/converters/circuit_to_gate.py +107 -0
  263. qiskit/converters/circuit_to_instruction.py +155 -0
  264. qiskit/converters/dag_to_circuit.py +79 -0
  265. qiskit/converters/dag_to_dagdependency.py +55 -0
  266. qiskit/converters/dag_to_dagdependency_v2.py +44 -0
  267. qiskit/converters/dagdependency_to_circuit.py +46 -0
  268. qiskit/converters/dagdependency_to_dag.py +54 -0
  269. qiskit/dagcircuit/__init__.py +44 -0
  270. qiskit/dagcircuit/collect_blocks.py +391 -0
  271. qiskit/dagcircuit/dagcircuit.py +24 -0
  272. qiskit/dagcircuit/dagdependency.py +646 -0
  273. qiskit/dagcircuit/dagdependency_v2.py +641 -0
  274. qiskit/dagcircuit/dagdepnode.py +160 -0
  275. qiskit/dagcircuit/dagnode.py +176 -0
  276. qiskit/dagcircuit/exceptions.py +42 -0
  277. qiskit/exceptions.py +153 -0
  278. qiskit/passmanager/__init__.py +240 -0
  279. qiskit/passmanager/base_tasks.py +230 -0
  280. qiskit/passmanager/compilation_status.py +74 -0
  281. qiskit/passmanager/exceptions.py +19 -0
  282. qiskit/passmanager/flow_controllers.py +116 -0
  283. qiskit/passmanager/passmanager.py +333 -0
  284. qiskit/primitives/__init__.py +481 -0
  285. qiskit/primitives/backend_estimator.py +486 -0
  286. qiskit/primitives/backend_estimator_v2.py +434 -0
  287. qiskit/primitives/backend_sampler.py +222 -0
  288. qiskit/primitives/backend_sampler_v2.py +339 -0
  289. qiskit/primitives/base/__init__.py +20 -0
  290. qiskit/primitives/base/base_estimator.py +252 -0
  291. qiskit/primitives/base/base_primitive.py +45 -0
  292. qiskit/primitives/base/base_primitive_job.py +78 -0
  293. qiskit/primitives/base/base_result.py +65 -0
  294. qiskit/primitives/base/base_sampler.py +204 -0
  295. qiskit/primitives/base/estimator_result.py +46 -0
  296. qiskit/primitives/base/sampler_result.py +45 -0
  297. qiskit/primitives/base/validation.py +231 -0
  298. qiskit/primitives/containers/__init__.py +26 -0
  299. qiskit/primitives/containers/bindings_array.py +389 -0
  300. qiskit/primitives/containers/bit_array.py +741 -0
  301. qiskit/primitives/containers/data_bin.py +173 -0
  302. qiskit/primitives/containers/estimator_pub.py +222 -0
  303. qiskit/primitives/containers/object_array.py +94 -0
  304. qiskit/primitives/containers/observables_array.py +279 -0
  305. qiskit/primitives/containers/primitive_result.py +53 -0
  306. qiskit/primitives/containers/pub_result.py +51 -0
  307. qiskit/primitives/containers/sampler_pub.py +193 -0
  308. qiskit/primitives/containers/sampler_pub_result.py +74 -0
  309. qiskit/primitives/containers/shape.py +129 -0
  310. qiskit/primitives/estimator.py +172 -0
  311. qiskit/primitives/primitive_job.py +81 -0
  312. qiskit/primitives/sampler.py +162 -0
  313. qiskit/primitives/statevector_estimator.py +174 -0
  314. qiskit/primitives/statevector_sampler.py +292 -0
  315. qiskit/primitives/utils.py +247 -0
  316. qiskit/providers/__init__.py +803 -0
  317. qiskit/providers/backend.py +667 -0
  318. qiskit/providers/backend_compat.py +472 -0
  319. qiskit/providers/basic_provider/__init__.py +45 -0
  320. qiskit/providers/basic_provider/basic_provider.py +101 -0
  321. qiskit/providers/basic_provider/basic_provider_job.py +65 -0
  322. qiskit/providers/basic_provider/basic_provider_tools.py +218 -0
  323. qiskit/providers/basic_provider/basic_simulator.py +821 -0
  324. qiskit/providers/basic_provider/exceptions.py +30 -0
  325. qiskit/providers/exceptions.py +45 -0
  326. qiskit/providers/fake_provider/__init__.py +105 -0
  327. qiskit/providers/fake_provider/backends_v1/__init__.py +22 -0
  328. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +18 -0
  329. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +1 -0
  330. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +1 -0
  331. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +37 -0
  332. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +1 -0
  333. qiskit/providers/fake_provider/backends_v1/fake_20q/__init__.py +18 -0
  334. qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +1 -0
  335. qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +43 -0
  336. qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +1 -0
  337. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +18 -0
  338. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +1 -0
  339. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +1 -0
  340. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +50 -0
  341. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +1 -0
  342. qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +18 -0
  343. qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +1 -0
  344. qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +41 -0
  345. qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +1 -0
  346. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +18 -0
  347. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +1 -0
  348. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +1 -0
  349. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +44 -0
  350. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +1 -0
  351. qiskit/providers/fake_provider/fake_1q.py +91 -0
  352. qiskit/providers/fake_provider/fake_backend.py +165 -0
  353. qiskit/providers/fake_provider/fake_openpulse_2q.py +391 -0
  354. qiskit/providers/fake_provider/fake_openpulse_3q.py +340 -0
  355. qiskit/providers/fake_provider/fake_pulse_backend.py +49 -0
  356. qiskit/providers/fake_provider/fake_qasm_backend.py +77 -0
  357. qiskit/providers/fake_provider/generic_backend_v2.py +1035 -0
  358. qiskit/providers/fake_provider/utils/__init__.py +15 -0
  359. qiskit/providers/fake_provider/utils/backend_converter.py +150 -0
  360. qiskit/providers/fake_provider/utils/json_decoder.py +109 -0
  361. qiskit/providers/job.py +147 -0
  362. qiskit/providers/jobstatus.py +30 -0
  363. qiskit/providers/models/__init__.py +89 -0
  364. qiskit/providers/models/backendconfiguration.py +1040 -0
  365. qiskit/providers/models/backendproperties.py +517 -0
  366. qiskit/providers/models/backendstatus.py +94 -0
  367. qiskit/providers/models/jobstatus.py +66 -0
  368. qiskit/providers/models/pulsedefaults.py +305 -0
  369. qiskit/providers/options.py +273 -0
  370. qiskit/providers/provider.py +95 -0
  371. qiskit/providers/providerutils.py +110 -0
  372. qiskit/pulse/__init__.py +158 -0
  373. qiskit/pulse/builder.py +2254 -0
  374. qiskit/pulse/calibration_entries.py +381 -0
  375. qiskit/pulse/channels.py +227 -0
  376. qiskit/pulse/configuration.py +245 -0
  377. qiskit/pulse/exceptions.py +45 -0
  378. qiskit/pulse/filters.py +309 -0
  379. qiskit/pulse/instruction_schedule_map.py +424 -0
  380. qiskit/pulse/instructions/__init__.py +67 -0
  381. qiskit/pulse/instructions/acquire.py +150 -0
  382. qiskit/pulse/instructions/delay.py +71 -0
  383. qiskit/pulse/instructions/directives.py +154 -0
  384. qiskit/pulse/instructions/frequency.py +135 -0
  385. qiskit/pulse/instructions/instruction.py +270 -0
  386. qiskit/pulse/instructions/phase.py +152 -0
  387. qiskit/pulse/instructions/play.py +99 -0
  388. qiskit/pulse/instructions/reference.py +100 -0
  389. qiskit/pulse/instructions/snapshot.py +82 -0
  390. qiskit/pulse/library/__init__.py +97 -0
  391. qiskit/pulse/library/continuous.py +430 -0
  392. qiskit/pulse/library/pulse.py +148 -0
  393. qiskit/pulse/library/samplers/__init__.py +15 -0
  394. qiskit/pulse/library/samplers/decorators.py +295 -0
  395. qiskit/pulse/library/samplers/strategies.py +71 -0
  396. qiskit/pulse/library/symbolic_pulses.py +1988 -0
  397. qiskit/pulse/library/waveform.py +136 -0
  398. qiskit/pulse/macros.py +262 -0
  399. qiskit/pulse/parameter_manager.py +445 -0
  400. qiskit/pulse/parser.py +314 -0
  401. qiskit/pulse/reference_manager.py +58 -0
  402. qiskit/pulse/schedule.py +1854 -0
  403. qiskit/pulse/transforms/__init__.py +106 -0
  404. qiskit/pulse/transforms/alignments.py +406 -0
  405. qiskit/pulse/transforms/base_transforms.py +71 -0
  406. qiskit/pulse/transforms/canonicalization.py +498 -0
  407. qiskit/pulse/transforms/dag.py +122 -0
  408. qiskit/pulse/utils.py +149 -0
  409. qiskit/qasm/libs/dummy/stdgates.inc +75 -0
  410. qiskit/qasm/libs/qelib1.inc +266 -0
  411. qiskit/qasm/libs/stdgates.inc +82 -0
  412. qiskit/qasm2/__init__.py +654 -0
  413. qiskit/qasm2/exceptions.py +27 -0
  414. qiskit/qasm2/export.py +372 -0
  415. qiskit/qasm2/parse.py +452 -0
  416. qiskit/qasm3/__init__.py +367 -0
  417. qiskit/qasm3/ast.py +738 -0
  418. qiskit/qasm3/exceptions.py +27 -0
  419. qiskit/qasm3/experimental.py +70 -0
  420. qiskit/qasm3/exporter.py +1299 -0
  421. qiskit/qasm3/printer.py +577 -0
  422. qiskit/qobj/__init__.py +75 -0
  423. qiskit/qobj/common.py +81 -0
  424. qiskit/qobj/converters/__init__.py +18 -0
  425. qiskit/qobj/converters/lo_config.py +177 -0
  426. qiskit/qobj/converters/pulse_instruction.py +897 -0
  427. qiskit/qobj/pulse_qobj.py +709 -0
  428. qiskit/qobj/qasm_qobj.py +708 -0
  429. qiskit/qobj/utils.py +46 -0
  430. qiskit/qpy/__init__.py +1822 -0
  431. qiskit/qpy/binary_io/__init__.py +36 -0
  432. qiskit/qpy/binary_io/circuits.py +1475 -0
  433. qiskit/qpy/binary_io/schedules.py +635 -0
  434. qiskit/qpy/binary_io/value.py +1025 -0
  435. qiskit/qpy/common.py +350 -0
  436. qiskit/qpy/exceptions.py +53 -0
  437. qiskit/qpy/formats.py +401 -0
  438. qiskit/qpy/interface.py +377 -0
  439. qiskit/qpy/type_keys.py +572 -0
  440. qiskit/quantum_info/__init__.py +162 -0
  441. qiskit/quantum_info/analysis/__init__.py +17 -0
  442. qiskit/quantum_info/analysis/average.py +47 -0
  443. qiskit/quantum_info/analysis/distance.py +102 -0
  444. qiskit/quantum_info/analysis/make_observable.py +44 -0
  445. qiskit/quantum_info/analysis/z2_symmetries.py +484 -0
  446. qiskit/quantum_info/operators/__init__.py +28 -0
  447. qiskit/quantum_info/operators/base_operator.py +145 -0
  448. qiskit/quantum_info/operators/channel/__init__.py +29 -0
  449. qiskit/quantum_info/operators/channel/chi.py +191 -0
  450. qiskit/quantum_info/operators/channel/choi.py +218 -0
  451. qiskit/quantum_info/operators/channel/kraus.py +337 -0
  452. qiskit/quantum_info/operators/channel/ptm.py +204 -0
  453. qiskit/quantum_info/operators/channel/quantum_channel.py +348 -0
  454. qiskit/quantum_info/operators/channel/stinespring.py +296 -0
  455. qiskit/quantum_info/operators/channel/superop.py +377 -0
  456. qiskit/quantum_info/operators/channel/transformations.py +475 -0
  457. qiskit/quantum_info/operators/custom_iterator.py +48 -0
  458. qiskit/quantum_info/operators/dihedral/__init__.py +18 -0
  459. qiskit/quantum_info/operators/dihedral/dihedral.py +509 -0
  460. qiskit/quantum_info/operators/dihedral/dihedral_circuits.py +216 -0
  461. qiskit/quantum_info/operators/dihedral/polynomial.py +313 -0
  462. qiskit/quantum_info/operators/dihedral/random.py +64 -0
  463. qiskit/quantum_info/operators/linear_op.py +25 -0
  464. qiskit/quantum_info/operators/measures.py +418 -0
  465. qiskit/quantum_info/operators/mixins/__init__.py +52 -0
  466. qiskit/quantum_info/operators/mixins/adjoint.py +52 -0
  467. qiskit/quantum_info/operators/mixins/group.py +171 -0
  468. qiskit/quantum_info/operators/mixins/linear.py +84 -0
  469. qiskit/quantum_info/operators/mixins/multiply.py +62 -0
  470. qiskit/quantum_info/operators/mixins/tolerances.py +72 -0
  471. qiskit/quantum_info/operators/op_shape.py +525 -0
  472. qiskit/quantum_info/operators/operator.py +865 -0
  473. qiskit/quantum_info/operators/operator_utils.py +76 -0
  474. qiskit/quantum_info/operators/predicates.py +183 -0
  475. qiskit/quantum_info/operators/random.py +154 -0
  476. qiskit/quantum_info/operators/scalar_op.py +254 -0
  477. qiskit/quantum_info/operators/symplectic/__init__.py +23 -0
  478. qiskit/quantum_info/operators/symplectic/base_pauli.py +719 -0
  479. qiskit/quantum_info/operators/symplectic/clifford.py +1030 -0
  480. qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
  481. qiskit/quantum_info/operators/symplectic/pauli.py +753 -0
  482. qiskit/quantum_info/operators/symplectic/pauli_list.py +1230 -0
  483. qiskit/quantum_info/operators/symplectic/pauli_utils.py +40 -0
  484. qiskit/quantum_info/operators/symplectic/random.py +117 -0
  485. qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +1196 -0
  486. qiskit/quantum_info/operators/utils/__init__.py +20 -0
  487. qiskit/quantum_info/operators/utils/anti_commutator.py +36 -0
  488. qiskit/quantum_info/operators/utils/commutator.py +36 -0
  489. qiskit/quantum_info/operators/utils/double_commutator.py +76 -0
  490. qiskit/quantum_info/quaternion.py +156 -0
  491. qiskit/quantum_info/random.py +26 -0
  492. qiskit/quantum_info/states/__init__.py +28 -0
  493. qiskit/quantum_info/states/densitymatrix.py +845 -0
  494. qiskit/quantum_info/states/measures.py +288 -0
  495. qiskit/quantum_info/states/quantum_state.py +503 -0
  496. qiskit/quantum_info/states/random.py +157 -0
  497. qiskit/quantum_info/states/stabilizerstate.py +773 -0
  498. qiskit/quantum_info/states/statevector.py +958 -0
  499. qiskit/quantum_info/states/utils.py +247 -0
  500. qiskit/result/__init__.py +73 -0
  501. qiskit/result/counts.py +189 -0
  502. qiskit/result/distributions/__init__.py +17 -0
  503. qiskit/result/distributions/probability.py +100 -0
  504. qiskit/result/distributions/quasi.py +154 -0
  505. qiskit/result/exceptions.py +40 -0
  506. qiskit/result/mitigation/__init__.py +13 -0
  507. qiskit/result/mitigation/base_readout_mitigator.py +79 -0
  508. qiskit/result/mitigation/correlated_readout_mitigator.py +277 -0
  509. qiskit/result/mitigation/local_readout_mitigator.py +328 -0
  510. qiskit/result/mitigation/utils.py +217 -0
  511. qiskit/result/models.py +234 -0
  512. qiskit/result/postprocess.py +239 -0
  513. qiskit/result/result.py +392 -0
  514. qiskit/result/sampled_expval.py +75 -0
  515. qiskit/result/utils.py +295 -0
  516. qiskit/scheduler/__init__.py +40 -0
  517. qiskit/scheduler/config.py +37 -0
  518. qiskit/scheduler/lowering.py +187 -0
  519. qiskit/scheduler/methods/__init__.py +15 -0
  520. qiskit/scheduler/methods/basic.py +140 -0
  521. qiskit/scheduler/schedule_circuit.py +69 -0
  522. qiskit/scheduler/sequence.py +104 -0
  523. qiskit/synthesis/__init__.py +220 -0
  524. qiskit/synthesis/arithmetic/__init__.py +16 -0
  525. qiskit/synthesis/arithmetic/adders/__init__.py +17 -0
  526. qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +154 -0
  527. qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +103 -0
  528. qiskit/synthesis/arithmetic/adders/vbe_ripple_carry_adder.py +161 -0
  529. qiskit/synthesis/arithmetic/multipliers/__init__.py +16 -0
  530. qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +102 -0
  531. qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +99 -0
  532. qiskit/synthesis/clifford/__init__.py +19 -0
  533. qiskit/synthesis/clifford/clifford_decompose_ag.py +178 -0
  534. qiskit/synthesis/clifford/clifford_decompose_bm.py +46 -0
  535. qiskit/synthesis/clifford/clifford_decompose_full.py +64 -0
  536. qiskit/synthesis/clifford/clifford_decompose_greedy.py +58 -0
  537. qiskit/synthesis/clifford/clifford_decompose_layers.py +447 -0
  538. qiskit/synthesis/cnotdihedral/__init__.py +17 -0
  539. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py +52 -0
  540. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py +141 -0
  541. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py +266 -0
  542. qiskit/synthesis/discrete_basis/__init__.py +16 -0
  543. qiskit/synthesis/discrete_basis/commutator_decompose.py +241 -0
  544. qiskit/synthesis/discrete_basis/gate_sequence.py +415 -0
  545. qiskit/synthesis/discrete_basis/generate_basis_approximations.py +163 -0
  546. qiskit/synthesis/discrete_basis/solovay_kitaev.py +217 -0
  547. qiskit/synthesis/evolution/__init__.py +21 -0
  548. qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
  549. qiskit/synthesis/evolution/lie_trotter.py +117 -0
  550. qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
  551. qiskit/synthesis/evolution/pauli_network.py +80 -0
  552. qiskit/synthesis/evolution/product_formula.py +311 -0
  553. qiskit/synthesis/evolution/qdrift.py +138 -0
  554. qiskit/synthesis/evolution/suzuki_trotter.py +215 -0
  555. qiskit/synthesis/linear/__init__.py +26 -0
  556. qiskit/synthesis/linear/cnot_synth.py +69 -0
  557. qiskit/synthesis/linear/linear_circuits_utils.py +128 -0
  558. qiskit/synthesis/linear/linear_depth_lnn.py +276 -0
  559. qiskit/synthesis/linear/linear_matrix_utils.py +27 -0
  560. qiskit/synthesis/linear_phase/__init__.py +17 -0
  561. qiskit/synthesis/linear_phase/cnot_phase_synth.py +206 -0
  562. qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +262 -0
  563. qiskit/synthesis/linear_phase/cz_depth_lnn.py +58 -0
  564. qiskit/synthesis/multi_controlled/__init__.py +24 -0
  565. qiskit/synthesis/multi_controlled/mcmt_vchain.py +52 -0
  566. qiskit/synthesis/multi_controlled/mcx_synthesis.py +356 -0
  567. qiskit/synthesis/one_qubit/__init__.py +15 -0
  568. qiskit/synthesis/one_qubit/one_qubit_decompose.py +288 -0
  569. qiskit/synthesis/permutation/__init__.py +18 -0
  570. qiskit/synthesis/permutation/permutation_full.py +78 -0
  571. qiskit/synthesis/permutation/permutation_lnn.py +54 -0
  572. qiskit/synthesis/permutation/permutation_reverse_lnn.py +93 -0
  573. qiskit/synthesis/permutation/permutation_utils.py +16 -0
  574. qiskit/synthesis/qft/__init__.py +16 -0
  575. qiskit/synthesis/qft/qft_decompose_full.py +97 -0
  576. qiskit/synthesis/qft/qft_decompose_lnn.py +79 -0
  577. qiskit/synthesis/stabilizer/__init__.py +16 -0
  578. qiskit/synthesis/stabilizer/stabilizer_circuit.py +149 -0
  579. qiskit/synthesis/stabilizer/stabilizer_decompose.py +194 -0
  580. qiskit/synthesis/two_qubit/__init__.py +19 -0
  581. qiskit/synthesis/two_qubit/local_invariance.py +63 -0
  582. qiskit/synthesis/two_qubit/two_qubit_decompose.py +700 -0
  583. qiskit/synthesis/two_qubit/xx_decompose/__init__.py +19 -0
  584. qiskit/synthesis/two_qubit/xx_decompose/circuits.py +300 -0
  585. qiskit/synthesis/two_qubit/xx_decompose/decomposer.py +324 -0
  586. qiskit/synthesis/two_qubit/xx_decompose/embodiments.py +163 -0
  587. qiskit/synthesis/two_qubit/xx_decompose/paths.py +412 -0
  588. qiskit/synthesis/two_qubit/xx_decompose/polytopes.py +262 -0
  589. qiskit/synthesis/two_qubit/xx_decompose/utilities.py +40 -0
  590. qiskit/synthesis/two_qubit/xx_decompose/weyl.py +133 -0
  591. qiskit/synthesis/unitary/__init__.py +13 -0
  592. qiskit/synthesis/unitary/aqc/__init__.py +177 -0
  593. qiskit/synthesis/unitary/aqc/approximate.py +116 -0
  594. qiskit/synthesis/unitary/aqc/aqc.py +175 -0
  595. qiskit/synthesis/unitary/aqc/cnot_structures.py +300 -0
  596. qiskit/synthesis/unitary/aqc/cnot_unit_circuit.py +103 -0
  597. qiskit/synthesis/unitary/aqc/cnot_unit_objective.py +299 -0
  598. qiskit/synthesis/unitary/aqc/elementary_operations.py +108 -0
  599. qiskit/synthesis/unitary/aqc/fast_gradient/__init__.py +164 -0
  600. qiskit/synthesis/unitary/aqc/fast_gradient/fast_grad_utils.py +237 -0
  601. qiskit/synthesis/unitary/aqc/fast_gradient/fast_gradient.py +226 -0
  602. qiskit/synthesis/unitary/aqc/fast_gradient/layer.py +370 -0
  603. qiskit/synthesis/unitary/aqc/fast_gradient/pmatrix.py +312 -0
  604. qiskit/synthesis/unitary/qsd.py +288 -0
  605. qiskit/transpiler/__init__.py +1290 -0
  606. qiskit/transpiler/basepasses.py +221 -0
  607. qiskit/transpiler/coupling.py +500 -0
  608. qiskit/transpiler/exceptions.py +59 -0
  609. qiskit/transpiler/instruction_durations.py +281 -0
  610. qiskit/transpiler/layout.py +737 -0
  611. qiskit/transpiler/passes/__init__.py +312 -0
  612. qiskit/transpiler/passes/analysis/__init__.py +23 -0
  613. qiskit/transpiler/passes/analysis/count_ops.py +30 -0
  614. qiskit/transpiler/passes/analysis/count_ops_longest_path.py +26 -0
  615. qiskit/transpiler/passes/analysis/dag_longest_path.py +24 -0
  616. qiskit/transpiler/passes/analysis/depth.py +33 -0
  617. qiskit/transpiler/passes/analysis/num_qubits.py +26 -0
  618. qiskit/transpiler/passes/analysis/num_tensor_factors.py +26 -0
  619. qiskit/transpiler/passes/analysis/resource_estimation.py +41 -0
  620. qiskit/transpiler/passes/analysis/size.py +36 -0
  621. qiskit/transpiler/passes/analysis/width.py +27 -0
  622. qiskit/transpiler/passes/basis/__init__.py +19 -0
  623. qiskit/transpiler/passes/basis/basis_translator.py +137 -0
  624. qiskit/transpiler/passes/basis/decompose.py +131 -0
  625. qiskit/transpiler/passes/basis/translate_parameterized.py +175 -0
  626. qiskit/transpiler/passes/basis/unroll_3q_or_more.py +88 -0
  627. qiskit/transpiler/passes/basis/unroll_custom_definitions.py +109 -0
  628. qiskit/transpiler/passes/calibration/__init__.py +17 -0
  629. qiskit/transpiler/passes/calibration/base_builder.py +79 -0
  630. qiskit/transpiler/passes/calibration/builders.py +20 -0
  631. qiskit/transpiler/passes/calibration/exceptions.py +22 -0
  632. qiskit/transpiler/passes/calibration/pulse_gate.py +100 -0
  633. qiskit/transpiler/passes/calibration/rx_builder.py +164 -0
  634. qiskit/transpiler/passes/calibration/rzx_builder.py +411 -0
  635. qiskit/transpiler/passes/calibration/rzx_templates.py +51 -0
  636. qiskit/transpiler/passes/layout/__init__.py +26 -0
  637. qiskit/transpiler/passes/layout/_csp_custom_solver.py +65 -0
  638. qiskit/transpiler/passes/layout/apply_layout.py +123 -0
  639. qiskit/transpiler/passes/layout/csp_layout.py +132 -0
  640. qiskit/transpiler/passes/layout/dense_layout.py +202 -0
  641. qiskit/transpiler/passes/layout/disjoint_utils.py +219 -0
  642. qiskit/transpiler/passes/layout/enlarge_with_ancilla.py +49 -0
  643. qiskit/transpiler/passes/layout/full_ancilla_allocation.py +117 -0
  644. qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
  645. qiskit/transpiler/passes/layout/sabre_layout.py +487 -0
  646. qiskit/transpiler/passes/layout/sabre_pre_layout.py +225 -0
  647. qiskit/transpiler/passes/layout/set_layout.py +69 -0
  648. qiskit/transpiler/passes/layout/trivial_layout.py +66 -0
  649. qiskit/transpiler/passes/layout/vf2_layout.py +263 -0
  650. qiskit/transpiler/passes/layout/vf2_post_layout.py +419 -0
  651. qiskit/transpiler/passes/layout/vf2_utils.py +260 -0
  652. qiskit/transpiler/passes/optimization/__init__.py +43 -0
  653. qiskit/transpiler/passes/optimization/_gate_extension.py +80 -0
  654. qiskit/transpiler/passes/optimization/collect_1q_runs.py +31 -0
  655. qiskit/transpiler/passes/optimization/collect_2q_blocks.py +35 -0
  656. qiskit/transpiler/passes/optimization/collect_and_collapse.py +115 -0
  657. qiskit/transpiler/passes/optimization/collect_cliffords.py +104 -0
  658. qiskit/transpiler/passes/optimization/collect_linear_functions.py +80 -0
  659. qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +227 -0
  660. qiskit/transpiler/passes/optimization/commutation_analysis.py +44 -0
  661. qiskit/transpiler/passes/optimization/commutative_cancellation.py +82 -0
  662. qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py +140 -0
  663. qiskit/transpiler/passes/optimization/consolidate_blocks.py +149 -0
  664. qiskit/transpiler/passes/optimization/cx_cancellation.py +65 -0
  665. qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +162 -0
  666. qiskit/transpiler/passes/optimization/elide_permutations.py +91 -0
  667. qiskit/transpiler/passes/optimization/hoare_opt.py +420 -0
  668. qiskit/transpiler/passes/optimization/inverse_cancellation.py +95 -0
  669. qiskit/transpiler/passes/optimization/normalize_rx_angle.py +149 -0
  670. qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +268 -0
  671. qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +254 -0
  672. qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
  673. qiskit/transpiler/passes/optimization/optimize_annotated.py +448 -0
  674. qiskit/transpiler/passes/optimization/optimize_cliffords.py +89 -0
  675. qiskit/transpiler/passes/optimization/optimize_swap_before_measure.py +71 -0
  676. qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py +41 -0
  677. qiskit/transpiler/passes/optimization/remove_final_reset.py +37 -0
  678. qiskit/transpiler/passes/optimization/remove_identity_equiv.py +69 -0
  679. qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
  680. qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +47 -0
  681. qiskit/transpiler/passes/optimization/split_2q_unitaries.py +40 -0
  682. qiskit/transpiler/passes/optimization/template_matching/__init__.py +19 -0
  683. qiskit/transpiler/passes/optimization/template_matching/backward_match.py +749 -0
  684. qiskit/transpiler/passes/optimization/template_matching/forward_match.py +452 -0
  685. qiskit/transpiler/passes/optimization/template_matching/maximal_matches.py +77 -0
  686. qiskit/transpiler/passes/optimization/template_matching/template_matching.py +370 -0
  687. qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +638 -0
  688. qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
  689. qiskit/transpiler/passes/routing/__init__.py +22 -0
  690. qiskit/transpiler/passes/routing/algorithms/__init__.py +33 -0
  691. qiskit/transpiler/passes/routing/algorithms/token_swapper.py +105 -0
  692. qiskit/transpiler/passes/routing/algorithms/types.py +46 -0
  693. qiskit/transpiler/passes/routing/algorithms/util.py +103 -0
  694. qiskit/transpiler/passes/routing/basic_swap.py +166 -0
  695. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/__init__.py +25 -0
  696. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_block.py +60 -0
  697. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +395 -0
  698. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/pauli_2q_evolution_commutation.py +145 -0
  699. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/swap_strategy.py +306 -0
  700. qiskit/transpiler/passes/routing/layout_transformation.py +119 -0
  701. qiskit/transpiler/passes/routing/lookahead_swap.py +390 -0
  702. qiskit/transpiler/passes/routing/sabre_swap.py +447 -0
  703. qiskit/transpiler/passes/routing/star_prerouting.py +392 -0
  704. qiskit/transpiler/passes/routing/stochastic_swap.py +532 -0
  705. qiskit/transpiler/passes/routing/utils.py +35 -0
  706. qiskit/transpiler/passes/scheduling/__init__.py +27 -0
  707. qiskit/transpiler/passes/scheduling/alap.py +153 -0
  708. qiskit/transpiler/passes/scheduling/alignments/__init__.py +81 -0
  709. qiskit/transpiler/passes/scheduling/alignments/align_measures.py +255 -0
  710. qiskit/transpiler/passes/scheduling/alignments/check_durations.py +78 -0
  711. qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +107 -0
  712. qiskit/transpiler/passes/scheduling/alignments/reschedule.py +250 -0
  713. qiskit/transpiler/passes/scheduling/asap.py +175 -0
  714. qiskit/transpiler/passes/scheduling/base_scheduler.py +310 -0
  715. qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +312 -0
  716. qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
  717. qiskit/transpiler/passes/scheduling/padding/base_padding.py +256 -0
  718. qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +452 -0
  719. qiskit/transpiler/passes/scheduling/padding/pad_delay.py +82 -0
  720. qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
  721. qiskit/transpiler/passes/scheduling/scheduling/alap.py +127 -0
  722. qiskit/transpiler/passes/scheduling/scheduling/asap.py +131 -0
  723. qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +94 -0
  724. qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
  725. qiskit/transpiler/passes/scheduling/time_unit_conversion.py +165 -0
  726. qiskit/transpiler/passes/synthesis/__init__.py +20 -0
  727. qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
  728. qiskit/transpiler/passes/synthesis/high_level_synthesis.py +854 -0
  729. qiskit/transpiler/passes/synthesis/hls_plugins.py +1559 -0
  730. qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +41 -0
  731. qiskit/transpiler/passes/synthesis/plugin.py +734 -0
  732. qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +297 -0
  733. qiskit/transpiler/passes/synthesis/unitary_synthesis.py +1076 -0
  734. qiskit/transpiler/passes/utils/__init__.py +33 -0
  735. qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +41 -0
  736. qiskit/transpiler/passes/utils/check_gate_direction.py +52 -0
  737. qiskit/transpiler/passes/utils/check_map.py +78 -0
  738. qiskit/transpiler/passes/utils/contains_instruction.py +45 -0
  739. qiskit/transpiler/passes/utils/control_flow.py +65 -0
  740. qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +93 -0
  741. qiskit/transpiler/passes/utils/dag_fixed_point.py +36 -0
  742. qiskit/transpiler/passes/utils/error.py +69 -0
  743. qiskit/transpiler/passes/utils/filter_op_nodes.py +65 -0
  744. qiskit/transpiler/passes/utils/fixed_point.py +48 -0
  745. qiskit/transpiler/passes/utils/gate_direction.py +86 -0
  746. qiskit/transpiler/passes/utils/gates_basis.py +51 -0
  747. qiskit/transpiler/passes/utils/merge_adjacent_barriers.py +163 -0
  748. qiskit/transpiler/passes/utils/minimum_point.py +118 -0
  749. qiskit/transpiler/passes/utils/remove_barriers.py +49 -0
  750. qiskit/transpiler/passes/utils/remove_final_measurements.py +114 -0
  751. qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
  752. qiskit/transpiler/passmanager.py +490 -0
  753. qiskit/transpiler/passmanager_config.py +216 -0
  754. qiskit/transpiler/preset_passmanagers/__init__.py +73 -0
  755. qiskit/transpiler/preset_passmanagers/builtin_plugins.py +1045 -0
  756. qiskit/transpiler/preset_passmanagers/common.py +649 -0
  757. qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +626 -0
  758. qiskit/transpiler/preset_passmanagers/level0.py +113 -0
  759. qiskit/transpiler/preset_passmanagers/level1.py +120 -0
  760. qiskit/transpiler/preset_passmanagers/level2.py +119 -0
  761. qiskit/transpiler/preset_passmanagers/level3.py +119 -0
  762. qiskit/transpiler/preset_passmanagers/plugin.py +353 -0
  763. qiskit/transpiler/target.py +1319 -0
  764. qiskit/transpiler/timing_constraints.py +59 -0
  765. qiskit/user_config.py +262 -0
  766. qiskit/utils/__init__.py +89 -0
  767. qiskit/utils/classtools.py +146 -0
  768. qiskit/utils/deprecate_pulse.py +119 -0
  769. qiskit/utils/deprecation.py +490 -0
  770. qiskit/utils/lazy_tester.py +363 -0
  771. qiskit/utils/multiprocessing.py +56 -0
  772. qiskit/utils/optionals.py +347 -0
  773. qiskit/utils/parallel.py +191 -0
  774. qiskit/utils/units.py +143 -0
  775. qiskit/version.py +84 -0
  776. qiskit/visualization/__init__.py +288 -0
  777. qiskit/visualization/array.py +204 -0
  778. qiskit/visualization/bloch.py +778 -0
  779. qiskit/visualization/circuit/__init__.py +15 -0
  780. qiskit/visualization/circuit/_utils.py +675 -0
  781. qiskit/visualization/circuit/circuit_visualization.py +727 -0
  782. qiskit/visualization/circuit/latex.py +661 -0
  783. qiskit/visualization/circuit/matplotlib.py +2029 -0
  784. qiskit/visualization/circuit/qcstyle.py +278 -0
  785. qiskit/visualization/circuit/styles/__init__.py +13 -0
  786. qiskit/visualization/circuit/styles/bw.json +202 -0
  787. qiskit/visualization/circuit/styles/clifford.json +202 -0
  788. qiskit/visualization/circuit/styles/iqp-dark.json +214 -0
  789. qiskit/visualization/circuit/styles/iqp.json +214 -0
  790. qiskit/visualization/circuit/styles/textbook.json +202 -0
  791. qiskit/visualization/circuit/text.py +1844 -0
  792. qiskit/visualization/circuit_visualization.py +19 -0
  793. qiskit/visualization/counts_visualization.py +481 -0
  794. qiskit/visualization/dag_visualization.py +316 -0
  795. qiskit/visualization/exceptions.py +21 -0
  796. qiskit/visualization/gate_map.py +1485 -0
  797. qiskit/visualization/library.py +37 -0
  798. qiskit/visualization/pass_manager_visualization.py +308 -0
  799. qiskit/visualization/pulse_v2/__init__.py +21 -0
  800. qiskit/visualization/pulse_v2/core.py +901 -0
  801. qiskit/visualization/pulse_v2/device_info.py +173 -0
  802. qiskit/visualization/pulse_v2/drawings.py +253 -0
  803. qiskit/visualization/pulse_v2/events.py +254 -0
  804. qiskit/visualization/pulse_v2/generators/__init__.py +40 -0
  805. qiskit/visualization/pulse_v2/generators/barrier.py +76 -0
  806. qiskit/visualization/pulse_v2/generators/chart.py +208 -0
  807. qiskit/visualization/pulse_v2/generators/frame.py +436 -0
  808. qiskit/visualization/pulse_v2/generators/snapshot.py +133 -0
  809. qiskit/visualization/pulse_v2/generators/waveform.py +645 -0
  810. qiskit/visualization/pulse_v2/interface.py +458 -0
  811. qiskit/visualization/pulse_v2/layouts.py +387 -0
  812. qiskit/visualization/pulse_v2/plotters/__init__.py +17 -0
  813. qiskit/visualization/pulse_v2/plotters/base_plotter.py +53 -0
  814. qiskit/visualization/pulse_v2/plotters/matplotlib.py +201 -0
  815. qiskit/visualization/pulse_v2/stylesheet.py +312 -0
  816. qiskit/visualization/pulse_v2/types.py +242 -0
  817. qiskit/visualization/state_visualization.py +1518 -0
  818. qiskit/visualization/timeline/__init__.py +21 -0
  819. qiskit/visualization/timeline/core.py +480 -0
  820. qiskit/visualization/timeline/drawings.py +260 -0
  821. qiskit/visualization/timeline/generators.py +506 -0
  822. qiskit/visualization/timeline/interface.py +436 -0
  823. qiskit/visualization/timeline/layouts.py +115 -0
  824. qiskit/visualization/timeline/plotters/__init__.py +16 -0
  825. qiskit/visualization/timeline/plotters/base_plotter.py +58 -0
  826. qiskit/visualization/timeline/plotters/matplotlib.py +192 -0
  827. qiskit/visualization/timeline/stylesheet.py +301 -0
  828. qiskit/visualization/timeline/types.py +148 -0
  829. qiskit/visualization/transition_visualization.py +369 -0
  830. qiskit/visualization/utils.py +49 -0
  831. qiskit-1.3.0.dist-info/LICENSE.txt +203 -0
  832. qiskit-1.3.0.dist-info/METADATA +222 -0
  833. qiskit-1.3.0.dist-info/RECORD +836 -0
  834. qiskit-1.3.0.dist-info/WHEEL +5 -0
  835. qiskit-1.3.0.dist-info/entry_points.txt +76 -0
  836. qiskit-1.3.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,958 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2017, 2019.
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
+ Statevector quantum state class.
15
+ """
16
+ from __future__ import annotations
17
+ import copy as _copy
18
+ import math
19
+ import re
20
+ from numbers import Number
21
+
22
+ import numpy as np
23
+
24
+ from qiskit import _numpy_compat
25
+ from qiskit.circuit.quantumcircuit import QuantumCircuit
26
+ from qiskit.circuit.instruction import Instruction
27
+ from qiskit.exceptions import QiskitError
28
+ from qiskit.quantum_info.states.quantum_state import QuantumState
29
+ from qiskit.quantum_info.operators.mixins.tolerances import TolerancesMixin
30
+ from qiskit.quantum_info.operators.operator import Operator, BaseOperator
31
+ from qiskit.quantum_info.operators.symplectic import Pauli, SparsePauliOp
32
+ from qiskit.quantum_info.operators.op_shape import OpShape
33
+ from qiskit.quantum_info.operators.predicates import matrix_equal
34
+
35
+ from qiskit._accelerate.pauli_expval import (
36
+ expval_pauli_no_x,
37
+ expval_pauli_with_x,
38
+ )
39
+
40
+
41
+ class Statevector(QuantumState, TolerancesMixin):
42
+ """Statevector class"""
43
+
44
+ def __init__(
45
+ self,
46
+ data: np.ndarray | list | Statevector | Operator | QuantumCircuit | Instruction,
47
+ dims: int | tuple | list | None = None,
48
+ ):
49
+ """Initialize a statevector object.
50
+
51
+ Args:
52
+ data (np.array or list or Statevector or Operator or QuantumCircuit or
53
+ qiskit.circuit.Instruction):
54
+ Data from which the statevector can be constructed. This can be either a complex
55
+ vector, another statevector, a ``Operator`` with only one column or a
56
+ ``QuantumCircuit`` or ``Instruction``. If the data is a circuit or instruction,
57
+ the statevector is constructed by assuming that all qubits are initialized to the
58
+ zero state.
59
+ dims (int or tuple or list): Optional. The subsystem dimension of
60
+ the state (See additional information).
61
+
62
+ Raises:
63
+ QiskitError: if input data is not valid.
64
+
65
+ Additional Information:
66
+ The ``dims`` kwarg can be None, an integer, or an iterable of
67
+ integers.
68
+
69
+ * ``Iterable`` -- the subsystem dimensions are the values in the list
70
+ with the total number of subsystems given by the length of the list.
71
+
72
+ * ``Int`` or ``None`` -- the length of the input vector
73
+ specifies the total dimension of the density matrix. If it is a
74
+ power of two the state will be initialized as an N-qubit state.
75
+ If it is not a power of two the state will have a single
76
+ d-dimensional subsystem.
77
+ """
78
+ if isinstance(data, (list, np.ndarray)):
79
+ # Finally we check if the input is a raw vector in either a
80
+ # python list or numpy array format.
81
+ self._data = np.asarray(data, dtype=complex)
82
+ elif isinstance(data, Statevector):
83
+ self._data = data._data
84
+ if dims is None:
85
+ dims = data._op_shape._dims_l
86
+ elif isinstance(data, Operator):
87
+ # We allow conversion of column-vector operators to Statevectors
88
+ input_dim, _ = data.dim
89
+ if input_dim != 1:
90
+ raise QiskitError("Input Operator is not a column-vector.")
91
+ self._data = np.ravel(data.data)
92
+ elif isinstance(data, (QuantumCircuit, Instruction)):
93
+ self._data = Statevector.from_instruction(data).data
94
+ else:
95
+ raise QiskitError("Invalid input data format for Statevector")
96
+ # Check that the input is a numpy vector or column-vector numpy
97
+ # matrix. If it is a column-vector matrix reshape to a vector.
98
+ ndim = self._data.ndim
99
+ shape = self._data.shape
100
+ if ndim != 1:
101
+ if ndim == 2 and shape[1] == 1:
102
+ self._data = np.reshape(self._data, shape[0])
103
+ shape = self._data.shape
104
+ elif ndim != 2 or shape[1] != 1:
105
+ raise QiskitError("Invalid input: not a vector or column-vector.")
106
+ super().__init__(op_shape=OpShape.auto(shape=shape, dims_l=dims, num_qubits_r=0))
107
+
108
+ def __array__(self, dtype=None, copy=_numpy_compat.COPY_ONLY_IF_NEEDED):
109
+ dtype = self.data.dtype if dtype is None else dtype
110
+ return np.array(self.data, dtype=dtype, copy=copy)
111
+
112
+ def __eq__(self, other):
113
+ return super().__eq__(other) and np.allclose(
114
+ self._data, other._data, rtol=self.rtol, atol=self.atol
115
+ )
116
+
117
+ def __repr__(self):
118
+ prefix = "Statevector("
119
+ pad = len(prefix) * " "
120
+ return (
121
+ f"{prefix}{np.array2string(self._data, separator=', ', prefix=prefix)},\n{pad}"
122
+ f"dims={self._op_shape.dims_l()})"
123
+ )
124
+
125
+ @property
126
+ def settings(self) -> dict:
127
+ """Return settings."""
128
+ return {"data": self._data, "dims": self._op_shape.dims_l()}
129
+
130
+ def draw(self, output: str | None = None, **drawer_args):
131
+ """Return a visualization of the Statevector.
132
+
133
+ **repr**: ASCII TextMatrix of the state's ``__repr__``.
134
+
135
+ **text**: ASCII TextMatrix that can be printed in the console.
136
+
137
+ **latex**: An IPython Latex object for displaying in Jupyter Notebooks.
138
+
139
+ **latex_source**: Raw, uncompiled ASCII source to generate array using LaTeX.
140
+
141
+ **qsphere**: Matplotlib figure, rendering of statevector using `plot_state_qsphere()`.
142
+
143
+ **hinton**: Matplotlib figure, rendering of statevector using `plot_state_hinton()`.
144
+
145
+ **bloch**: Matplotlib figure, rendering of statevector using `plot_bloch_multivector()`.
146
+
147
+ **city**: Matplotlib figure, rendering of statevector using `plot_state_city()`.
148
+
149
+ **paulivec**: Matplotlib figure, rendering of statevector using `plot_state_paulivec()`.
150
+
151
+ Args:
152
+ output (str): Select the output method to use for drawing the
153
+ state. Valid choices are `repr`, `text`, `latex`, `latex_source`,
154
+ `qsphere`, `hinton`, `bloch`, `city`, or `paulivec`. Default is `repr`.
155
+ Default can be changed by adding the line ``state_drawer = <default>`` to
156
+ ``~/.qiskit/settings.conf`` under ``[default]``.
157
+ drawer_args: Arguments to be passed directly to the relevant drawing
158
+ function or constructor (`TextMatrix()`, `array_to_latex()`,
159
+ `plot_state_qsphere()`, `plot_state_hinton()` or `plot_bloch_multivector()`).
160
+ See the relevant function under `qiskit.visualization` for that function's
161
+ documentation.
162
+
163
+ Returns:
164
+ :class:`matplotlib.Figure` or :class:`str` or
165
+ :class:`TextMatrix` or :class:`IPython.display.Latex`:
166
+ Drawing of the Statevector.
167
+
168
+ Raises:
169
+ ValueError: when an invalid output method is selected.
170
+
171
+ Examples:
172
+
173
+ Plot one of the Bell states
174
+
175
+ .. plot::
176
+ :include-source:
177
+
178
+ from numpy import sqrt
179
+ from qiskit.quantum_info import Statevector
180
+ sv=Statevector([1/sqrt(2), 0, 0, -1/sqrt(2)])
181
+ sv.draw(output='hinton')
182
+
183
+ """
184
+ # pylint: disable=cyclic-import
185
+ from qiskit.visualization.state_visualization import state_drawer
186
+
187
+ return state_drawer(self, output=output, **drawer_args)
188
+
189
+ def _ipython_display_(self):
190
+ out = self.draw()
191
+ if isinstance(out, str):
192
+ print(out)
193
+ else:
194
+ from IPython.display import display
195
+
196
+ display(out)
197
+
198
+ def __getitem__(self, key: int | str) -> np.complex128:
199
+ """Return Statevector item either by index or binary label
200
+ Args:
201
+ key (int or str): index or corresponding binary label, e.g. '01' = 1.
202
+
203
+ Returns:
204
+ numpy.complex128: Statevector item.
205
+
206
+ Raises:
207
+ QiskitError: if key is not valid.
208
+ """
209
+ if isinstance(key, str):
210
+ try:
211
+ key = int(key, 2)
212
+ except ValueError:
213
+ raise QiskitError(f"Key '{key}' is not a valid binary string.") from None
214
+ if isinstance(key, int):
215
+ if key >= self.dim:
216
+ raise QiskitError(f"Key {key} is greater than Statevector dimension {self.dim}.")
217
+ if key < 0:
218
+ raise QiskitError(f"Key {key} is not a valid positive value.")
219
+ return self._data[key]
220
+ else:
221
+ raise QiskitError("Key must be int or a valid binary string.")
222
+
223
+ def __iter__(self):
224
+ yield from self._data
225
+
226
+ def __len__(self):
227
+ return len(self._data)
228
+
229
+ @property
230
+ def data(self) -> np.ndarray:
231
+ """Return data."""
232
+ return self._data
233
+
234
+ def is_valid(self, atol: float | None = None, rtol: float | None = None) -> bool:
235
+ """Return True if a Statevector has norm 1."""
236
+ if atol is None:
237
+ atol = self.atol
238
+ if rtol is None:
239
+ rtol = self.rtol
240
+ norm = np.linalg.norm(self.data)
241
+ return np.allclose(norm, 1, rtol=rtol, atol=atol)
242
+
243
+ def to_operator(self) -> Operator:
244
+ """Convert state to a rank-1 projector operator"""
245
+ mat = np.outer(self.data, np.conj(self.data))
246
+ return Operator(mat, input_dims=self.dims(), output_dims=self.dims())
247
+
248
+ def conjugate(self) -> Statevector:
249
+ """Return the conjugate of the operator."""
250
+ return Statevector(np.conj(self.data), dims=self.dims())
251
+
252
+ def trace(self) -> np.float64:
253
+ """Return the trace of the quantum state as a density matrix."""
254
+ return np.sum(np.abs(self.data) ** 2)
255
+
256
+ def purity(self) -> np.float64:
257
+ """Return the purity of the quantum state."""
258
+ # For a valid statevector the purity is always 1, however if we simply
259
+ # have an arbitrary vector (not correctly normalized) then the
260
+ # purity is equivalent to the trace squared:
261
+ # P(|psi>) = Tr[|psi><psi|psi><psi|] = |<psi|psi>|^2
262
+ return self.trace() ** 2
263
+
264
+ def tensor(self, other: Statevector) -> Statevector:
265
+ """Return the tensor product state self ⊗ other.
266
+
267
+ Args:
268
+ other (Statevector): a quantum state object.
269
+
270
+ Returns:
271
+ Statevector: the tensor product operator self ⊗ other.
272
+
273
+ Raises:
274
+ QiskitError: if other is not a quantum state.
275
+ """
276
+ if not isinstance(other, Statevector):
277
+ other = Statevector(other)
278
+ ret = _copy.copy(self)
279
+ ret._op_shape = self._op_shape.tensor(other._op_shape)
280
+ ret._data = np.kron(self._data, other._data)
281
+ return ret
282
+
283
+ def inner(self, other: Statevector) -> np.complex128:
284
+ r"""Return the inner product of self and other as
285
+ :math:`\langle self| other \rangle`.
286
+
287
+ Args:
288
+ other (Statevector): a quantum state object.
289
+
290
+ Returns:
291
+ np.complex128: the inner product of self and other, :math:`\langle self| other \rangle`.
292
+
293
+ Raises:
294
+ QiskitError: if other is not a quantum state or has different dimension.
295
+ """
296
+ if not isinstance(other, Statevector):
297
+ other = Statevector(other)
298
+ if self.dims() != other.dims():
299
+ raise QiskitError(
300
+ f"Statevector dimensions do not match: {self.dims()} and {other.dims()}."
301
+ )
302
+ inner = np.vdot(self.data, other.data)
303
+ return inner
304
+
305
+ def expand(self, other: Statevector) -> Statevector:
306
+ """Return the tensor product state other ⊗ self.
307
+
308
+ Args:
309
+ other (Statevector): a quantum state object.
310
+
311
+ Returns:
312
+ Statevector: the tensor product state other ⊗ self.
313
+
314
+ Raises:
315
+ QiskitError: if other is not a quantum state.
316
+ """
317
+ if not isinstance(other, Statevector):
318
+ other = Statevector(other)
319
+ ret = _copy.copy(self)
320
+ ret._op_shape = self._op_shape.expand(other._op_shape)
321
+ ret._data = np.kron(other._data, self._data)
322
+ return ret
323
+
324
+ def _add(self, other):
325
+ """Return the linear combination self + other.
326
+
327
+ Args:
328
+ other (Statevector): a quantum state object.
329
+
330
+ Returns:
331
+ Statevector: the linear combination self + other.
332
+
333
+ Raises:
334
+ QiskitError: if other is not a quantum state, or has
335
+ incompatible dimensions.
336
+ """
337
+ if not isinstance(other, Statevector):
338
+ other = Statevector(other)
339
+ self._op_shape._validate_add(other._op_shape)
340
+ ret = _copy.copy(self)
341
+ ret._data = self.data + other.data
342
+ return ret
343
+
344
+ def _multiply(self, other):
345
+ """Return the scalar multiplied state self * other.
346
+
347
+ Args:
348
+ other (complex): a complex number.
349
+
350
+ Returns:
351
+ Statevector: the scalar multiplied state other * self.
352
+
353
+ Raises:
354
+ QiskitError: if other is not a valid complex number.
355
+ """
356
+ if not isinstance(other, Number):
357
+ raise QiskitError("other is not a number")
358
+ ret = _copy.copy(self)
359
+ ret._data = other * self.data
360
+ return ret
361
+
362
+ def evolve(
363
+ self, other: Operator | QuantumCircuit | Instruction, qargs: list[int] | None = None
364
+ ) -> Statevector:
365
+ """Evolve a quantum state by the operator.
366
+
367
+ Args:
368
+ other (Operator | QuantumCircuit | circuit.Instruction): The operator to evolve by.
369
+ qargs (list): a list of Statevector subsystem positions to apply
370
+ the operator on.
371
+
372
+ Returns:
373
+ Statevector: the output quantum state.
374
+
375
+ Raises:
376
+ QiskitError: if the operator dimension does not match the
377
+ specified Statevector subsystem dimensions.
378
+ """
379
+ if qargs is None:
380
+ qargs = getattr(other, "qargs", None)
381
+
382
+ # Get return vector
383
+ ret = _copy.copy(self)
384
+
385
+ # Evolution by a circuit or instruction
386
+ if isinstance(other, QuantumCircuit):
387
+ other = other.to_instruction()
388
+ if isinstance(other, Instruction):
389
+ if self.num_qubits is None:
390
+ raise QiskitError("Cannot apply QuantumCircuit to non-qubit Statevector.")
391
+ return self._evolve_instruction(ret, other, qargs=qargs)
392
+
393
+ # Evolution by an Operator
394
+ if not isinstance(other, Operator):
395
+ dims = self.dims(qargs=qargs)
396
+ other = Operator(other, input_dims=dims, output_dims=dims)
397
+
398
+ # check dimension
399
+ if self.dims(qargs) != other.input_dims():
400
+ raise QiskitError(
401
+ "Operator input dimensions are not equal to statevector subsystem dimensions."
402
+ )
403
+ return Statevector._evolve_operator(ret, other, qargs=qargs)
404
+
405
+ def equiv(
406
+ self, other: Statevector, rtol: float | None = None, atol: float | None = None
407
+ ) -> bool:
408
+ """Return True if other is equivalent as a statevector up to global phase.
409
+
410
+ .. note::
411
+
412
+ If other is not a Statevector, but can be used to initialize a statevector object,
413
+ this will check that Statevector(other) is equivalent to the current statevector up
414
+ to global phase.
415
+
416
+ Args:
417
+ other (Statevector): an object from which a ``Statevector`` can be constructed.
418
+ rtol (float): relative tolerance value for comparison.
419
+ atol (float): absolute tolerance value for comparison.
420
+
421
+ Returns:
422
+ bool: True if statevectors are equivalent up to global phase.
423
+ """
424
+ if not isinstance(other, Statevector):
425
+ try:
426
+ other = Statevector(other)
427
+ except QiskitError:
428
+ return False
429
+ if self.dim != other.dim:
430
+ return False
431
+ if atol is None:
432
+ atol = self.atol
433
+ if rtol is None:
434
+ rtol = self.rtol
435
+ return matrix_equal(self.data, other.data, ignore_phase=True, rtol=rtol, atol=atol)
436
+
437
+ def reverse_qargs(self) -> Statevector:
438
+ r"""Return a Statevector with reversed subsystem ordering.
439
+
440
+ For a tensor product state this is equivalent to reversing the order
441
+ of tensor product subsystems. For a statevector
442
+ :math:`|\psi \rangle = |\psi_{n-1} \rangle \otimes ... \otimes |\psi_0 \rangle`
443
+ the returned statevector will be
444
+ :math:`|\psi_{0} \rangle \otimes ... \otimes |\psi_{n-1} \rangle`.
445
+
446
+ Returns:
447
+ Statevector: the Statevector with reversed subsystem order.
448
+ """
449
+ ret = _copy.copy(self)
450
+ axes = tuple(range(self._op_shape._num_qargs_l - 1, -1, -1))
451
+ ret._data = np.reshape(
452
+ np.transpose(np.reshape(self.data, self._op_shape.tensor_shape), axes),
453
+ self._op_shape.shape,
454
+ )
455
+ ret._op_shape = self._op_shape.reverse()
456
+ return ret
457
+
458
+ def _expectation_value_pauli(self, pauli, qargs=None):
459
+ """Compute the expectation value of a Pauli.
460
+
461
+ Args:
462
+ pauli (Pauli): a Pauli operator to evaluate expval of.
463
+ qargs (None or list): subsystems to apply operator on.
464
+
465
+ Returns:
466
+ complex: the expectation value.
467
+ """
468
+ n_pauli = len(pauli)
469
+ if qargs is None:
470
+ qubits = np.arange(n_pauli)
471
+ else:
472
+ qubits = np.array(qargs)
473
+
474
+ x_mask = np.dot(1 << qubits, pauli.x)
475
+ z_mask = np.dot(1 << qubits, pauli.z)
476
+ pauli_phase = (-1j) ** pauli.phase if pauli.phase else 1
477
+
478
+ if x_mask + z_mask == 0:
479
+ return pauli_phase * np.linalg.norm(self.data) ** 2
480
+
481
+ if x_mask == 0:
482
+ return pauli_phase * expval_pauli_no_x(self.data, self.num_qubits, z_mask)
483
+
484
+ x_max = qubits[pauli.x][-1]
485
+ y_phase = (-1j) ** pauli._count_y()
486
+ y_phase = y_phase[0]
487
+
488
+ return pauli_phase * expval_pauli_with_x(
489
+ self.data, self.num_qubits, z_mask, x_mask, y_phase, x_max
490
+ )
491
+
492
+ def expectation_value(
493
+ self, oper: BaseOperator | QuantumCircuit | Instruction, qargs: None | list[int] = None
494
+ ) -> complex:
495
+ """Compute the expectation value of an operator.
496
+
497
+ Args:
498
+ oper (Operator): an operator to evaluate expval of.
499
+ qargs (None or list): subsystems to apply operator on.
500
+
501
+ Returns:
502
+ complex: the expectation value.
503
+ """
504
+ if isinstance(oper, Pauli):
505
+ return self._expectation_value_pauli(oper, qargs)
506
+
507
+ if isinstance(oper, SparsePauliOp):
508
+ return sum(
509
+ coeff * self._expectation_value_pauli(Pauli((z, x)), qargs)
510
+ for z, x, coeff in zip(oper.paulis.z, oper.paulis.x, oper.coeffs)
511
+ )
512
+
513
+ val = self.evolve(oper, qargs=qargs)
514
+ conj = self.conjugate()
515
+ return np.dot(conj.data, val.data)
516
+
517
+ def probabilities(
518
+ self, qargs: None | list[int] = None, decimals: None | int = None
519
+ ) -> np.ndarray:
520
+ """Return the subsystem measurement probability vector.
521
+
522
+ Measurement probabilities are with respect to measurement in the
523
+ computation (diagonal) basis.
524
+
525
+ Args:
526
+ qargs (None or list): subsystems to return probabilities for,
527
+ if None return for all subsystems (Default: None).
528
+ decimals (None or int): the number of decimal places to round
529
+ values. If None no rounding is done (Default: None).
530
+
531
+ Returns:
532
+ np.array: The Numpy vector array of probabilities.
533
+
534
+ Examples:
535
+
536
+ Consider a 2-qubit product state
537
+ :math:`|\\psi\\rangle=|+\\rangle\\otimes|0\\rangle`.
538
+
539
+ .. code-block::
540
+
541
+ from qiskit.quantum_info import Statevector
542
+
543
+ psi = Statevector.from_label('+0')
544
+
545
+ # Probabilities for measuring both qubits
546
+ probs = psi.probabilities()
547
+ print('probs: {}'.format(probs))
548
+
549
+ # Probabilities for measuring only qubit-0
550
+ probs_qubit_0 = psi.probabilities([0])
551
+ print('Qubit-0 probs: {}'.format(probs_qubit_0))
552
+
553
+ # Probabilities for measuring only qubit-1
554
+ probs_qubit_1 = psi.probabilities([1])
555
+ print('Qubit-1 probs: {}'.format(probs_qubit_1))
556
+
557
+ .. code-block:: text
558
+
559
+ probs: [0.5 0. 0.5 0. ]
560
+ Qubit-0 probs: [1. 0.]
561
+ Qubit-1 probs: [0.5 0.5]
562
+
563
+ We can also permute the order of qubits in the ``qargs`` list
564
+ to change the qubit position in the probabilities output
565
+
566
+ .. code-block::
567
+
568
+ from qiskit.quantum_info import Statevector
569
+
570
+ psi = Statevector.from_label('+0')
571
+
572
+ # Probabilities for measuring both qubits
573
+ probs = psi.probabilities([0, 1])
574
+ print('probs: {}'.format(probs))
575
+
576
+ # Probabilities for measuring both qubits
577
+ # but swapping qubits 0 and 1 in output
578
+ probs_swapped = psi.probabilities([1, 0])
579
+ print('Swapped probs: {}'.format(probs_swapped))
580
+
581
+ .. code-block:: text
582
+
583
+ probs: [0.5 0. 0.5 0. ]
584
+ Swapped probs: [0.5 0.5 0. 0. ]
585
+
586
+ """
587
+ probs = self._subsystem_probabilities(
588
+ np.abs(self.data) ** 2, self._op_shape.dims_l(), qargs=qargs
589
+ )
590
+
591
+ # to account for roundoff errors, we clip
592
+ probs = np.clip(probs, a_min=0, a_max=1)
593
+
594
+ if decimals is not None:
595
+ probs = probs.round(decimals=decimals)
596
+
597
+ return probs
598
+
599
+ def reset(self, qargs: list[int] | None = None) -> Statevector:
600
+ """Reset state or subsystems to the 0-state.
601
+
602
+ Args:
603
+ qargs (list or None): subsystems to reset, if None all
604
+ subsystems will be reset to their 0-state
605
+ (Default: None).
606
+
607
+ Returns:
608
+ Statevector: the reset state.
609
+
610
+ Additional Information:
611
+ If all subsystems are reset this will return the ground state
612
+ on all subsystems. If only a some subsystems are reset this
613
+ function will perform a measurement on those subsystems and
614
+ evolve the subsystems so that the collapsed post-measurement
615
+ states are rotated to the 0-state. The RNG seed for this
616
+ sampling can be set using the :meth:`seed` method.
617
+ """
618
+ if qargs is None:
619
+ # Resetting all qubits does not require sampling or RNG
620
+ ret = _copy.copy(self)
621
+ state = np.zeros(self._op_shape.shape, dtype=complex)
622
+ state[0] = 1
623
+ ret._data = state
624
+ return ret
625
+
626
+ # Sample a single measurement outcome
627
+ dims = self.dims(qargs)
628
+ probs = self.probabilities(qargs)
629
+ sample = self._rng.choice(len(probs), p=probs, size=1)
630
+
631
+ # Convert to projector for state update
632
+ proj = np.zeros(len(probs), dtype=complex)
633
+ proj[sample] = 1 / np.sqrt(probs[sample])
634
+
635
+ # Rotate outcome to 0
636
+ reset = np.eye(len(probs))
637
+ reset[0, 0] = 0
638
+ reset[sample, sample] = 0
639
+ reset[0, sample] = 1
640
+
641
+ # compose with reset projection
642
+ reset = np.dot(reset, np.diag(proj))
643
+ return self.evolve(Operator(reset, input_dims=dims, output_dims=dims), qargs=qargs)
644
+
645
+ @classmethod
646
+ def from_label(cls, label: str) -> Statevector:
647
+ """Return a tensor product of Pauli X,Y,Z eigenstates.
648
+
649
+ .. list-table:: Single-qubit state labels
650
+ :header-rows: 1
651
+
652
+ * - Label
653
+ - Statevector
654
+ * - ``"0"``
655
+ - :math:`[1, 0]`
656
+ * - ``"1"``
657
+ - :math:`[0, 1]`
658
+ * - ``"+"``
659
+ - :math:`[1 / \\sqrt{2}, 1 / \\sqrt{2}]`
660
+ * - ``"-"``
661
+ - :math:`[1 / \\sqrt{2}, -1 / \\sqrt{2}]`
662
+ * - ``"r"``
663
+ - :math:`[1 / \\sqrt{2}, i / \\sqrt{2}]`
664
+ * - ``"l"``
665
+ - :math:`[1 / \\sqrt{2}, -i / \\sqrt{2}]`
666
+
667
+ Args:
668
+ label (string): a eigenstate string ket label (see table for
669
+ allowed values).
670
+
671
+ Returns:
672
+ Statevector: The N-qubit basis state density matrix.
673
+
674
+ Raises:
675
+ QiskitError: if the label contains invalid characters, or the
676
+ length of the label is larger than an explicitly
677
+ specified num_qubits.
678
+ """
679
+ # Check label is valid
680
+ if re.match(r"^[01rl\-+]+$", label) is None:
681
+ raise QiskitError("Label contains invalid characters.")
682
+ # We can prepare Z-eigenstates by converting the computational
683
+ # basis bit-string to an integer and preparing that unit vector
684
+ # However, for X-basis states, we will prepare a Z-eigenstate first
685
+ # then apply Hadamard gates to rotate 0 and 1s to + and -.
686
+ z_label = label
687
+ xy_states = False
688
+ if re.match("^[01]+$", label) is None:
689
+ # We have X or Y eigenstates so replace +,r with 0 and
690
+ # -,l with 1 and prepare the corresponding Z state
691
+ xy_states = True
692
+ z_label = z_label.replace("+", "0")
693
+ z_label = z_label.replace("r", "0")
694
+ z_label = z_label.replace("-", "1")
695
+ z_label = z_label.replace("l", "1")
696
+ # Initialize Z eigenstate vector
697
+ num_qubits = len(label)
698
+ data = np.zeros(1 << num_qubits, dtype=complex)
699
+ pos = int(z_label, 2)
700
+ data[pos] = 1
701
+ state = Statevector(data)
702
+ if xy_states:
703
+ # Apply hadamards to all qubits in X eigenstates
704
+ x_mat = np.array([[1, 1], [1, -1]], dtype=complex) / math.sqrt(2)
705
+ # Apply S.H to qubits in Y eigenstates
706
+ y_mat = np.dot(np.diag([1, 1j]), x_mat)
707
+ for qubit, char in enumerate(reversed(label)):
708
+ if char in ["+", "-"]:
709
+ state = state.evolve(x_mat, qargs=[qubit])
710
+ elif char in ["r", "l"]:
711
+ state = state.evolve(y_mat, qargs=[qubit])
712
+ return state
713
+
714
+ @staticmethod
715
+ def from_int(i: int, dims: int | tuple | list) -> Statevector:
716
+ """Return a computational basis statevector.
717
+
718
+ Args:
719
+ i (int): the basis state element.
720
+ dims (int or tuple or list): The subsystem dimensions of the statevector
721
+ (See additional information).
722
+
723
+ Returns:
724
+ Statevector: The computational basis state :math:`|i\\rangle`.
725
+
726
+ Additional Information:
727
+ The ``dims`` kwarg can be an integer or an iterable of integers.
728
+
729
+ * ``Iterable`` -- the subsystem dimensions are the values in the list
730
+ with the total number of subsystems given by the length of the list.
731
+
732
+ * ``Int`` -- the integer specifies the total dimension of the
733
+ state. If it is a power of two the state will be initialized
734
+ as an N-qubit state. If it is not a power of two the state
735
+ will have a single d-dimensional subsystem.
736
+ """
737
+ size = np.prod(dims)
738
+ state = np.zeros(size, dtype=complex)
739
+ state[i] = 1.0
740
+ return Statevector(state, dims=dims)
741
+
742
+ @classmethod
743
+ def from_instruction(cls, instruction: Instruction | QuantumCircuit) -> Statevector:
744
+ """Return the output statevector of an instruction.
745
+
746
+ The statevector is initialized in the state :math:`|{0,\\ldots,0}\\rangle` of the
747
+ same number of qubits as the input instruction or circuit, evolved
748
+ by the input instruction, and the output statevector returned.
749
+
750
+ Args:
751
+ instruction (qiskit.circuit.Instruction or QuantumCircuit): instruction or circuit
752
+
753
+ Returns:
754
+ Statevector: The final statevector.
755
+
756
+ Raises:
757
+ QiskitError: if the instruction contains invalid instructions for
758
+ the statevector simulation.
759
+ """
760
+ # Convert circuit to an instruction
761
+ if isinstance(instruction, QuantumCircuit):
762
+ instruction = instruction.to_instruction()
763
+ # Initialize an the statevector in the all |0> state
764
+ init = np.zeros(2**instruction.num_qubits, dtype=complex)
765
+ init[0] = 1.0
766
+ vec = Statevector(init, dims=instruction.num_qubits * (2,))
767
+ return Statevector._evolve_instruction(vec, instruction)
768
+
769
+ def to_dict(self, decimals: None | int = None) -> dict:
770
+ r"""Convert the statevector to dictionary form.
771
+
772
+ This dictionary representation uses a Ket-like notation where the
773
+ dictionary keys are qudit strings for the subsystem basis vectors.
774
+ If any subsystem has a dimension greater than 10 comma delimiters are
775
+ inserted between integers so that subsystems can be distinguished.
776
+
777
+ Args:
778
+ decimals (None or int): the number of decimal places to round
779
+ values. If None no rounding is done
780
+ (Default: None).
781
+
782
+ Returns:
783
+ dict: the dictionary form of the Statevector.
784
+
785
+ Example:
786
+
787
+ The ket-form of a 2-qubit statevector
788
+ :math:`|\psi\rangle = |-\rangle\otimes |0\rangle`
789
+
790
+ .. code-block::
791
+
792
+ from qiskit.quantum_info import Statevector
793
+
794
+ psi = Statevector.from_label('-0')
795
+ print(psi.to_dict())
796
+
797
+ .. code-block:: text
798
+
799
+ {'00': (0.7071067811865475+0j), '10': (-0.7071067811865475+0j)}
800
+
801
+ For non-qubit subsystems the integer range can go from 0 to 9. For
802
+ example in a qutrit system
803
+
804
+ .. code-block::
805
+
806
+ import numpy as np
807
+ from qiskit.quantum_info import Statevector
808
+
809
+ vec = np.zeros(9)
810
+ vec[0] = 1 / np.sqrt(2)
811
+ vec[-1] = 1 / np.sqrt(2)
812
+ psi = Statevector(vec, dims=(3, 3))
813
+ print(psi.to_dict())
814
+
815
+ .. code-block:: text
816
+
817
+ {'00': (0.7071067811865475+0j), '22': (0.7071067811865475+0j)}
818
+
819
+ For large subsystem dimensions delimiters are required. The
820
+ following example is for a 20-dimensional system consisting of
821
+ a qubit and 10-dimensional qudit.
822
+
823
+ .. code-block::
824
+
825
+ import numpy as np
826
+ from qiskit.quantum_info import Statevector
827
+
828
+ vec = np.zeros(2 * 10)
829
+ vec[0] = 1 / np.sqrt(2)
830
+ vec[-1] = 1 / np.sqrt(2)
831
+ psi = Statevector(vec, dims=(2, 10))
832
+ print(psi.to_dict())
833
+
834
+ .. code-block:: text
835
+
836
+ {'00': (0.7071067811865475+0j), '91': (0.7071067811865475+0j)}
837
+
838
+ """
839
+ return self._vector_to_dict(
840
+ self.data, self._op_shape.dims_l(), decimals=decimals, string_labels=True
841
+ )
842
+
843
+ @staticmethod
844
+ def _evolve_operator(statevec, oper, qargs=None):
845
+ """Evolve a qudit statevector"""
846
+ new_shape = statevec._op_shape.compose(oper._op_shape, qargs=qargs)
847
+ if qargs is None:
848
+ # Full system evolution
849
+ statevec._data = np.dot(oper._data, statevec._data)
850
+ statevec._op_shape = new_shape
851
+ return statevec
852
+
853
+ # Get transpose axes
854
+ num_qargs = statevec._op_shape.num_qargs[0]
855
+ indices = [num_qargs - 1 - i for i in reversed(qargs)]
856
+ axes = indices + [i for i in range(num_qargs) if i not in indices]
857
+ axes_inv = np.argsort(axes).tolist()
858
+
859
+ # Calculate contraction dimensions
860
+ contract_dim = oper._op_shape.shape[1]
861
+ contract_shape = (contract_dim, statevec._op_shape.shape[0] // contract_dim)
862
+
863
+ # Reshape and transpose input array for contraction
864
+ tensor = np.transpose(
865
+ np.reshape(statevec.data, statevec._op_shape.tensor_shape),
866
+ axes,
867
+ )
868
+ tensor_shape = tensor.shape
869
+
870
+ # Perform contraction
871
+ tensor = np.reshape(
872
+ np.dot(oper.data, np.reshape(tensor, contract_shape)),
873
+ tensor_shape,
874
+ )
875
+
876
+ # Transpose back to original subsystem spec and flatten
877
+ statevec._data = np.reshape(np.transpose(tensor, axes_inv), new_shape.shape[0])
878
+
879
+ # Update dimension
880
+ statevec._op_shape = new_shape
881
+ return statevec
882
+
883
+ @staticmethod
884
+ def _evolve_instruction(statevec, obj, qargs=None):
885
+ """Update the current Statevector by applying an instruction."""
886
+ from qiskit.circuit.reset import Reset
887
+ from qiskit.circuit.barrier import Barrier
888
+
889
+ # pylint complains about a cyclic import since the following Initialize file
890
+ # imports the StatePreparation, which again requires the Statevector (this file),
891
+ # but as this is a local import, it's not actually an issue and can be ignored
892
+ # pylint: disable=cyclic-import
893
+ from qiskit.circuit.library.data_preparation.initializer import Initialize
894
+
895
+ mat = Operator._instruction_to_matrix(obj)
896
+ if mat is not None:
897
+ # Perform the composition and inplace update the current state
898
+ # of the operator
899
+ return Statevector._evolve_operator(statevec, Operator(mat), qargs=qargs)
900
+
901
+ # Special instruction types
902
+ if isinstance(obj, Reset):
903
+ statevec._data = statevec.reset(qargs)._data
904
+ return statevec
905
+ if isinstance(obj, Barrier):
906
+ return statevec
907
+ if isinstance(obj, Initialize):
908
+ # state is initialized to labels in the initialize object
909
+ if all(isinstance(param, str) for param in obj.params):
910
+ initialization = Statevector.from_label("".join(obj.params))._data
911
+ # state is initialized to an integer
912
+ # here we're only checking the length as (1) a length-1 object necessarily means the
913
+ # state is described by an integer (as labels were already covered) and (2) the int
914
+ # was cast to a complex and we cannot do an int typecheck anyways
915
+ elif len(obj.params) == 1:
916
+ state = int(np.real(obj.params[0]))
917
+ initialization = Statevector.from_int(state, (2,) * obj.num_qubits)._data
918
+ # state is initialized to the statevector
919
+ else:
920
+ initialization = np.asarray(obj.params, dtype=complex)
921
+
922
+ if qargs is None:
923
+ statevec._data = initialization
924
+ else:
925
+ # if we act on a subsystem we first need to reset and then apply the
926
+ # state preparation
927
+ statevec._data = statevec.reset(qargs)._data
928
+ mat = np.zeros((2 ** len(qargs), 2 ** len(qargs)), dtype=complex)
929
+ mat[:, 0] = initialization
930
+ statevec = Statevector._evolve_operator(statevec, Operator(mat), qargs=qargs)
931
+
932
+ return statevec
933
+
934
+ # If the instruction doesn't have a matrix defined we use its
935
+ # circuit decomposition definition if it exists, otherwise we
936
+ # cannot compose this gate and raise an error.
937
+ if obj.definition is None:
938
+ raise QiskitError(f"Cannot apply Instruction: {obj.name}")
939
+ if not isinstance(obj.definition, QuantumCircuit):
940
+ raise QiskitError(
941
+ f"{obj.name} instruction definition is {type(obj.definition)}; expected QuantumCircuit"
942
+ )
943
+
944
+ if obj.definition.global_phase:
945
+ statevec._data *= np.exp(1j * float(obj.definition.global_phase))
946
+ qubits = {qubit: i for i, qubit in enumerate(obj.definition.qubits)}
947
+ for instruction in obj.definition:
948
+ if instruction.clbits:
949
+ raise QiskitError(
950
+ f"Cannot apply instruction with classical bits: {instruction.operation.name}"
951
+ )
952
+ # Get the integer position of the flat register
953
+ if qargs is None:
954
+ new_qargs = [qubits[tup] for tup in instruction.qubits]
955
+ else:
956
+ new_qargs = [qargs[qubits[tup]] for tup in instruction.qubits]
957
+ Statevector._evolve_instruction(statevec, instruction.operation, qargs=new_qargs)
958
+ return statevec