qiskit 1.3.0__cp39-abi3-macosx_11_0_arm64.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.abi3.so +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,419 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2021.
4
+ #
5
+ # This code is licensed under the Apache License, Version 2.0. You may
6
+ # obtain a copy of this license in the LICENSE.txt file in the root directory
7
+ # of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
8
+ #
9
+ # Any modifications or derivative works of this code must retain this
10
+ # copyright notice, and modified files need to carry a notice indicating
11
+ # that they have been altered from the originals.
12
+
13
+
14
+ """VF2PostLayout pass to find a layout after transpile using subgraph isomorphism"""
15
+ from enum import Enum
16
+ import logging
17
+ import inspect
18
+ import itertools
19
+ import time
20
+
21
+ from rustworkx import PyDiGraph, vf2_mapping, PyGraph
22
+
23
+ from qiskit.transpiler.layout import Layout
24
+ from qiskit.transpiler.basepasses import AnalysisPass
25
+ from qiskit.transpiler.exceptions import TranspilerError
26
+ from qiskit.providers.exceptions import BackendPropertyError
27
+ from qiskit.transpiler.passes.layout import vf2_utils
28
+
29
+
30
+ logger = logging.getLogger(__name__)
31
+
32
+
33
+ class VF2PostLayoutStopReason(Enum):
34
+ """Stop reasons for VF2PostLayout pass."""
35
+
36
+ SOLUTION_FOUND = "solution found"
37
+ NO_BETTER_SOLUTION_FOUND = "no better solution found"
38
+ NO_SOLUTION_FOUND = "nonexistent solution"
39
+ MORE_THAN_2Q = ">2q gates in basis"
40
+
41
+
42
+ def _target_match(node_a, node_b):
43
+ # Node A is the set of operations in the target. Node B is the count dict
44
+ # of operations on the node or edge in the circuit.
45
+ if isinstance(node_a, set):
46
+ return node_a.issuperset(node_b.keys())
47
+ # Node A is the count dict of operations on the node or edge in the circuit
48
+ # Node B is the set of operations in the target on the same qubit(s).
49
+ else:
50
+ return set(node_a).issubset(node_b)
51
+
52
+
53
+ class VF2PostLayout(AnalysisPass):
54
+ """A pass for improving an existing Layout after transpilation of a circuit onto a
55
+ Coupling graph, as a subgraph isomorphism problem, solved by VF2++.
56
+
57
+ Unlike the :class:`~.VF2Layout` transpiler pass which is designed to find an
58
+ initial layout for a circuit early in the transpilation pipeline this transpiler
59
+ pass is designed to try and find a better layout after transpilation is complete.
60
+ The initial layout phase of the transpiler doesn't have as much information available
61
+ as we do after transpilation. This pass is designed to be paired in a similar pipeline
62
+ as the layout passes. This pass will strip any idle wires from the circuit, use VF2
63
+ to find a subgraph in the coupling graph for the circuit to run on with better fidelity
64
+ and then update the circuit layout to use the new qubits. The algorithm used in this
65
+ pass is described in `arXiv:2209.15512 <https://arxiv.org/abs/2209.15512>`__.
66
+
67
+ If a solution is found that means there is a lower error layout available for the
68
+ circuit. If a solution is found the layout will be set in the property set as
69
+ ``property_set['post_layout']``. However, if no solution or no better solution is found, no
70
+ ``property_set['post_layout']`` is set. The stopping reason is
71
+ set in ``property_set['VF2PostLayout_stop_reason']`` in all the cases and will be
72
+ one of the values enumerated in ``VF2PostLayoutStopReason`` which has the
73
+ following values:
74
+
75
+ * ``"solution found"``: If a solution was found.
76
+ * ``"no better solution found"``: If the initial layout of the circuit is the best solution.
77
+ * ``"nonexistent solution"``: If no solution was found.
78
+ * ``">2q gates in basis"``: If VF2PostLayout can't work with the basis of the circuit.
79
+
80
+ By default, this pass will construct a heuristic scoring map based on
81
+ the error rates in the provided ``target`` (or ``properties`` if ``target``
82
+ is not provided). However, analysis passes can be run prior to this pass
83
+ and set ``vf2_avg_error_map`` in the property set with a :class:`~.ErrorMap`
84
+ instance. If a value is ``NaN`` that is treated as an ideal edge
85
+ For example if an error map is created as::
86
+
87
+ from qiskit.transpiler.passes.layout.vf2_utils import ErrorMap
88
+
89
+ error_map = ErrorMap(3)
90
+ error_map.add_error((0, 0), 0.0024)
91
+ error_map.add_error((0, 1), 0.01)
92
+ error_map.add_error((1, 1), 0.0032)
93
+
94
+ that represents the error map for a 2 qubit target, where the avg 1q error
95
+ rate is ``0.0024`` on qubit 0 and ``0.0032`` on qubit 1. Then the avg 2q
96
+ error rate for gates that operate on (0, 1) is 0.01 and (1, 0) is not
97
+ supported by the target. This will be used for scoring if it's set as the
98
+ ``vf2_avg_error_map`` key in the property set when :class:`~.VF2PostLayout`
99
+ is run.
100
+ """
101
+
102
+ def __init__(
103
+ self,
104
+ target=None,
105
+ coupling_map=None,
106
+ properties=None,
107
+ seed=None,
108
+ call_limit=None,
109
+ time_limit=None,
110
+ strict_direction=True,
111
+ max_trials=0,
112
+ ):
113
+ """Initialize a ``VF2PostLayout`` pass instance
114
+
115
+ Args:
116
+ target (Target): A target representing the backend device to run ``VF2PostLayout`` on.
117
+ If specified it will supersede a set value for ``properties`` and
118
+ ``coupling_map``.
119
+ coupling_map (CouplingMap): Directed graph representing a coupling map.
120
+ properties (BackendProperties): The backend properties for the backend. If
121
+ :meth:`~qiskit.providers.models.BackendProperties.readout_error` is available
122
+ it is used to score the layout.
123
+ seed (int): Sets the seed of the PRNG. -1 Means no node shuffling.
124
+ call_limit (int): The number of state visits to attempt in each execution of
125
+ VF2.
126
+ time_limit (float): The total time limit in seconds to run ``VF2PostLayout``
127
+ strict_direction (bool): Whether the pass is configured to follow
128
+ the strict direction in the coupling graph. If this is set to
129
+ false, the pass will treat any edge in the coupling graph as
130
+ a weak edge and the interaction graph will be undirected. For
131
+ the purposes of evaluating layouts the avg error rate for
132
+ each qubit and 2q link will be used. This enables the pass to be
133
+ run prior to basis translation and work with any 1q and 2q operations.
134
+ However, if ``strict_direction=True`` the pass expects the input
135
+ :class:`~.DAGCircuit` object to :meth:`~.VF2PostLayout.run` to be in
136
+ the target set of instructions.
137
+ max_trials (int): The maximum number of trials to run VF2 to find
138
+ a layout. A value of ``0`` (the default) means 'unlimited'.
139
+
140
+ Raises:
141
+ TypeError: At runtime, if neither ``coupling_map`` or ``target`` are provided.
142
+ """
143
+ super().__init__()
144
+ self.target = target
145
+ self.coupling_map = coupling_map
146
+ self.properties = properties
147
+ self.call_limit = call_limit
148
+ self.time_limit = time_limit
149
+ self.max_trials = max_trials
150
+ self.seed = seed
151
+ self.strict_direction = strict_direction
152
+ self.avg_error_map = None
153
+
154
+ def run(self, dag):
155
+ """run the layout method"""
156
+ if self.target is None and (self.coupling_map is None or self.properties is None):
157
+ raise TranspilerError(
158
+ "A target must be specified or a coupling map and properties must be provided"
159
+ )
160
+ if not self.strict_direction:
161
+ self.avg_error_map = self.property_set["vf2_avg_error_map"]
162
+ if self.avg_error_map is None:
163
+ self.avg_error_map = vf2_utils.build_average_error_map(
164
+ self.target, self.properties, self.coupling_map
165
+ )
166
+
167
+ result = vf2_utils.build_interaction_graph(dag, self.strict_direction)
168
+ if result is None:
169
+ self.property_set["VF2PostLayout_stop_reason"] = VF2PostLayoutStopReason.MORE_THAN_2Q
170
+ return
171
+ im_graph, im_graph_node_map, reverse_im_graph_node_map, free_nodes = result
172
+ scoring_bit_list = vf2_utils.build_bit_list(im_graph, im_graph_node_map)
173
+ scoring_edge_list = vf2_utils.build_edge_list(im_graph)
174
+
175
+ if self.target is not None:
176
+ # If qargs is None then target is global and ideal so no
177
+ # scoring is needed
178
+ if self.target.qargs is None:
179
+ return
180
+ if self.strict_direction:
181
+ cm_graph = PyDiGraph(multigraph=False)
182
+ else:
183
+ cm_graph = PyGraph(multigraph=False)
184
+ # If None is present in qargs there are globally defined ideal operations
185
+ # we should add these to all entries based on the number of qubits, so we
186
+ # treat that as a valid operation even if there is no scoring for the
187
+ # strict direction case
188
+ global_ops = None
189
+ if None in self.target.qargs:
190
+ global_ops = {1: [], 2: []}
191
+ for op in self.target.operation_names_for_qargs(None):
192
+ operation = self.target.operation_for_name(op)
193
+ # If operation is a class this is a variable width ideal instruction
194
+ # so we treat it as available on both 1 and 2 qubits
195
+ if inspect.isclass(operation):
196
+ global_ops[1].append(op)
197
+ global_ops[2].append(op)
198
+ else:
199
+ num_qubits = operation.num_qubits
200
+ if num_qubits in global_ops:
201
+ global_ops[num_qubits].append(op)
202
+ op_names = []
203
+ for i in range(self.target.num_qubits):
204
+ try:
205
+ entry = set(self.target.operation_names_for_qargs((i,)))
206
+ except KeyError:
207
+ entry = set()
208
+ if global_ops is not None:
209
+ entry.update(global_ops[1])
210
+ op_names.append(entry)
211
+ cm_graph.add_nodes_from(op_names)
212
+ for qargs in self.target.qargs:
213
+ len_args = len(qargs)
214
+ # If qargs == 1 we already populated it and if qargs > 2 there are no instructions
215
+ # using those in the circuit because we'd have already returned by this point
216
+ if len_args == 2:
217
+ ops = set(self.target.operation_names_for_qargs(qargs))
218
+ if global_ops is not None:
219
+ ops.update(global_ops[2])
220
+ cm_graph.add_edge(qargs[0], qargs[1], ops)
221
+ cm_nodes = list(cm_graph.node_indexes())
222
+ # Filter qubits without any supported operations. If they
223
+ # don't support any operations, they're not valid for layout selection.
224
+ # This is only needed in the undirected case because in strict direction
225
+ # mode the node matcher will not match since none of the circuit ops
226
+ # will match the cmap ops.
227
+ if not self.strict_direction:
228
+ has_operations = set(itertools.chain.from_iterable(self.target.qargs))
229
+ to_remove = set(cm_graph.node_indices()).difference(has_operations)
230
+ if to_remove:
231
+ cm_graph.remove_nodes_from(list(to_remove))
232
+ else:
233
+ cm_graph, cm_nodes = vf2_utils.shuffle_coupling_graph(
234
+ self.coupling_map, self.seed, self.strict_direction
235
+ )
236
+
237
+ logger.debug("Running VF2 to find post transpile mappings")
238
+ if self.target and self.strict_direction:
239
+ mappings = vf2_mapping(
240
+ cm_graph,
241
+ im_graph,
242
+ node_matcher=_target_match,
243
+ edge_matcher=_target_match,
244
+ subgraph=True,
245
+ id_order=False,
246
+ induced=False,
247
+ call_limit=self.call_limit,
248
+ )
249
+ else:
250
+ mappings = vf2_mapping(
251
+ cm_graph,
252
+ im_graph,
253
+ subgraph=True,
254
+ id_order=False,
255
+ induced=False,
256
+ call_limit=self.call_limit,
257
+ )
258
+ chosen_layout = None
259
+ try:
260
+ if self.strict_direction:
261
+ initial_layout = Layout({bit: index for index, bit in enumerate(dag.qubits)})
262
+ chosen_layout_score = self._score_layout(
263
+ initial_layout,
264
+ im_graph_node_map,
265
+ reverse_im_graph_node_map,
266
+ im_graph,
267
+ )
268
+ else:
269
+ initial_layout = {
270
+ im_graph_node_map[bit]: index
271
+ for index, bit in enumerate(dag.qubits)
272
+ if bit in im_graph_node_map
273
+ }
274
+ chosen_layout_score = vf2_utils.score_layout(
275
+ self.avg_error_map,
276
+ initial_layout,
277
+ im_graph_node_map,
278
+ reverse_im_graph_node_map,
279
+ im_graph,
280
+ self.strict_direction,
281
+ edge_list=scoring_edge_list,
282
+ bit_list=scoring_bit_list,
283
+ )
284
+ chosen_layout = initial_layout
285
+ stop_reason = VF2PostLayoutStopReason.NO_BETTER_SOLUTION_FOUND
286
+ # Circuit not in basis so we have nothing to compare against return here
287
+ except KeyError:
288
+ self.property_set["VF2PostLayout_stop_reason"] = (
289
+ VF2PostLayoutStopReason.NO_SOLUTION_FOUND
290
+ )
291
+ return
292
+
293
+ logger.debug("Initial layout has score %s", chosen_layout_score)
294
+
295
+ start_time = time.time()
296
+ trials = 0
297
+ for mapping in mappings:
298
+ trials += 1
299
+ logger.debug("Running trial: %s", trials)
300
+ layout_mapping = {im_i: cm_nodes[cm_i] for cm_i, im_i in mapping.items()}
301
+ if self.strict_direction:
302
+ layout = Layout(
303
+ {reverse_im_graph_node_map[k]: v for k, v in layout_mapping.items()}
304
+ )
305
+ layout_score = self._score_layout(
306
+ layout, im_graph_node_map, reverse_im_graph_node_map, im_graph
307
+ )
308
+ else:
309
+ layout_score = vf2_utils.score_layout(
310
+ self.avg_error_map,
311
+ layout_mapping,
312
+ im_graph_node_map,
313
+ reverse_im_graph_node_map,
314
+ im_graph,
315
+ self.strict_direction,
316
+ edge_list=scoring_edge_list,
317
+ bit_list=scoring_bit_list,
318
+ )
319
+ logger.debug("Trial %s has score %s", trials, layout_score)
320
+ if layout_score < chosen_layout_score:
321
+ layout = Layout(
322
+ {reverse_im_graph_node_map[k]: v for k, v in layout_mapping.items()}
323
+ )
324
+ logger.debug(
325
+ "Found layout %s has a lower score (%s) than previous best %s (%s)",
326
+ layout,
327
+ layout_score,
328
+ chosen_layout,
329
+ chosen_layout_score,
330
+ )
331
+ chosen_layout = layout
332
+ chosen_layout_score = layout_score
333
+ stop_reason = VF2PostLayoutStopReason.SOLUTION_FOUND
334
+
335
+ if self.max_trials and trials >= self.max_trials:
336
+ logger.debug("Trial %s is >= configured max trials %s", trials, self.max_trials)
337
+ break
338
+
339
+ elapsed_time = time.time() - start_time
340
+ if self.time_limit is not None and elapsed_time >= self.time_limit:
341
+ logger.debug(
342
+ "VFPostLayout has taken %s which exceeds configured max time: %s",
343
+ elapsed_time,
344
+ self.time_limit,
345
+ )
346
+ break
347
+ if stop_reason == VF2PostLayoutStopReason.SOLUTION_FOUND:
348
+ chosen_layout = vf2_utils.map_free_qubits(
349
+ free_nodes,
350
+ chosen_layout,
351
+ cm_graph.num_nodes(),
352
+ reverse_im_graph_node_map,
353
+ self.avg_error_map,
354
+ )
355
+ existing_layout = self.property_set["layout"]
356
+ # If any ancillas in initial layout map them back to the final layout output
357
+ if existing_layout is not None and len(existing_layout) > len(chosen_layout):
358
+ virtual_bits = chosen_layout.get_virtual_bits()
359
+ used_bits = set(virtual_bits.values())
360
+ num_qubits = len(cm_graph)
361
+ for bit in dag.qubits:
362
+ if len(chosen_layout) == len(existing_layout):
363
+ break
364
+ if bit not in virtual_bits:
365
+ for i in range(num_qubits):
366
+ if i not in used_bits:
367
+ used_bits.add(i)
368
+ chosen_layout.add(bit, i)
369
+ break
370
+ self.property_set["post_layout"] = chosen_layout
371
+ else:
372
+ if chosen_layout is None:
373
+ stop_reason = VF2PostLayoutStopReason.NO_SOLUTION_FOUND
374
+ # else the initial layout is optimal -> don't set post_layout, return 'no better solution'
375
+ self.property_set["VF2PostLayout_stop_reason"] = stop_reason
376
+
377
+ def _score_layout(self, layout, bit_map, reverse_bit_map, im_graph):
378
+ bits = layout.get_virtual_bits()
379
+ fidelity = 1
380
+ if self.target is not None:
381
+ for bit, node_index in bit_map.items():
382
+ gate_counts = im_graph[node_index]
383
+ for gate, count in gate_counts.items():
384
+ if self.target[gate] is not None and None not in self.target[gate]:
385
+ props = self.target[gate][(bits[bit],)]
386
+ if props is not None and props.error is not None:
387
+ fidelity *= (1 - props.error) ** count
388
+
389
+ for edge in im_graph.edge_index_map().values():
390
+ qargs = (bits[reverse_bit_map[edge[0]]], bits[reverse_bit_map[edge[1]]])
391
+ gate_counts = edge[2]
392
+ for gate, count in gate_counts.items():
393
+ if self.target[gate] is not None and None not in self.target[gate]:
394
+ props = self.target[gate][qargs]
395
+ if props is not None and props.error is not None:
396
+ fidelity *= (1 - props.error) ** count
397
+ else:
398
+ for bit, node_index in bit_map.items():
399
+ gate_counts = im_graph[node_index]
400
+ for gate, count in gate_counts.items():
401
+ if gate == "measure":
402
+ try:
403
+ fidelity *= (1 - self.properties.readout_error(bits[bit])) ** count
404
+ except BackendPropertyError:
405
+ pass
406
+ else:
407
+ try:
408
+ fidelity *= (1 - self.properties.gate_error(gate, bits[bit])) ** count
409
+ except BackendPropertyError:
410
+ pass
411
+ for edge in im_graph.edge_index_map().values():
412
+ qargs = (bits[reverse_bit_map[edge[0]]], bits[reverse_bit_map[edge[1]]])
413
+ gate_counts = edge[2]
414
+ for gate, count in gate_counts.items():
415
+ try:
416
+ fidelity *= (1 - self.properties.gate_error(gate, qargs)) ** count
417
+ except BackendPropertyError:
418
+ pass
419
+ return 1 - fidelity
@@ -0,0 +1,260 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2022.
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
+ """This module contains common utils for vf2 layout passes."""
14
+
15
+ from collections import defaultdict
16
+ import statistics
17
+ import random
18
+
19
+ import numpy as np
20
+ from rustworkx import PyDiGraph, PyGraph, connected_components
21
+
22
+ from qiskit.circuit import ForLoopOp
23
+ from qiskit.converters import circuit_to_dag
24
+ from qiskit._accelerate import vf2_layout
25
+ from qiskit._accelerate.nlayout import NLayout
26
+ from qiskit._accelerate.error_map import ErrorMap
27
+
28
+
29
+ def build_interaction_graph(dag, strict_direction=True):
30
+ """Build an interaction graph from a dag."""
31
+ im_graph = PyDiGraph(multigraph=False) if strict_direction else PyGraph(multigraph=False)
32
+ im_graph_node_map = {}
33
+ reverse_im_graph_node_map = {}
34
+
35
+ class MultiQEncountered(Exception):
36
+ """Used to singal an error-status return from the DAG visitor."""
37
+
38
+ def _visit(dag, weight, wire_map):
39
+ for node in dag.op_nodes(include_directives=False):
40
+ if node.is_control_flow():
41
+ if isinstance(node.op, ForLoopOp):
42
+ inner_weight = len(node.op.params[0]) * weight
43
+ else:
44
+ inner_weight = weight
45
+ for block in node.op.blocks:
46
+ inner_wire_map = {
47
+ inner: wire_map[outer] for outer, inner in zip(node.qargs, block.qubits)
48
+ }
49
+ _visit(circuit_to_dag(block), inner_weight, inner_wire_map)
50
+ continue
51
+ len_args = len(node.qargs)
52
+ qargs = [wire_map[q] for q in node.qargs]
53
+ if len_args == 1:
54
+ if qargs[0] not in im_graph_node_map:
55
+ weights = defaultdict(int)
56
+ weights[node.name] += weight
57
+ im_graph_node_map[qargs[0]] = im_graph.add_node(weights)
58
+ reverse_im_graph_node_map[im_graph_node_map[qargs[0]]] = qargs[0]
59
+ else:
60
+ im_graph[im_graph_node_map[qargs[0]]][node.name] += weight
61
+ if len_args == 2:
62
+ if qargs[0] not in im_graph_node_map:
63
+ im_graph_node_map[qargs[0]] = im_graph.add_node(defaultdict(int))
64
+ reverse_im_graph_node_map[im_graph_node_map[qargs[0]]] = qargs[0]
65
+ if qargs[1] not in im_graph_node_map:
66
+ im_graph_node_map[qargs[1]] = im_graph.add_node(defaultdict(int))
67
+ reverse_im_graph_node_map[im_graph_node_map[qargs[1]]] = qargs[1]
68
+ edge = (im_graph_node_map[qargs[0]], im_graph_node_map[qargs[1]])
69
+ if im_graph.has_edge(*edge):
70
+ im_graph.get_edge_data(*edge)[node.name] += weight
71
+ else:
72
+ weights = defaultdict(int)
73
+ weights[node.name] += weight
74
+ im_graph.add_edge(*edge, weights)
75
+ if len_args > 2:
76
+ raise MultiQEncountered()
77
+
78
+ try:
79
+ _visit(dag, 1, {bit: bit for bit in dag.qubits})
80
+ except MultiQEncountered:
81
+ return None
82
+ # Remove components with no 2q interactions from interaction graph
83
+ # these will be evaluated separately independently of scoring isomorphic
84
+ # mappings. This is not done for strict direction because for post layout
85
+ # we need to factor in local operation constraints when evaluating a graph
86
+ free_nodes = {}
87
+ if not strict_direction:
88
+ conn_comp = connected_components(im_graph)
89
+ for comp in conn_comp:
90
+ if len(comp) == 1:
91
+ index = comp.pop()
92
+ free_nodes[index] = im_graph[index]
93
+ im_graph.remove_node(index)
94
+
95
+ return im_graph, im_graph_node_map, reverse_im_graph_node_map, free_nodes
96
+
97
+
98
+ def build_edge_list(im_graph):
99
+ """Generate an edge list for scoring."""
100
+ return vf2_layout.EdgeList(
101
+ [((edge[0], edge[1]), sum(edge[2].values())) for edge in im_graph.edge_index_map().values()]
102
+ )
103
+
104
+
105
+ def build_bit_list(im_graph, bit_map):
106
+ """Generate a bit list for scoring."""
107
+ bit_list = np.zeros(len(im_graph), dtype=np.int32)
108
+ for node_index in bit_map.values():
109
+ try:
110
+ bit_list[node_index] = sum(im_graph[node_index].values())
111
+ # If node_index not in im_graph that means there was a standalone
112
+ # node we will score/sort separately outside the vf2 mapping, so we
113
+ # can skip the hole
114
+ except IndexError:
115
+ pass
116
+ return bit_list
117
+
118
+
119
+ def score_layout(
120
+ avg_error_map,
121
+ layout_mapping,
122
+ bit_map,
123
+ _reverse_bit_map,
124
+ im_graph,
125
+ strict_direction=False,
126
+ run_in_parallel=False,
127
+ edge_list=None,
128
+ bit_list=None,
129
+ ):
130
+ """Score a layout given an average error map."""
131
+ if layout_mapping:
132
+ size = max(max(layout_mapping), max(layout_mapping.values()))
133
+ else:
134
+ size = 0
135
+ nlayout = NLayout(layout_mapping, size + 1, size + 1)
136
+ if bit_list is None:
137
+ bit_list = build_bit_list(im_graph, bit_map)
138
+ if edge_list is None:
139
+ edge_list = build_edge_list(im_graph)
140
+ return vf2_layout.score_layout(
141
+ bit_list, edge_list, avg_error_map, nlayout, strict_direction, run_in_parallel
142
+ )
143
+
144
+
145
+ def build_average_error_map(target, properties, coupling_map):
146
+ """Build an average error map used for scoring layouts pre-basis translation."""
147
+ num_qubits = 0
148
+ if target is not None and target.qargs is not None:
149
+ num_qubits = target.num_qubits
150
+ avg_map = ErrorMap(len(target.qargs))
151
+ elif coupling_map is not None:
152
+ num_qubits = coupling_map.size()
153
+ avg_map = ErrorMap(num_qubits + coupling_map.graph.num_edges())
154
+ else:
155
+ # If coupling map is not defined almost certainly we don't have any
156
+ # data to build an error map, but just in case initialize an empty
157
+ # object
158
+ avg_map = ErrorMap(0)
159
+ built = False
160
+ if target is not None and target.qargs is not None:
161
+ for qargs in target.qargs:
162
+ if qargs is None:
163
+ continue
164
+ qarg_error = 0.0
165
+ count = 0
166
+ for op in target.operation_names_for_qargs(qargs):
167
+ inst_props = target[op].get(qargs, None)
168
+ if inst_props is not None and inst_props.error is not None:
169
+ count += 1
170
+ qarg_error += inst_props.error
171
+ if count > 0:
172
+ if len(qargs) == 1:
173
+ qargs = (qargs[0], qargs[0])
174
+ avg_map.add_error(qargs, qarg_error / count)
175
+ built = True
176
+ elif properties is not None:
177
+ errors = defaultdict(list)
178
+ for qubit in range(len(properties.qubits)):
179
+ errors[(qubit,)].append(properties.readout_error(qubit))
180
+ for gate in properties.gates:
181
+ qubits = tuple(gate.qubits)
182
+ for param in gate.parameters:
183
+ if param.name == "gate_error":
184
+ errors[qubits].append(param.value)
185
+ for k, v in errors.items():
186
+ if len(k) == 1:
187
+ qargs = (k[0], k[0])
188
+ else:
189
+ qargs = k
190
+ # If the properties payload contains an index outside the number of qubits
191
+ # the properties are invalid for the given input. This normally happens either
192
+ # with a malconstructed properties payload or if the faulty qubits feature of
193
+ # BackendV1/BackendPropeties is being used. In such cases we map noise characteristics
194
+ # so we should just treat the mapping as an ideal case.
195
+ if qargs[0] >= num_qubits or qargs[1] >= num_qubits:
196
+ continue
197
+ avg_map.add_error(qargs, statistics.mean(v))
198
+ built = True
199
+ # if there are no error rates in the target we should fallback to using the degree heuristic
200
+ # used for a coupling map. To do this we can build the coupling map from the target before
201
+ # running the fallback heuristic
202
+ if not built and target is not None and coupling_map is None:
203
+ coupling_map = target.build_coupling_map()
204
+ if not built and coupling_map is not None:
205
+ for qubit in range(num_qubits):
206
+ avg_map.add_error(
207
+ (qubit, qubit),
208
+ (coupling_map.graph.out_degree(qubit) + coupling_map.graph.in_degree(qubit))
209
+ / num_qubits,
210
+ )
211
+ for edge in coupling_map.graph.edge_list():
212
+ avg_map.add_error(edge, (avg_map[edge[0], edge[0]] + avg_map[edge[1], edge[1]]) / 2)
213
+ built = True
214
+ if built:
215
+ return avg_map
216
+ else:
217
+ return None
218
+
219
+
220
+ def shuffle_coupling_graph(coupling_map, seed, strict_direction=True):
221
+ """Create a shuffled coupling graph from a coupling map."""
222
+ if strict_direction:
223
+ cm_graph = coupling_map.graph
224
+ else:
225
+ cm_graph = coupling_map.graph.to_undirected(multigraph=False)
226
+ cm_nodes = list(cm_graph.node_indexes())
227
+ if seed != -1:
228
+ random.Random(seed).shuffle(cm_nodes)
229
+ shuffled_cm_graph = type(cm_graph)()
230
+ shuffled_cm_graph.add_nodes_from(cm_nodes)
231
+ new_edges = [(cm_nodes[edge[0]], cm_nodes[edge[1]]) for edge in cm_graph.edge_list()]
232
+ shuffled_cm_graph.add_edges_from_no_data(new_edges)
233
+ cm_nodes = [k for k, v in sorted(enumerate(cm_nodes), key=lambda item: item[1])]
234
+ cm_graph = shuffled_cm_graph
235
+ return cm_graph, cm_nodes
236
+
237
+
238
+ def map_free_qubits(
239
+ free_nodes, partial_layout, num_physical_qubits, reverse_bit_map, avg_error_map
240
+ ):
241
+ """Add any free nodes to a layout."""
242
+ if not free_nodes:
243
+ return partial_layout
244
+ if avg_error_map is not None:
245
+ free_qubits = sorted(
246
+ set(range(num_physical_qubits)) - partial_layout.get_physical_bits().keys(),
247
+ key=lambda bit: avg_error_map.get((bit, bit), 1.0),
248
+ )
249
+ # If no error map is available this means there is no scoring heuristic available for this
250
+ # backend and we can just randomly pick a free qubit
251
+ else:
252
+ free_qubits = list(
253
+ set(range(num_physical_qubits)) - partial_layout.get_physical_bits().keys()
254
+ )
255
+ for im_index in sorted(free_nodes, key=lambda x: sum(free_nodes[x].values())):
256
+ if not free_qubits:
257
+ return None
258
+ selected_qubit = free_qubits.pop(0)
259
+ partial_layout.add(reverse_bit_map[im_index], selected_qubit)
260
+ return partial_layout