qiskit 1.4.1__cp39-abi3-macosx_11_0_arm64.whl → 2.0.0rc1__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 (456) hide show
  1. qiskit/VERSION.txt +1 -1
  2. qiskit/__init__.py +2 -5
  3. qiskit/_accelerate.abi3.so +0 -0
  4. qiskit/circuit/__init__.py +24 -5
  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 +248 -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 +34 -5
  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/hamiltonian_gate.py +1 -1
  60. qiskit/circuit/library/n_local/evolved_operator_ansatz.py +1 -1
  61. qiskit/circuit/library/n_local/n_local.py +1 -1
  62. qiskit/circuit/library/n_local/qaoa_ansatz.py +1 -1
  63. qiskit/circuit/library/overlap.py +2 -2
  64. qiskit/circuit/library/pauli_evolution.py +39 -24
  65. qiskit/circuit/library/phase_oracle.py +130 -51
  66. qiskit/circuit/library/standard_gates/__init__.py +0 -1
  67. qiskit/circuit/library/standard_gates/dcx.py +3 -4
  68. qiskit/circuit/library/standard_gates/ecr.py +3 -4
  69. qiskit/circuit/library/standard_gates/global_phase.py +5 -6
  70. qiskit/circuit/library/standard_gates/h.py +4 -9
  71. qiskit/circuit/library/standard_gates/i.py +2 -2
  72. qiskit/circuit/library/standard_gates/iswap.py +3 -4
  73. qiskit/circuit/library/standard_gates/p.py +15 -34
  74. qiskit/circuit/library/standard_gates/r.py +2 -6
  75. qiskit/circuit/library/standard_gates/rx.py +5 -15
  76. qiskit/circuit/library/standard_gates/rxx.py +3 -6
  77. qiskit/circuit/library/standard_gates/ry.py +5 -17
  78. qiskit/circuit/library/standard_gates/ryy.py +3 -6
  79. qiskit/circuit/library/standard_gates/rz.py +5 -17
  80. qiskit/circuit/library/standard_gates/rzx.py +3 -6
  81. qiskit/circuit/library/standard_gates/rzz.py +3 -6
  82. qiskit/circuit/library/standard_gates/s.py +6 -15
  83. qiskit/circuit/library/standard_gates/swap.py +4 -11
  84. qiskit/circuit/library/standard_gates/sx.py +7 -12
  85. qiskit/circuit/library/standard_gates/t.py +6 -7
  86. qiskit/circuit/library/standard_gates/u.py +2 -10
  87. qiskit/circuit/library/standard_gates/u1.py +5 -16
  88. qiskit/circuit/library/standard_gates/u2.py +2 -6
  89. qiskit/circuit/library/standard_gates/u3.py +3 -11
  90. qiskit/circuit/library/standard_gates/x.py +13 -60
  91. qiskit/circuit/library/standard_gates/xx_minus_yy.py +2 -5
  92. qiskit/circuit/library/standard_gates/xx_plus_yy.py +2 -5
  93. qiskit/circuit/library/standard_gates/y.py +4 -9
  94. qiskit/circuit/library/standard_gates/z.py +5 -15
  95. qiskit/circuit/measure.py +11 -2
  96. qiskit/circuit/parameterexpression.py +4 -0
  97. qiskit/circuit/quantumcircuit.py +881 -555
  98. qiskit/circuit/random/utils.py +12 -6
  99. qiskit/circuit/reset.py +5 -2
  100. qiskit/circuit/singleton.py +5 -11
  101. qiskit/circuit/store.py +0 -8
  102. qiskit/compiler/__init__.py +1 -7
  103. qiskit/compiler/transpiler.py +38 -196
  104. qiskit/converters/circuit_to_dag.py +4 -2
  105. qiskit/converters/circuit_to_dagdependency.py +0 -2
  106. qiskit/converters/circuit_to_dagdependency_v2.py +0 -1
  107. qiskit/converters/circuit_to_gate.py +1 -1
  108. qiskit/converters/circuit_to_instruction.py +16 -29
  109. qiskit/converters/dag_to_circuit.py +5 -5
  110. qiskit/converters/dag_to_dagdependency.py +0 -1
  111. qiskit/converters/dag_to_dagdependency_v2.py +0 -1
  112. qiskit/converters/dagdependency_to_circuit.py +0 -6
  113. qiskit/converters/dagdependency_to_dag.py +0 -6
  114. qiskit/dagcircuit/collect_blocks.py +32 -20
  115. qiskit/dagcircuit/dagdependency.py +3 -37
  116. qiskit/dagcircuit/dagdependency_v2.py +2 -80
  117. qiskit/dagcircuit/dagnode.py +14 -2
  118. qiskit/passmanager/__init__.py +24 -6
  119. qiskit/passmanager/passmanager.py +26 -24
  120. qiskit/primitives/__init__.py +44 -35
  121. qiskit/primitives/backend_estimator_v2.py +102 -23
  122. qiskit/primitives/backend_sampler_v2.py +5 -20
  123. qiskit/primitives/base/__init__.py +4 -4
  124. qiskit/primitives/base/base_estimator.py +77 -82
  125. qiskit/primitives/base/base_primitive_job.py +2 -2
  126. qiskit/primitives/base/{base_primitive.py → base_primitive_v1.py} +1 -1
  127. qiskit/primitives/base/{base_result.py → base_result_v1.py} +1 -1
  128. qiskit/primitives/base/base_sampler.py +52 -60
  129. qiskit/primitives/base/{estimator_result.py → estimator_result_v1.py} +2 -2
  130. qiskit/primitives/base/{sampler_result.py → sampler_result_v1.py} +2 -2
  131. qiskit/primitives/base/{validation.py → validation_v1.py} +34 -15
  132. qiskit/primitives/containers/bindings_array.py +3 -1
  133. qiskit/primitives/containers/bit_array.py +23 -0
  134. qiskit/primitives/containers/data_bin.py +3 -1
  135. qiskit/primitives/containers/observables_array.py +19 -2
  136. qiskit/primitives/statevector_sampler.py +6 -8
  137. qiskit/primitives/utils.py +14 -189
  138. qiskit/providers/__init__.py +4 -130
  139. qiskit/providers/backend.py +11 -314
  140. qiskit/providers/basic_provider/__init__.py +3 -1
  141. qiskit/providers/basic_provider/basic_provider.py +29 -9
  142. qiskit/providers/basic_provider/basic_simulator.py +158 -298
  143. qiskit/providers/exceptions.py +0 -33
  144. qiskit/providers/fake_provider/__init__.py +0 -37
  145. qiskit/providers/fake_provider/generic_backend_v2.py +32 -693
  146. qiskit/qasm2/__init__.py +21 -6
  147. qiskit/qasm2/export.py +2 -10
  148. qiskit/qasm2/parse.py +11 -25
  149. qiskit/qasm3/__init__.py +5 -1
  150. qiskit/qasm3/ast.py +44 -0
  151. qiskit/qasm3/exporter.py +65 -27
  152. qiskit/qasm3/printer.py +35 -4
  153. qiskit/qpy/__init__.py +141 -19
  154. qiskit/qpy/binary_io/__init__.py +0 -1
  155. qiskit/qpy/binary_io/circuits.py +91 -116
  156. qiskit/qpy/binary_io/schedules.py +61 -388
  157. qiskit/qpy/binary_io/value.py +154 -28
  158. qiskit/qpy/common.py +10 -7
  159. qiskit/qpy/formats.py +41 -0
  160. qiskit/qpy/interface.py +29 -62
  161. qiskit/qpy/type_keys.py +58 -221
  162. qiskit/quantum_info/analysis/distance.py +3 -1
  163. qiskit/quantum_info/operators/dihedral/dihedral.py +3 -1
  164. qiskit/quantum_info/operators/operator.py +6 -2
  165. qiskit/quantum_info/operators/symplectic/clifford.py +3 -1
  166. qiskit/quantum_info/operators/symplectic/pauli.py +4 -2
  167. qiskit/quantum_info/operators/symplectic/pauli_list.py +17 -5
  168. qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +40 -6
  169. qiskit/quantum_info/states/densitymatrix.py +16 -6
  170. qiskit/quantum_info/states/stabilizerstate.py +35 -4
  171. qiskit/quantum_info/states/statevector.py +16 -6
  172. qiskit/result/__init__.py +5 -17
  173. qiskit/result/models.py +18 -10
  174. qiskit/result/result.py +28 -126
  175. qiskit/result/sampled_expval.py +1 -2
  176. qiskit/result/utils.py +3 -4
  177. qiskit/synthesis/__init__.py +21 -1
  178. qiskit/synthesis/arithmetic/__init__.py +3 -1
  179. qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +1 -1
  180. qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +1 -1
  181. qiskit/synthesis/arithmetic/adders/vbe_ripple_carry_adder.py +2 -2
  182. qiskit/{providers/fake_provider/backends_v1/fake_20q → synthesis/arithmetic/comparators}/__init__.py +4 -6
  183. qiskit/synthesis/arithmetic/comparators/compare_2s.py +112 -0
  184. qiskit/synthesis/arithmetic/comparators/compare_greedy.py +66 -0
  185. qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +1 -1
  186. qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +1 -1
  187. qiskit/synthesis/arithmetic/weighted_sum.py +155 -0
  188. qiskit/{result/mitigation → synthesis/boolean}/__init__.py +2 -2
  189. qiskit/synthesis/boolean/boolean_expression.py +231 -0
  190. qiskit/synthesis/boolean/boolean_expression_synth.py +124 -0
  191. qiskit/synthesis/boolean/boolean_expression_visitor.py +96 -0
  192. qiskit/synthesis/discrete_basis/generate_basis_approximations.py +2 -0
  193. qiskit/synthesis/evolution/lie_trotter.py +10 -7
  194. qiskit/synthesis/evolution/product_formula.py +44 -35
  195. qiskit/synthesis/evolution/qdrift.py +17 -24
  196. qiskit/synthesis/evolution/suzuki_trotter.py +20 -27
  197. qiskit/synthesis/linear/linear_depth_lnn.py +6 -221
  198. qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +4 -205
  199. qiskit/synthesis/multi_controlled/__init__.py +1 -0
  200. qiskit/synthesis/multi_controlled/mcx_synthesis.py +5 -2
  201. qiskit/synthesis/multi_controlled/multi_control_rotation_gates.py +206 -0
  202. qiskit/synthesis/one_qubit/one_qubit_decompose.py +1 -1
  203. qiskit/synthesis/two_qubit/__init__.py +1 -0
  204. qiskit/synthesis/two_qubit/two_qubit_decompose.py +28 -145
  205. qiskit/transpiler/__init__.py +32 -232
  206. qiskit/transpiler/basepasses.py +20 -51
  207. qiskit/transpiler/layout.py +1 -1
  208. qiskit/transpiler/passes/__init__.py +2 -40
  209. qiskit/transpiler/passes/basis/basis_translator.py +4 -3
  210. qiskit/transpiler/passes/basis/decompose.py +1 -15
  211. qiskit/transpiler/passes/basis/unroll_3q_or_more.py +1 -5
  212. qiskit/transpiler/passes/basis/unroll_custom_definitions.py +3 -2
  213. qiskit/transpiler/passes/layout/apply_layout.py +4 -0
  214. qiskit/transpiler/passes/layout/dense_layout.py +2 -39
  215. qiskit/transpiler/passes/layout/full_ancilla_allocation.py +4 -4
  216. qiskit/transpiler/passes/layout/sabre_layout.py +7 -3
  217. qiskit/transpiler/passes/layout/vf2_layout.py +2 -20
  218. qiskit/transpiler/passes/layout/vf2_post_layout.py +60 -125
  219. qiskit/transpiler/passes/layout/vf2_utils.py +2 -26
  220. qiskit/transpiler/passes/optimization/__init__.py +1 -3
  221. qiskit/transpiler/passes/optimization/collect_and_collapse.py +2 -0
  222. qiskit/transpiler/passes/optimization/collect_cliffords.py +5 -0
  223. qiskit/transpiler/passes/optimization/collect_linear_functions.py +5 -0
  224. qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +16 -1
  225. qiskit/transpiler/passes/optimization/commutation_analysis.py +3 -3
  226. qiskit/transpiler/passes/optimization/consolidate_blocks.py +41 -19
  227. qiskit/transpiler/passes/optimization/contract_idle_wires_in_control_flow.py +104 -0
  228. qiskit/transpiler/passes/optimization/light_cone.py +135 -0
  229. qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +0 -1
  230. qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +18 -22
  231. qiskit/transpiler/passes/optimization/optimize_annotated.py +3 -2
  232. qiskit/transpiler/passes/optimization/remove_identity_equiv.py +6 -4
  233. qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +5 -2
  234. qiskit/transpiler/passes/optimization/split_2q_unitaries.py +26 -3
  235. qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +1 -0
  236. qiskit/transpiler/passes/routing/__init__.py +0 -1
  237. qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +3 -1
  238. qiskit/transpiler/passes/routing/sabre_swap.py +14 -6
  239. qiskit/transpiler/passes/routing/star_prerouting.py +1 -1
  240. qiskit/transpiler/passes/scheduling/__init__.py +1 -7
  241. qiskit/transpiler/passes/scheduling/alignments/__init__.py +2 -4
  242. qiskit/transpiler/passes/scheduling/alignments/check_durations.py +1 -9
  243. qiskit/transpiler/passes/scheduling/alignments/reschedule.py +17 -16
  244. qiskit/transpiler/passes/scheduling/padding/base_padding.py +30 -2
  245. qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +20 -58
  246. qiskit/transpiler/passes/scheduling/padding/pad_delay.py +11 -3
  247. qiskit/transpiler/passes/scheduling/scheduling/alap.py +5 -39
  248. qiskit/transpiler/passes/scheduling/scheduling/asap.py +4 -35
  249. qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +10 -16
  250. qiskit/transpiler/passes/scheduling/time_unit_conversion.py +127 -59
  251. qiskit/transpiler/passes/synthesis/default_unitary_synth_plugin.py +653 -0
  252. qiskit/transpiler/passes/synthesis/high_level_synthesis.py +176 -601
  253. qiskit/transpiler/passes/synthesis/hls_plugins.py +294 -1
  254. qiskit/transpiler/passes/synthesis/plugin.py +4 -0
  255. qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +16 -10
  256. qiskit/transpiler/passes/synthesis/unitary_synthesis.py +34 -697
  257. qiskit/transpiler/passes/utils/__init__.py +0 -1
  258. qiskit/transpiler/passes/utils/check_gate_direction.py +13 -5
  259. qiskit/transpiler/passes/utils/control_flow.py +2 -6
  260. qiskit/transpiler/passes/utils/gate_direction.py +7 -0
  261. qiskit/transpiler/passes/utils/remove_final_measurements.py +40 -33
  262. qiskit/transpiler/passmanager.py +13 -0
  263. qiskit/transpiler/passmanager_config.py +5 -81
  264. qiskit/transpiler/preset_passmanagers/builtin_plugins.py +225 -344
  265. qiskit/transpiler/preset_passmanagers/common.py +140 -167
  266. qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +101 -322
  267. qiskit/transpiler/preset_passmanagers/level0.py +2 -11
  268. qiskit/transpiler/preset_passmanagers/level1.py +2 -14
  269. qiskit/transpiler/preset_passmanagers/level2.py +2 -12
  270. qiskit/transpiler/preset_passmanagers/level3.py +2 -11
  271. qiskit/transpiler/preset_passmanagers/plugin.py +5 -3
  272. qiskit/transpiler/target.py +67 -524
  273. qiskit/user_config.py +8 -4
  274. qiskit/utils/__init__.py +13 -12
  275. qiskit/utils/deprecation.py +4 -112
  276. qiskit/utils/optionals.py +11 -4
  277. qiskit/utils/parallel.py +214 -87
  278. qiskit/utils/units.py +4 -1
  279. qiskit/visualization/__init__.py +3 -7
  280. qiskit/visualization/array.py +4 -1
  281. qiskit/visualization/bloch.py +1 -1
  282. qiskit/visualization/circuit/_utils.py +19 -19
  283. qiskit/visualization/circuit/circuit_visualization.py +11 -4
  284. qiskit/visualization/circuit/matplotlib.py +13 -23
  285. qiskit/visualization/circuit/text.py +7 -3
  286. qiskit/visualization/dag_visualization.py +2 -1
  287. qiskit/visualization/gate_map.py +39 -154
  288. qiskit/visualization/pass_manager_visualization.py +6 -2
  289. qiskit/visualization/state_visualization.py +6 -0
  290. qiskit/visualization/timeline/core.py +18 -12
  291. qiskit/visualization/timeline/interface.py +19 -18
  292. {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/METADATA +2 -2
  293. {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/RECORD +297 -444
  294. {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/WHEEL +2 -1
  295. {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/entry_points.txt +8 -2
  296. qiskit/assembler/__init__.py +0 -42
  297. qiskit/assembler/assemble_circuits.py +0 -451
  298. qiskit/assembler/assemble_schedules.py +0 -367
  299. qiskit/assembler/disassemble.py +0 -310
  300. qiskit/assembler/run_config.py +0 -77
  301. qiskit/circuit/bit.py +0 -106
  302. qiskit/circuit/classicalfunction/__init__.py +0 -152
  303. qiskit/circuit/classicalfunction/boolean_expression.py +0 -138
  304. qiskit/circuit/classicalfunction/classical_element.py +0 -54
  305. qiskit/circuit/classicalfunction/classical_function_visitor.py +0 -155
  306. qiskit/circuit/classicalfunction/classicalfunction.py +0 -182
  307. qiskit/circuit/classicalfunction/exceptions.py +0 -41
  308. qiskit/circuit/classicalfunction/types.py +0 -18
  309. qiskit/circuit/classicalfunction/utils.py +0 -91
  310. qiskit/circuit/classicalregister.py +0 -57
  311. qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +0 -405
  312. qiskit/circuit/quantumregister.py +0 -75
  313. qiskit/circuit/register.py +0 -246
  314. qiskit/compiler/assembler.py +0 -689
  315. qiskit/compiler/scheduler.py +0 -109
  316. qiskit/compiler/sequencer.py +0 -71
  317. qiskit/primitives/backend_estimator.py +0 -486
  318. qiskit/primitives/backend_sampler.py +0 -222
  319. qiskit/primitives/estimator.py +0 -172
  320. qiskit/primitives/sampler.py +0 -162
  321. qiskit/providers/backend_compat.py +0 -507
  322. qiskit/providers/fake_provider/backends_v1/__init__.py +0 -22
  323. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +0 -18
  324. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +0 -1
  325. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +0 -1
  326. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +0 -37
  327. qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +0 -1
  328. qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +0 -1
  329. qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +0 -43
  330. qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +0 -1
  331. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +0 -18
  332. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +0 -1
  333. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +0 -1
  334. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +0 -50
  335. qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +0 -1
  336. qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +0 -18
  337. qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +0 -1
  338. qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +0 -41
  339. qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +0 -1
  340. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +0 -18
  341. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +0 -1
  342. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +0 -1
  343. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +0 -44
  344. qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +0 -1
  345. qiskit/providers/fake_provider/fake_1q.py +0 -91
  346. qiskit/providers/fake_provider/fake_backend.py +0 -165
  347. qiskit/providers/fake_provider/fake_openpulse_2q.py +0 -391
  348. qiskit/providers/fake_provider/fake_openpulse_3q.py +0 -340
  349. qiskit/providers/fake_provider/fake_pulse_backend.py +0 -49
  350. qiskit/providers/fake_provider/fake_qasm_backend.py +0 -77
  351. qiskit/providers/fake_provider/utils/backend_converter.py +0 -150
  352. qiskit/providers/fake_provider/utils/json_decoder.py +0 -109
  353. qiskit/providers/models/__init__.py +0 -89
  354. qiskit/providers/models/backendconfiguration.py +0 -1040
  355. qiskit/providers/models/backendproperties.py +0 -535
  356. qiskit/providers/models/backendstatus.py +0 -104
  357. qiskit/providers/models/jobstatus.py +0 -77
  358. qiskit/providers/models/pulsedefaults.py +0 -305
  359. qiskit/providers/provider.py +0 -95
  360. qiskit/pulse/__init__.py +0 -158
  361. qiskit/pulse/builder.py +0 -2262
  362. qiskit/pulse/calibration_entries.py +0 -381
  363. qiskit/pulse/channels.py +0 -227
  364. qiskit/pulse/configuration.py +0 -245
  365. qiskit/pulse/exceptions.py +0 -45
  366. qiskit/pulse/filters.py +0 -309
  367. qiskit/pulse/instruction_schedule_map.py +0 -424
  368. qiskit/pulse/instructions/__init__.py +0 -67
  369. qiskit/pulse/instructions/acquire.py +0 -150
  370. qiskit/pulse/instructions/delay.py +0 -71
  371. qiskit/pulse/instructions/directives.py +0 -154
  372. qiskit/pulse/instructions/frequency.py +0 -135
  373. qiskit/pulse/instructions/instruction.py +0 -270
  374. qiskit/pulse/instructions/phase.py +0 -152
  375. qiskit/pulse/instructions/play.py +0 -99
  376. qiskit/pulse/instructions/reference.py +0 -100
  377. qiskit/pulse/instructions/snapshot.py +0 -82
  378. qiskit/pulse/library/__init__.py +0 -97
  379. qiskit/pulse/library/continuous.py +0 -430
  380. qiskit/pulse/library/pulse.py +0 -148
  381. qiskit/pulse/library/samplers/__init__.py +0 -15
  382. qiskit/pulse/library/samplers/decorators.py +0 -295
  383. qiskit/pulse/library/samplers/strategies.py +0 -71
  384. qiskit/pulse/library/symbolic_pulses.py +0 -1989
  385. qiskit/pulse/library/waveform.py +0 -136
  386. qiskit/pulse/macros.py +0 -262
  387. qiskit/pulse/parameter_manager.py +0 -445
  388. qiskit/pulse/parser.py +0 -314
  389. qiskit/pulse/reference_manager.py +0 -58
  390. qiskit/pulse/schedule.py +0 -1854
  391. qiskit/pulse/transforms/__init__.py +0 -106
  392. qiskit/pulse/transforms/alignments.py +0 -406
  393. qiskit/pulse/transforms/base_transforms.py +0 -71
  394. qiskit/pulse/transforms/canonicalization.py +0 -498
  395. qiskit/pulse/transforms/dag.py +0 -122
  396. qiskit/pulse/utils.py +0 -149
  397. qiskit/qobj/__init__.py +0 -75
  398. qiskit/qobj/common.py +0 -81
  399. qiskit/qobj/converters/__init__.py +0 -18
  400. qiskit/qobj/converters/lo_config.py +0 -177
  401. qiskit/qobj/converters/pulse_instruction.py +0 -897
  402. qiskit/qobj/pulse_qobj.py +0 -709
  403. qiskit/qobj/qasm_qobj.py +0 -708
  404. qiskit/qobj/utils.py +0 -46
  405. qiskit/result/mitigation/base_readout_mitigator.py +0 -79
  406. qiskit/result/mitigation/correlated_readout_mitigator.py +0 -277
  407. qiskit/result/mitigation/local_readout_mitigator.py +0 -328
  408. qiskit/result/mitigation/utils.py +0 -217
  409. qiskit/scheduler/__init__.py +0 -40
  410. qiskit/scheduler/config.py +0 -37
  411. qiskit/scheduler/lowering.py +0 -187
  412. qiskit/scheduler/methods/__init__.py +0 -15
  413. qiskit/scheduler/methods/basic.py +0 -140
  414. qiskit/scheduler/schedule_circuit.py +0 -69
  415. qiskit/scheduler/sequence.py +0 -104
  416. qiskit/transpiler/passes/calibration/__init__.py +0 -17
  417. qiskit/transpiler/passes/calibration/base_builder.py +0 -79
  418. qiskit/transpiler/passes/calibration/builders.py +0 -20
  419. qiskit/transpiler/passes/calibration/exceptions.py +0 -22
  420. qiskit/transpiler/passes/calibration/pulse_gate.py +0 -100
  421. qiskit/transpiler/passes/calibration/rx_builder.py +0 -164
  422. qiskit/transpiler/passes/calibration/rzx_builder.py +0 -411
  423. qiskit/transpiler/passes/calibration/rzx_templates.py +0 -58
  424. qiskit/transpiler/passes/optimization/cx_cancellation.py +0 -65
  425. qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +0 -162
  426. qiskit/transpiler/passes/optimization/normalize_rx_angle.py +0 -157
  427. qiskit/transpiler/passes/routing/stochastic_swap.py +0 -532
  428. qiskit/transpiler/passes/scheduling/alap.py +0 -153
  429. qiskit/transpiler/passes/scheduling/alignments/align_measures.py +0 -255
  430. qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +0 -107
  431. qiskit/transpiler/passes/scheduling/asap.py +0 -175
  432. qiskit/transpiler/passes/scheduling/base_scheduler.py +0 -310
  433. qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +0 -313
  434. qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +0 -93
  435. qiskit/utils/deprecate_pulse.py +0 -119
  436. qiskit/utils/multiprocessing.py +0 -56
  437. qiskit/visualization/pulse_v2/__init__.py +0 -21
  438. qiskit/visualization/pulse_v2/core.py +0 -901
  439. qiskit/visualization/pulse_v2/device_info.py +0 -173
  440. qiskit/visualization/pulse_v2/drawings.py +0 -253
  441. qiskit/visualization/pulse_v2/events.py +0 -254
  442. qiskit/visualization/pulse_v2/generators/__init__.py +0 -40
  443. qiskit/visualization/pulse_v2/generators/barrier.py +0 -76
  444. qiskit/visualization/pulse_v2/generators/chart.py +0 -208
  445. qiskit/visualization/pulse_v2/generators/frame.py +0 -436
  446. qiskit/visualization/pulse_v2/generators/snapshot.py +0 -133
  447. qiskit/visualization/pulse_v2/generators/waveform.py +0 -645
  448. qiskit/visualization/pulse_v2/interface.py +0 -459
  449. qiskit/visualization/pulse_v2/layouts.py +0 -387
  450. qiskit/visualization/pulse_v2/plotters/__init__.py +0 -17
  451. qiskit/visualization/pulse_v2/plotters/base_plotter.py +0 -53
  452. qiskit/visualization/pulse_v2/plotters/matplotlib.py +0 -201
  453. qiskit/visualization/pulse_v2/stylesheet.py +0 -312
  454. qiskit/visualization/pulse_v2/types.py +0 -242
  455. {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/LICENSE.txt +0 -0
  456. {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.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