qiskit 1.3.0b1__cp39-abi3-macosx_10_9_x86_64.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 (825) hide show
  1. qiskit/VERSION.txt +1 -0
  2. qiskit/__init__.py +127 -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 +365 -0
  8. qiskit/assembler/disassemble.py +310 -0
  9. qiskit/assembler/run_config.py +77 -0
  10. qiskit/circuit/__init__.py +1270 -0
  11. qiskit/circuit/_classical_resource_map.py +148 -0
  12. qiskit/circuit/_standard_gates_commutations.py +3264 -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 +48 -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 +503 -0
  45. qiskit/circuit/controlflow/switch_case.py +417 -0
  46. qiskit/circuit/controlflow/while_loop.py +163 -0
  47. qiskit/circuit/controlledgate.py +274 -0
  48. qiskit/circuit/delay.py +106 -0
  49. qiskit/circuit/duration.py +95 -0
  50. qiskit/circuit/equivalence.py +295 -0
  51. qiskit/circuit/equivalence_library.py +18 -0
  52. qiskit/circuit/exceptions.py +19 -0
  53. qiskit/circuit/gate.py +261 -0
  54. qiskit/circuit/instruction.py +676 -0
  55. qiskit/circuit/instructionset.py +177 -0
  56. qiskit/circuit/library/__init__.py +572 -0
  57. qiskit/circuit/library/arithmetic/__init__.py +27 -0
  58. qiskit/circuit/library/arithmetic/adders/__init__.py +17 -0
  59. qiskit/circuit/library/arithmetic/adders/adder.py +58 -0
  60. qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +159 -0
  61. qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +116 -0
  62. qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +165 -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 +16 -0
  69. qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py +138 -0
  70. qiskit/circuit/library/arithmetic/multipliers/multiplier.py +101 -0
  71. qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +101 -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 +331 -0
  80. qiskit/circuit/library/blueprintcircuit.py +216 -0
  81. qiskit/circuit/library/boolean_logic/__init__.py +18 -0
  82. qiskit/circuit/library/boolean_logic/inner_product.py +78 -0
  83. qiskit/circuit/library/boolean_logic/quantum_and.py +97 -0
  84. qiskit/circuit/library/boolean_logic/quantum_or.py +98 -0
  85. qiskit/circuit/library/boolean_logic/quantum_xor.py +71 -0
  86. qiskit/circuit/library/data_preparation/__init__.py +54 -0
  87. qiskit/circuit/library/data_preparation/initializer.py +107 -0
  88. qiskit/circuit/library/data_preparation/pauli_feature_map.py +343 -0
  89. qiskit/circuit/library/data_preparation/state_preparation.py +336 -0
  90. qiskit/circuit/library/data_preparation/z_feature_map.py +104 -0
  91. qiskit/circuit/library/data_preparation/zz_feature_map.py +118 -0
  92. qiskit/circuit/library/fourier_checking.py +97 -0
  93. qiskit/circuit/library/generalized_gates/__init__.py +30 -0
  94. qiskit/circuit/library/generalized_gates/diagonal.py +165 -0
  95. qiskit/circuit/library/generalized_gates/gms.py +121 -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 +312 -0
  99. qiskit/circuit/library/generalized_gates/mcg_up_to_diagonal.py +143 -0
  100. qiskit/circuit/library/generalized_gates/mcmt.py +256 -0
  101. qiskit/circuit/library/generalized_gates/pauli.py +85 -0
  102. qiskit/circuit/library/generalized_gates/permutation.py +192 -0
  103. qiskit/circuit/library/generalized_gates/rv.py +97 -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 +86 -0
  111. qiskit/circuit/library/grover_operator.py +311 -0
  112. qiskit/circuit/library/hamiltonian_gate.py +142 -0
  113. qiskit/circuit/library/hidden_linear_function.py +98 -0
  114. qiskit/circuit/library/iqp.py +96 -0
  115. qiskit/circuit/library/n_local/__init__.py +33 -0
  116. qiskit/circuit/library/n_local/efficient_su2.py +164 -0
  117. qiskit/circuit/library/n_local/evolved_operator_ansatz.py +256 -0
  118. qiskit/circuit/library/n_local/excitation_preserving.py +173 -0
  119. qiskit/circuit/library/n_local/n_local.py +1071 -0
  120. qiskit/circuit/library/n_local/pauli_two_design.py +141 -0
  121. qiskit/circuit/library/n_local/qaoa_ansatz.py +287 -0
  122. qiskit/circuit/library/n_local/real_amplitudes.py +186 -0
  123. qiskit/circuit/library/n_local/two_local.py +282 -0
  124. qiskit/circuit/library/overlap.py +117 -0
  125. qiskit/circuit/library/pauli_evolution.py +184 -0
  126. qiskit/circuit/library/phase_estimation.py +99 -0
  127. qiskit/circuit/library/phase_oracle.py +153 -0
  128. qiskit/circuit/library/quantum_volume.py +115 -0
  129. qiskit/circuit/library/standard_gates/__init__.py +123 -0
  130. qiskit/circuit/library/standard_gates/dcx.py +77 -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 +257 -0
  135. qiskit/circuit/library/standard_gates/i.py +75 -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 +433 -0
  139. qiskit/circuit/library/standard_gates/r.py +117 -0
  140. qiskit/circuit/library/standard_gates/rx.py +302 -0
  141. qiskit/circuit/library/standard_gates/rxx.py +183 -0
  142. qiskit/circuit/library/standard_gates/ry.py +297 -0
  143. qiskit/circuit/library/standard_gates/ryy.py +183 -0
  144. qiskit/circuit/library/standard_gates/rz.py +318 -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 +314 -0
  150. qiskit/circuit/library/standard_gates/t.py +179 -0
  151. qiskit/circuit/library/standard_gates/u.py +395 -0
  152. qiskit/circuit/library/standard_gates/u1.py +451 -0
  153. qiskit/circuit/library/standard_gates/u2.py +146 -0
  154. qiskit/circuit/library/standard_gates/u3.py +408 -0
  155. qiskit/circuit/library/standard_gates/x.py +1527 -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 +261 -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 +33 -0
  163. qiskit/circuit/library/templates/clifford/clifford_2_2.py +34 -0
  164. qiskit/circuit/library/templates/clifford/clifford_2_3.py +32 -0
  165. qiskit/circuit/library/templates/clifford/clifford_2_4.py +33 -0
  166. qiskit/circuit/library/templates/clifford/clifford_3_1.py +34 -0
  167. qiskit/circuit/library/templates/clifford/clifford_4_1.py +37 -0
  168. qiskit/circuit/library/templates/clifford/clifford_4_2.py +36 -0
  169. qiskit/circuit/library/templates/clifford/clifford_4_3.py +37 -0
  170. qiskit/circuit/library/templates/clifford/clifford_4_4.py +36 -0
  171. qiskit/circuit/library/templates/clifford/clifford_5_1.py +39 -0
  172. qiskit/circuit/library/templates/clifford/clifford_6_1.py +39 -0
  173. qiskit/circuit/library/templates/clifford/clifford_6_2.py +39 -0
  174. qiskit/circuit/library/templates/clifford/clifford_6_3.py +39 -0
  175. qiskit/circuit/library/templates/clifford/clifford_6_4.py +37 -0
  176. qiskit/circuit/library/templates/clifford/clifford_6_5.py +39 -0
  177. qiskit/circuit/library/templates/clifford/clifford_8_1.py +41 -0
  178. qiskit/circuit/library/templates/clifford/clifford_8_2.py +41 -0
  179. qiskit/circuit/library/templates/clifford/clifford_8_3.py +40 -0
  180. qiskit/circuit/library/templates/nct/__init__.py +67 -0
  181. qiskit/circuit/library/templates/nct/template_nct_2a_1.py +32 -0
  182. qiskit/circuit/library/templates/nct/template_nct_2a_2.py +33 -0
  183. qiskit/circuit/library/templates/nct/template_nct_2a_3.py +35 -0
  184. qiskit/circuit/library/templates/nct/template_nct_4a_1.py +41 -0
  185. qiskit/circuit/library/templates/nct/template_nct_4a_2.py +39 -0
  186. qiskit/circuit/library/templates/nct/template_nct_4a_3.py +37 -0
  187. qiskit/circuit/library/templates/nct/template_nct_4b_1.py +39 -0
  188. qiskit/circuit/library/templates/nct/template_nct_4b_2.py +37 -0
  189. qiskit/circuit/library/templates/nct/template_nct_5a_1.py +38 -0
  190. qiskit/circuit/library/templates/nct/template_nct_5a_2.py +38 -0
  191. qiskit/circuit/library/templates/nct/template_nct_5a_3.py +38 -0
  192. qiskit/circuit/library/templates/nct/template_nct_5a_4.py +37 -0
  193. qiskit/circuit/library/templates/nct/template_nct_6a_1.py +38 -0
  194. qiskit/circuit/library/templates/nct/template_nct_6a_2.py +39 -0
  195. qiskit/circuit/library/templates/nct/template_nct_6a_3.py +39 -0
  196. qiskit/circuit/library/templates/nct/template_nct_6a_4.py +39 -0
  197. qiskit/circuit/library/templates/nct/template_nct_6b_1.py +39 -0
  198. qiskit/circuit/library/templates/nct/template_nct_6b_2.py +39 -0
  199. qiskit/circuit/library/templates/nct/template_nct_6c_1.py +39 -0
  200. qiskit/circuit/library/templates/nct/template_nct_7a_1.py +41 -0
  201. qiskit/circuit/library/templates/nct/template_nct_7b_1.py +41 -0
  202. qiskit/circuit/library/templates/nct/template_nct_7c_1.py +41 -0
  203. qiskit/circuit/library/templates/nct/template_nct_7d_1.py +41 -0
  204. qiskit/circuit/library/templates/nct/template_nct_7e_1.py +41 -0
  205. qiskit/circuit/library/templates/nct/template_nct_9a_1.py +43 -0
  206. qiskit/circuit/library/templates/nct/template_nct_9c_1.py +41 -0
  207. qiskit/circuit/library/templates/nct/template_nct_9c_10.py +42 -0
  208. qiskit/circuit/library/templates/nct/template_nct_9c_11.py +42 -0
  209. qiskit/circuit/library/templates/nct/template_nct_9c_12.py +42 -0
  210. qiskit/circuit/library/templates/nct/template_nct_9c_2.py +42 -0
  211. qiskit/circuit/library/templates/nct/template_nct_9c_3.py +42 -0
  212. qiskit/circuit/library/templates/nct/template_nct_9c_4.py +42 -0
  213. qiskit/circuit/library/templates/nct/template_nct_9c_5.py +42 -0
  214. qiskit/circuit/library/templates/nct/template_nct_9c_6.py +42 -0
  215. qiskit/circuit/library/templates/nct/template_nct_9c_7.py +42 -0
  216. qiskit/circuit/library/templates/nct/template_nct_9c_8.py +42 -0
  217. qiskit/circuit/library/templates/nct/template_nct_9c_9.py +42 -0
  218. qiskit/circuit/library/templates/nct/template_nct_9d_1.py +41 -0
  219. qiskit/circuit/library/templates/nct/template_nct_9d_10.py +42 -0
  220. qiskit/circuit/library/templates/nct/template_nct_9d_2.py +42 -0
  221. qiskit/circuit/library/templates/nct/template_nct_9d_3.py +42 -0
  222. qiskit/circuit/library/templates/nct/template_nct_9d_4.py +42 -0
  223. qiskit/circuit/library/templates/nct/template_nct_9d_5.py +42 -0
  224. qiskit/circuit/library/templates/nct/template_nct_9d_6.py +42 -0
  225. qiskit/circuit/library/templates/nct/template_nct_9d_7.py +42 -0
  226. qiskit/circuit/library/templates/nct/template_nct_9d_8.py +42 -0
  227. qiskit/circuit/library/templates/nct/template_nct_9d_9.py +42 -0
  228. qiskit/circuit/library/templates/rzx/__init__.py +25 -0
  229. qiskit/circuit/library/templates/rzx/rzx_cy.py +46 -0
  230. qiskit/circuit/library/templates/rzx/rzx_xz.py +53 -0
  231. qiskit/circuit/library/templates/rzx/rzx_yz.py +43 -0
  232. qiskit/circuit/library/templates/rzx/rzx_zz1.py +67 -0
  233. qiskit/circuit/library/templates/rzx/rzx_zz2.py +58 -0
  234. qiskit/circuit/library/templates/rzx/rzx_zz3.py +57 -0
  235. qiskit/circuit/measure.py +44 -0
  236. qiskit/circuit/operation.py +67 -0
  237. qiskit/circuit/parameter.py +174 -0
  238. qiskit/circuit/parameterexpression.py +559 -0
  239. qiskit/circuit/parametertable.py +119 -0
  240. qiskit/circuit/parametervector.py +120 -0
  241. qiskit/circuit/quantumcircuit.py +6793 -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 +604 -0
  249. qiskit/circuit/store.py +95 -0
  250. qiskit/circuit/tools/__init__.py +16 -0
  251. qiskit/circuit/tools/pi_check.py +190 -0
  252. qiskit/compiler/__init__.py +33 -0
  253. qiskit/compiler/assembler.py +668 -0
  254. qiskit/compiler/scheduler.py +107 -0
  255. qiskit/compiler/sequencer.py +69 -0
  256. qiskit/compiler/transpiler.py +478 -0
  257. qiskit/converters/__init__.py +74 -0
  258. qiskit/converters/circuit_to_dag.py +78 -0
  259. qiskit/converters/circuit_to_dagdependency.py +51 -0
  260. qiskit/converters/circuit_to_dagdependency_v2.py +47 -0
  261. qiskit/converters/circuit_to_gate.py +107 -0
  262. qiskit/converters/circuit_to_instruction.py +155 -0
  263. qiskit/converters/dag_to_circuit.py +77 -0
  264. qiskit/converters/dag_to_dagdependency.py +55 -0
  265. qiskit/converters/dag_to_dagdependency_v2.py +44 -0
  266. qiskit/converters/dagdependency_to_circuit.py +42 -0
  267. qiskit/converters/dagdependency_to_dag.py +49 -0
  268. qiskit/dagcircuit/__init__.py +44 -0
  269. qiskit/dagcircuit/collect_blocks.py +391 -0
  270. qiskit/dagcircuit/dagcircuit.py +24 -0
  271. qiskit/dagcircuit/dagdependency.py +633 -0
  272. qiskit/dagcircuit/dagdependency_v2.py +641 -0
  273. qiskit/dagcircuit/dagdepnode.py +160 -0
  274. qiskit/dagcircuit/dagnode.py +176 -0
  275. qiskit/dagcircuit/exceptions.py +42 -0
  276. qiskit/exceptions.py +153 -0
  277. qiskit/passmanager/__init__.py +240 -0
  278. qiskit/passmanager/base_tasks.py +230 -0
  279. qiskit/passmanager/compilation_status.py +74 -0
  280. qiskit/passmanager/exceptions.py +19 -0
  281. qiskit/passmanager/flow_controllers.py +116 -0
  282. qiskit/passmanager/passmanager.py +333 -0
  283. qiskit/primitives/__init__.py +481 -0
  284. qiskit/primitives/backend_estimator.py +483 -0
  285. qiskit/primitives/backend_estimator_v2.py +434 -0
  286. qiskit/primitives/backend_sampler.py +222 -0
  287. qiskit/primitives/backend_sampler_v2.py +296 -0
  288. qiskit/primitives/base/__init__.py +20 -0
  289. qiskit/primitives/base/base_estimator.py +252 -0
  290. qiskit/primitives/base/base_primitive.py +45 -0
  291. qiskit/primitives/base/base_primitive_job.py +78 -0
  292. qiskit/primitives/base/base_result.py +65 -0
  293. qiskit/primitives/base/base_sampler.py +204 -0
  294. qiskit/primitives/base/estimator_result.py +46 -0
  295. qiskit/primitives/base/sampler_result.py +45 -0
  296. qiskit/primitives/base/validation.py +231 -0
  297. qiskit/primitives/containers/__init__.py +26 -0
  298. qiskit/primitives/containers/bindings_array.py +389 -0
  299. qiskit/primitives/containers/bit_array.py +741 -0
  300. qiskit/primitives/containers/data_bin.py +165 -0
  301. qiskit/primitives/containers/estimator_pub.py +222 -0
  302. qiskit/primitives/containers/object_array.py +94 -0
  303. qiskit/primitives/containers/observables_array.py +279 -0
  304. qiskit/primitives/containers/primitive_result.py +53 -0
  305. qiskit/primitives/containers/pub_result.py +51 -0
  306. qiskit/primitives/containers/sampler_pub.py +193 -0
  307. qiskit/primitives/containers/sampler_pub_result.py +74 -0
  308. qiskit/primitives/containers/shape.py +129 -0
  309. qiskit/primitives/estimator.py +172 -0
  310. qiskit/primitives/primitive_job.py +81 -0
  311. qiskit/primitives/sampler.py +162 -0
  312. qiskit/primitives/statevector_estimator.py +174 -0
  313. qiskit/primitives/statevector_sampler.py +292 -0
  314. qiskit/primitives/utils.py +247 -0
  315. qiskit/providers/__init__.py +803 -0
  316. qiskit/providers/backend.py +656 -0
  317. qiskit/providers/backend_compat.py +452 -0
  318. qiskit/providers/basic_provider/__init__.py +45 -0
  319. qiskit/providers/basic_provider/basic_provider.py +101 -0
  320. qiskit/providers/basic_provider/basic_provider_job.py +65 -0
  321. qiskit/providers/basic_provider/basic_provider_tools.py +218 -0
  322. qiskit/providers/basic_provider/basic_simulator.py +811 -0
  323. qiskit/providers/basic_provider/exceptions.py +30 -0
  324. qiskit/providers/exceptions.py +45 -0
  325. qiskit/providers/fake_provider/__init__.py +105 -0
  326. qiskit/providers/fake_provider/backends_v1/__init__.py +22 -0
  327. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +18 -0
  328. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +1 -0
  329. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +1 -0
  330. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +37 -0
  331. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +1 -0
  332. qiskit/providers/fake_provider/backends_v1/fake_20q/__init__.py +18 -0
  333. qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +1 -0
  334. qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +43 -0
  335. qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +1 -0
  336. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +18 -0
  337. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +1 -0
  338. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +1 -0
  339. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +50 -0
  340. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +1 -0
  341. qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +18 -0
  342. qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +1 -0
  343. qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +41 -0
  344. qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +1 -0
  345. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +18 -0
  346. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +1 -0
  347. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +1 -0
  348. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +44 -0
  349. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +1 -0
  350. qiskit/providers/fake_provider/fake_1q.py +91 -0
  351. qiskit/providers/fake_provider/fake_backend.py +165 -0
  352. qiskit/providers/fake_provider/fake_openpulse_2q.py +391 -0
  353. qiskit/providers/fake_provider/fake_openpulse_3q.py +340 -0
  354. qiskit/providers/fake_provider/fake_pulse_backend.py +44 -0
  355. qiskit/providers/fake_provider/fake_qasm_backend.py +77 -0
  356. qiskit/providers/fake_provider/generic_backend_v2.py +1019 -0
  357. qiskit/providers/fake_provider/utils/__init__.py +15 -0
  358. qiskit/providers/fake_provider/utils/backend_converter.py +150 -0
  359. qiskit/providers/fake_provider/utils/json_decoder.py +109 -0
  360. qiskit/providers/job.py +147 -0
  361. qiskit/providers/jobstatus.py +30 -0
  362. qiskit/providers/models/__init__.py +89 -0
  363. qiskit/providers/models/backendconfiguration.py +1040 -0
  364. qiskit/providers/models/backendproperties.py +517 -0
  365. qiskit/providers/models/backendstatus.py +94 -0
  366. qiskit/providers/models/jobstatus.py +66 -0
  367. qiskit/providers/models/pulsedefaults.py +303 -0
  368. qiskit/providers/options.py +273 -0
  369. qiskit/providers/provider.py +95 -0
  370. qiskit/providers/providerutils.py +110 -0
  371. qiskit/pulse/__init__.py +158 -0
  372. qiskit/pulse/builder.py +2213 -0
  373. qiskit/pulse/calibration_entries.py +378 -0
  374. qiskit/pulse/channels.py +225 -0
  375. qiskit/pulse/configuration.py +245 -0
  376. qiskit/pulse/exceptions.py +43 -0
  377. qiskit/pulse/filters.py +309 -0
  378. qiskit/pulse/instruction_schedule_map.py +409 -0
  379. qiskit/pulse/instructions/__init__.py +67 -0
  380. qiskit/pulse/instructions/acquire.py +148 -0
  381. qiskit/pulse/instructions/delay.py +69 -0
  382. qiskit/pulse/instructions/directives.py +146 -0
  383. qiskit/pulse/instructions/frequency.py +132 -0
  384. qiskit/pulse/instructions/instruction.py +268 -0
  385. qiskit/pulse/instructions/phase.py +149 -0
  386. qiskit/pulse/instructions/play.py +97 -0
  387. qiskit/pulse/instructions/reference.py +98 -0
  388. qiskit/pulse/instructions/snapshot.py +80 -0
  389. qiskit/pulse/library/__init__.py +97 -0
  390. qiskit/pulse/library/continuous.py +430 -0
  391. qiskit/pulse/library/pulse.py +146 -0
  392. qiskit/pulse/library/samplers/__init__.py +15 -0
  393. qiskit/pulse/library/samplers/decorators.py +295 -0
  394. qiskit/pulse/library/samplers/strategies.py +71 -0
  395. qiskit/pulse/library/symbolic_pulses.py +1960 -0
  396. qiskit/pulse/library/waveform.py +134 -0
  397. qiskit/pulse/macros.py +262 -0
  398. qiskit/pulse/parameter_manager.py +445 -0
  399. qiskit/pulse/parser.py +314 -0
  400. qiskit/pulse/reference_manager.py +58 -0
  401. qiskit/pulse/schedule.py +1855 -0
  402. qiskit/pulse/transforms/__init__.py +106 -0
  403. qiskit/pulse/transforms/alignments.py +404 -0
  404. qiskit/pulse/transforms/base_transforms.py +71 -0
  405. qiskit/pulse/transforms/canonicalization.py +498 -0
  406. qiskit/pulse/transforms/dag.py +115 -0
  407. qiskit/pulse/utils.py +149 -0
  408. qiskit/qasm/libs/dummy/stdgates.inc +75 -0
  409. qiskit/qasm/libs/qelib1.inc +266 -0
  410. qiskit/qasm/libs/stdgates.inc +82 -0
  411. qiskit/qasm2/__init__.py +654 -0
  412. qiskit/qasm2/exceptions.py +27 -0
  413. qiskit/qasm2/export.py +370 -0
  414. qiskit/qasm2/parse.py +408 -0
  415. qiskit/qasm3/__init__.py +366 -0
  416. qiskit/qasm3/ast.py +630 -0
  417. qiskit/qasm3/exceptions.py +27 -0
  418. qiskit/qasm3/experimental.py +70 -0
  419. qiskit/qasm3/exporter.py +1273 -0
  420. qiskit/qasm3/printer.py +577 -0
  421. qiskit/qobj/__init__.py +75 -0
  422. qiskit/qobj/common.py +81 -0
  423. qiskit/qobj/converters/__init__.py +18 -0
  424. qiskit/qobj/converters/lo_config.py +177 -0
  425. qiskit/qobj/converters/pulse_instruction.py +895 -0
  426. qiskit/qobj/pulse_qobj.py +709 -0
  427. qiskit/qobj/qasm_qobj.py +708 -0
  428. qiskit/qobj/utils.py +46 -0
  429. qiskit/qpy/__init__.py +1641 -0
  430. qiskit/qpy/binary_io/__init__.py +36 -0
  431. qiskit/qpy/binary_io/circuits.py +1460 -0
  432. qiskit/qpy/binary_io/schedules.py +636 -0
  433. qiskit/qpy/binary_io/value.py +728 -0
  434. qiskit/qpy/common.py +306 -0
  435. qiskit/qpy/exceptions.py +53 -0
  436. qiskit/qpy/formats.py +394 -0
  437. qiskit/qpy/interface.py +341 -0
  438. qiskit/qpy/type_keys.py +572 -0
  439. qiskit/quantum_info/__init__.py +158 -0
  440. qiskit/quantum_info/analysis/__init__.py +17 -0
  441. qiskit/quantum_info/analysis/average.py +47 -0
  442. qiskit/quantum_info/analysis/distance.py +102 -0
  443. qiskit/quantum_info/analysis/make_observable.py +44 -0
  444. qiskit/quantum_info/analysis/z2_symmetries.py +484 -0
  445. qiskit/quantum_info/operators/__init__.py +28 -0
  446. qiskit/quantum_info/operators/base_operator.py +145 -0
  447. qiskit/quantum_info/operators/channel/__init__.py +29 -0
  448. qiskit/quantum_info/operators/channel/chi.py +191 -0
  449. qiskit/quantum_info/operators/channel/choi.py +218 -0
  450. qiskit/quantum_info/operators/channel/kraus.py +337 -0
  451. qiskit/quantum_info/operators/channel/ptm.py +204 -0
  452. qiskit/quantum_info/operators/channel/quantum_channel.py +348 -0
  453. qiskit/quantum_info/operators/channel/stinespring.py +296 -0
  454. qiskit/quantum_info/operators/channel/superop.py +377 -0
  455. qiskit/quantum_info/operators/channel/transformations.py +468 -0
  456. qiskit/quantum_info/operators/custom_iterator.py +48 -0
  457. qiskit/quantum_info/operators/dihedral/__init__.py +18 -0
  458. qiskit/quantum_info/operators/dihedral/dihedral.py +509 -0
  459. qiskit/quantum_info/operators/dihedral/dihedral_circuits.py +216 -0
  460. qiskit/quantum_info/operators/dihedral/polynomial.py +313 -0
  461. qiskit/quantum_info/operators/dihedral/random.py +64 -0
  462. qiskit/quantum_info/operators/linear_op.py +25 -0
  463. qiskit/quantum_info/operators/measures.py +418 -0
  464. qiskit/quantum_info/operators/mixins/__init__.py +52 -0
  465. qiskit/quantum_info/operators/mixins/adjoint.py +52 -0
  466. qiskit/quantum_info/operators/mixins/group.py +171 -0
  467. qiskit/quantum_info/operators/mixins/linear.py +84 -0
  468. qiskit/quantum_info/operators/mixins/multiply.py +62 -0
  469. qiskit/quantum_info/operators/mixins/tolerances.py +72 -0
  470. qiskit/quantum_info/operators/op_shape.py +525 -0
  471. qiskit/quantum_info/operators/operator.py +819 -0
  472. qiskit/quantum_info/operators/operator_utils.py +76 -0
  473. qiskit/quantum_info/operators/predicates.py +183 -0
  474. qiskit/quantum_info/operators/random.py +154 -0
  475. qiskit/quantum_info/operators/scalar_op.py +254 -0
  476. qiskit/quantum_info/operators/symplectic/__init__.py +23 -0
  477. qiskit/quantum_info/operators/symplectic/base_pauli.py +727 -0
  478. qiskit/quantum_info/operators/symplectic/clifford.py +1030 -0
  479. qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
  480. qiskit/quantum_info/operators/symplectic/pauli.py +751 -0
  481. qiskit/quantum_info/operators/symplectic/pauli_list.py +1230 -0
  482. qiskit/quantum_info/operators/symplectic/pauli_utils.py +40 -0
  483. qiskit/quantum_info/operators/symplectic/random.py +117 -0
  484. qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +1175 -0
  485. qiskit/quantum_info/operators/utils/__init__.py +20 -0
  486. qiskit/quantum_info/operators/utils/anti_commutator.py +36 -0
  487. qiskit/quantum_info/operators/utils/commutator.py +36 -0
  488. qiskit/quantum_info/operators/utils/double_commutator.py +76 -0
  489. qiskit/quantum_info/quaternion.py +156 -0
  490. qiskit/quantum_info/random.py +26 -0
  491. qiskit/quantum_info/states/__init__.py +28 -0
  492. qiskit/quantum_info/states/densitymatrix.py +845 -0
  493. qiskit/quantum_info/states/measures.py +288 -0
  494. qiskit/quantum_info/states/quantum_state.py +503 -0
  495. qiskit/quantum_info/states/random.py +157 -0
  496. qiskit/quantum_info/states/stabilizerstate.py +773 -0
  497. qiskit/quantum_info/states/statevector.py +958 -0
  498. qiskit/quantum_info/states/utils.py +247 -0
  499. qiskit/result/__init__.py +73 -0
  500. qiskit/result/counts.py +189 -0
  501. qiskit/result/distributions/__init__.py +17 -0
  502. qiskit/result/distributions/probability.py +100 -0
  503. qiskit/result/distributions/quasi.py +154 -0
  504. qiskit/result/exceptions.py +40 -0
  505. qiskit/result/mitigation/__init__.py +13 -0
  506. qiskit/result/mitigation/base_readout_mitigator.py +79 -0
  507. qiskit/result/mitigation/correlated_readout_mitigator.py +269 -0
  508. qiskit/result/mitigation/local_readout_mitigator.py +320 -0
  509. qiskit/result/mitigation/utils.py +160 -0
  510. qiskit/result/models.py +234 -0
  511. qiskit/result/postprocess.py +239 -0
  512. qiskit/result/result.py +392 -0
  513. qiskit/result/sampled_expval.py +75 -0
  514. qiskit/result/utils.py +295 -0
  515. qiskit/scheduler/__init__.py +40 -0
  516. qiskit/scheduler/config.py +35 -0
  517. qiskit/scheduler/lowering.py +187 -0
  518. qiskit/scheduler/methods/__init__.py +15 -0
  519. qiskit/scheduler/methods/basic.py +137 -0
  520. qiskit/scheduler/schedule_circuit.py +67 -0
  521. qiskit/scheduler/sequence.py +102 -0
  522. qiskit/synthesis/__init__.py +195 -0
  523. qiskit/synthesis/clifford/__init__.py +19 -0
  524. qiskit/synthesis/clifford/clifford_decompose_ag.py +178 -0
  525. qiskit/synthesis/clifford/clifford_decompose_bm.py +47 -0
  526. qiskit/synthesis/clifford/clifford_decompose_full.py +64 -0
  527. qiskit/synthesis/clifford/clifford_decompose_greedy.py +57 -0
  528. qiskit/synthesis/clifford/clifford_decompose_layers.py +446 -0
  529. qiskit/synthesis/cnotdihedral/__init__.py +17 -0
  530. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py +52 -0
  531. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py +141 -0
  532. qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py +266 -0
  533. qiskit/synthesis/discrete_basis/__init__.py +16 -0
  534. qiskit/synthesis/discrete_basis/commutator_decompose.py +241 -0
  535. qiskit/synthesis/discrete_basis/gate_sequence.py +415 -0
  536. qiskit/synthesis/discrete_basis/generate_basis_approximations.py +163 -0
  537. qiskit/synthesis/discrete_basis/solovay_kitaev.py +217 -0
  538. qiskit/synthesis/evolution/__init__.py +20 -0
  539. qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
  540. qiskit/synthesis/evolution/lie_trotter.py +143 -0
  541. qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
  542. qiskit/synthesis/evolution/product_formula.py +384 -0
  543. qiskit/synthesis/evolution/qdrift.py +131 -0
  544. qiskit/synthesis/evolution/suzuki_trotter.py +155 -0
  545. qiskit/synthesis/linear/__init__.py +26 -0
  546. qiskit/synthesis/linear/cnot_synth.py +69 -0
  547. qiskit/synthesis/linear/linear_circuits_utils.py +128 -0
  548. qiskit/synthesis/linear/linear_depth_lnn.py +276 -0
  549. qiskit/synthesis/linear/linear_matrix_utils.py +27 -0
  550. qiskit/synthesis/linear_phase/__init__.py +17 -0
  551. qiskit/synthesis/linear_phase/cnot_phase_synth.py +206 -0
  552. qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +262 -0
  553. qiskit/synthesis/linear_phase/cz_depth_lnn.py +58 -0
  554. qiskit/synthesis/multi_controlled/__init__.py +23 -0
  555. qiskit/synthesis/multi_controlled/mcx_synthesis.py +356 -0
  556. qiskit/synthesis/one_qubit/__init__.py +15 -0
  557. qiskit/synthesis/one_qubit/one_qubit_decompose.py +288 -0
  558. qiskit/synthesis/permutation/__init__.py +18 -0
  559. qiskit/synthesis/permutation/permutation_full.py +78 -0
  560. qiskit/synthesis/permutation/permutation_lnn.py +54 -0
  561. qiskit/synthesis/permutation/permutation_reverse_lnn.py +93 -0
  562. qiskit/synthesis/permutation/permutation_utils.py +16 -0
  563. qiskit/synthesis/qft/__init__.py +16 -0
  564. qiskit/synthesis/qft/qft_decompose_full.py +79 -0
  565. qiskit/synthesis/qft/qft_decompose_lnn.py +78 -0
  566. qiskit/synthesis/stabilizer/__init__.py +16 -0
  567. qiskit/synthesis/stabilizer/stabilizer_circuit.py +149 -0
  568. qiskit/synthesis/stabilizer/stabilizer_decompose.py +193 -0
  569. qiskit/synthesis/two_qubit/__init__.py +19 -0
  570. qiskit/synthesis/two_qubit/local_invariance.py +63 -0
  571. qiskit/synthesis/two_qubit/two_qubit_decompose.py +759 -0
  572. qiskit/synthesis/two_qubit/weyl.py +97 -0
  573. qiskit/synthesis/two_qubit/xx_decompose/__init__.py +19 -0
  574. qiskit/synthesis/two_qubit/xx_decompose/circuits.py +300 -0
  575. qiskit/synthesis/two_qubit/xx_decompose/decomposer.py +324 -0
  576. qiskit/synthesis/two_qubit/xx_decompose/embodiments.py +163 -0
  577. qiskit/synthesis/two_qubit/xx_decompose/paths.py +412 -0
  578. qiskit/synthesis/two_qubit/xx_decompose/polytopes.py +262 -0
  579. qiskit/synthesis/two_qubit/xx_decompose/utilities.py +40 -0
  580. qiskit/synthesis/two_qubit/xx_decompose/weyl.py +133 -0
  581. qiskit/synthesis/unitary/__init__.py +13 -0
  582. qiskit/synthesis/unitary/aqc/__init__.py +177 -0
  583. qiskit/synthesis/unitary/aqc/approximate.py +116 -0
  584. qiskit/synthesis/unitary/aqc/aqc.py +175 -0
  585. qiskit/synthesis/unitary/aqc/cnot_structures.py +300 -0
  586. qiskit/synthesis/unitary/aqc/cnot_unit_circuit.py +103 -0
  587. qiskit/synthesis/unitary/aqc/cnot_unit_objective.py +299 -0
  588. qiskit/synthesis/unitary/aqc/elementary_operations.py +108 -0
  589. qiskit/synthesis/unitary/aqc/fast_gradient/__init__.py +164 -0
  590. qiskit/synthesis/unitary/aqc/fast_gradient/fast_grad_utils.py +237 -0
  591. qiskit/synthesis/unitary/aqc/fast_gradient/fast_gradient.py +226 -0
  592. qiskit/synthesis/unitary/aqc/fast_gradient/layer.py +370 -0
  593. qiskit/synthesis/unitary/aqc/fast_gradient/pmatrix.py +312 -0
  594. qiskit/synthesis/unitary/qsd.py +288 -0
  595. qiskit/transpiler/__init__.py +1283 -0
  596. qiskit/transpiler/basepasses.py +221 -0
  597. qiskit/transpiler/coupling.py +500 -0
  598. qiskit/transpiler/exceptions.py +59 -0
  599. qiskit/transpiler/instruction_durations.py +281 -0
  600. qiskit/transpiler/layout.py +737 -0
  601. qiskit/transpiler/passes/__init__.py +310 -0
  602. qiskit/transpiler/passes/analysis/__init__.py +23 -0
  603. qiskit/transpiler/passes/analysis/count_ops.py +30 -0
  604. qiskit/transpiler/passes/analysis/count_ops_longest_path.py +26 -0
  605. qiskit/transpiler/passes/analysis/dag_longest_path.py +24 -0
  606. qiskit/transpiler/passes/analysis/depth.py +33 -0
  607. qiskit/transpiler/passes/analysis/num_qubits.py +26 -0
  608. qiskit/transpiler/passes/analysis/num_tensor_factors.py +26 -0
  609. qiskit/transpiler/passes/analysis/resource_estimation.py +41 -0
  610. qiskit/transpiler/passes/analysis/size.py +36 -0
  611. qiskit/transpiler/passes/analysis/width.py +27 -0
  612. qiskit/transpiler/passes/basis/__init__.py +19 -0
  613. qiskit/transpiler/passes/basis/basis_translator.py +693 -0
  614. qiskit/transpiler/passes/basis/decompose.py +98 -0
  615. qiskit/transpiler/passes/basis/translate_parameterized.py +175 -0
  616. qiskit/transpiler/passes/basis/unroll_3q_or_more.py +88 -0
  617. qiskit/transpiler/passes/basis/unroll_custom_definitions.py +109 -0
  618. qiskit/transpiler/passes/calibration/__init__.py +17 -0
  619. qiskit/transpiler/passes/calibration/base_builder.py +79 -0
  620. qiskit/transpiler/passes/calibration/builders.py +20 -0
  621. qiskit/transpiler/passes/calibration/exceptions.py +22 -0
  622. qiskit/transpiler/passes/calibration/pulse_gate.py +98 -0
  623. qiskit/transpiler/passes/calibration/rx_builder.py +160 -0
  624. qiskit/transpiler/passes/calibration/rzx_builder.py +395 -0
  625. qiskit/transpiler/passes/calibration/rzx_templates.py +51 -0
  626. qiskit/transpiler/passes/layout/__init__.py +26 -0
  627. qiskit/transpiler/passes/layout/_csp_custom_solver.py +65 -0
  628. qiskit/transpiler/passes/layout/apply_layout.py +123 -0
  629. qiskit/transpiler/passes/layout/csp_layout.py +132 -0
  630. qiskit/transpiler/passes/layout/dense_layout.py +202 -0
  631. qiskit/transpiler/passes/layout/disjoint_utils.py +217 -0
  632. qiskit/transpiler/passes/layout/enlarge_with_ancilla.py +49 -0
  633. qiskit/transpiler/passes/layout/full_ancilla_allocation.py +117 -0
  634. qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
  635. qiskit/transpiler/passes/layout/sabre_layout.py +482 -0
  636. qiskit/transpiler/passes/layout/sabre_pre_layout.py +220 -0
  637. qiskit/transpiler/passes/layout/set_layout.py +69 -0
  638. qiskit/transpiler/passes/layout/trivial_layout.py +66 -0
  639. qiskit/transpiler/passes/layout/vf2_layout.py +263 -0
  640. qiskit/transpiler/passes/layout/vf2_post_layout.py +419 -0
  641. qiskit/transpiler/passes/layout/vf2_utils.py +260 -0
  642. qiskit/transpiler/passes/optimization/__init__.py +42 -0
  643. qiskit/transpiler/passes/optimization/_gate_extension.py +80 -0
  644. qiskit/transpiler/passes/optimization/collect_1q_runs.py +31 -0
  645. qiskit/transpiler/passes/optimization/collect_2q_blocks.py +35 -0
  646. qiskit/transpiler/passes/optimization/collect_and_collapse.py +115 -0
  647. qiskit/transpiler/passes/optimization/collect_cliffords.py +88 -0
  648. qiskit/transpiler/passes/optimization/collect_linear_functions.py +80 -0
  649. qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +227 -0
  650. qiskit/transpiler/passes/optimization/commutation_analysis.py +44 -0
  651. qiskit/transpiler/passes/optimization/commutative_cancellation.py +82 -0
  652. qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py +140 -0
  653. qiskit/transpiler/passes/optimization/consolidate_blocks.py +232 -0
  654. qiskit/transpiler/passes/optimization/cx_cancellation.py +65 -0
  655. qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +160 -0
  656. qiskit/transpiler/passes/optimization/elide_permutations.py +114 -0
  657. qiskit/transpiler/passes/optimization/hoare_opt.py +420 -0
  658. qiskit/transpiler/passes/optimization/inverse_cancellation.py +93 -0
  659. qiskit/transpiler/passes/optimization/normalize_rx_angle.py +149 -0
  660. qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +268 -0
  661. qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +260 -0
  662. qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
  663. qiskit/transpiler/passes/optimization/optimize_annotated.py +448 -0
  664. qiskit/transpiler/passes/optimization/optimize_cliffords.py +89 -0
  665. qiskit/transpiler/passes/optimization/optimize_swap_before_measure.py +71 -0
  666. qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py +41 -0
  667. qiskit/transpiler/passes/optimization/remove_final_reset.py +37 -0
  668. qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
  669. qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +47 -0
  670. qiskit/transpiler/passes/optimization/split_2q_unitaries.py +40 -0
  671. qiskit/transpiler/passes/optimization/template_matching/__init__.py +19 -0
  672. qiskit/transpiler/passes/optimization/template_matching/backward_match.py +749 -0
  673. qiskit/transpiler/passes/optimization/template_matching/forward_match.py +452 -0
  674. qiskit/transpiler/passes/optimization/template_matching/maximal_matches.py +77 -0
  675. qiskit/transpiler/passes/optimization/template_matching/template_matching.py +370 -0
  676. qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +638 -0
  677. qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
  678. qiskit/transpiler/passes/routing/__init__.py +22 -0
  679. qiskit/transpiler/passes/routing/algorithms/__init__.py +33 -0
  680. qiskit/transpiler/passes/routing/algorithms/token_swapper.py +105 -0
  681. qiskit/transpiler/passes/routing/algorithms/types.py +46 -0
  682. qiskit/transpiler/passes/routing/algorithms/util.py +103 -0
  683. qiskit/transpiler/passes/routing/basic_swap.py +166 -0
  684. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/__init__.py +25 -0
  685. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_block.py +60 -0
  686. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +395 -0
  687. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/pauli_2q_evolution_commutation.py +145 -0
  688. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/swap_strategy.py +306 -0
  689. qiskit/transpiler/passes/routing/layout_transformation.py +119 -0
  690. qiskit/transpiler/passes/routing/lookahead_swap.py +390 -0
  691. qiskit/transpiler/passes/routing/sabre_swap.py +443 -0
  692. qiskit/transpiler/passes/routing/star_prerouting.py +392 -0
  693. qiskit/transpiler/passes/routing/stochastic_swap.py +532 -0
  694. qiskit/transpiler/passes/routing/utils.py +35 -0
  695. qiskit/transpiler/passes/scheduling/__init__.py +27 -0
  696. qiskit/transpiler/passes/scheduling/alap.py +153 -0
  697. qiskit/transpiler/passes/scheduling/alignments/__init__.py +81 -0
  698. qiskit/transpiler/passes/scheduling/alignments/align_measures.py +255 -0
  699. qiskit/transpiler/passes/scheduling/alignments/check_durations.py +78 -0
  700. qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +105 -0
  701. qiskit/transpiler/passes/scheduling/alignments/reschedule.py +250 -0
  702. qiskit/transpiler/passes/scheduling/asap.py +175 -0
  703. qiskit/transpiler/passes/scheduling/base_scheduler.py +308 -0
  704. qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +307 -0
  705. qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
  706. qiskit/transpiler/passes/scheduling/padding/base_padding.py +256 -0
  707. qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +441 -0
  708. qiskit/transpiler/passes/scheduling/padding/pad_delay.py +79 -0
  709. qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
  710. qiskit/transpiler/passes/scheduling/scheduling/alap.py +127 -0
  711. qiskit/transpiler/passes/scheduling/scheduling/asap.py +131 -0
  712. qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +90 -0
  713. qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
  714. qiskit/transpiler/passes/scheduling/time_unit_conversion.py +160 -0
  715. qiskit/transpiler/passes/synthesis/__init__.py +20 -0
  716. qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
  717. qiskit/transpiler/passes/synthesis/high_level_synthesis.py +691 -0
  718. qiskit/transpiler/passes/synthesis/hls_plugins.py +928 -0
  719. qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +41 -0
  720. qiskit/transpiler/passes/synthesis/plugin.py +734 -0
  721. qiskit/transpiler/passes/synthesis/qubit_tracker.py +132 -0
  722. qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +297 -0
  723. qiskit/transpiler/passes/synthesis/unitary_synthesis.py +1055 -0
  724. qiskit/transpiler/passes/utils/__init__.py +33 -0
  725. qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +95 -0
  726. qiskit/transpiler/passes/utils/check_gate_direction.py +52 -0
  727. qiskit/transpiler/passes/utils/check_map.py +78 -0
  728. qiskit/transpiler/passes/utils/contains_instruction.py +45 -0
  729. qiskit/transpiler/passes/utils/control_flow.py +65 -0
  730. qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +88 -0
  731. qiskit/transpiler/passes/utils/dag_fixed_point.py +36 -0
  732. qiskit/transpiler/passes/utils/error.py +69 -0
  733. qiskit/transpiler/passes/utils/filter_op_nodes.py +65 -0
  734. qiskit/transpiler/passes/utils/fixed_point.py +48 -0
  735. qiskit/transpiler/passes/utils/gate_direction.py +349 -0
  736. qiskit/transpiler/passes/utils/gates_basis.py +74 -0
  737. qiskit/transpiler/passes/utils/merge_adjacent_barriers.py +162 -0
  738. qiskit/transpiler/passes/utils/minimum_point.py +118 -0
  739. qiskit/transpiler/passes/utils/remove_barriers.py +49 -0
  740. qiskit/transpiler/passes/utils/remove_final_measurements.py +114 -0
  741. qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
  742. qiskit/transpiler/passmanager.py +490 -0
  743. qiskit/transpiler/passmanager_config.py +198 -0
  744. qiskit/transpiler/preset_passmanagers/__init__.py +73 -0
  745. qiskit/transpiler/preset_passmanagers/builtin_plugins.py +1019 -0
  746. qiskit/transpiler/preset_passmanagers/common.py +647 -0
  747. qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +543 -0
  748. qiskit/transpiler/preset_passmanagers/level0.py +113 -0
  749. qiskit/transpiler/preset_passmanagers/level1.py +120 -0
  750. qiskit/transpiler/preset_passmanagers/level2.py +119 -0
  751. qiskit/transpiler/preset_passmanagers/level3.py +119 -0
  752. qiskit/transpiler/preset_passmanagers/plugin.py +353 -0
  753. qiskit/transpiler/target.py +1261 -0
  754. qiskit/transpiler/timing_constraints.py +59 -0
  755. qiskit/user_config.py +262 -0
  756. qiskit/utils/__init__.py +89 -0
  757. qiskit/utils/classtools.py +146 -0
  758. qiskit/utils/deprecation.py +490 -0
  759. qiskit/utils/lazy_tester.py +363 -0
  760. qiskit/utils/multiprocessing.py +56 -0
  761. qiskit/utils/optionals.py +347 -0
  762. qiskit/utils/parallel.py +191 -0
  763. qiskit/utils/units.py +143 -0
  764. qiskit/version.py +84 -0
  765. qiskit/visualization/__init__.py +288 -0
  766. qiskit/visualization/array.py +204 -0
  767. qiskit/visualization/bloch.py +778 -0
  768. qiskit/visualization/circuit/__init__.py +15 -0
  769. qiskit/visualization/circuit/_utils.py +675 -0
  770. qiskit/visualization/circuit/circuit_visualization.py +726 -0
  771. qiskit/visualization/circuit/latex.py +661 -0
  772. qiskit/visualization/circuit/matplotlib.py +2029 -0
  773. qiskit/visualization/circuit/qcstyle.py +278 -0
  774. qiskit/visualization/circuit/styles/__init__.py +13 -0
  775. qiskit/visualization/circuit/styles/bw.json +202 -0
  776. qiskit/visualization/circuit/styles/clifford.json +202 -0
  777. qiskit/visualization/circuit/styles/iqp-dark.json +214 -0
  778. qiskit/visualization/circuit/styles/iqp.json +214 -0
  779. qiskit/visualization/circuit/styles/textbook.json +202 -0
  780. qiskit/visualization/circuit/text.py +1844 -0
  781. qiskit/visualization/circuit_visualization.py +19 -0
  782. qiskit/visualization/counts_visualization.py +481 -0
  783. qiskit/visualization/dag_visualization.py +316 -0
  784. qiskit/visualization/exceptions.py +21 -0
  785. qiskit/visualization/gate_map.py +1485 -0
  786. qiskit/visualization/library.py +37 -0
  787. qiskit/visualization/pass_manager_visualization.py +319 -0
  788. qiskit/visualization/pulse_v2/__init__.py +21 -0
  789. qiskit/visualization/pulse_v2/core.py +901 -0
  790. qiskit/visualization/pulse_v2/device_info.py +173 -0
  791. qiskit/visualization/pulse_v2/drawings.py +253 -0
  792. qiskit/visualization/pulse_v2/events.py +254 -0
  793. qiskit/visualization/pulse_v2/generators/__init__.py +40 -0
  794. qiskit/visualization/pulse_v2/generators/barrier.py +76 -0
  795. qiskit/visualization/pulse_v2/generators/chart.py +208 -0
  796. qiskit/visualization/pulse_v2/generators/frame.py +436 -0
  797. qiskit/visualization/pulse_v2/generators/snapshot.py +133 -0
  798. qiskit/visualization/pulse_v2/generators/waveform.py +645 -0
  799. qiskit/visualization/pulse_v2/interface.py +456 -0
  800. qiskit/visualization/pulse_v2/layouts.py +387 -0
  801. qiskit/visualization/pulse_v2/plotters/__init__.py +17 -0
  802. qiskit/visualization/pulse_v2/plotters/base_plotter.py +53 -0
  803. qiskit/visualization/pulse_v2/plotters/matplotlib.py +201 -0
  804. qiskit/visualization/pulse_v2/stylesheet.py +312 -0
  805. qiskit/visualization/pulse_v2/types.py +242 -0
  806. qiskit/visualization/state_visualization.py +1518 -0
  807. qiskit/visualization/timeline/__init__.py +21 -0
  808. qiskit/visualization/timeline/core.py +457 -0
  809. qiskit/visualization/timeline/drawings.py +260 -0
  810. qiskit/visualization/timeline/generators.py +506 -0
  811. qiskit/visualization/timeline/interface.py +424 -0
  812. qiskit/visualization/timeline/layouts.py +115 -0
  813. qiskit/visualization/timeline/plotters/__init__.py +16 -0
  814. qiskit/visualization/timeline/plotters/base_plotter.py +58 -0
  815. qiskit/visualization/timeline/plotters/matplotlib.py +192 -0
  816. qiskit/visualization/timeline/stylesheet.py +301 -0
  817. qiskit/visualization/timeline/types.py +148 -0
  818. qiskit/visualization/transition_visualization.py +369 -0
  819. qiskit/visualization/utils.py +49 -0
  820. qiskit-1.3.0b1.dist-info/LICENSE.txt +203 -0
  821. qiskit-1.3.0b1.dist-info/METADATA +221 -0
  822. qiskit-1.3.0b1.dist-info/RECORD +825 -0
  823. qiskit-1.3.0b1.dist-info/WHEEL +5 -0
  824. qiskit-1.3.0b1.dist-info/entry_points.txt +57 -0
  825. qiskit-1.3.0b1.dist-info/top_level.txt +1 -0
@@ -0,0 +1,1261 @@
1
+ # This code is part of Qiskit.
2
+ #
3
+ # (C) Copyright IBM 2021, 2023.
4
+ #
5
+ # This code is licensed under the Apache License, Version 2.0. You may
6
+ # obtain a copy of this license in the LICENSE.txt file in the root directory
7
+ # of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
8
+ #
9
+ # Any modifications or derivative works of this code must retain this
10
+ # copyright notice, and modified files need to carry a notice indicating
11
+ # that they have been altered from the originals.
12
+
13
+ # pylint: disable=too-many-return-statements
14
+
15
+ """
16
+ A target object represents the minimum set of information the transpiler needs
17
+ from a backend
18
+ """
19
+
20
+ from __future__ import annotations
21
+
22
+ import itertools
23
+ import warnings
24
+
25
+ from typing import Optional, List, Any
26
+ from collections.abc import Mapping
27
+ import datetime
28
+ import io
29
+ import logging
30
+ import inspect
31
+
32
+ import rustworkx as rx
33
+
34
+ # import target class from the rust side
35
+ from qiskit._accelerate.target import (
36
+ BaseTarget,
37
+ BaseInstructionProperties,
38
+ )
39
+
40
+ from qiskit.circuit.parameter import Parameter
41
+ from qiskit.circuit.parameterexpression import ParameterValueType
42
+ from qiskit.circuit.gate import Gate
43
+ from qiskit.circuit.library.standard_gates import get_standard_gate_name_mapping
44
+ from qiskit.pulse.instruction_schedule_map import InstructionScheduleMap
45
+ from qiskit.pulse.calibration_entries import CalibrationEntry, ScheduleDef
46
+ from qiskit.pulse.schedule import Schedule, ScheduleBlock
47
+ from qiskit.transpiler.coupling import CouplingMap
48
+ from qiskit.transpiler.exceptions import TranspilerError
49
+ from qiskit.transpiler.instruction_durations import InstructionDurations
50
+ from qiskit.transpiler.timing_constraints import TimingConstraints
51
+ from qiskit.providers.exceptions import BackendPropertyError
52
+ from qiskit.pulse.exceptions import PulseError, UnassignedDurationError
53
+ from qiskit.exceptions import QiskitError
54
+
55
+ # import QubitProperties here to provide convenience alias for building a
56
+ # full target
57
+ from qiskit.providers.backend import QubitProperties # pylint: disable=unused-import
58
+ from qiskit.providers.models.backendproperties import BackendProperties
59
+ from qiskit.utils import deprecate_func
60
+
61
+ logger = logging.getLogger(__name__)
62
+
63
+
64
+ class InstructionProperties(BaseInstructionProperties):
65
+ """A representation of the properties of a gate implementation.
66
+
67
+ This class provides the optional properties that a backend can provide
68
+ about an instruction. These represent the set that the transpiler can
69
+ currently work with if present. However, if your backend provides additional
70
+ properties for instructions you should subclass this to add additional
71
+ custom attributes for those custom/additional properties by the backend.
72
+ """
73
+
74
+ __slots__ = [
75
+ "_calibration",
76
+ ]
77
+
78
+ def __new__( # pylint: disable=keyword-arg-before-vararg
79
+ cls,
80
+ duration=None, # pylint: disable=keyword-arg-before-vararg
81
+ error=None, # pylint: disable=keyword-arg-before-vararg
82
+ *args, # pylint: disable=unused-argument
83
+ **kwargs, # pylint: disable=unused-argument
84
+ ):
85
+ return super(InstructionProperties, cls).__new__( # pylint: disable=too-many-function-args
86
+ cls, duration, error
87
+ )
88
+
89
+ def __init__(
90
+ self,
91
+ duration: float | None = None, # pylint: disable=unused-argument
92
+ error: float | None = None, # pylint: disable=unused-argument
93
+ calibration: Schedule | ScheduleBlock | CalibrationEntry | None = None,
94
+ ):
95
+ """Create a new ``InstructionProperties`` object
96
+
97
+ Args:
98
+ duration: The duration, in seconds, of the instruction on the
99
+ specified set of qubits
100
+ error: The average error rate for the instruction on the specified
101
+ set of qubits.
102
+ calibration: The pulse representation of the instruction.
103
+ """
104
+ super().__init__()
105
+ self._calibration: CalibrationEntry | None = None
106
+ self.calibration = calibration
107
+
108
+ @property
109
+ def calibration(self):
110
+ """The pulse representation of the instruction.
111
+
112
+ .. note::
113
+
114
+ This attribute always returns a Qiskit pulse program, but it is internally
115
+ wrapped by the :class:`.CalibrationEntry` to manage unbound parameters
116
+ and to uniformly handle different data representation,
117
+ for example, un-parsed Pulse Qobj JSON that a backend provider may provide.
118
+
119
+ This value can be overridden through the property setter in following manner.
120
+ When you set either :class:`.Schedule` or :class:`.ScheduleBlock` this is
121
+ always treated as a user-defined (custom) calibration and
122
+ the transpiler may automatically attach the calibration data to the output circuit.
123
+ This calibration data may appear in the wire format as an inline calibration,
124
+ which may further update the backend standard instruction set architecture.
125
+
126
+ If you are a backend provider who provides a default calibration data
127
+ that is not needed to be attached to the transpiled quantum circuit,
128
+ you can directly set :class:`.CalibrationEntry` instance to this attribute,
129
+ in which you should set :code:`user_provided=False` when you define
130
+ calibration data for the entry. End users can still intentionally utilize
131
+ the calibration data, for example, to run pulse-level simulation of the circuit.
132
+ However, such entry doesn't appear in the wire format, and backend must
133
+ use own definition to compile the circuit down to the execution format.
134
+
135
+ """
136
+ if self._calibration is None:
137
+ return None
138
+ return self._calibration.get_schedule()
139
+
140
+ @calibration.setter
141
+ def calibration(self, calibration: Schedule | ScheduleBlock | CalibrationEntry):
142
+ if isinstance(calibration, (Schedule, ScheduleBlock)):
143
+ new_entry = ScheduleDef()
144
+ new_entry.define(calibration, user_provided=True)
145
+ else:
146
+ new_entry = calibration
147
+ self._calibration = new_entry
148
+
149
+ def __repr__(self):
150
+ return (
151
+ f"InstructionProperties(duration={self.duration}, error={self.error}"
152
+ f", calibration={self._calibration})"
153
+ )
154
+
155
+ def __getstate__(self) -> tuple:
156
+ return (super().__getstate__(), self.calibration, self._calibration)
157
+
158
+ def __setstate__(self, state: tuple):
159
+ super().__setstate__(state[0])
160
+ self.calibration = state[1]
161
+ self._calibration = state[2]
162
+
163
+
164
+ class Target(BaseTarget):
165
+ """
166
+ The intent of the ``Target`` object is to inform Qiskit's compiler about
167
+ the constraints of a particular backend so the compiler can compile an
168
+ input circuit to something that works and is optimized for a device. It
169
+ currently contains a description of instructions on a backend and their
170
+ properties as well as some timing information. However, this exact
171
+ interface may evolve over time as the needs of the compiler change. These
172
+ changes will be done in a backwards compatible and controlled manner when
173
+ they are made (either through versioning, subclassing, or mixins) to add
174
+ on to the set of information exposed by a target.
175
+
176
+ As a basic example, let's assume backend has two qubits, supports
177
+ :class:`~qiskit.circuit.library.UGate` on both qubits and
178
+ :class:`~qiskit.circuit.library.CXGate` in both directions. To model this
179
+ you would create the target like::
180
+
181
+ from qiskit.transpiler import Target, InstructionProperties
182
+ from qiskit.circuit.library import UGate, CXGate
183
+ from qiskit.circuit import Parameter
184
+
185
+ gmap = Target()
186
+ theta = Parameter('theta')
187
+ phi = Parameter('phi')
188
+ lam = Parameter('lambda')
189
+ u_props = {
190
+ (0,): InstructionProperties(duration=5.23e-8, error=0.00038115),
191
+ (1,): InstructionProperties(duration=4.52e-8, error=0.00032115),
192
+ }
193
+ gmap.add_instruction(UGate(theta, phi, lam), u_props)
194
+ cx_props = {
195
+ (0,1): InstructionProperties(duration=5.23e-7, error=0.00098115),
196
+ (1,0): InstructionProperties(duration=4.52e-7, error=0.00132115),
197
+ }
198
+ gmap.add_instruction(CXGate(), cx_props)
199
+
200
+ Each instruction in the ``Target`` is indexed by a unique string name that uniquely
201
+ identifies that instance of an :class:`~qiskit.circuit.Instruction` object in
202
+ the Target. There is a 1:1 mapping between a name and an
203
+ :class:`~qiskit.circuit.Instruction` instance in the target and each name must
204
+ be unique. By default, the name is the :attr:`~qiskit.circuit.Instruction.name`
205
+ attribute of the instruction, but can be set to anything. This lets a single
206
+ target have multiple instances of the same instruction class with different
207
+ parameters. For example, if a backend target has two instances of an
208
+ :class:`~qiskit.circuit.library.RXGate` one is parameterized over any theta
209
+ while the other is tuned up for a theta of pi/6 you can add these by doing something
210
+ like::
211
+
212
+ import math
213
+
214
+ from qiskit.transpiler import Target, InstructionProperties
215
+ from qiskit.circuit.library import RXGate
216
+ from qiskit.circuit import Parameter
217
+
218
+ target = Target()
219
+ theta = Parameter('theta')
220
+ rx_props = {
221
+ (0,): InstructionProperties(duration=5.23e-8, error=0.00038115),
222
+ }
223
+ target.add_instruction(RXGate(theta), rx_props)
224
+ rx_30_props = {
225
+ (0,): InstructionProperties(duration=1.74e-6, error=.00012)
226
+ }
227
+ target.add_instruction(RXGate(math.pi / 6), rx_30_props, name='rx_30')
228
+
229
+ Then in the ``target`` object accessing by ``rx_30`` will get the fixed
230
+ angle :class:`~qiskit.circuit.library.RXGate` while ``rx`` will get the
231
+ parameterized :class:`~qiskit.circuit.library.RXGate`.
232
+
233
+ .. note::
234
+
235
+ This class assumes that qubit indices start at 0 and are a contiguous
236
+ set if you want a submapping the bits will need to be reindexed in
237
+ a new``Target`` object.
238
+
239
+ .. note::
240
+
241
+ This class only supports additions of gates, qargs, and qubits.
242
+ If you need to remove one of these the best option is to iterate over
243
+ an existing object and create a new subset (or use one of the methods
244
+ to do this). The object internally caches different views and these
245
+ would potentially be invalidated by removals.
246
+ """
247
+
248
+ __slots__ = (
249
+ "_gate_map",
250
+ "_coupling_graph",
251
+ "_instruction_durations",
252
+ "_instruction_schedule_map",
253
+ )
254
+
255
+ def __new__( # pylint: disable=keyword-arg-before-vararg
256
+ cls,
257
+ description: str | None = None,
258
+ num_qubits: int = 0,
259
+ dt: float | None = None,
260
+ granularity: int = 1,
261
+ min_length: int = 1,
262
+ pulse_alignment: int = 1,
263
+ acquire_alignment: int = 1,
264
+ qubit_properties: list | None = None,
265
+ concurrent_measurements: list | None = None,
266
+ *args, # pylint: disable=unused-argument disable=keyword-arg-before-vararg
267
+ **kwargs, # pylint: disable=unused-argument
268
+ ):
269
+ """
270
+ Create a new ``Target`` object
271
+
272
+ Args:
273
+ description (str): An optional string to describe the Target.
274
+ num_qubits (int): An optional int to specify the number of qubits
275
+ the backend target has. If not set it will be implicitly set
276
+ based on the qargs when :meth:`~qiskit.Target.add_instruction`
277
+ is called. Note this must be set if the backend target is for a
278
+ noiseless simulator that doesn't have constraints on the
279
+ instructions so the transpiler knows how many qubits are
280
+ available.
281
+ dt (float): The system time resolution of input signals in seconds
282
+ granularity (int): An integer value representing minimum pulse gate
283
+ resolution in units of ``dt``. A user-defined pulse gate should
284
+ have duration of a multiple of this granularity value.
285
+ min_length (int): An integer value representing minimum pulse gate
286
+ length in units of ``dt``. A user-defined pulse gate should be
287
+ longer than this length.
288
+ pulse_alignment (int): An integer value representing a time
289
+ resolution of gate instruction starting time. Gate instruction
290
+ should start at time which is a multiple of the alignment
291
+ value.
292
+ acquire_alignment (int): An integer value representing a time
293
+ resolution of measure instruction starting time. Measure
294
+ instruction should start at time which is a multiple of the
295
+ alignment value.
296
+ qubit_properties (list): A list of :class:`~.QubitProperties`
297
+ objects defining the characteristics of each qubit on the
298
+ target device. If specified the length of this list must match
299
+ the number of qubits in the target, where the index in the list
300
+ matches the qubit number the properties are defined for. If some
301
+ qubits don't have properties available you can set that entry to
302
+ ``None``
303
+ concurrent_measurements(list): A list of sets of qubits that must be
304
+ measured together. This must be provided
305
+ as a nested list like ``[[0, 1], [2, 3, 4]]``.
306
+ Raises:
307
+ ValueError: If both ``num_qubits`` and ``qubit_properties`` are both
308
+ defined and the value of ``num_qubits`` differs from the length of
309
+ ``qubit_properties``.
310
+ """
311
+ if description is not None:
312
+ description = str(description)
313
+ return super(Target, cls).__new__( # pylint: disable=too-many-function-args
314
+ cls,
315
+ description,
316
+ num_qubits,
317
+ dt,
318
+ granularity,
319
+ min_length,
320
+ pulse_alignment,
321
+ acquire_alignment,
322
+ qubit_properties,
323
+ concurrent_measurements,
324
+ )
325
+
326
+ def __init__(
327
+ self,
328
+ description=None, # pylint: disable=unused-argument
329
+ num_qubits=0, # pylint: disable=unused-argument
330
+ dt=None, # pylint: disable=unused-argument
331
+ granularity=1, # pylint: disable=unused-argument
332
+ min_length=1, # pylint: disable=unused-argument
333
+ pulse_alignment=1, # pylint: disable=unused-argument
334
+ acquire_alignment=1, # pylint: disable=unused-argument
335
+ qubit_properties=None, # pylint: disable=unused-argument
336
+ concurrent_measurements=None, # pylint: disable=unused-argument
337
+ ):
338
+ # A nested mapping of gate name -> qargs -> properties
339
+ self._gate_map = {}
340
+ self._coupling_graph = None
341
+ self._instruction_durations = None
342
+ self._instruction_schedule_map = None
343
+
344
+ def add_instruction(self, instruction, properties=None, name=None):
345
+ """Add a new instruction to the :class:`~qiskit.transpiler.Target`
346
+
347
+ As ``Target`` objects are strictly additive this is the primary method
348
+ for modifying a ``Target``. Typically, you will use this to fully populate
349
+ a ``Target`` before using it in :class:`~qiskit.providers.BackendV2`. For
350
+ example::
351
+
352
+ from qiskit.circuit.library import CXGate
353
+ from qiskit.transpiler import Target, InstructionProperties
354
+
355
+ target = Target()
356
+ cx_properties = {
357
+ (0, 1): None,
358
+ (1, 0): None,
359
+ (0, 2): None,
360
+ (2, 0): None,
361
+ (0, 3): None,
362
+ (2, 3): None,
363
+ (3, 0): None,
364
+ (3, 2): None
365
+ }
366
+ target.add_instruction(CXGate(), cx_properties)
367
+
368
+ Will add a :class:`~qiskit.circuit.library.CXGate` to the target with no
369
+ properties (duration, error, etc) with the coupling edge list:
370
+ ``(0, 1), (1, 0), (0, 2), (2, 0), (0, 3), (2, 3), (3, 0), (3, 2)``. If
371
+ there are properties available for the instruction you can replace the
372
+ ``None`` value in the properties dictionary with an
373
+ :class:`~qiskit.transpiler.InstructionProperties` object. This pattern
374
+ is repeated for each :class:`~qiskit.circuit.Instruction` the target
375
+ supports.
376
+
377
+ Args:
378
+ instruction (Union[qiskit.circuit.Instruction, Type[qiskit.circuit.Instruction]]):
379
+ The operation object to add to the map. If it's parameterized any value
380
+ of the parameter can be set. Optionally for variable width
381
+ instructions (such as control flow operations such as :class:`~.ForLoop` or
382
+ :class:`~MCXGate`) you can specify the class. If the class is specified than the
383
+ ``name`` argument must be specified. When a class is used the gate is treated as global
384
+ and not having any properties set.
385
+ properties (dict): A dictionary of qarg entries to an
386
+ :class:`~qiskit.transpiler.InstructionProperties` object for that
387
+ instruction implementation on the backend. Properties are optional
388
+ for any instruction implementation, if there are no
389
+ :class:`~qiskit.transpiler.InstructionProperties` available for the
390
+ backend the value can be None. If there are no constraints on the
391
+ instruction (as in a noiseless/ideal simulation) this can be set to
392
+ ``{None, None}`` which will indicate it runs on all qubits (or all
393
+ available permutations of qubits for multi-qubit gates). The first
394
+ ``None`` indicates it applies to all qubits and the second ``None``
395
+ indicates there are no
396
+ :class:`~qiskit.transpiler.InstructionProperties` for the
397
+ instruction. By default, if properties is not set it is equivalent to
398
+ passing ``{None: None}``.
399
+ name (str): An optional name to use for identifying the instruction. If not
400
+ specified the :attr:`~qiskit.circuit.Instruction.name` attribute
401
+ of ``gate`` will be used. All gates in the ``Target`` need unique
402
+ names. Backends can differentiate between different
403
+ parameterization of a single gate by providing a unique name for
404
+ each (e.g. `"rx30"`, `"rx60", ``"rx90"`` similar to the example in the
405
+ documentation for the :class:`~qiskit.transpiler.Target` class).
406
+ Raises:
407
+ AttributeError: If gate is already in map
408
+ TranspilerError: If an operation class is passed in for ``instruction`` and no name
409
+ is specified or ``properties`` is set.
410
+ """
411
+ is_class = inspect.isclass(instruction)
412
+ if not is_class:
413
+ instruction_name = name or instruction.name
414
+ else:
415
+ # Invalid to have class input without a name with characters set "" is not a valid name
416
+ if not name:
417
+ raise TranspilerError(
418
+ "A name must be specified when defining a supported global operation by class"
419
+ )
420
+ if properties is not None:
421
+ raise TranspilerError(
422
+ "An instruction added globally by class can't have properties set."
423
+ )
424
+ instruction_name = name
425
+ if properties is None or is_class:
426
+ properties = {None: None}
427
+ if instruction_name in self._gate_map:
428
+ raise AttributeError(f"Instruction {instruction_name} is already in the target")
429
+ super().add_instruction(instruction, instruction_name, properties)
430
+ self._gate_map[instruction_name] = properties
431
+ self._coupling_graph = None
432
+ self._instruction_durations = None
433
+ self._instruction_schedule_map = None
434
+
435
+ def update_instruction_properties(self, instruction, qargs, properties):
436
+ """Update the property object for an instruction qarg pair already in the Target
437
+
438
+ Args:
439
+ instruction (str): The instruction name to update
440
+ qargs (tuple): The qargs to update the properties of
441
+ properties (InstructionProperties): The properties to set for this instruction
442
+ Raises:
443
+ KeyError: If ``instruction`` or ``qarg`` are not in the target
444
+ """
445
+ super().update_instruction_properties(instruction, qargs, properties)
446
+ self._gate_map[instruction][qargs] = properties
447
+ self._instruction_durations = None
448
+ self._instruction_schedule_map = None
449
+
450
+ def update_from_instruction_schedule_map(self, inst_map, inst_name_map=None, error_dict=None):
451
+ """Update the target from an instruction schedule map.
452
+
453
+ If the input instruction schedule map contains new instructions not in
454
+ the target they will be added. However, if it contains additional qargs
455
+ for an existing instruction in the target it will error.
456
+
457
+ Args:
458
+ inst_map (InstructionScheduleMap): The instruction
459
+ inst_name_map (dict): An optional dictionary that maps any
460
+ instruction name in ``inst_map`` to an instruction object.
461
+ If not provided, instruction is pulled from the standard Qiskit gates,
462
+ and finally custom gate instance is created with schedule name.
463
+ error_dict (dict): A dictionary of errors of the form::
464
+
465
+ {gate_name: {qarg: error}}
466
+
467
+ for example::
468
+
469
+ {'rx': {(0, ): 1.4e-4, (1, ): 1.2e-4}}
470
+
471
+ For each entry in the ``inst_map`` if ``error_dict`` is defined
472
+ a when updating the ``Target`` the error value will be pulled from
473
+ this dictionary. If one is not found in ``error_dict`` then
474
+ ``None`` will be used.
475
+ """
476
+ get_calibration = getattr(inst_map, "_get_calibration_entry")
477
+
478
+ # Expand name mapping with custom gate name provided by user.
479
+ qiskit_inst_name_map = get_standard_gate_name_mapping()
480
+ if inst_name_map is not None:
481
+ qiskit_inst_name_map.update(inst_name_map)
482
+
483
+ for inst_name in inst_map.instructions:
484
+ # Prepare dictionary of instruction properties
485
+ out_props = {}
486
+ for qargs in inst_map.qubits_with_instruction(inst_name):
487
+ try:
488
+ qargs = tuple(qargs)
489
+ except TypeError:
490
+ qargs = (qargs,)
491
+ try:
492
+ props = self._gate_map[inst_name][qargs]
493
+ except (KeyError, TypeError):
494
+ props = None
495
+
496
+ entry = get_calibration(inst_name, qargs)
497
+ if entry.user_provided and getattr(props, "_calibration", None) != entry:
498
+ # It only copies user-provided calibration from the inst map.
499
+ # Backend defined entry must already exist in Target.
500
+ if self.dt is not None:
501
+ try:
502
+ duration = entry.get_schedule().duration * self.dt
503
+ except UnassignedDurationError:
504
+ # duration of schedule is parameterized
505
+ duration = None
506
+ else:
507
+ duration = None
508
+ props = InstructionProperties(
509
+ duration=duration,
510
+ calibration=entry,
511
+ )
512
+ else:
513
+ if props is None:
514
+ # Edge case. Calibration is backend defined, but this is not
515
+ # registered in the backend target. Ignore this entry.
516
+ continue
517
+ try:
518
+ # Update gate error if provided.
519
+ props.error = error_dict[inst_name][qargs]
520
+ except (KeyError, TypeError):
521
+ pass
522
+ out_props[qargs] = props
523
+ if not out_props:
524
+ continue
525
+ # Prepare Qiskit Gate object assigned to the entries
526
+ if inst_name not in self._gate_map:
527
+ # Entry not found: Add new instruction
528
+ if inst_name in qiskit_inst_name_map:
529
+ # Remove qargs with length that doesn't match with instruction qubit number
530
+ inst_obj = qiskit_inst_name_map[inst_name]
531
+ normalized_props = {}
532
+ for qargs, prop in out_props.items():
533
+ if len(qargs) != inst_obj.num_qubits:
534
+ continue
535
+ normalized_props[qargs] = prop
536
+ self.add_instruction(inst_obj, normalized_props, name=inst_name)
537
+ else:
538
+ # Check qubit length parameter name uniformity.
539
+ qlen = set()
540
+ param_names = set()
541
+ for qargs in inst_map.qubits_with_instruction(inst_name):
542
+ if isinstance(qargs, int):
543
+ qargs = (qargs,)
544
+ qlen.add(len(qargs))
545
+ cal = getattr(out_props[tuple(qargs)], "_calibration")
546
+ param_names.add(tuple(cal.get_signature().parameters.keys()))
547
+ if len(qlen) > 1 or len(param_names) > 1:
548
+ raise QiskitError(
549
+ f"Schedules for {inst_name} are defined non-uniformly for "
550
+ f"multiple qubit lengths {qlen}, "
551
+ f"or different parameter names {param_names}. "
552
+ "Provide these schedules with inst_name_map or define them with "
553
+ "different names for different gate parameters."
554
+ )
555
+ inst_obj = Gate(
556
+ name=inst_name,
557
+ num_qubits=next(iter(qlen)),
558
+ params=list(map(Parameter, next(iter(param_names)))),
559
+ )
560
+ self.add_instruction(inst_obj, out_props, name=inst_name)
561
+ else:
562
+ # Entry found: Update "existing" instructions.
563
+ for qargs, prop in out_props.items():
564
+ if qargs not in self._gate_map[inst_name]:
565
+ continue
566
+ self.update_instruction_properties(inst_name, qargs, prop)
567
+
568
+ def qargs_for_operation_name(self, operation):
569
+ """Get the qargs for a given operation name
570
+
571
+ Args:
572
+ operation (str): The operation name to get qargs for
573
+ Returns:
574
+ set: The set of qargs the gate instance applies to.
575
+ """
576
+ if None in self._gate_map[operation]:
577
+ return None
578
+ return self._gate_map[operation].keys()
579
+
580
+ def durations(self):
581
+ """Get an InstructionDurations object from the target
582
+
583
+ Returns:
584
+ InstructionDurations: The instruction duration represented in the
585
+ target
586
+ """
587
+ if self._instruction_durations is not None:
588
+ return self._instruction_durations
589
+ out_durations = []
590
+ for instruction, props_map in self._gate_map.items():
591
+ for qarg, properties in props_map.items():
592
+ if properties is not None and properties.duration is not None:
593
+ out_durations.append((instruction, list(qarg), properties.duration, "s"))
594
+ self._instruction_durations = InstructionDurations(out_durations, dt=self.dt)
595
+ return self._instruction_durations
596
+
597
+ def timing_constraints(self):
598
+ """Get an :class:`~qiskit.transpiler.TimingConstraints` object from the target
599
+
600
+ Returns:
601
+ TimingConstraints: The timing constraints represented in the ``Target``
602
+ """
603
+ return TimingConstraints(
604
+ self.granularity, self.min_length, self.pulse_alignment, self.acquire_alignment
605
+ )
606
+
607
+ def instruction_schedule_map(self):
608
+ """Return an :class:`~qiskit.pulse.InstructionScheduleMap` for the
609
+ instructions in the target with a pulse schedule defined.
610
+
611
+ Returns:
612
+ InstructionScheduleMap: The instruction schedule map for the
613
+ instructions in this target with a pulse schedule defined.
614
+ """
615
+ if self._instruction_schedule_map is not None:
616
+ return self._instruction_schedule_map
617
+ out_inst_schedule_map = InstructionScheduleMap()
618
+ for instruction, qargs in self._gate_map.items():
619
+ for qarg, properties in qargs.items():
620
+ # Directly getting CalibrationEntry not to invoke .get_schedule().
621
+ # This keeps PulseQobjDef un-parsed.
622
+ cal_entry = getattr(properties, "_calibration", None)
623
+ if cal_entry is not None:
624
+ # Use fast-path to add entries to the inst map.
625
+ out_inst_schedule_map._add(instruction, qarg, cal_entry)
626
+ self._instruction_schedule_map = out_inst_schedule_map
627
+ return out_inst_schedule_map
628
+
629
+ def has_calibration(
630
+ self,
631
+ operation_name: str,
632
+ qargs: tuple[int, ...],
633
+ ) -> bool:
634
+ """Return whether the instruction (operation + qubits) defines a calibration.
635
+
636
+ Args:
637
+ operation_name: The name of the operation for the instruction.
638
+ qargs: The tuple of qubit indices for the instruction.
639
+
640
+ Returns:
641
+ Returns ``True`` if the calibration is supported and ``False`` if it isn't.
642
+ """
643
+ qargs = tuple(qargs)
644
+ if operation_name not in self._gate_map:
645
+ return False
646
+ if qargs not in self._gate_map[operation_name]:
647
+ return False
648
+ return getattr(self._gate_map[operation_name][qargs], "_calibration", None) is not None
649
+
650
+ def get_calibration(
651
+ self,
652
+ operation_name: str,
653
+ qargs: tuple[int, ...],
654
+ *args: ParameterValueType,
655
+ **kwargs: ParameterValueType,
656
+ ) -> Schedule | ScheduleBlock:
657
+ """Get calibrated pulse schedule for the instruction.
658
+
659
+ If calibration is templated with parameters, one can also provide those values
660
+ to build a schedule with assigned parameters.
661
+
662
+ Args:
663
+ operation_name: The name of the operation for the instruction.
664
+ qargs: The tuple of qubit indices for the instruction.
665
+ args: Parameter values to build schedule if any.
666
+ kwargs: Parameter values with name to build schedule if any.
667
+
668
+ Returns:
669
+ Calibrated pulse schedule of corresponding instruction.
670
+ """
671
+ if not self.has_calibration(operation_name, qargs):
672
+ raise KeyError(
673
+ f"Calibration of instruction {operation_name} for qubit {qargs} is not defined."
674
+ )
675
+ cal_entry = getattr(self._gate_map[operation_name][qargs], "_calibration")
676
+ return cal_entry.get_schedule(*args, **kwargs)
677
+
678
+ @property
679
+ def operation_names(self):
680
+ """Get the operation names in the target."""
681
+ return self._gate_map.keys()
682
+
683
+ @property
684
+ def instructions(self):
685
+ """Get the list of tuples ``(:class:`~qiskit.circuit.Instruction`, (qargs))``
686
+ for the target
687
+
688
+ For globally defined variable width operations the tuple will be of the form
689
+ ``(class, None)`` where class is the actual operation class that
690
+ is globally defined.
691
+ """
692
+ return [
693
+ (self._gate_name_map[op], qarg)
694
+ for op, qargs in self._gate_map.items()
695
+ for qarg in qargs
696
+ ]
697
+
698
+ def instruction_properties(self, index):
699
+ """Get the instruction properties for a specific instruction tuple
700
+
701
+ This method is to be used in conjunction with the
702
+ :attr:`~qiskit.transpiler.Target.instructions` attribute of a
703
+ :class:`~qiskit.transpiler.Target` object. You can use this method to quickly
704
+ get the instruction properties for an element of
705
+ :attr:`~qiskit.transpiler.Target.instructions` by using the index in that list.
706
+ However, if you're not working with :attr:`~qiskit.transpiler.Target.instructions`
707
+ directly it is likely more efficient to access the target directly via the name
708
+ and qubits to get the instruction properties. For example, if
709
+ :attr:`~qiskit.transpiler.Target.instructions` returned::
710
+
711
+ [(XGate(), (0,)), (XGate(), (1,))]
712
+
713
+ you could get the properties of the ``XGate`` on qubit 1 with::
714
+
715
+ props = target.instruction_properties(1)
716
+
717
+ but just accessing it directly via the name would be more efficient::
718
+
719
+ props = target['x'][(1,)]
720
+
721
+ (assuming the ``XGate``'s canonical name in the target is ``'x'``)
722
+ This is especially true for larger targets as this will scale worse with the number
723
+ of instruction tuples in a target.
724
+
725
+ Args:
726
+ index (int): The index of the instruction tuple from the
727
+ :attr:`~qiskit.transpiler.Target.instructions` attribute. For, example
728
+ if you want the properties from the third element in
729
+ :attr:`~qiskit.transpiler.Target.instructions` you would set this to be ``2``.
730
+ Returns:
731
+ InstructionProperties: The instruction properties for the specified instruction tuple
732
+ """
733
+ instruction_properties = [
734
+ inst_props for qargs in self._gate_map.values() for inst_props in qargs.values()
735
+ ]
736
+ return instruction_properties[index]
737
+
738
+ def _build_coupling_graph(self):
739
+ self._coupling_graph = rx.PyDiGraph(multigraph=False)
740
+ if self.num_qubits is not None:
741
+ self._coupling_graph.add_nodes_from([{} for _ in range(self.num_qubits)])
742
+ for gate, qarg_map in self._gate_map.items():
743
+ if qarg_map is None:
744
+ if self._gate_name_map[gate].num_qubits == 2:
745
+ self._coupling_graph = None # pylint: disable=attribute-defined-outside-init
746
+ return
747
+ continue
748
+ for qarg, properties in qarg_map.items():
749
+ if qarg is None:
750
+ if self.operation_from_name(gate).num_qubits == 2:
751
+ self._coupling_graph = None
752
+ return
753
+ continue
754
+ if len(qarg) == 1:
755
+ self._coupling_graph[qarg[0]] = (
756
+ properties # pylint: disable=attribute-defined-outside-init
757
+ )
758
+ elif len(qarg) == 2:
759
+ try:
760
+ edge_data = self._coupling_graph.get_edge_data(*qarg)
761
+ edge_data[gate] = properties
762
+ except rx.NoEdgeBetweenNodes:
763
+ self._coupling_graph.add_edge(*qarg, {gate: properties})
764
+ qargs = self.qargs
765
+ if self._coupling_graph.num_edges() == 0 and (
766
+ qargs is None or any(x is None for x in qargs)
767
+ ):
768
+ self._coupling_graph = None # pylint: disable=attribute-defined-outside-init
769
+
770
+ def build_coupling_map(self, two_q_gate=None, filter_idle_qubits=False):
771
+ """Get a :class:`~qiskit.transpiler.CouplingMap` from this target.
772
+
773
+ If there is a mix of two qubit operations that have a connectivity
774
+ constraint and those that are globally defined this will also return
775
+ ``None`` because the globally connectivity means there is no constraint
776
+ on the target. If you wish to see the constraints of the two qubit
777
+ operations that have constraints you should use the ``two_q_gate``
778
+ argument to limit the output to the gates which have a constraint.
779
+
780
+ Args:
781
+ two_q_gate (str): An optional gate name for a two qubit gate in
782
+ the ``Target`` to generate the coupling map for. If specified the
783
+ output coupling map will only have edges between qubits where
784
+ this gate is present.
785
+ filter_idle_qubits (bool): If set to ``True`` the output :class:`~.CouplingMap`
786
+ will remove any qubits that don't have any operations defined in the
787
+ target. Note that using this argument will result in an output
788
+ :class:`~.CouplingMap` object which has holes in its indices
789
+ which might differ from the assumptions of the class. The typical use
790
+ case of this argument is to be paired with
791
+ :meth:`.CouplingMap.connected_components` which will handle the holes
792
+ as expected.
793
+ Returns:
794
+ CouplingMap: The :class:`~qiskit.transpiler.CouplingMap` object
795
+ for this target. If there are no connectivity constraints in
796
+ the target this will return ``None``.
797
+
798
+ Raises:
799
+ ValueError: If a non-two qubit gate is passed in for ``two_q_gate``.
800
+ IndexError: If an Instruction not in the ``Target`` is passed in for
801
+ ``two_q_gate``.
802
+ """
803
+ if self.qargs is None:
804
+ return None
805
+ if None not in self.qargs and any(len(x) > 2 for x in self.qargs):
806
+ logger.warning(
807
+ "This Target object contains multiqubit gates that "
808
+ "operate on > 2 qubits. This will not be reflected in "
809
+ "the output coupling map."
810
+ )
811
+
812
+ if two_q_gate is not None:
813
+ coupling_graph = rx.PyDiGraph(multigraph=False)
814
+ coupling_graph.add_nodes_from([None] * self.num_qubits)
815
+ for qargs, properties in self[two_q_gate].items():
816
+ if len(qargs) != 2:
817
+ raise ValueError(
818
+ f"Specified two_q_gate: {two_q_gate} is not a 2 qubit instruction"
819
+ )
820
+ coupling_graph.add_edge(*qargs, {two_q_gate: properties})
821
+ cmap = CouplingMap()
822
+ cmap.graph = coupling_graph
823
+ return cmap
824
+ if self._coupling_graph is None:
825
+ self._build_coupling_graph()
826
+ # if there is no connectivity constraints in the coupling graph treat it as not
827
+ # existing and return
828
+ if self._coupling_graph is not None:
829
+ cmap = CouplingMap()
830
+ if filter_idle_qubits:
831
+ cmap.graph = self._filter_coupling_graph()
832
+ else:
833
+ cmap.graph = self._coupling_graph.copy()
834
+ return cmap
835
+ else:
836
+ return None
837
+
838
+ def _filter_coupling_graph(self):
839
+ has_operations = set(itertools.chain.from_iterable(x for x in self.qargs if x is not None))
840
+ graph = self._coupling_graph.copy()
841
+ to_remove = set(graph.node_indices()).difference(has_operations)
842
+ if to_remove:
843
+ graph.remove_nodes_from(list(to_remove))
844
+ return graph
845
+
846
+ def __iter__(self):
847
+ return iter(self._gate_map)
848
+
849
+ def __getitem__(self, key):
850
+ return self._gate_map[key]
851
+
852
+ def get(self, key, default=None):
853
+ """Gets an item from the Target. If not found return a provided default or `None`."""
854
+ try:
855
+ return self[key]
856
+ except KeyError:
857
+ return default
858
+
859
+ def __len__(self):
860
+ return len(self._gate_map)
861
+
862
+ def __contains__(self, item):
863
+ return item in self._gate_map
864
+
865
+ def keys(self):
866
+ """Return the keys (operation_names) of the Target"""
867
+ return self._gate_map.keys()
868
+
869
+ def values(self):
870
+ """Return the Property Map (qargs -> InstructionProperties) of every instruction in the Target"""
871
+ return self._gate_map.values()
872
+
873
+ def items(self):
874
+ """Returns pairs of Gate names and its property map (str, dict[tuple, InstructionProperties])"""
875
+ return self._gate_map.items()
876
+
877
+ def __str__(self):
878
+ output = io.StringIO()
879
+ if self.description is not None:
880
+ output.write(f"Target: {self.description}\n")
881
+ else:
882
+ output.write("Target\n")
883
+ output.write(f"Number of qubits: {self.num_qubits}\n")
884
+ output.write("Instructions:\n")
885
+ for inst, qarg_props in self._gate_map.items():
886
+ output.write(f"\t{inst}\n")
887
+ for qarg, props in qarg_props.items():
888
+ if qarg is None:
889
+ continue
890
+ if props is None:
891
+ output.write(f"\t\t{qarg}\n")
892
+ continue
893
+ prop_str_pieces = [f"\t\t{qarg}:\n"]
894
+ duration = getattr(props, "duration", None)
895
+ if duration is not None:
896
+ prop_str_pieces.append(f"\t\t\tDuration: {duration:g} sec.\n")
897
+ error = getattr(props, "error", None)
898
+ if error is not None:
899
+ prop_str_pieces.append(f"\t\t\tError Rate: {error:g}\n")
900
+ schedule = getattr(props, "_calibration", None)
901
+ if schedule is not None:
902
+ prop_str_pieces.append("\t\t\tWith pulse schedule calibration\n")
903
+ extra_props = getattr(props, "properties", None)
904
+ if extra_props is not None:
905
+ extra_props_pieces = [
906
+ f"\t\t\t\t{key}: {value}\n" for key, value in extra_props.items()
907
+ ]
908
+ extra_props_str = "".join(extra_props_pieces)
909
+ prop_str_pieces.append(f"\t\t\tExtra properties:\n{extra_props_str}\n")
910
+ output.write("".join(prop_str_pieces))
911
+ return output.getvalue()
912
+
913
+ def __getstate__(self) -> dict:
914
+ return {
915
+ "_gate_map": self._gate_map,
916
+ "coupling_graph": self._coupling_graph,
917
+ "instruction_durations": self._instruction_durations,
918
+ "instruction_schedule_map": self._instruction_schedule_map,
919
+ "base": super().__getstate__(),
920
+ }
921
+
922
+ def __setstate__(self, state: tuple):
923
+ self._gate_map = state["_gate_map"]
924
+ self._coupling_graph = state["coupling_graph"]
925
+ self._instruction_durations = state["instruction_durations"]
926
+ self._instruction_schedule_map = state["instruction_schedule_map"]
927
+ super().__setstate__(state["base"])
928
+
929
+ @classmethod
930
+ def from_configuration(
931
+ cls,
932
+ basis_gates: list[str],
933
+ num_qubits: int | None = None,
934
+ coupling_map: CouplingMap | None = None,
935
+ inst_map: InstructionScheduleMap | None = None,
936
+ backend_properties: BackendProperties | None = None,
937
+ instruction_durations: InstructionDurations | None = None,
938
+ concurrent_measurements: Optional[List[List[int]]] = None,
939
+ dt: float | None = None,
940
+ timing_constraints: TimingConstraints | None = None,
941
+ custom_name_mapping: dict[str, Any] | None = None,
942
+ ) -> Target:
943
+ """Create a target object from the individual global configuration
944
+
945
+ Prior to the creation of the :class:`~.Target` class, the constraints
946
+ of a backend were represented by a collection of different objects
947
+ which combined represent a subset of the information contained in
948
+ the :class:`~.Target`. This function provides a simple interface
949
+ to convert those separate objects to a :class:`~.Target`.
950
+
951
+ This constructor will use the input from ``basis_gates``, ``num_qubits``,
952
+ and ``coupling_map`` to build a base model of the backend and the
953
+ ``instruction_durations``, ``backend_properties``, and ``inst_map`` inputs
954
+ are then queried (in that order) based on that model to look up the properties
955
+ of each instruction and qubit. If there is an inconsistency between the inputs
956
+ any extra or conflicting information present in ``instruction_durations``,
957
+ ``backend_properties``, or ``inst_map`` will be ignored.
958
+
959
+ Args:
960
+ basis_gates: The list of basis gate names for the backend. For the
961
+ target to be created these names must either be in the output
962
+ from :func:`~.get_standard_gate_name_mapping` or present in the
963
+ specified ``custom_name_mapping`` argument.
964
+ num_qubits: The number of qubits supported on the backend.
965
+ coupling_map: The coupling map representing connectivity constraints
966
+ on the backend. If specified all gates from ``basis_gates`` will
967
+ be supported on all qubits (or pairs of qubits).
968
+ inst_map: The instruction schedule map representing the pulse
969
+ :class:`~.Schedule` definitions for each instruction. If this
970
+ is specified ``coupling_map`` must be specified. The
971
+ ``coupling_map`` is used as the source of truth for connectivity
972
+ and if ``inst_map`` is used the schedule is looked up based
973
+ on the instructions from the pair of ``basis_gates`` and
974
+ ``coupling_map``. If you want to define a custom gate for
975
+ a particular qubit or qubit pair, you can manually build :class:`.Target`.
976
+ backend_properties: The :class:`~.BackendProperties` object which is
977
+ used for instruction properties and qubit properties.
978
+ If specified and instruction properties are intended to be used
979
+ then the ``coupling_map`` argument must be specified. This is
980
+ only used to lookup error rates and durations (unless
981
+ ``instruction_durations`` is specified which would take
982
+ precedence) for instructions specified via ``coupling_map`` and
983
+ ``basis_gates``.
984
+ instruction_durations: Optional instruction durations for instructions. If specified
985
+ it will take priority for setting the ``duration`` field in the
986
+ :class:`~InstructionProperties` objects for the instructions in the target.
987
+ concurrent_measurements(list): A list of sets of qubits that must be
988
+ measured together. This must be provided
989
+ as a nested list like ``[[0, 1], [2, 3, 4]]``.
990
+ dt: The system time resolution of input signals in seconds
991
+ timing_constraints: Optional timing constraints to include in the
992
+ :class:`~.Target`
993
+ custom_name_mapping: An optional dictionary that maps custom gate/operation names in
994
+ ``basis_gates`` to an :class:`~.Operation` object representing that
995
+ gate/operation. By default, most standard gates names are mapped to the
996
+ standard gate object from :mod:`qiskit.circuit.library` this only needs
997
+ to be specified if the input ``basis_gates`` defines gates in names outside
998
+ that set.
999
+
1000
+ Returns:
1001
+ Target: the target built from the input configuration
1002
+
1003
+ Raises:
1004
+ TranspilerError: If the input basis gates contain > 2 qubits and ``coupling_map`` is
1005
+ specified.
1006
+ KeyError: If no mapping is available for a specified ``basis_gate``.
1007
+ """
1008
+ granularity = 1
1009
+ min_length = 1
1010
+ pulse_alignment = 1
1011
+ acquire_alignment = 1
1012
+ if timing_constraints is not None:
1013
+ granularity = timing_constraints.granularity
1014
+ min_length = timing_constraints.min_length
1015
+ pulse_alignment = timing_constraints.pulse_alignment
1016
+ acquire_alignment = timing_constraints.acquire_alignment
1017
+
1018
+ qubit_properties = None
1019
+ if backend_properties is not None:
1020
+ # pylint: disable=cyclic-import
1021
+ from qiskit.providers.backend_compat import qubit_props_list_from_props
1022
+
1023
+ qubit_properties = qubit_props_list_from_props(properties=backend_properties)
1024
+
1025
+ target = cls(
1026
+ num_qubits=num_qubits,
1027
+ dt=dt,
1028
+ granularity=granularity,
1029
+ min_length=min_length,
1030
+ pulse_alignment=pulse_alignment,
1031
+ acquire_alignment=acquire_alignment,
1032
+ qubit_properties=qubit_properties,
1033
+ concurrent_measurements=concurrent_measurements,
1034
+ )
1035
+ name_mapping = get_standard_gate_name_mapping()
1036
+ if custom_name_mapping is not None:
1037
+ name_mapping.update(custom_name_mapping)
1038
+
1039
+ # While BackendProperties can also contain coupling information we
1040
+ # rely solely on CouplingMap to determine connectivity. This is because
1041
+ # in legacy transpiler usage (and implicitly in the BackendV1 data model)
1042
+ # the coupling map is used to define connectivity constraints and
1043
+ # the properties is only used for error rate and duration population.
1044
+ # If coupling map is not specified we ignore the backend_properties
1045
+ if coupling_map is None:
1046
+ for gate in basis_gates:
1047
+ if gate not in name_mapping:
1048
+ raise KeyError(
1049
+ f"The specified basis gate: {gate} is not present in the standard gate "
1050
+ "names or a provided custom_name_mapping"
1051
+ )
1052
+ target.add_instruction(name_mapping[gate], name=gate)
1053
+ else:
1054
+ one_qubit_gates = []
1055
+ two_qubit_gates = []
1056
+ global_ideal_variable_width_gates = [] # pylint: disable=invalid-name
1057
+ if num_qubits is None:
1058
+ num_qubits = len(coupling_map.graph)
1059
+ for gate in basis_gates:
1060
+ if gate not in name_mapping:
1061
+ raise KeyError(
1062
+ f"The specified basis gate: {gate} is not present in the standard gate "
1063
+ "names or a provided custom_name_mapping"
1064
+ )
1065
+ gate_obj = name_mapping[gate]
1066
+ if gate_obj.num_qubits == 1:
1067
+ one_qubit_gates.append(gate)
1068
+ elif gate_obj.num_qubits == 2:
1069
+ two_qubit_gates.append(gate)
1070
+ elif inspect.isclass(gate_obj):
1071
+ global_ideal_variable_width_gates.append(gate)
1072
+ else:
1073
+ raise TranspilerError(
1074
+ f"The specified basis gate: {gate} has {gate_obj.num_qubits} "
1075
+ "qubits. This constructor method only supports fixed width operations "
1076
+ "with <= 2 qubits (because connectivity is defined on a CouplingMap)."
1077
+ )
1078
+ for gate in one_qubit_gates:
1079
+ gate_properties: dict[tuple, InstructionProperties] = {}
1080
+ for qubit in range(num_qubits):
1081
+ error = None
1082
+ duration = None
1083
+ calibration = None
1084
+ if backend_properties is not None:
1085
+ if duration is None:
1086
+ try:
1087
+ duration = backend_properties.gate_length(gate, qubit)
1088
+ except BackendPropertyError:
1089
+ duration = None
1090
+ try:
1091
+ error = backend_properties.gate_error(gate, qubit)
1092
+ except BackendPropertyError:
1093
+ error = None
1094
+ if inst_map is not None:
1095
+ try:
1096
+ calibration = inst_map._get_calibration_entry(gate, qubit)
1097
+ # If we have dt defined and there is a custom calibration which is user
1098
+ # generate use that custom pulse schedule for the duration. If it is
1099
+ # not user generated than we assume it's the same duration as what is
1100
+ # defined in the backend properties
1101
+ if dt and calibration.user_provided:
1102
+ duration = calibration.get_schedule().duration * dt
1103
+ except PulseError:
1104
+ calibration = None
1105
+ # Durations if specified manually should override model objects
1106
+ if instruction_durations is not None:
1107
+ try:
1108
+ duration = instruction_durations.get(gate, qubit, unit="s")
1109
+ except TranspilerError:
1110
+ duration = None
1111
+
1112
+ if error is None and duration is None and calibration is None:
1113
+ gate_properties[(qubit,)] = None
1114
+ else:
1115
+ gate_properties[(qubit,)] = InstructionProperties(
1116
+ duration=duration, error=error, calibration=calibration
1117
+ )
1118
+ target.add_instruction(name_mapping[gate], properties=gate_properties, name=gate)
1119
+ edges = list(coupling_map.get_edges())
1120
+ for gate in two_qubit_gates:
1121
+ gate_properties = {}
1122
+ for edge in edges:
1123
+ error = None
1124
+ duration = None
1125
+ calibration = None
1126
+ if backend_properties is not None:
1127
+ if duration is None:
1128
+ try:
1129
+ duration = backend_properties.gate_length(gate, edge)
1130
+ except BackendPropertyError:
1131
+ duration = None
1132
+ try:
1133
+ error = backend_properties.gate_error(gate, edge)
1134
+ except BackendPropertyError:
1135
+ error = None
1136
+ if inst_map is not None:
1137
+ try:
1138
+ calibration = inst_map._get_calibration_entry(gate, edge)
1139
+ # If we have dt defined and there is a custom calibration which is user
1140
+ # generate use that custom pulse schedule for the duration. If it is
1141
+ # not user generated than we assume it's the same duration as what is
1142
+ # defined in the backend properties
1143
+ if dt and calibration.user_provided:
1144
+ duration = calibration.get_schedule().duration * dt
1145
+ except PulseError:
1146
+ calibration = None
1147
+ # Durations if specified manually should override model objects
1148
+ if instruction_durations is not None:
1149
+ try:
1150
+ duration = instruction_durations.get(gate, edge, unit="s")
1151
+ except TranspilerError:
1152
+ duration = None
1153
+
1154
+ if error is None and duration is None and calibration is None:
1155
+ gate_properties[edge] = None
1156
+ else:
1157
+ gate_properties[edge] = InstructionProperties(
1158
+ duration=duration, error=error, calibration=calibration
1159
+ )
1160
+ target.add_instruction(name_mapping[gate], properties=gate_properties, name=gate)
1161
+ for gate in global_ideal_variable_width_gates:
1162
+ target.add_instruction(name_mapping[gate], name=gate)
1163
+ return target
1164
+
1165
+
1166
+ Mapping.register(Target)
1167
+
1168
+
1169
+ @deprecate_func(
1170
+ since="1.2",
1171
+ removal_timeline="in the 2.0 release",
1172
+ additional_msg="This method is used to build an element from the deprecated "
1173
+ "``qiskit.providers.models`` module. These models are part of the deprecated `BackendV1` "
1174
+ "workflow and no longer necessary for `BackendV2`. If a user workflow requires these "
1175
+ "representations it likely relies on deprecated functionality and "
1176
+ "should be updated to use `BackendV2`.",
1177
+ )
1178
+ def target_to_backend_properties(target: Target):
1179
+ """Convert a :class:`~.Target` object into a legacy :class:`~.BackendProperties`"""
1180
+
1181
+ properties_dict: dict[str, Any] = {
1182
+ "backend_name": "",
1183
+ "backend_version": "",
1184
+ "last_update_date": None,
1185
+ "general": [],
1186
+ }
1187
+ gates = []
1188
+ qubits = []
1189
+ for gate, qargs_list in target.items():
1190
+ if gate != "measure":
1191
+ for qargs, props in qargs_list.items():
1192
+ property_list = []
1193
+ if getattr(props, "duration", None) is not None:
1194
+ property_list.append(
1195
+ {
1196
+ "date": datetime.datetime.now(datetime.timezone.utc),
1197
+ "name": "gate_length",
1198
+ "unit": "s",
1199
+ "value": props.duration,
1200
+ }
1201
+ )
1202
+ if getattr(props, "error", None) is not None:
1203
+ property_list.append(
1204
+ {
1205
+ "date": datetime.datetime.now(datetime.timezone.utc),
1206
+ "name": "gate_error",
1207
+ "unit": "",
1208
+ "value": props.error,
1209
+ }
1210
+ )
1211
+ if property_list:
1212
+ gates.append(
1213
+ {
1214
+ "gate": gate,
1215
+ "qubits": list(qargs),
1216
+ "parameters": property_list,
1217
+ "name": gate + "_".join([str(x) for x in qargs]),
1218
+ }
1219
+ )
1220
+ else:
1221
+ qubit_props: dict[int, Any] = {}
1222
+ if target.num_qubits is not None:
1223
+ qubit_props = {x: None for x in range(target.num_qubits)}
1224
+ for qargs, props in qargs_list.items():
1225
+ if qargs is None:
1226
+ continue
1227
+ qubit = qargs[0]
1228
+ props_list = []
1229
+ if getattr(props, "error", None) is not None:
1230
+ props_list.append(
1231
+ {
1232
+ "date": datetime.datetime.now(datetime.timezone.utc),
1233
+ "name": "readout_error",
1234
+ "unit": "",
1235
+ "value": props.error,
1236
+ }
1237
+ )
1238
+ if getattr(props, "duration", None) is not None:
1239
+ props_list.append(
1240
+ {
1241
+ "date": datetime.datetime.now(datetime.timezone.utc),
1242
+ "name": "readout_length",
1243
+ "unit": "s",
1244
+ "value": props.duration,
1245
+ }
1246
+ )
1247
+ if not props_list:
1248
+ qubit_props = {}
1249
+ break
1250
+ qubit_props[qubit] = props_list
1251
+ if qubit_props and all(x is not None for x in qubit_props.values()):
1252
+ qubits = [qubit_props[i] for i in range(target.num_qubits)]
1253
+ if gates or qubits:
1254
+ properties_dict["gates"] = gates
1255
+ properties_dict["qubits"] = qubits
1256
+ with warnings.catch_warnings():
1257
+ # This raises BackendProperties internally
1258
+ warnings.filterwarnings("ignore", category=DeprecationWarning)
1259
+ return BackendProperties.from_dict(properties_dict)
1260
+ else:
1261
+ return None