qiskit 1.4.1__cp39-abi3-macosx_11_0_arm64.whl → 2.0.0__cp39-abi3-macosx_11_0_arm64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (462) hide show
  1. qiskit/VERSION.txt +1 -1
  2. qiskit/__init__.py +3 -9
  3. qiskit/_accelerate.abi3.so +0 -0
  4. qiskit/circuit/__init__.py +35 -10
  5. qiskit/circuit/{add_control.py → _add_control.py} +32 -12
  6. qiskit/circuit/_classical_resource_map.py +5 -3
  7. qiskit/circuit/barrier.py +3 -7
  8. qiskit/circuit/classical/expr/__init__.py +31 -3
  9. qiskit/circuit/classical/expr/constructors.py +236 -28
  10. qiskit/circuit/classical/expr/expr.py +104 -3
  11. qiskit/circuit/classical/expr/visitors.py +75 -0
  12. qiskit/circuit/classical/types/__init__.py +12 -8
  13. qiskit/circuit/classical/types/ordering.py +14 -7
  14. qiskit/circuit/classical/types/types.py +36 -0
  15. qiskit/circuit/commutation_checker.py +34 -7
  16. qiskit/circuit/controlflow/__init__.py +32 -1
  17. qiskit/circuit/controlflow/_builder_utils.py +9 -5
  18. qiskit/circuit/controlflow/box.py +163 -0
  19. qiskit/circuit/controlflow/break_loop.py +1 -1
  20. qiskit/circuit/controlflow/builder.py +139 -39
  21. qiskit/circuit/controlflow/continue_loop.py +1 -3
  22. qiskit/circuit/controlflow/control_flow.py +10 -0
  23. qiskit/circuit/controlflow/for_loop.py +2 -1
  24. qiskit/circuit/controlflow/if_else.py +3 -16
  25. qiskit/circuit/controlflow/switch_case.py +2 -8
  26. qiskit/circuit/controlflow/while_loop.py +2 -7
  27. qiskit/circuit/controlledgate.py +2 -4
  28. qiskit/circuit/delay.py +40 -11
  29. qiskit/circuit/duration.py +0 -15
  30. qiskit/circuit/gate.py +2 -4
  31. qiskit/circuit/instruction.py +2 -141
  32. qiskit/circuit/instructionset.py +7 -54
  33. qiskit/circuit/library/__init__.py +469 -154
  34. qiskit/circuit/library/arithmetic/__init__.py +16 -10
  35. qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +1 -1
  36. qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +2 -2
  37. qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +1 -1
  38. qiskit/circuit/library/arithmetic/exact_reciprocal.py +64 -21
  39. qiskit/circuit/library/arithmetic/integer_comparator.py +37 -80
  40. qiskit/circuit/library/arithmetic/linear_amplitude_function.py +169 -2
  41. qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +59 -5
  42. qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +154 -6
  43. qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +114 -4
  44. qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +191 -15
  45. qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +93 -39
  46. qiskit/circuit/library/arithmetic/quadratic_form.py +168 -2
  47. qiskit/circuit/library/arithmetic/weighted_adder.py +73 -1
  48. qiskit/circuit/library/bit_flip_oracle.py +130 -0
  49. qiskit/circuit/library/blueprintcircuit.py +52 -16
  50. qiskit/circuit/library/data_preparation/initializer.py +1 -1
  51. qiskit/circuit/library/data_preparation/pauli_feature_map.py +4 -4
  52. qiskit/circuit/library/data_preparation/state_preparation.py +1 -1
  53. qiskit/circuit/library/generalized_gates/gms.py +1 -1
  54. qiskit/circuit/library/generalized_gates/isometry.py +1 -1
  55. qiskit/circuit/library/generalized_gates/pauli.py +1 -2
  56. qiskit/circuit/library/generalized_gates/uc.py +97 -7
  57. qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +1 -1
  58. qiskit/circuit/library/generalized_gates/unitary.py +4 -2
  59. qiskit/circuit/library/graph_state.py +1 -0
  60. qiskit/circuit/library/hamiltonian_gate.py +1 -1
  61. qiskit/circuit/library/n_local/evolved_operator_ansatz.py +1 -1
  62. qiskit/circuit/library/n_local/n_local.py +1 -1
  63. qiskit/circuit/library/n_local/qaoa_ansatz.py +1 -1
  64. qiskit/circuit/library/overlap.py +2 -2
  65. qiskit/circuit/library/pauli_evolution.py +39 -24
  66. qiskit/circuit/library/phase_oracle.py +130 -51
  67. qiskit/circuit/library/standard_gates/__init__.py +0 -1
  68. qiskit/circuit/library/standard_gates/dcx.py +3 -4
  69. qiskit/circuit/library/standard_gates/ecr.py +3 -4
  70. qiskit/circuit/library/standard_gates/global_phase.py +5 -6
  71. qiskit/circuit/library/standard_gates/h.py +4 -9
  72. qiskit/circuit/library/standard_gates/i.py +2 -2
  73. qiskit/circuit/library/standard_gates/iswap.py +3 -4
  74. qiskit/circuit/library/standard_gates/p.py +15 -34
  75. qiskit/circuit/library/standard_gates/r.py +7 -10
  76. qiskit/circuit/library/standard_gates/rx.py +5 -15
  77. qiskit/circuit/library/standard_gates/rxx.py +3 -6
  78. qiskit/circuit/library/standard_gates/ry.py +5 -17
  79. qiskit/circuit/library/standard_gates/ryy.py +3 -6
  80. qiskit/circuit/library/standard_gates/rz.py +5 -17
  81. qiskit/circuit/library/standard_gates/rzx.py +3 -6
  82. qiskit/circuit/library/standard_gates/rzz.py +3 -6
  83. qiskit/circuit/library/standard_gates/s.py +6 -15
  84. qiskit/circuit/library/standard_gates/swap.py +4 -11
  85. qiskit/circuit/library/standard_gates/sx.py +7 -12
  86. qiskit/circuit/library/standard_gates/t.py +6 -7
  87. qiskit/circuit/library/standard_gates/u.py +2 -10
  88. qiskit/circuit/library/standard_gates/u1.py +5 -16
  89. qiskit/circuit/library/standard_gates/u2.py +2 -6
  90. qiskit/circuit/library/standard_gates/u3.py +3 -11
  91. qiskit/circuit/library/standard_gates/x.py +14 -62
  92. qiskit/circuit/library/standard_gates/xx_minus_yy.py +2 -5
  93. qiskit/circuit/library/standard_gates/xx_plus_yy.py +2 -5
  94. qiskit/circuit/library/standard_gates/y.py +4 -9
  95. qiskit/circuit/library/standard_gates/z.py +5 -15
  96. qiskit/circuit/measure.py +11 -2
  97. qiskit/circuit/parameterexpression.py +11 -0
  98. qiskit/circuit/quantumcircuit.py +890 -564
  99. qiskit/circuit/random/utils.py +12 -6
  100. qiskit/circuit/reset.py +5 -2
  101. qiskit/circuit/singleton.py +5 -11
  102. qiskit/circuit/store.py +0 -8
  103. qiskit/circuit/tools/pi_check.py +3 -0
  104. qiskit/compiler/__init__.py +1 -7
  105. qiskit/compiler/transpiler.py +38 -196
  106. qiskit/converters/circuit_to_dag.py +6 -4
  107. qiskit/converters/circuit_to_dagdependency.py +0 -2
  108. qiskit/converters/circuit_to_dagdependency_v2.py +0 -1
  109. qiskit/converters/circuit_to_gate.py +1 -1
  110. qiskit/converters/circuit_to_instruction.py +16 -29
  111. qiskit/converters/dag_to_circuit.py +7 -8
  112. qiskit/converters/dag_to_dagdependency.py +0 -1
  113. qiskit/converters/dag_to_dagdependency_v2.py +0 -1
  114. qiskit/converters/dagdependency_to_circuit.py +0 -6
  115. qiskit/converters/dagdependency_to_dag.py +0 -6
  116. qiskit/dagcircuit/collect_blocks.py +32 -20
  117. qiskit/dagcircuit/dagdependency.py +3 -37
  118. qiskit/dagcircuit/dagdependency_v2.py +5 -82
  119. qiskit/dagcircuit/dagnode.py +14 -2
  120. qiskit/passmanager/__init__.py +24 -6
  121. qiskit/passmanager/passmanager.py +26 -24
  122. qiskit/primitives/__init__.py +44 -35
  123. qiskit/primitives/backend_estimator_v2.py +102 -23
  124. qiskit/primitives/backend_sampler_v2.py +5 -20
  125. qiskit/primitives/base/__init__.py +4 -4
  126. qiskit/primitives/base/base_estimator.py +77 -82
  127. qiskit/primitives/base/base_primitive_job.py +2 -2
  128. qiskit/primitives/base/{base_primitive.py → base_primitive_v1.py} +1 -1
  129. qiskit/primitives/base/{base_result.py → base_result_v1.py} +1 -1
  130. qiskit/primitives/base/base_sampler.py +52 -60
  131. qiskit/primitives/base/{estimator_result.py → estimator_result_v1.py} +2 -2
  132. qiskit/primitives/base/{sampler_result.py → sampler_result_v1.py} +2 -2
  133. qiskit/primitives/base/{validation.py → validation_v1.py} +34 -15
  134. qiskit/primitives/containers/bindings_array.py +3 -1
  135. qiskit/primitives/containers/bit_array.py +23 -0
  136. qiskit/primitives/containers/data_bin.py +3 -1
  137. qiskit/primitives/containers/observables_array.py +19 -2
  138. qiskit/primitives/statevector_sampler.py +6 -8
  139. qiskit/primitives/utils.py +14 -189
  140. qiskit/providers/__init__.py +4 -130
  141. qiskit/providers/backend.py +11 -314
  142. qiskit/providers/basic_provider/__init__.py +3 -1
  143. qiskit/providers/basic_provider/basic_provider.py +29 -9
  144. qiskit/providers/basic_provider/basic_simulator.py +158 -298
  145. qiskit/providers/exceptions.py +0 -33
  146. qiskit/providers/fake_provider/__init__.py +0 -37
  147. qiskit/providers/fake_provider/generic_backend_v2.py +32 -693
  148. qiskit/qasm2/__init__.py +21 -6
  149. qiskit/qasm2/export.py +2 -10
  150. qiskit/qasm2/parse.py +11 -25
  151. qiskit/qasm3/__init__.py +5 -1
  152. qiskit/qasm3/ast.py +44 -0
  153. qiskit/qasm3/exporter.py +65 -27
  154. qiskit/qasm3/printer.py +35 -4
  155. qiskit/qpy/__init__.py +162 -19
  156. qiskit/qpy/binary_io/__init__.py +0 -1
  157. qiskit/qpy/binary_io/circuits.py +96 -116
  158. qiskit/qpy/binary_io/parse_sympy_repr.py +121 -0
  159. qiskit/qpy/binary_io/schedules.py +61 -388
  160. qiskit/qpy/binary_io/value.py +159 -33
  161. qiskit/qpy/common.py +10 -7
  162. qiskit/qpy/formats.py +41 -0
  163. qiskit/qpy/interface.py +29 -62
  164. qiskit/qpy/type_keys.py +58 -221
  165. qiskit/quantum_info/analysis/distance.py +3 -1
  166. qiskit/quantum_info/operators/dihedral/dihedral.py +3 -1
  167. qiskit/quantum_info/operators/operator.py +6 -2
  168. qiskit/quantum_info/operators/symplectic/clifford.py +3 -1
  169. qiskit/quantum_info/operators/symplectic/pauli.py +4 -2
  170. qiskit/quantum_info/operators/symplectic/pauli_list.py +17 -5
  171. qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +40 -6
  172. qiskit/quantum_info/states/densitymatrix.py +16 -6
  173. qiskit/quantum_info/states/stabilizerstate.py +35 -4
  174. qiskit/quantum_info/states/statevector.py +16 -6
  175. qiskit/result/__init__.py +5 -17
  176. qiskit/result/models.py +18 -11
  177. qiskit/result/result.py +38 -134
  178. qiskit/result/sampled_expval.py +1 -2
  179. qiskit/result/utils.py +3 -4
  180. qiskit/synthesis/__init__.py +21 -1
  181. qiskit/synthesis/arithmetic/__init__.py +3 -1
  182. qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +1 -1
  183. qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +1 -1
  184. qiskit/synthesis/arithmetic/adders/vbe_ripple_carry_adder.py +2 -2
  185. qiskit/{providers/fake_provider/backends_v1/fake_20q → synthesis/arithmetic/comparators}/__init__.py +4 -6
  186. qiskit/synthesis/arithmetic/comparators/compare_2s.py +112 -0
  187. qiskit/synthesis/arithmetic/comparators/compare_greedy.py +66 -0
  188. qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +1 -1
  189. qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +1 -1
  190. qiskit/synthesis/arithmetic/weighted_sum.py +155 -0
  191. qiskit/{result/mitigation → synthesis/boolean}/__init__.py +2 -2
  192. qiskit/synthesis/boolean/boolean_expression.py +231 -0
  193. qiskit/synthesis/boolean/boolean_expression_synth.py +124 -0
  194. qiskit/synthesis/boolean/boolean_expression_visitor.py +96 -0
  195. qiskit/synthesis/discrete_basis/generate_basis_approximations.py +2 -0
  196. qiskit/synthesis/evolution/lie_trotter.py +10 -7
  197. qiskit/synthesis/evolution/product_formula.py +44 -35
  198. qiskit/synthesis/evolution/qdrift.py +17 -24
  199. qiskit/synthesis/evolution/suzuki_trotter.py +20 -27
  200. qiskit/synthesis/linear/linear_depth_lnn.py +6 -221
  201. qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +4 -205
  202. qiskit/synthesis/multi_controlled/__init__.py +1 -0
  203. qiskit/synthesis/multi_controlled/mcx_synthesis.py +5 -2
  204. qiskit/synthesis/multi_controlled/multi_control_rotation_gates.py +206 -0
  205. qiskit/synthesis/one_qubit/one_qubit_decompose.py +1 -1
  206. qiskit/synthesis/two_qubit/__init__.py +1 -0
  207. qiskit/synthesis/two_qubit/two_qubit_decompose.py +28 -145
  208. qiskit/transpiler/__init__.py +32 -232
  209. qiskit/transpiler/basepasses.py +20 -51
  210. qiskit/transpiler/layout.py +1 -1
  211. qiskit/transpiler/passes/__init__.py +4 -40
  212. qiskit/transpiler/passes/basis/basis_translator.py +5 -4
  213. qiskit/transpiler/passes/basis/decompose.py +1 -15
  214. qiskit/transpiler/passes/basis/unroll_3q_or_more.py +1 -5
  215. qiskit/transpiler/passes/basis/unroll_custom_definitions.py +3 -2
  216. qiskit/transpiler/passes/layout/apply_layout.py +4 -0
  217. qiskit/transpiler/passes/layout/dense_layout.py +2 -39
  218. qiskit/transpiler/passes/layout/full_ancilla_allocation.py +3 -4
  219. qiskit/transpiler/passes/layout/sabre_layout.py +7 -3
  220. qiskit/transpiler/passes/layout/vf2_layout.py +2 -20
  221. qiskit/transpiler/passes/layout/vf2_post_layout.py +60 -125
  222. qiskit/transpiler/passes/layout/vf2_utils.py +2 -26
  223. qiskit/transpiler/passes/optimization/__init__.py +2 -3
  224. qiskit/transpiler/passes/optimization/collect_and_collapse.py +2 -0
  225. qiskit/transpiler/passes/optimization/collect_cliffords.py +5 -0
  226. qiskit/transpiler/passes/optimization/collect_linear_functions.py +5 -0
  227. qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +16 -1
  228. qiskit/transpiler/passes/optimization/commutation_analysis.py +3 -3
  229. qiskit/transpiler/passes/optimization/consolidate_blocks.py +41 -19
  230. qiskit/transpiler/passes/optimization/contract_idle_wires_in_control_flow.py +104 -0
  231. qiskit/transpiler/passes/optimization/light_cone.py +135 -0
  232. qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +0 -1
  233. qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +18 -22
  234. qiskit/transpiler/passes/optimization/optimize_annotated.py +3 -2
  235. qiskit/transpiler/passes/optimization/remove_identity_equiv.py +6 -4
  236. qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +5 -2
  237. qiskit/transpiler/passes/optimization/split_2q_unitaries.py +26 -3
  238. qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +3 -2
  239. qiskit/transpiler/passes/routing/__init__.py +0 -1
  240. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +3 -1
  241. qiskit/transpiler/passes/routing/sabre_swap.py +14 -6
  242. qiskit/transpiler/passes/routing/star_prerouting.py +1 -1
  243. qiskit/transpiler/passes/scheduling/__init__.py +1 -7
  244. qiskit/transpiler/passes/scheduling/alignments/__init__.py +2 -4
  245. qiskit/transpiler/passes/scheduling/alignments/check_durations.py +1 -9
  246. qiskit/transpiler/passes/scheduling/alignments/reschedule.py +17 -16
  247. qiskit/transpiler/passes/scheduling/padding/base_padding.py +32 -4
  248. qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +25 -63
  249. qiskit/transpiler/passes/scheduling/padding/pad_delay.py +12 -4
  250. qiskit/transpiler/passes/scheduling/scheduling/alap.py +5 -39
  251. qiskit/transpiler/passes/scheduling/scheduling/asap.py +4 -35
  252. qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +10 -16
  253. qiskit/transpiler/passes/scheduling/time_unit_conversion.py +134 -62
  254. qiskit/transpiler/passes/synthesis/default_unitary_synth_plugin.py +653 -0
  255. qiskit/transpiler/passes/synthesis/high_level_synthesis.py +176 -601
  256. qiskit/transpiler/passes/synthesis/hls_plugins.py +294 -1
  257. qiskit/transpiler/passes/synthesis/plugin.py +4 -0
  258. qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +16 -10
  259. qiskit/transpiler/passes/synthesis/unitary_synthesis.py +34 -697
  260. qiskit/transpiler/passes/utils/__init__.py +0 -1
  261. qiskit/transpiler/passes/utils/check_gate_direction.py +13 -5
  262. qiskit/transpiler/passes/utils/control_flow.py +2 -6
  263. qiskit/transpiler/passes/utils/gate_direction.py +7 -0
  264. qiskit/transpiler/passes/utils/remove_final_measurements.py +40 -33
  265. qiskit/transpiler/passmanager.py +13 -0
  266. qiskit/transpiler/passmanager_config.py +5 -81
  267. qiskit/transpiler/preset_passmanagers/builtin_plugins.py +225 -344
  268. qiskit/transpiler/preset_passmanagers/common.py +140 -167
  269. qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +107 -322
  270. qiskit/transpiler/preset_passmanagers/level0.py +2 -11
  271. qiskit/transpiler/preset_passmanagers/level1.py +2 -14
  272. qiskit/transpiler/preset_passmanagers/level2.py +2 -12
  273. qiskit/transpiler/preset_passmanagers/level3.py +2 -11
  274. qiskit/transpiler/preset_passmanagers/plugin.py +5 -3
  275. qiskit/transpiler/target.py +78 -524
  276. qiskit/user_config.py +8 -4
  277. qiskit/utils/__init__.py +13 -12
  278. qiskit/utils/deprecation.py +4 -112
  279. qiskit/utils/optionals.py +11 -4
  280. qiskit/utils/parallel.py +214 -87
  281. qiskit/utils/units.py +4 -1
  282. qiskit/visualization/__init__.py +3 -7
  283. qiskit/visualization/array.py +4 -1
  284. qiskit/visualization/bloch.py +1 -1
  285. qiskit/visualization/circuit/_utils.py +19 -19
  286. qiskit/visualization/circuit/circuit_visualization.py +11 -4
  287. qiskit/visualization/circuit/matplotlib.py +13 -23
  288. qiskit/visualization/circuit/text.py +7 -3
  289. qiskit/visualization/counts_visualization.py +4 -0
  290. qiskit/visualization/dag_visualization.py +2 -1
  291. qiskit/visualization/gate_map.py +39 -154
  292. qiskit/visualization/library.py +4 -1
  293. qiskit/visualization/pass_manager_visualization.py +6 -2
  294. qiskit/visualization/state_visualization.py +19 -2
  295. qiskit/visualization/timeline/core.py +19 -13
  296. qiskit/visualization/timeline/interface.py +19 -18
  297. qiskit/visualization/timeline/plotters/matplotlib.py +4 -1
  298. {qiskit-1.4.1.dist-info → qiskit-2.0.0.dist-info}/METADATA +4 -3
  299. {qiskit-1.4.1.dist-info → qiskit-2.0.0.dist-info}/RECORD +303 -449
  300. {qiskit-1.4.1.dist-info → qiskit-2.0.0.dist-info}/WHEEL +2 -1
  301. {qiskit-1.4.1.dist-info → qiskit-2.0.0.dist-info}/entry_points.txt +8 -2
  302. qiskit/assembler/__init__.py +0 -42
  303. qiskit/assembler/assemble_circuits.py +0 -451
  304. qiskit/assembler/assemble_schedules.py +0 -367
  305. qiskit/assembler/disassemble.py +0 -310
  306. qiskit/assembler/run_config.py +0 -77
  307. qiskit/circuit/bit.py +0 -106
  308. qiskit/circuit/classicalfunction/__init__.py +0 -152
  309. qiskit/circuit/classicalfunction/boolean_expression.py +0 -138
  310. qiskit/circuit/classicalfunction/classical_element.py +0 -54
  311. qiskit/circuit/classicalfunction/classical_function_visitor.py +0 -155
  312. qiskit/circuit/classicalfunction/classicalfunction.py +0 -182
  313. qiskit/circuit/classicalfunction/exceptions.py +0 -41
  314. qiskit/circuit/classicalfunction/types.py +0 -18
  315. qiskit/circuit/classicalfunction/utils.py +0 -91
  316. qiskit/circuit/classicalregister.py +0 -57
  317. qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +0 -405
  318. qiskit/circuit/quantumregister.py +0 -75
  319. qiskit/circuit/register.py +0 -246
  320. qiskit/compiler/assembler.py +0 -689
  321. qiskit/compiler/scheduler.py +0 -109
  322. qiskit/compiler/sequencer.py +0 -71
  323. qiskit/primitives/backend_estimator.py +0 -486
  324. qiskit/primitives/backend_sampler.py +0 -222
  325. qiskit/primitives/estimator.py +0 -172
  326. qiskit/primitives/sampler.py +0 -162
  327. qiskit/providers/backend_compat.py +0 -507
  328. qiskit/providers/fake_provider/backends_v1/__init__.py +0 -22
  329. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +0 -18
  330. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +0 -1
  331. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +0 -1
  332. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +0 -37
  333. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +0 -1
  334. qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +0 -1
  335. qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +0 -43
  336. qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +0 -1
  337. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +0 -18
  338. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +0 -1
  339. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +0 -1
  340. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +0 -50
  341. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +0 -1
  342. qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +0 -18
  343. qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +0 -1
  344. qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +0 -41
  345. qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +0 -1
  346. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +0 -18
  347. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +0 -1
  348. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +0 -1
  349. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +0 -44
  350. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +0 -1
  351. qiskit/providers/fake_provider/fake_1q.py +0 -91
  352. qiskit/providers/fake_provider/fake_backend.py +0 -165
  353. qiskit/providers/fake_provider/fake_openpulse_2q.py +0 -391
  354. qiskit/providers/fake_provider/fake_openpulse_3q.py +0 -340
  355. qiskit/providers/fake_provider/fake_pulse_backend.py +0 -49
  356. qiskit/providers/fake_provider/fake_qasm_backend.py +0 -77
  357. qiskit/providers/fake_provider/utils/backend_converter.py +0 -150
  358. qiskit/providers/fake_provider/utils/json_decoder.py +0 -109
  359. qiskit/providers/models/__init__.py +0 -89
  360. qiskit/providers/models/backendconfiguration.py +0 -1040
  361. qiskit/providers/models/backendproperties.py +0 -535
  362. qiskit/providers/models/backendstatus.py +0 -104
  363. qiskit/providers/models/jobstatus.py +0 -77
  364. qiskit/providers/models/pulsedefaults.py +0 -305
  365. qiskit/providers/provider.py +0 -95
  366. qiskit/pulse/__init__.py +0 -158
  367. qiskit/pulse/builder.py +0 -2262
  368. qiskit/pulse/calibration_entries.py +0 -381
  369. qiskit/pulse/channels.py +0 -227
  370. qiskit/pulse/configuration.py +0 -245
  371. qiskit/pulse/exceptions.py +0 -45
  372. qiskit/pulse/filters.py +0 -309
  373. qiskit/pulse/instruction_schedule_map.py +0 -424
  374. qiskit/pulse/instructions/__init__.py +0 -67
  375. qiskit/pulse/instructions/acquire.py +0 -150
  376. qiskit/pulse/instructions/delay.py +0 -71
  377. qiskit/pulse/instructions/directives.py +0 -154
  378. qiskit/pulse/instructions/frequency.py +0 -135
  379. qiskit/pulse/instructions/instruction.py +0 -270
  380. qiskit/pulse/instructions/phase.py +0 -152
  381. qiskit/pulse/instructions/play.py +0 -99
  382. qiskit/pulse/instructions/reference.py +0 -100
  383. qiskit/pulse/instructions/snapshot.py +0 -82
  384. qiskit/pulse/library/__init__.py +0 -97
  385. qiskit/pulse/library/continuous.py +0 -430
  386. qiskit/pulse/library/pulse.py +0 -148
  387. qiskit/pulse/library/samplers/__init__.py +0 -15
  388. qiskit/pulse/library/samplers/decorators.py +0 -295
  389. qiskit/pulse/library/samplers/strategies.py +0 -71
  390. qiskit/pulse/library/symbolic_pulses.py +0 -1989
  391. qiskit/pulse/library/waveform.py +0 -136
  392. qiskit/pulse/macros.py +0 -262
  393. qiskit/pulse/parameter_manager.py +0 -445
  394. qiskit/pulse/parser.py +0 -314
  395. qiskit/pulse/reference_manager.py +0 -58
  396. qiskit/pulse/schedule.py +0 -1854
  397. qiskit/pulse/transforms/__init__.py +0 -106
  398. qiskit/pulse/transforms/alignments.py +0 -406
  399. qiskit/pulse/transforms/base_transforms.py +0 -71
  400. qiskit/pulse/transforms/canonicalization.py +0 -498
  401. qiskit/pulse/transforms/dag.py +0 -122
  402. qiskit/pulse/utils.py +0 -149
  403. qiskit/qobj/__init__.py +0 -75
  404. qiskit/qobj/common.py +0 -81
  405. qiskit/qobj/converters/__init__.py +0 -18
  406. qiskit/qobj/converters/lo_config.py +0 -177
  407. qiskit/qobj/converters/pulse_instruction.py +0 -897
  408. qiskit/qobj/pulse_qobj.py +0 -709
  409. qiskit/qobj/qasm_qobj.py +0 -708
  410. qiskit/qobj/utils.py +0 -46
  411. qiskit/result/mitigation/base_readout_mitigator.py +0 -79
  412. qiskit/result/mitigation/correlated_readout_mitigator.py +0 -277
  413. qiskit/result/mitigation/local_readout_mitigator.py +0 -328
  414. qiskit/result/mitigation/utils.py +0 -217
  415. qiskit/scheduler/__init__.py +0 -40
  416. qiskit/scheduler/config.py +0 -37
  417. qiskit/scheduler/lowering.py +0 -187
  418. qiskit/scheduler/methods/__init__.py +0 -15
  419. qiskit/scheduler/methods/basic.py +0 -140
  420. qiskit/scheduler/schedule_circuit.py +0 -69
  421. qiskit/scheduler/sequence.py +0 -104
  422. qiskit/transpiler/passes/calibration/__init__.py +0 -17
  423. qiskit/transpiler/passes/calibration/base_builder.py +0 -79
  424. qiskit/transpiler/passes/calibration/builders.py +0 -20
  425. qiskit/transpiler/passes/calibration/exceptions.py +0 -22
  426. qiskit/transpiler/passes/calibration/pulse_gate.py +0 -100
  427. qiskit/transpiler/passes/calibration/rx_builder.py +0 -164
  428. qiskit/transpiler/passes/calibration/rzx_builder.py +0 -411
  429. qiskit/transpiler/passes/calibration/rzx_templates.py +0 -58
  430. qiskit/transpiler/passes/optimization/cx_cancellation.py +0 -65
  431. qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +0 -162
  432. qiskit/transpiler/passes/optimization/normalize_rx_angle.py +0 -157
  433. qiskit/transpiler/passes/routing/stochastic_swap.py +0 -532
  434. qiskit/transpiler/passes/scheduling/alap.py +0 -153
  435. qiskit/transpiler/passes/scheduling/alignments/align_measures.py +0 -255
  436. qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +0 -107
  437. qiskit/transpiler/passes/scheduling/asap.py +0 -175
  438. qiskit/transpiler/passes/scheduling/base_scheduler.py +0 -310
  439. qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +0 -313
  440. qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +0 -93
  441. qiskit/utils/deprecate_pulse.py +0 -119
  442. qiskit/utils/multiprocessing.py +0 -56
  443. qiskit/visualization/pulse_v2/__init__.py +0 -21
  444. qiskit/visualization/pulse_v2/core.py +0 -901
  445. qiskit/visualization/pulse_v2/device_info.py +0 -173
  446. qiskit/visualization/pulse_v2/drawings.py +0 -253
  447. qiskit/visualization/pulse_v2/events.py +0 -254
  448. qiskit/visualization/pulse_v2/generators/__init__.py +0 -40
  449. qiskit/visualization/pulse_v2/generators/barrier.py +0 -76
  450. qiskit/visualization/pulse_v2/generators/chart.py +0 -208
  451. qiskit/visualization/pulse_v2/generators/frame.py +0 -436
  452. qiskit/visualization/pulse_v2/generators/snapshot.py +0 -133
  453. qiskit/visualization/pulse_v2/generators/waveform.py +0 -645
  454. qiskit/visualization/pulse_v2/interface.py +0 -459
  455. qiskit/visualization/pulse_v2/layouts.py +0 -387
  456. qiskit/visualization/pulse_v2/plotters/__init__.py +0 -17
  457. qiskit/visualization/pulse_v2/plotters/base_plotter.py +0 -53
  458. qiskit/visualization/pulse_v2/plotters/matplotlib.py +0 -201
  459. qiskit/visualization/pulse_v2/stylesheet.py +0 -312
  460. qiskit/visualization/pulse_v2/types.py +0 -242
  461. {qiskit-1.4.1.dist-info → qiskit-2.0.0.dist-info/licenses}/LICENSE.txt +0 -0
  462. {qiskit-1.4.1.dist-info → qiskit-2.0.0.dist-info}/top_level.txt +0 -0
@@ -1,430 +0,0 @@
1
- # This code is part of Qiskit.
2
- #
3
- # (C) Copyright IBM 2017, 2019.
4
- #
5
- # This code is licensed under the Apache License, Version 2.0. You may
6
- # obtain a copy of this license in the LICENSE.txt file in the root directory
7
- # of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
8
- #
9
- # Any modifications or derivative works of this code must retain this
10
- # copyright notice, and modified files need to carry a notice indicating
11
- # that they have been altered from the originals.
12
-
13
- # pylint: disable=invalid-unary-operand-type
14
-
15
- """Module for builtin continuous pulse functions."""
16
- from __future__ import annotations
17
-
18
- import functools
19
-
20
- import numpy as np
21
- from qiskit.pulse.exceptions import PulseError
22
-
23
-
24
- def constant(times: np.ndarray, amp: complex) -> np.ndarray:
25
- """Continuous constant pulse.
26
-
27
- Args:
28
- times: Times to output pulse for.
29
- amp: Complex pulse amplitude.
30
- """
31
- return np.full(len(times), amp, dtype=np.complex128)
32
-
33
-
34
- def zero(times: np.ndarray) -> np.ndarray:
35
- """Continuous zero pulse.
36
-
37
- Args:
38
- times: Times to output pulse for.
39
- """
40
- return constant(times, 0)
41
-
42
-
43
- def square(times: np.ndarray, amp: complex, freq: float, phase: float = 0) -> np.ndarray:
44
- """Continuous square wave.
45
-
46
- Args:
47
- times: Times to output wave for.
48
- amp: Pulse amplitude. Wave range is [-amp, amp].
49
- freq: Pulse frequency. units of 1/dt.
50
- phase: Pulse phase.
51
- """
52
- x = times * freq + phase / np.pi
53
- return amp * (2 * (2 * np.floor(x) - np.floor(2 * x)) + 1).astype(np.complex128)
54
-
55
-
56
- def sawtooth(times: np.ndarray, amp: complex, freq: float, phase: float = 0) -> np.ndarray:
57
- """Continuous sawtooth wave.
58
-
59
- Args:
60
- times: Times to output wave for.
61
- amp: Pulse amplitude. Wave range is [-amp, amp].
62
- freq: Pulse frequency. units of 1/dt.
63
- phase: Pulse phase.
64
- """
65
- x = times * freq + phase / np.pi
66
- return amp * 2 * (x - np.floor(1 / 2 + x)).astype(np.complex128)
67
-
68
-
69
- def triangle(times: np.ndarray, amp: complex, freq: float, phase: float = 0) -> np.ndarray:
70
- """Continuous triangle wave.
71
-
72
- Args:
73
- times: Times to output wave for.
74
- amp: Pulse amplitude. Wave range is [-amp, amp].
75
- freq: Pulse frequency. units of 1/dt.
76
- phase: Pulse phase.
77
- """
78
- return amp * (-2 * np.abs(sawtooth(times, 1, freq, phase=(phase - np.pi / 2) / 2)) + 1).astype(
79
- np.complex128
80
- )
81
-
82
-
83
- def cos(times: np.ndarray, amp: complex, freq: float, phase: float = 0) -> np.ndarray:
84
- """Continuous cosine wave.
85
-
86
- Args:
87
- times: Times to output wave for.
88
- amp: Pulse amplitude.
89
- freq: Pulse frequency, units of 1/dt.
90
- phase: Pulse phase.
91
- """
92
- return amp * np.cos(2 * np.pi * freq * times + phase).astype(np.complex128)
93
-
94
-
95
- def sin(times: np.ndarray, amp: complex, freq: float, phase: float = 0) -> np.ndarray:
96
- """Continuous cosine wave.
97
-
98
- Args:
99
- times: Times to output wave for.
100
- amp: Pulse amplitude.
101
- freq: Pulse frequency, units of 1/dt.
102
- phase: Pulse phase.
103
- """
104
- return amp * np.sin(2 * np.pi * freq * times + phase).astype(np.complex128)
105
-
106
-
107
- def _fix_gaussian_width(
108
- gaussian_samples: np.ndarray,
109
- amp: complex,
110
- center: float,
111
- sigma: float,
112
- zeroed_width: float | None = None,
113
- rescale_amp: bool = False,
114
- ret_scale_factor: bool = False,
115
- ) -> np.ndarray | tuple[np.ndarray, float]:
116
- r"""Enforce that the supplied gaussian pulse is zeroed at a specific width.
117
-
118
- This is achieved by subtracting $\Omega_g(center \pm zeroed_width/2)$ from all samples.
119
-
120
- amp: Pulse amplitude at `center`.
121
- center: Center (mean) of pulse.
122
- sigma: Standard deviation of pulse.
123
- zeroed_width: Subtract baseline from gaussian pulses to make sure
124
- $\Omega_g(center \pm zeroed_width/2)=0$ is satisfied. This is used to avoid
125
- large discontinuities at the start of a gaussian pulse. If unsupplied,
126
- defaults to $2*(center + 1)$ such that $\Omega_g(-1)=0$ and $\Omega_g(2*(center + 1))=0$.
127
- rescale_amp: If True the pulse will be rescaled so that $\Omega_g(center)=amp$.
128
- ret_scale_factor: Return amplitude scale factor.
129
- """
130
- if zeroed_width is None:
131
- zeroed_width = 2 * (center + 1)
132
-
133
- zero_offset = gaussian(np.array([zeroed_width / 2]), amp, 0, sigma)
134
- gaussian_samples -= zero_offset
135
- amp_scale_factor: complex | float | np.ndarray = 1.0
136
- if rescale_amp:
137
- amp_scale_factor = amp / (amp - zero_offset) if amp - zero_offset != 0 else 1.0
138
- gaussian_samples *= amp_scale_factor
139
-
140
- if ret_scale_factor:
141
- return gaussian_samples, amp_scale_factor
142
- return gaussian_samples
143
-
144
-
145
- def gaussian(
146
- times: np.ndarray,
147
- amp: complex,
148
- center: float,
149
- sigma: float,
150
- zeroed_width: float | None = None,
151
- rescale_amp: bool = False,
152
- ret_x: bool = False,
153
- ) -> np.ndarray | tuple[np.ndarray, np.ndarray]:
154
- r"""Continuous unnormalized gaussian pulse.
155
-
156
- Integrated area under curve is $\Omega_g(amp, sigma) = amp \times np.sqrt(2\pi \sigma^2)$
157
-
158
- Args:
159
- times: Times to output pulse for.
160
- amp: Pulse amplitude at `center`. If `zeroed_width` is set pulse amplitude at center
161
- will be $amp-\Omega_g(center \pm zeroed_width/2)$ unless `rescale_amp` is set,
162
- in which case all samples will be rescaled such that the center
163
- amplitude will be `amp`.
164
- center: Center (mean) of pulse.
165
- sigma: Width (standard deviation) of pulse.
166
- zeroed_width: Subtract baseline from gaussian pulses to make sure
167
- $\Omega_g(center \pm zeroed_width/2)=0$ is satisfied. This is used to avoid
168
- large discontinuities at the start of a gaussian pulse.
169
- rescale_amp: If `zeroed_width` is not `None` and `rescale_amp=True` the pulse will
170
- be rescaled so that $\Omega_g(center)=amp$.
171
- ret_x: Return centered and standard deviation normalized pulse location.
172
- $x=(times-center)/sigma.
173
- """
174
- times = np.asarray(times, dtype=np.complex128)
175
- x = (times - center) / sigma
176
- gauss = amp * np.exp(-(x**2) / 2).astype(np.complex128)
177
-
178
- if zeroed_width is not None:
179
- gauss = _fix_gaussian_width(
180
- gauss,
181
- amp=amp,
182
- center=center,
183
- sigma=sigma,
184
- zeroed_width=zeroed_width,
185
- rescale_amp=rescale_amp,
186
- )
187
-
188
- if ret_x:
189
- return gauss, x
190
- return gauss
191
-
192
-
193
- def gaussian_deriv(
194
- times: np.ndarray,
195
- amp: complex,
196
- center: float,
197
- sigma: float,
198
- ret_gaussian: bool = False,
199
- zeroed_width: float | None = None,
200
- rescale_amp: bool = False,
201
- ) -> np.ndarray | tuple[np.ndarray, np.ndarray]:
202
- r"""Continuous unnormalized gaussian derivative pulse.
203
-
204
- Args:
205
- times: Times to output pulse for.
206
- amp: Pulse amplitude at `center`.
207
- center: Center (mean) of pulse.
208
- sigma: Width (standard deviation) of pulse.
209
- ret_gaussian: Return gaussian with which derivative was taken with.
210
- zeroed_width: Subtract baseline of pulse to make sure
211
- $\Omega_g(center \pm zeroed_width/2)=0$ is satisfied. This is used to avoid
212
- large discontinuities at the start of a pulse.
213
- rescale_amp: If `zeroed_width` is not `None` and `rescale_amp=True` the pulse will
214
- be rescaled so that $\Omega_g(center)=amp$.
215
- """
216
- gauss, x = gaussian(
217
- times,
218
- amp=amp,
219
- center=center,
220
- sigma=sigma,
221
- zeroed_width=zeroed_width,
222
- rescale_amp=rescale_amp,
223
- ret_x=True,
224
- )
225
- gauss_deriv = -x / sigma * gauss # Note that x is shifted and normalized by sigma
226
- if ret_gaussian:
227
- return gauss_deriv, gauss
228
- return gauss_deriv
229
-
230
-
231
- def _fix_sech_width(
232
- sech_samples: np.ndarray,
233
- amp: complex,
234
- center: float,
235
- sigma: float,
236
- zeroed_width: float | None = None,
237
- rescale_amp: bool = False,
238
- ret_scale_factor: bool = False,
239
- ) -> np.ndarray | tuple[np.ndarray, float]:
240
- r"""Enforce that the supplied sech pulse is zeroed at a specific width.
241
-
242
- This is achieved by subtracting $\Omega_g(center \pm zeroed_width/2)$ from all samples.
243
-
244
- amp: Pulse amplitude at `center`.
245
- center: Center (mean) of pulse.
246
- sigma: Standard deviation of pulse.
247
- zeroed_width: Subtract baseline from sech pulses to make sure
248
- $\Omega_g(center \pm zeroed_width/2)=0$ is satisfied. This is used to avoid
249
- large discontinuities at the start of a sech pulse. If unsupplied,
250
- defaults to $2*(center + 1)$ such that $\Omega_g(-1)=0$ and $\Omega_g(2*(center + 1))=0$.
251
- rescale_amp: If True the pulse will be rescaled so that $\Omega_g(center)=amp$.
252
- ret_scale_factor: Return amplitude scale factor.
253
- """
254
- if zeroed_width is None:
255
- zeroed_width = 2 * (center + 1)
256
-
257
- zero_offset = sech(np.array([zeroed_width / 2]), amp, 0, sigma)
258
- sech_samples -= zero_offset
259
- amp_scale_factor: complex | float | np.ndarray = 1.0
260
- if rescale_amp:
261
- amp_scale_factor = amp / (amp - zero_offset) if amp - zero_offset != 0 else 1.0
262
- sech_samples *= amp_scale_factor
263
-
264
- if ret_scale_factor:
265
- return sech_samples, amp_scale_factor
266
- return sech_samples
267
-
268
-
269
- def sech_fn(x, *args, **kwargs):
270
- r"""Hyperbolic secant function"""
271
- return 1.0 / np.cosh(x, *args, **kwargs)
272
-
273
-
274
- def sech(
275
- times: np.ndarray,
276
- amp: complex,
277
- center: float,
278
- sigma: float,
279
- zeroed_width: float | None = None,
280
- rescale_amp: bool = False,
281
- ret_x: bool = False,
282
- ) -> np.ndarray | tuple[np.ndarray, np.ndarray]:
283
- r"""Continuous unnormalized sech pulse.
284
-
285
- Args:
286
- times: Times to output pulse for.
287
- amp: Pulse amplitude at `center`.
288
- center: Center (mean) of pulse.
289
- sigma: Width (standard deviation) of pulse.
290
- zeroed_width: Subtract baseline from pulse to make sure
291
- $\Omega_g(center \pm zeroed_width/2)=0$ is satisfied. This is used to avoid
292
- large discontinuities at the start and end of the pulse.
293
- rescale_amp: If `zeroed_width` is not `None` and `rescale_amp=True` the pulse will
294
- be rescaled so that $\Omega_g(center)=amp$.
295
- ret_x: Return centered and standard deviation normalized pulse location.
296
- $x=(times-center)/sigma$.
297
- """
298
- times = np.asarray(times, dtype=np.complex128)
299
- x = (times - center) / sigma
300
- sech_out = amp * sech_fn(x).astype(np.complex128)
301
-
302
- if zeroed_width is not None:
303
- sech_out = _fix_sech_width(
304
- sech_out,
305
- amp=amp,
306
- center=center,
307
- sigma=sigma,
308
- zeroed_width=zeroed_width,
309
- rescale_amp=rescale_amp,
310
- )
311
-
312
- if ret_x:
313
- return sech_out, x
314
- return sech_out
315
-
316
-
317
- def sech_deriv(
318
- times: np.ndarray, amp: complex, center: float, sigma: float, ret_sech: bool = False
319
- ) -> np.ndarray | tuple[np.ndarray, np.ndarray]:
320
- """Continuous unnormalized sech derivative pulse.
321
-
322
- Args:
323
- times: Times to output pulse for.
324
- amp: Pulse amplitude at `center`.
325
- center: Center (mean) of pulse.
326
- sigma: Width (standard deviation) of pulse.
327
- ret_sech: Return sech with which derivative was taken with.
328
- """
329
- sech_out, x = sech(times, amp=amp, center=center, sigma=sigma, ret_x=True)
330
- sech_out_deriv = -sech_out * np.tanh(x) / sigma
331
- if ret_sech:
332
- return sech_out_deriv, sech_out
333
- return sech_out_deriv
334
-
335
-
336
- def gaussian_square(
337
- times: np.ndarray,
338
- amp: complex,
339
- center: float,
340
- square_width: float,
341
- sigma: float,
342
- zeroed_width: float | None = None,
343
- ) -> np.ndarray:
344
- r"""Continuous gaussian square pulse.
345
-
346
- Args:
347
- times: Times to output pulse for.
348
- amp: Pulse amplitude.
349
- center: Center of the square pulse component.
350
- square_width: Width of the square pulse component.
351
- sigma: Standard deviation of Gaussian rise/fall portion of the pulse.
352
- zeroed_width: Subtract baseline of gaussian square pulse
353
- to enforce $\OmegaSquare(center \pm zeroed_width/2)=0$.
354
-
355
- Raises:
356
- PulseError: if zeroed_width is not compatible with square_width.
357
- """
358
- square_start = center - square_width / 2
359
- square_stop = center + square_width / 2
360
- if zeroed_width:
361
- if zeroed_width < square_width:
362
- raise PulseError("zeroed_width cannot be smaller than square_width.")
363
- gaussian_zeroed_width = zeroed_width - square_width
364
- else:
365
- gaussian_zeroed_width = None
366
-
367
- funclist = [
368
- functools.partial(
369
- gaussian,
370
- amp=amp,
371
- center=square_start,
372
- sigma=sigma,
373
- zeroed_width=gaussian_zeroed_width,
374
- rescale_amp=True,
375
- ),
376
- functools.partial(
377
- gaussian,
378
- amp=amp,
379
- center=square_stop,
380
- sigma=sigma,
381
- zeroed_width=gaussian_zeroed_width,
382
- rescale_amp=True,
383
- ),
384
- functools.partial(constant, amp=amp),
385
- ]
386
- condlist = [times <= square_start, times >= square_stop]
387
- return np.piecewise(times.astype(np.complex128), condlist, funclist)
388
-
389
-
390
- def drag(
391
- times: np.ndarray,
392
- amp: complex,
393
- center: float,
394
- sigma: float,
395
- beta: float,
396
- zeroed_width: float | None = None,
397
- rescale_amp: bool = False,
398
- ) -> np.ndarray:
399
- r"""Continuous Y-only correction DRAG pulse for standard nonlinear oscillator (SNO) [1].
400
-
401
- [1] Gambetta, J. M., Motzoi, F., Merkel, S. T. & Wilhelm, F. K.
402
- Analytic control methods for high-fidelity unitary operations
403
- in a weakly nonlinear oscillator. Phys. Rev. A 83, 012308 (2011).
404
-
405
- Args:
406
- times: Times to output pulse for.
407
- amp: Pulse amplitude at `center`.
408
- center: Center (mean) of pulse.
409
- sigma: Width (standard deviation) of pulse.
410
- beta: Y correction amplitude. For the SNO this is $\beta=-\frac{\lambda_1^2}{4\Delta_2}$.
411
- Where $\lambds_1$ is the relative coupling strength between the first excited and second
412
- excited states and $\Delta_2$ is the detuning between the respective excited states.
413
- zeroed_width: Subtract baseline of drag pulse to make sure
414
- $\Omega_g(center \pm zeroed_width/2)=0$ is satisfied. This is used to avoid
415
- large discontinuities at the start of a drag pulse.
416
- rescale_amp: If `zeroed_width` is not `None` and `rescale_amp=True` the pulse will
417
- be rescaled so that $\Omega_g(center)=amp$.
418
-
419
- """
420
- gauss_deriv, gauss = gaussian_deriv(
421
- times,
422
- amp=amp,
423
- center=center,
424
- sigma=sigma,
425
- ret_gaussian=True,
426
- zeroed_width=zeroed_width,
427
- rescale_amp=rescale_amp,
428
- )
429
-
430
- return gauss + 1j * beta * gauss_deriv
@@ -1,148 +0,0 @@
1
- # This code is part of Qiskit.
2
- #
3
- # (C) Copyright IBM 2020.
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
- """Pulses are descriptions of waveform envelopes. They can be transmitted by control electronics
14
- to the device.
15
- """
16
- from __future__ import annotations
17
-
18
- import typing
19
- from abc import ABC, abstractmethod
20
- from typing import Any
21
- from qiskit.utils.deprecate_pulse import deprecate_pulse_func
22
-
23
- from qiskit.circuit.parameterexpression import ParameterExpression
24
-
25
-
26
- if typing.TYPE_CHECKING:
27
- from qiskit.providers import Backend # pylint: disable=cyclic-import
28
-
29
-
30
- class Pulse(ABC):
31
- """The abstract superclass for pulses. Pulses are complex-valued waveform envelopes. The
32
- modulation phase and frequency are specified separately from ``Pulse``s.
33
- """
34
-
35
- __slots__ = ("duration", "name", "_limit_amplitude")
36
-
37
- limit_amplitude = True
38
-
39
- @abstractmethod
40
- @deprecate_pulse_func
41
- def __init__(
42
- self,
43
- duration: int | ParameterExpression,
44
- name: str | None = None,
45
- limit_amplitude: bool | None = None,
46
- ):
47
- """Abstract base class for pulses
48
- Args:
49
- duration: Duration of the pulse
50
- name: Optional name for the pulse
51
- limit_amplitude: If ``True``, then limit the amplitude of the waveform to 1.
52
- The default value of ``None`` causes the flag value to be
53
- derived from :py:attr:`~limit_amplitude` which is ``True``
54
- by default but may be set by the user to disable amplitude
55
- checks globally.
56
- """
57
- if limit_amplitude is None:
58
- limit_amplitude = self.__class__.limit_amplitude
59
-
60
- self.duration = duration
61
- self.name = name
62
- self._limit_amplitude = limit_amplitude
63
-
64
- @property
65
- def id(self) -> int: # pylint: disable=invalid-name
66
- """Unique identifier for this pulse."""
67
- return id(self)
68
-
69
- @property
70
- @abstractmethod
71
- def parameters(self) -> dict[str, typing.Any]:
72
- """Return a dictionary containing the pulse's parameters."""
73
- pass
74
-
75
- def is_parameterized(self) -> bool:
76
- """Return True iff the instruction is parameterized."""
77
- raise NotImplementedError
78
-
79
- def draw(
80
- self,
81
- style: dict[str, Any] | None = None,
82
- backend: Backend | None = None,
83
- time_range: tuple[int, int] | None = None,
84
- time_unit: str = "dt",
85
- show_waveform_info: bool = True,
86
- plotter: str = "mpl2d",
87
- axis: Any | None = None,
88
- ):
89
- """Plot the interpolated envelope of pulse.
90
-
91
- Args:
92
- style: Stylesheet options. This can be dictionary or preset stylesheet classes. See
93
- :py:class:`~qiskit.visualization.pulse_v2.stylesheets.IQXStandard`,
94
- :py:class:`~qiskit.visualization.pulse_v2.stylesheets.IQXSimple`, and
95
- :py:class:`~qiskit.visualization.pulse_v2.stylesheets.IQXDebugging` for details of
96
- preset stylesheets.
97
- backend (Optional[BaseBackend]): Backend object to play the input pulse program.
98
- If provided, the plotter may use to make the visualization hardware aware.
99
- time_range: Set horizontal axis limit. Tuple ``(tmin, tmax)``.
100
- time_unit: The unit of specified time range either ``dt`` or ``ns``.
101
- The unit of ``ns`` is available only when ``backend`` object is provided.
102
- show_waveform_info: Show waveform annotations, i.e. name, of waveforms.
103
- Set ``True`` to show additional information about waveforms.
104
- plotter: Name of plotter API to generate an output image.
105
- One of following APIs should be specified::
106
-
107
- mpl2d: Matplotlib API for 2D image generation.
108
- Matplotlib API to generate 2D image. Charts are placed along y axis with
109
- vertical offset. This API takes matplotlib.axes.Axes as `axis` input.
110
-
111
- `axis` and `style` kwargs may depend on the plotter.
112
- axis: Arbitrary object passed to the plotter. If this object is provided,
113
- the plotters use a given ``axis`` instead of internally initializing
114
- a figure object. This object format depends on the plotter.
115
- See plotter argument for details.
116
-
117
- Returns:
118
- Visualization output data.
119
- The returned data type depends on the ``plotter``.
120
- If matplotlib family is specified, this will be a ``matplotlib.pyplot.Figure`` data.
121
- """
122
- # pylint: disable=cyclic-import
123
- from qiskit.visualization import pulse_drawer
124
-
125
- return pulse_drawer(
126
- program=self,
127
- style=style,
128
- backend=backend,
129
- time_range=time_range,
130
- time_unit=time_unit,
131
- show_waveform_info=show_waveform_info,
132
- plotter=plotter,
133
- axis=axis,
134
- )
135
-
136
- @abstractmethod
137
- def __eq__(self, other: object) -> bool:
138
- if not isinstance(other, Pulse):
139
- return NotImplemented
140
- return isinstance(other, type(self))
141
-
142
- @abstractmethod
143
- def __hash__(self) -> int:
144
- raise NotImplementedError
145
-
146
- @abstractmethod
147
- def __repr__(self) -> str:
148
- raise NotImplementedError
@@ -1,15 +0,0 @@
1
- # This code is part of Qiskit.
2
- #
3
- # (C) Copyright IBM 2017, 2019.
4
- #
5
- # This code is licensed under the Apache License, Version 2.0. You may
6
- # obtain a copy of this license in the LICENSE.txt file in the root directory
7
- # of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
8
- #
9
- # Any modifications or derivative works of this code must retain this
10
- # copyright notice, and modified files need to carry a notice indicating
11
- # that they have been altered from the originals.
12
-
13
- """Module for methods which sample continuous functions."""
14
-
15
- from .decorators import left, right, midpoint