qiskit 1.4.1__cp39-abi3-win_amd64.whl → 2.0.0rc1__cp39-abi3-win_amd64.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.
- qiskit/VERSION.txt +1 -1
- qiskit/__init__.py +2 -5
- qiskit/_accelerate.pyd +0 -0
- qiskit/circuit/__init__.py +24 -5
- qiskit/circuit/{add_control.py → _add_control.py} +32 -12
- qiskit/circuit/_classical_resource_map.py +5 -3
- qiskit/circuit/barrier.py +3 -7
- qiskit/circuit/classical/expr/__init__.py +31 -3
- qiskit/circuit/classical/expr/constructors.py +248 -28
- qiskit/circuit/classical/expr/expr.py +104 -3
- qiskit/circuit/classical/expr/visitors.py +75 -0
- qiskit/circuit/classical/types/__init__.py +12 -8
- qiskit/circuit/classical/types/ordering.py +14 -7
- qiskit/circuit/classical/types/types.py +36 -0
- qiskit/circuit/commutation_checker.py +34 -7
- qiskit/circuit/controlflow/__init__.py +32 -1
- qiskit/circuit/controlflow/_builder_utils.py +9 -5
- qiskit/circuit/controlflow/box.py +163 -0
- qiskit/circuit/controlflow/break_loop.py +1 -1
- qiskit/circuit/controlflow/builder.py +139 -39
- qiskit/circuit/controlflow/continue_loop.py +1 -3
- qiskit/circuit/controlflow/control_flow.py +10 -0
- qiskit/circuit/controlflow/for_loop.py +2 -1
- qiskit/circuit/controlflow/if_else.py +3 -16
- qiskit/circuit/controlflow/switch_case.py +2 -8
- qiskit/circuit/controlflow/while_loop.py +2 -7
- qiskit/circuit/controlledgate.py +2 -4
- qiskit/circuit/delay.py +40 -11
- qiskit/circuit/duration.py +0 -15
- qiskit/circuit/gate.py +2 -4
- qiskit/circuit/instruction.py +2 -141
- qiskit/circuit/instructionset.py +7 -54
- qiskit/circuit/library/__init__.py +34 -5
- qiskit/circuit/library/arithmetic/__init__.py +16 -10
- qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +1 -1
- qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +2 -2
- qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +1 -1
- qiskit/circuit/library/arithmetic/exact_reciprocal.py +64 -21
- qiskit/circuit/library/arithmetic/integer_comparator.py +37 -80
- qiskit/circuit/library/arithmetic/linear_amplitude_function.py +169 -2
- qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +59 -5
- qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +154 -6
- qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +114 -4
- qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +191 -15
- qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +93 -39
- qiskit/circuit/library/arithmetic/quadratic_form.py +168 -2
- qiskit/circuit/library/arithmetic/weighted_adder.py +73 -1
- qiskit/circuit/library/bit_flip_oracle.py +130 -0
- qiskit/circuit/library/blueprintcircuit.py +52 -16
- qiskit/circuit/library/data_preparation/initializer.py +1 -1
- qiskit/circuit/library/data_preparation/pauli_feature_map.py +4 -4
- qiskit/circuit/library/data_preparation/state_preparation.py +1 -1
- qiskit/circuit/library/generalized_gates/gms.py +1 -1
- qiskit/circuit/library/generalized_gates/isometry.py +1 -1
- qiskit/circuit/library/generalized_gates/pauli.py +1 -2
- qiskit/circuit/library/generalized_gates/uc.py +97 -7
- qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +1 -1
- qiskit/circuit/library/generalized_gates/unitary.py +4 -2
- qiskit/circuit/library/hamiltonian_gate.py +1 -1
- qiskit/circuit/library/n_local/evolved_operator_ansatz.py +1 -1
- qiskit/circuit/library/n_local/n_local.py +1 -1
- qiskit/circuit/library/n_local/qaoa_ansatz.py +1 -1
- qiskit/circuit/library/overlap.py +2 -2
- qiskit/circuit/library/pauli_evolution.py +39 -24
- qiskit/circuit/library/phase_oracle.py +130 -51
- qiskit/circuit/library/standard_gates/__init__.py +0 -1
- qiskit/circuit/library/standard_gates/dcx.py +3 -4
- qiskit/circuit/library/standard_gates/ecr.py +3 -4
- qiskit/circuit/library/standard_gates/global_phase.py +5 -6
- qiskit/circuit/library/standard_gates/h.py +4 -9
- qiskit/circuit/library/standard_gates/i.py +2 -2
- qiskit/circuit/library/standard_gates/iswap.py +3 -4
- qiskit/circuit/library/standard_gates/p.py +15 -34
- qiskit/circuit/library/standard_gates/r.py +2 -6
- qiskit/circuit/library/standard_gates/rx.py +5 -15
- qiskit/circuit/library/standard_gates/rxx.py +3 -6
- qiskit/circuit/library/standard_gates/ry.py +5 -17
- qiskit/circuit/library/standard_gates/ryy.py +3 -6
- qiskit/circuit/library/standard_gates/rz.py +5 -17
- qiskit/circuit/library/standard_gates/rzx.py +3 -6
- qiskit/circuit/library/standard_gates/rzz.py +3 -6
- qiskit/circuit/library/standard_gates/s.py +6 -15
- qiskit/circuit/library/standard_gates/swap.py +4 -11
- qiskit/circuit/library/standard_gates/sx.py +7 -12
- qiskit/circuit/library/standard_gates/t.py +6 -7
- qiskit/circuit/library/standard_gates/u.py +2 -10
- qiskit/circuit/library/standard_gates/u1.py +5 -16
- qiskit/circuit/library/standard_gates/u2.py +2 -6
- qiskit/circuit/library/standard_gates/u3.py +3 -11
- qiskit/circuit/library/standard_gates/x.py +13 -60
- qiskit/circuit/library/standard_gates/xx_minus_yy.py +2 -5
- qiskit/circuit/library/standard_gates/xx_plus_yy.py +2 -5
- qiskit/circuit/library/standard_gates/y.py +4 -9
- qiskit/circuit/library/standard_gates/z.py +5 -15
- qiskit/circuit/measure.py +11 -2
- qiskit/circuit/parameterexpression.py +4 -0
- qiskit/circuit/quantumcircuit.py +881 -555
- qiskit/circuit/random/utils.py +12 -6
- qiskit/circuit/reset.py +5 -2
- qiskit/circuit/singleton.py +5 -11
- qiskit/circuit/store.py +0 -8
- qiskit/compiler/__init__.py +1 -7
- qiskit/compiler/transpiler.py +38 -196
- qiskit/converters/circuit_to_dag.py +4 -2
- qiskit/converters/circuit_to_dagdependency.py +0 -2
- qiskit/converters/circuit_to_dagdependency_v2.py +0 -1
- qiskit/converters/circuit_to_gate.py +1 -1
- qiskit/converters/circuit_to_instruction.py +16 -29
- qiskit/converters/dag_to_circuit.py +5 -5
- qiskit/converters/dag_to_dagdependency.py +0 -1
- qiskit/converters/dag_to_dagdependency_v2.py +0 -1
- qiskit/converters/dagdependency_to_circuit.py +0 -6
- qiskit/converters/dagdependency_to_dag.py +0 -6
- qiskit/dagcircuit/collect_blocks.py +32 -20
- qiskit/dagcircuit/dagdependency.py +3 -37
- qiskit/dagcircuit/dagdependency_v2.py +2 -80
- qiskit/dagcircuit/dagnode.py +14 -2
- qiskit/passmanager/__init__.py +24 -6
- qiskit/passmanager/passmanager.py +26 -24
- qiskit/primitives/__init__.py +44 -35
- qiskit/primitives/backend_estimator_v2.py +102 -23
- qiskit/primitives/backend_sampler_v2.py +5 -20
- qiskit/primitives/base/__init__.py +4 -4
- qiskit/primitives/base/base_estimator.py +77 -82
- qiskit/primitives/base/base_primitive_job.py +2 -2
- qiskit/primitives/base/{base_primitive.py → base_primitive_v1.py} +1 -1
- qiskit/primitives/base/{base_result.py → base_result_v1.py} +1 -1
- qiskit/primitives/base/base_sampler.py +52 -60
- qiskit/primitives/base/{estimator_result.py → estimator_result_v1.py} +2 -2
- qiskit/primitives/base/{sampler_result.py → sampler_result_v1.py} +2 -2
- qiskit/primitives/base/{validation.py → validation_v1.py} +34 -15
- qiskit/primitives/containers/bindings_array.py +3 -1
- qiskit/primitives/containers/bit_array.py +23 -0
- qiskit/primitives/containers/data_bin.py +3 -1
- qiskit/primitives/containers/observables_array.py +19 -2
- qiskit/primitives/statevector_sampler.py +6 -8
- qiskit/primitives/utils.py +14 -189
- qiskit/providers/__init__.py +4 -130
- qiskit/providers/backend.py +11 -314
- qiskit/providers/basic_provider/__init__.py +3 -1
- qiskit/providers/basic_provider/basic_provider.py +29 -9
- qiskit/providers/basic_provider/basic_simulator.py +158 -298
- qiskit/providers/exceptions.py +0 -33
- qiskit/providers/fake_provider/__init__.py +0 -37
- qiskit/providers/fake_provider/generic_backend_v2.py +32 -693
- qiskit/qasm2/__init__.py +21 -6
- qiskit/qasm2/export.py +2 -10
- qiskit/qasm2/parse.py +11 -25
- qiskit/qasm3/__init__.py +5 -1
- qiskit/qasm3/ast.py +44 -0
- qiskit/qasm3/exporter.py +65 -27
- qiskit/qasm3/printer.py +35 -4
- qiskit/qpy/__init__.py +141 -19
- qiskit/qpy/binary_io/__init__.py +0 -1
- qiskit/qpy/binary_io/circuits.py +91 -116
- qiskit/qpy/binary_io/schedules.py +61 -388
- qiskit/qpy/binary_io/value.py +154 -28
- qiskit/qpy/common.py +10 -7
- qiskit/qpy/formats.py +41 -0
- qiskit/qpy/interface.py +29 -62
- qiskit/qpy/type_keys.py +58 -221
- qiskit/quantum_info/analysis/distance.py +3 -1
- qiskit/quantum_info/operators/dihedral/dihedral.py +3 -1
- qiskit/quantum_info/operators/operator.py +6 -2
- qiskit/quantum_info/operators/symplectic/clifford.py +3 -1
- qiskit/quantum_info/operators/symplectic/pauli.py +4 -2
- qiskit/quantum_info/operators/symplectic/pauli_list.py +17 -5
- qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +40 -6
- qiskit/quantum_info/states/densitymatrix.py +16 -6
- qiskit/quantum_info/states/stabilizerstate.py +35 -4
- qiskit/quantum_info/states/statevector.py +16 -6
- qiskit/result/__init__.py +5 -17
- qiskit/result/models.py +18 -10
- qiskit/result/result.py +28 -126
- qiskit/result/sampled_expval.py +1 -2
- qiskit/result/utils.py +3 -4
- qiskit/synthesis/__init__.py +21 -1
- qiskit/synthesis/arithmetic/__init__.py +3 -1
- qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +1 -1
- qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +1 -1
- qiskit/synthesis/arithmetic/adders/vbe_ripple_carry_adder.py +2 -2
- qiskit/{providers/fake_provider/backends_v1/fake_20q → synthesis/arithmetic/comparators}/__init__.py +4 -6
- qiskit/synthesis/arithmetic/comparators/compare_2s.py +112 -0
- qiskit/synthesis/arithmetic/comparators/compare_greedy.py +66 -0
- qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +1 -1
- qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +1 -1
- qiskit/synthesis/arithmetic/weighted_sum.py +155 -0
- qiskit/{result/mitigation → synthesis/boolean}/__init__.py +2 -2
- qiskit/synthesis/boolean/boolean_expression.py +231 -0
- qiskit/synthesis/boolean/boolean_expression_synth.py +124 -0
- qiskit/synthesis/boolean/boolean_expression_visitor.py +96 -0
- qiskit/synthesis/discrete_basis/generate_basis_approximations.py +2 -0
- qiskit/synthesis/evolution/lie_trotter.py +10 -7
- qiskit/synthesis/evolution/product_formula.py +44 -35
- qiskit/synthesis/evolution/qdrift.py +17 -24
- qiskit/synthesis/evolution/suzuki_trotter.py +20 -27
- qiskit/synthesis/linear/linear_depth_lnn.py +6 -221
- qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +4 -205
- qiskit/synthesis/multi_controlled/__init__.py +1 -0
- qiskit/synthesis/multi_controlled/mcx_synthesis.py +5 -2
- qiskit/synthesis/multi_controlled/multi_control_rotation_gates.py +206 -0
- qiskit/synthesis/one_qubit/one_qubit_decompose.py +1 -1
- qiskit/synthesis/two_qubit/__init__.py +1 -0
- qiskit/synthesis/two_qubit/two_qubit_decompose.py +28 -145
- qiskit/transpiler/__init__.py +32 -232
- qiskit/transpiler/basepasses.py +20 -51
- qiskit/transpiler/layout.py +1 -1
- qiskit/transpiler/passes/__init__.py +2 -40
- qiskit/transpiler/passes/basis/basis_translator.py +4 -3
- qiskit/transpiler/passes/basis/decompose.py +1 -15
- qiskit/transpiler/passes/basis/unroll_3q_or_more.py +1 -5
- qiskit/transpiler/passes/basis/unroll_custom_definitions.py +3 -2
- qiskit/transpiler/passes/layout/apply_layout.py +4 -0
- qiskit/transpiler/passes/layout/dense_layout.py +2 -39
- qiskit/transpiler/passes/layout/full_ancilla_allocation.py +4 -4
- qiskit/transpiler/passes/layout/sabre_layout.py +7 -3
- qiskit/transpiler/passes/layout/vf2_layout.py +2 -20
- qiskit/transpiler/passes/layout/vf2_post_layout.py +60 -125
- qiskit/transpiler/passes/layout/vf2_utils.py +2 -26
- qiskit/transpiler/passes/optimization/__init__.py +1 -3
- qiskit/transpiler/passes/optimization/collect_and_collapse.py +2 -0
- qiskit/transpiler/passes/optimization/collect_cliffords.py +5 -0
- qiskit/transpiler/passes/optimization/collect_linear_functions.py +5 -0
- qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +16 -1
- qiskit/transpiler/passes/optimization/commutation_analysis.py +3 -3
- qiskit/transpiler/passes/optimization/consolidate_blocks.py +41 -19
- qiskit/transpiler/passes/optimization/contract_idle_wires_in_control_flow.py +104 -0
- qiskit/transpiler/passes/optimization/light_cone.py +135 -0
- qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +0 -1
- qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +18 -22
- qiskit/transpiler/passes/optimization/optimize_annotated.py +3 -2
- qiskit/transpiler/passes/optimization/remove_identity_equiv.py +6 -4
- qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +5 -2
- qiskit/transpiler/passes/optimization/split_2q_unitaries.py +26 -3
- qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +1 -0
- qiskit/transpiler/passes/routing/__init__.py +0 -1
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +3 -1
- qiskit/transpiler/passes/routing/sabre_swap.py +14 -6
- qiskit/transpiler/passes/routing/star_prerouting.py +1 -1
- qiskit/transpiler/passes/scheduling/__init__.py +1 -7
- qiskit/transpiler/passes/scheduling/alignments/__init__.py +2 -4
- qiskit/transpiler/passes/scheduling/alignments/check_durations.py +1 -9
- qiskit/transpiler/passes/scheduling/alignments/reschedule.py +17 -16
- qiskit/transpiler/passes/scheduling/padding/base_padding.py +30 -2
- qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +20 -58
- qiskit/transpiler/passes/scheduling/padding/pad_delay.py +11 -3
- qiskit/transpiler/passes/scheduling/scheduling/alap.py +5 -39
- qiskit/transpiler/passes/scheduling/scheduling/asap.py +4 -35
- qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +10 -16
- qiskit/transpiler/passes/scheduling/time_unit_conversion.py +127 -59
- qiskit/transpiler/passes/synthesis/default_unitary_synth_plugin.py +653 -0
- qiskit/transpiler/passes/synthesis/high_level_synthesis.py +176 -601
- qiskit/transpiler/passes/synthesis/hls_plugins.py +294 -1
- qiskit/transpiler/passes/synthesis/plugin.py +4 -0
- qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +16 -10
- qiskit/transpiler/passes/synthesis/unitary_synthesis.py +34 -697
- qiskit/transpiler/passes/utils/__init__.py +0 -1
- qiskit/transpiler/passes/utils/check_gate_direction.py +13 -5
- qiskit/transpiler/passes/utils/control_flow.py +2 -6
- qiskit/transpiler/passes/utils/gate_direction.py +7 -0
- qiskit/transpiler/passes/utils/remove_final_measurements.py +40 -33
- qiskit/transpiler/passmanager.py +13 -0
- qiskit/transpiler/passmanager_config.py +5 -81
- qiskit/transpiler/preset_passmanagers/builtin_plugins.py +225 -344
- qiskit/transpiler/preset_passmanagers/common.py +140 -167
- qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +101 -322
- qiskit/transpiler/preset_passmanagers/level0.py +2 -11
- qiskit/transpiler/preset_passmanagers/level1.py +2 -14
- qiskit/transpiler/preset_passmanagers/level2.py +2 -12
- qiskit/transpiler/preset_passmanagers/level3.py +2 -11
- qiskit/transpiler/preset_passmanagers/plugin.py +5 -3
- qiskit/transpiler/target.py +67 -524
- qiskit/user_config.py +8 -4
- qiskit/utils/__init__.py +13 -12
- qiskit/utils/deprecation.py +4 -112
- qiskit/utils/optionals.py +11 -4
- qiskit/utils/parallel.py +214 -87
- qiskit/utils/units.py +4 -1
- qiskit/visualization/__init__.py +3 -7
- qiskit/visualization/array.py +4 -1
- qiskit/visualization/bloch.py +1 -1
- qiskit/visualization/circuit/_utils.py +19 -19
- qiskit/visualization/circuit/circuit_visualization.py +11 -4
- qiskit/visualization/circuit/matplotlib.py +13 -23
- qiskit/visualization/circuit/text.py +7 -3
- qiskit/visualization/dag_visualization.py +2 -1
- qiskit/visualization/gate_map.py +39 -154
- qiskit/visualization/pass_manager_visualization.py +6 -2
- qiskit/visualization/state_visualization.py +6 -0
- qiskit/visualization/timeline/core.py +18 -12
- qiskit/visualization/timeline/interface.py +19 -18
- {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/METADATA +2 -2
- {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/RECORD +297 -444
- {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/WHEEL +1 -1
- {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/entry_points.txt +8 -2
- qiskit/assembler/__init__.py +0 -42
- qiskit/assembler/assemble_circuits.py +0 -451
- qiskit/assembler/assemble_schedules.py +0 -367
- qiskit/assembler/disassemble.py +0 -310
- qiskit/assembler/run_config.py +0 -77
- qiskit/circuit/bit.py +0 -106
- qiskit/circuit/classicalfunction/__init__.py +0 -152
- qiskit/circuit/classicalfunction/boolean_expression.py +0 -138
- qiskit/circuit/classicalfunction/classical_element.py +0 -54
- qiskit/circuit/classicalfunction/classical_function_visitor.py +0 -155
- qiskit/circuit/classicalfunction/classicalfunction.py +0 -182
- qiskit/circuit/classicalfunction/exceptions.py +0 -41
- qiskit/circuit/classicalfunction/types.py +0 -18
- qiskit/circuit/classicalfunction/utils.py +0 -91
- qiskit/circuit/classicalregister.py +0 -57
- qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +0 -405
- qiskit/circuit/quantumregister.py +0 -75
- qiskit/circuit/register.py +0 -246
- qiskit/compiler/assembler.py +0 -689
- qiskit/compiler/scheduler.py +0 -109
- qiskit/compiler/sequencer.py +0 -71
- qiskit/primitives/backend_estimator.py +0 -486
- qiskit/primitives/backend_sampler.py +0 -222
- qiskit/primitives/estimator.py +0 -172
- qiskit/primitives/sampler.py +0 -162
- qiskit/providers/backend_compat.py +0 -507
- qiskit/providers/fake_provider/backends_v1/__init__.py +0 -22
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +0 -18
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +0 -37
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +0 -43
- qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +0 -18
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +0 -50
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +0 -18
- qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +0 -41
- qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +0 -18
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +0 -1
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +0 -44
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +0 -1
- qiskit/providers/fake_provider/fake_1q.py +0 -91
- qiskit/providers/fake_provider/fake_backend.py +0 -165
- qiskit/providers/fake_provider/fake_openpulse_2q.py +0 -391
- qiskit/providers/fake_provider/fake_openpulse_3q.py +0 -340
- qiskit/providers/fake_provider/fake_pulse_backend.py +0 -49
- qiskit/providers/fake_provider/fake_qasm_backend.py +0 -77
- qiskit/providers/fake_provider/utils/backend_converter.py +0 -150
- qiskit/providers/fake_provider/utils/json_decoder.py +0 -109
- qiskit/providers/models/__init__.py +0 -89
- qiskit/providers/models/backendconfiguration.py +0 -1040
- qiskit/providers/models/backendproperties.py +0 -535
- qiskit/providers/models/backendstatus.py +0 -104
- qiskit/providers/models/jobstatus.py +0 -77
- qiskit/providers/models/pulsedefaults.py +0 -305
- qiskit/providers/provider.py +0 -95
- qiskit/pulse/__init__.py +0 -158
- qiskit/pulse/builder.py +0 -2262
- qiskit/pulse/calibration_entries.py +0 -381
- qiskit/pulse/channels.py +0 -227
- qiskit/pulse/configuration.py +0 -245
- qiskit/pulse/exceptions.py +0 -45
- qiskit/pulse/filters.py +0 -309
- qiskit/pulse/instruction_schedule_map.py +0 -424
- qiskit/pulse/instructions/__init__.py +0 -67
- qiskit/pulse/instructions/acquire.py +0 -150
- qiskit/pulse/instructions/delay.py +0 -71
- qiskit/pulse/instructions/directives.py +0 -154
- qiskit/pulse/instructions/frequency.py +0 -135
- qiskit/pulse/instructions/instruction.py +0 -270
- qiskit/pulse/instructions/phase.py +0 -152
- qiskit/pulse/instructions/play.py +0 -99
- qiskit/pulse/instructions/reference.py +0 -100
- qiskit/pulse/instructions/snapshot.py +0 -82
- qiskit/pulse/library/__init__.py +0 -97
- qiskit/pulse/library/continuous.py +0 -430
- qiskit/pulse/library/pulse.py +0 -148
- qiskit/pulse/library/samplers/__init__.py +0 -15
- qiskit/pulse/library/samplers/decorators.py +0 -295
- qiskit/pulse/library/samplers/strategies.py +0 -71
- qiskit/pulse/library/symbolic_pulses.py +0 -1989
- qiskit/pulse/library/waveform.py +0 -136
- qiskit/pulse/macros.py +0 -262
- qiskit/pulse/parameter_manager.py +0 -445
- qiskit/pulse/parser.py +0 -314
- qiskit/pulse/reference_manager.py +0 -58
- qiskit/pulse/schedule.py +0 -1854
- qiskit/pulse/transforms/__init__.py +0 -106
- qiskit/pulse/transforms/alignments.py +0 -406
- qiskit/pulse/transforms/base_transforms.py +0 -71
- qiskit/pulse/transforms/canonicalization.py +0 -498
- qiskit/pulse/transforms/dag.py +0 -122
- qiskit/pulse/utils.py +0 -149
- qiskit/qobj/__init__.py +0 -75
- qiskit/qobj/common.py +0 -81
- qiskit/qobj/converters/__init__.py +0 -18
- qiskit/qobj/converters/lo_config.py +0 -177
- qiskit/qobj/converters/pulse_instruction.py +0 -897
- qiskit/qobj/pulse_qobj.py +0 -709
- qiskit/qobj/qasm_qobj.py +0 -708
- qiskit/qobj/utils.py +0 -46
- qiskit/result/mitigation/base_readout_mitigator.py +0 -79
- qiskit/result/mitigation/correlated_readout_mitigator.py +0 -277
- qiskit/result/mitigation/local_readout_mitigator.py +0 -328
- qiskit/result/mitigation/utils.py +0 -217
- qiskit/scheduler/__init__.py +0 -40
- qiskit/scheduler/config.py +0 -37
- qiskit/scheduler/lowering.py +0 -187
- qiskit/scheduler/methods/__init__.py +0 -15
- qiskit/scheduler/methods/basic.py +0 -140
- qiskit/scheduler/schedule_circuit.py +0 -69
- qiskit/scheduler/sequence.py +0 -104
- qiskit/transpiler/passes/calibration/__init__.py +0 -17
- qiskit/transpiler/passes/calibration/base_builder.py +0 -79
- qiskit/transpiler/passes/calibration/builders.py +0 -20
- qiskit/transpiler/passes/calibration/exceptions.py +0 -22
- qiskit/transpiler/passes/calibration/pulse_gate.py +0 -100
- qiskit/transpiler/passes/calibration/rx_builder.py +0 -164
- qiskit/transpiler/passes/calibration/rzx_builder.py +0 -411
- qiskit/transpiler/passes/calibration/rzx_templates.py +0 -58
- qiskit/transpiler/passes/optimization/cx_cancellation.py +0 -65
- qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +0 -162
- qiskit/transpiler/passes/optimization/normalize_rx_angle.py +0 -157
- qiskit/transpiler/passes/routing/stochastic_swap.py +0 -532
- qiskit/transpiler/passes/scheduling/alap.py +0 -153
- qiskit/transpiler/passes/scheduling/alignments/align_measures.py +0 -255
- qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +0 -107
- qiskit/transpiler/passes/scheduling/asap.py +0 -175
- qiskit/transpiler/passes/scheduling/base_scheduler.py +0 -310
- qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +0 -313
- qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +0 -93
- qiskit/utils/deprecate_pulse.py +0 -119
- qiskit/utils/multiprocessing.py +0 -56
- qiskit/visualization/pulse_v2/__init__.py +0 -21
- qiskit/visualization/pulse_v2/core.py +0 -901
- qiskit/visualization/pulse_v2/device_info.py +0 -173
- qiskit/visualization/pulse_v2/drawings.py +0 -253
- qiskit/visualization/pulse_v2/events.py +0 -254
- qiskit/visualization/pulse_v2/generators/__init__.py +0 -40
- qiskit/visualization/pulse_v2/generators/barrier.py +0 -76
- qiskit/visualization/pulse_v2/generators/chart.py +0 -208
- qiskit/visualization/pulse_v2/generators/frame.py +0 -436
- qiskit/visualization/pulse_v2/generators/snapshot.py +0 -133
- qiskit/visualization/pulse_v2/generators/waveform.py +0 -645
- qiskit/visualization/pulse_v2/interface.py +0 -459
- qiskit/visualization/pulse_v2/layouts.py +0 -387
- qiskit/visualization/pulse_v2/plotters/__init__.py +0 -17
- qiskit/visualization/pulse_v2/plotters/base_plotter.py +0 -53
- qiskit/visualization/pulse_v2/plotters/matplotlib.py +0 -201
- qiskit/visualization/pulse_v2/stylesheet.py +0 -312
- qiskit/visualization/pulse_v2/types.py +0 -242
- {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/LICENSE.txt +0 -0
- {qiskit-1.4.1.dist-info → qiskit-2.0.0rc1.dist-info}/top_level.txt +0 -0
@@ -1,255 +0,0 @@
|
|
1
|
-
# This code is part of Qiskit.
|
2
|
-
#
|
3
|
-
# (C) Copyright IBM 2021.
|
4
|
-
#
|
5
|
-
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
-
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
-
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
-
#
|
9
|
-
# Any modifications or derivative works of this code must retain this
|
10
|
-
# copyright notice, and modified files need to carry a notice indicating
|
11
|
-
# that they have been altered from the originals.
|
12
|
-
|
13
|
-
"""Align measurement instructions."""
|
14
|
-
from __future__ import annotations
|
15
|
-
import itertools
|
16
|
-
import warnings
|
17
|
-
from collections import defaultdict
|
18
|
-
from collections.abc import Iterable
|
19
|
-
from typing import Type
|
20
|
-
|
21
|
-
from qiskit.circuit.quantumcircuit import ClbitSpecifier, QubitSpecifier
|
22
|
-
|
23
|
-
from qiskit.circuit.delay import Delay
|
24
|
-
from qiskit.circuit.measure import Measure
|
25
|
-
from qiskit.circuit.parameterexpression import ParameterExpression
|
26
|
-
from qiskit.dagcircuit import DAGCircuit
|
27
|
-
from qiskit.transpiler.basepasses import TransformationPass
|
28
|
-
from qiskit.transpiler.exceptions import TranspilerError
|
29
|
-
from qiskit.utils.deprecation import deprecate_func
|
30
|
-
|
31
|
-
|
32
|
-
class AlignMeasures(TransformationPass):
|
33
|
-
"""Measurement alignment.
|
34
|
-
|
35
|
-
This is a control electronics aware optimization pass.
|
36
|
-
|
37
|
-
In many quantum computing architectures gates (instructions) are implemented with
|
38
|
-
shaped analog stimulus signals. These signals are digitally stored in the
|
39
|
-
waveform memory of the control electronics and converted into analog voltage signals
|
40
|
-
by electronic components called digital to analog converters (DAC).
|
41
|
-
|
42
|
-
In a typical hardware implementation of superconducting quantum processors,
|
43
|
-
a single qubit instruction is implemented by a
|
44
|
-
microwave signal with the duration of around several tens of ns with a per-sample
|
45
|
-
time resolution of ~0.1-10ns, as reported by ``backend.configuration().dt``.
|
46
|
-
In such systems requiring higher DAC bandwidth, control electronics often
|
47
|
-
defines a `pulse granularity`, in other words a data chunk, to allow the DAC to
|
48
|
-
perform the signal conversion in parallel to gain the bandwidth.
|
49
|
-
|
50
|
-
Measurement alignment is required if a backend only allows triggering ``measure``
|
51
|
-
instructions at a certain multiple value of this pulse granularity.
|
52
|
-
This value is usually provided by ``backend.configuration().timing_constraints``.
|
53
|
-
|
54
|
-
In Qiskit SDK, the duration of delay can take arbitrary value in units of ``dt``,
|
55
|
-
thus circuits involving delays may violate the above alignment constraint (i.e. misalignment).
|
56
|
-
This pass shifts measurement instructions to a new time position to fix the misalignment,
|
57
|
-
by inserting extra delay right before the measure instructions.
|
58
|
-
The input of this pass should be scheduled :class:`~qiskit.dagcircuit.DAGCircuit`,
|
59
|
-
thus one should select one of the scheduling passes
|
60
|
-
(:class:`~qiskit.transpiler.passes.ALAPSchedule` or
|
61
|
-
:class:`~qiskit.trasnpiler.passes.ASAPSchedule`) before calling this.
|
62
|
-
|
63
|
-
Examples:
|
64
|
-
We assume executing the following circuit on a backend with ``alignment=16``.
|
65
|
-
|
66
|
-
.. code-block:: text
|
67
|
-
|
68
|
-
┌───┐┌────────────────┐┌─┐
|
69
|
-
q_0: ┤ X ├┤ Delay(100[dt]) ├┤M├
|
70
|
-
└───┘└────────────────┘└╥┘
|
71
|
-
c: 1/════════════════════════╩═
|
72
|
-
0
|
73
|
-
|
74
|
-
Note that delay of 100 dt induces a misalignment of 4 dt at the measurement.
|
75
|
-
This pass appends an extra 12 dt time shift to the input circuit.
|
76
|
-
|
77
|
-
.. code-block:: text
|
78
|
-
|
79
|
-
┌───┐┌────────────────┐┌─┐
|
80
|
-
q_0: ┤ X ├┤ Delay(112[dt]) ├┤M├
|
81
|
-
└───┘└────────────────┘└╥┘
|
82
|
-
c: 1/════════════════════════╩═
|
83
|
-
0
|
84
|
-
|
85
|
-
This pass always inserts a positive delay before measurements
|
86
|
-
rather than reducing other delays.
|
87
|
-
|
88
|
-
Notes:
|
89
|
-
The Backend may allow users to execute circuits violating the alignment constraint.
|
90
|
-
However, it may return meaningless measurement data mainly due to the phase error.
|
91
|
-
"""
|
92
|
-
|
93
|
-
@deprecate_func(
|
94
|
-
additional_msg=(
|
95
|
-
"Instead, use :class:`~.ConstrainedReschedule`, which performs the same function "
|
96
|
-
"but also supports aligning to additional timing constraints."
|
97
|
-
),
|
98
|
-
since="1.1.0",
|
99
|
-
)
|
100
|
-
def __init__(self, alignment: int = 1):
|
101
|
-
"""Create new pass.
|
102
|
-
|
103
|
-
Args:
|
104
|
-
alignment: Integer number representing the minimum time resolution to
|
105
|
-
trigger measure instruction in units of ``dt``. This value depends on
|
106
|
-
the control electronics of your quantum processor.
|
107
|
-
"""
|
108
|
-
super().__init__()
|
109
|
-
self.alignment = alignment
|
110
|
-
|
111
|
-
def run(self, dag: DAGCircuit):
|
112
|
-
"""Run the measurement alignment pass on `dag`.
|
113
|
-
|
114
|
-
Args:
|
115
|
-
dag (DAGCircuit): DAG to be checked.
|
116
|
-
|
117
|
-
Returns:
|
118
|
-
DAGCircuit: DAG with consistent timing and op nodes annotated with duration.
|
119
|
-
|
120
|
-
Raises:
|
121
|
-
TranspilerError: If circuit is not scheduled.
|
122
|
-
"""
|
123
|
-
time_unit = self.property_set["time_unit"]
|
124
|
-
|
125
|
-
if not _check_alignment_required(dag, self.alignment, Measure):
|
126
|
-
# return input as-is to avoid unnecessary scheduling.
|
127
|
-
# because following procedure regenerate new DAGCircuit,
|
128
|
-
# we should avoid continuing if not necessary from performance viewpoint.
|
129
|
-
return dag
|
130
|
-
|
131
|
-
# if circuit is not yet scheduled, schedule with ALAP method
|
132
|
-
if dag.duration is None:
|
133
|
-
raise TranspilerError(
|
134
|
-
f"This circuit {dag.name} may involve a delay instruction violating the "
|
135
|
-
"pulse controller alignment. To adjust instructions to "
|
136
|
-
"right timing, you should call one of scheduling passes first. "
|
137
|
-
"This is usually done by calling transpiler with scheduling_method='alap'."
|
138
|
-
)
|
139
|
-
|
140
|
-
# the following lines are basically copied from ASAPSchedule pass
|
141
|
-
#
|
142
|
-
# * some validations for non-scheduled nodes are dropped, since we assume scheduled input
|
143
|
-
# * pad_with_delay is called only with non-delay node to avoid consecutive delay
|
144
|
-
new_dag = dag.copy_empty_like()
|
145
|
-
|
146
|
-
qubit_time_available: dict[QubitSpecifier, int] = defaultdict(int) # to track op start time
|
147
|
-
qubit_stop_times: dict[QubitSpecifier, int] = defaultdict(
|
148
|
-
int
|
149
|
-
) # to track delay start time for padding
|
150
|
-
clbit_readable: dict[ClbitSpecifier, int] = defaultdict(int)
|
151
|
-
clbit_writeable: dict[ClbitSpecifier, int] = defaultdict(int)
|
152
|
-
|
153
|
-
def pad_with_delays(qubits: Iterable[QubitSpecifier], until, unit) -> None:
|
154
|
-
"""Pad idle time-slots in ``qubits`` with delays in ``unit`` until ``until``."""
|
155
|
-
for q in qubits:
|
156
|
-
if qubit_stop_times[q] < until:
|
157
|
-
idle_duration = until - qubit_stop_times[q]
|
158
|
-
new_dag.apply_operation_back(Delay(idle_duration, unit), (q,), check=False)
|
159
|
-
|
160
|
-
for node in dag.topological_op_nodes():
|
161
|
-
# choose appropriate clbit available time depending on op
|
162
|
-
clbit_time_available = (
|
163
|
-
clbit_writeable if isinstance(node.op, Measure) else clbit_readable
|
164
|
-
)
|
165
|
-
# correction to change clbit start time to qubit start time
|
166
|
-
delta = node.op.duration if isinstance(node.op, Measure) else 0
|
167
|
-
start_time = max(
|
168
|
-
itertools.chain(
|
169
|
-
(qubit_time_available[q] for q in node.qargs),
|
170
|
-
(
|
171
|
-
clbit_time_available[c] - delta
|
172
|
-
for c in node.cargs + tuple(node.op.condition_bits)
|
173
|
-
),
|
174
|
-
)
|
175
|
-
)
|
176
|
-
|
177
|
-
if isinstance(node.op, Measure):
|
178
|
-
if start_time % self.alignment != 0:
|
179
|
-
start_time = ((start_time // self.alignment) + 1) * self.alignment
|
180
|
-
|
181
|
-
if not isinstance(node.op, Delay): # exclude delays for combining consecutive delays
|
182
|
-
pad_with_delays(node.qargs, until=start_time, unit=time_unit)
|
183
|
-
new_dag.apply_operation_back(node.op, node.qargs, node.cargs, check=False)
|
184
|
-
|
185
|
-
stop_time = start_time + node.op.duration
|
186
|
-
# update time table
|
187
|
-
for q in node.qargs:
|
188
|
-
qubit_time_available[q] = stop_time
|
189
|
-
if not isinstance(node.op, Delay):
|
190
|
-
qubit_stop_times[q] = stop_time
|
191
|
-
for c in node.cargs: # measure
|
192
|
-
clbit_writeable[c] = clbit_readable[c] = stop_time
|
193
|
-
for c in node.op.condition_bits: # conditional op
|
194
|
-
clbit_writeable[c] = max(start_time, clbit_writeable[c])
|
195
|
-
|
196
|
-
working_qubits = qubit_time_available.keys()
|
197
|
-
circuit_duration = max(qubit_time_available[q] for q in working_qubits)
|
198
|
-
pad_with_delays(new_dag.qubits, until=circuit_duration, unit=time_unit)
|
199
|
-
|
200
|
-
new_dag.name = dag.name
|
201
|
-
new_dag.metadata = dag.metadata
|
202
|
-
|
203
|
-
# set circuit duration and unit to indicate it is scheduled
|
204
|
-
new_dag.duration = circuit_duration
|
205
|
-
new_dag.unit = time_unit
|
206
|
-
|
207
|
-
return new_dag
|
208
|
-
|
209
|
-
|
210
|
-
def _check_alignment_required(
|
211
|
-
dag: DAGCircuit,
|
212
|
-
alignment: int,
|
213
|
-
instructions: Type | list[Type],
|
214
|
-
) -> bool:
|
215
|
-
"""Check DAG nodes and return a boolean representing if instruction scheduling is necessary.
|
216
|
-
|
217
|
-
Args:
|
218
|
-
dag: DAG circuit to check.
|
219
|
-
alignment: Instruction alignment condition.
|
220
|
-
instructions: Target instructions.
|
221
|
-
|
222
|
-
Returns:
|
223
|
-
If instruction scheduling is necessary.
|
224
|
-
"""
|
225
|
-
if not isinstance(instructions, list):
|
226
|
-
instructions = [instructions]
|
227
|
-
|
228
|
-
if alignment == 1:
|
229
|
-
# disable alignment if arbitrary t0 value can be used
|
230
|
-
return False
|
231
|
-
|
232
|
-
if all(len(dag.op_nodes(inst)) == 0 for inst in instructions):
|
233
|
-
# disable alignment if target instruction is not involved
|
234
|
-
return False
|
235
|
-
|
236
|
-
# check delay durations
|
237
|
-
for delay_node in dag.op_nodes(Delay):
|
238
|
-
duration = delay_node.op.duration
|
239
|
-
if isinstance(duration, ParameterExpression):
|
240
|
-
# duration is parametrized:
|
241
|
-
# raise user warning if backend alignment is not 1.
|
242
|
-
warnings.warn(
|
243
|
-
f"Parametrized delay with {repr(duration)} is found in circuit {dag.name}. "
|
244
|
-
f"This backend requires alignment={alignment}. "
|
245
|
-
"Please make sure all assigned values are multiple values of the alignment.",
|
246
|
-
UserWarning,
|
247
|
-
)
|
248
|
-
else:
|
249
|
-
# duration is bound:
|
250
|
-
# check duration and trigger alignment if it violates constraint
|
251
|
-
if duration % alignment != 0:
|
252
|
-
return True
|
253
|
-
|
254
|
-
# disable alignment if all delays are multiple values of the alignment
|
255
|
-
return False
|
@@ -1,107 +0,0 @@
|
|
1
|
-
# This code is part of Qiskit.
|
2
|
-
#
|
3
|
-
# (C) Copyright IBM 2021.
|
4
|
-
#
|
5
|
-
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
-
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
-
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
-
#
|
9
|
-
# Any modifications or derivative works of this code must retain this
|
10
|
-
# copyright notice, and modified files need to carry a notice indicating
|
11
|
-
# that they have been altered from the originals.
|
12
|
-
|
13
|
-
"""Analysis passes for hardware alignment constraints."""
|
14
|
-
|
15
|
-
from qiskit.dagcircuit import DAGCircuit
|
16
|
-
from qiskit.pulse import Play
|
17
|
-
from qiskit.transpiler.basepasses import AnalysisPass
|
18
|
-
from qiskit.transpiler.exceptions import TranspilerError
|
19
|
-
from qiskit.transpiler.target import Target
|
20
|
-
from qiskit.utils.deprecate_pulse import deprecate_pulse_dependency
|
21
|
-
|
22
|
-
|
23
|
-
class ValidatePulseGates(AnalysisPass):
|
24
|
-
"""Check custom gate length.
|
25
|
-
|
26
|
-
This is a control electronics aware analysis pass.
|
27
|
-
|
28
|
-
Quantum gates (instructions) are often implemented with shaped analog stimulus signals.
|
29
|
-
These signals may be digitally stored in the waveform memory of the control electronics
|
30
|
-
and converted into analog voltage signals by electronic components known as
|
31
|
-
digital to analog converters (DAC).
|
32
|
-
|
33
|
-
In Qiskit SDK, we can define the pulse-level implementation of custom quantum gate
|
34
|
-
instructions, as a `pulse gate
|
35
|
-
<https://docs.quantum.ibm.com/guides/pulse>`__,
|
36
|
-
thus user gates should satisfy all waveform memory constraints imposed by the backend.
|
37
|
-
|
38
|
-
This pass validates all attached calibration entries and raises ``TranspilerError`` to
|
39
|
-
kill the transpilation process if any invalid calibration entry is found.
|
40
|
-
This pass saves users from waiting until job execution time to get an invalid pulse error from
|
41
|
-
the backend control electronics.
|
42
|
-
"""
|
43
|
-
|
44
|
-
@deprecate_pulse_dependency
|
45
|
-
def __init__(
|
46
|
-
self,
|
47
|
-
granularity: int = 1,
|
48
|
-
min_length: int = 1,
|
49
|
-
target: Target = None,
|
50
|
-
):
|
51
|
-
"""Create new pass.
|
52
|
-
|
53
|
-
Args:
|
54
|
-
granularity: Integer number representing the minimum time resolution to
|
55
|
-
define the pulse gate length in units of ``dt``. This value depends on
|
56
|
-
the control electronics of your quantum processor.
|
57
|
-
min_length: Integer number representing the minimum data point length to
|
58
|
-
define the pulse gate in units of ``dt``. This value depends on
|
59
|
-
the control electronics of your quantum processor.
|
60
|
-
target: The :class:`~.Target` representing the target backend, if
|
61
|
-
``target`` is specified then this argument will take
|
62
|
-
precedence and ``granularity`` and ``min_length`` will be ignored.
|
63
|
-
"""
|
64
|
-
super().__init__()
|
65
|
-
self.granularity = granularity
|
66
|
-
self.min_length = min_length
|
67
|
-
if target is not None:
|
68
|
-
self.granularity = target.granularity
|
69
|
-
self.min_length = target.min_length
|
70
|
-
|
71
|
-
def run(self, dag: DAGCircuit):
|
72
|
-
"""Run the pulse gate validation attached to ``dag``.
|
73
|
-
|
74
|
-
Args:
|
75
|
-
dag: DAG to be validated.
|
76
|
-
|
77
|
-
Returns:
|
78
|
-
DAGCircuit: DAG with consistent timing and op nodes annotated with duration.
|
79
|
-
|
80
|
-
Raises:
|
81
|
-
TranspilerError: When pulse gate violate pulse controller constraints.
|
82
|
-
"""
|
83
|
-
if self.granularity == 1 and self.min_length == 1:
|
84
|
-
# we can define arbitrary length pulse with dt resolution
|
85
|
-
return
|
86
|
-
|
87
|
-
for gate, insts in dag.calibrations.items():
|
88
|
-
for qubit_param_pair, schedule in insts.items():
|
89
|
-
for _, inst in schedule.instructions:
|
90
|
-
if isinstance(inst, Play):
|
91
|
-
pulse = inst.pulse
|
92
|
-
if pulse.duration % self.granularity != 0:
|
93
|
-
raise TranspilerError(
|
94
|
-
f"Pulse duration is not multiple of {self.granularity}. "
|
95
|
-
"This pulse cannot be played on the specified backend. "
|
96
|
-
f"Please modify the duration of the custom gate pulse {pulse.name} "
|
97
|
-
f"which is associated with the gate {gate} of "
|
98
|
-
f"qubit {qubit_param_pair[0]}."
|
99
|
-
)
|
100
|
-
if pulse.duration < self.min_length:
|
101
|
-
raise TranspilerError(
|
102
|
-
f"Pulse gate duration is less than {self.min_length}. "
|
103
|
-
"This pulse cannot be played on the specified backend. "
|
104
|
-
f"Please modify the duration of the custom gate pulse {pulse.name} "
|
105
|
-
f"which is associated with the gate {gate} of "
|
106
|
-
"qubit {qubit_param_pair[0]}."
|
107
|
-
)
|
@@ -1,175 +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
|
-
"""ASAP Scheduling."""
|
14
|
-
|
15
|
-
from qiskit.circuit import Delay, Qubit, Measure
|
16
|
-
from qiskit.dagcircuit import DAGCircuit
|
17
|
-
from qiskit.transpiler.exceptions import TranspilerError
|
18
|
-
from qiskit.transpiler.passes.scheduling.base_scheduler import BaseSchedulerTransform
|
19
|
-
from qiskit.utils.deprecation import deprecate_func
|
20
|
-
|
21
|
-
|
22
|
-
class ASAPSchedule(BaseSchedulerTransform):
|
23
|
-
"""ASAP Scheduling pass, which schedules the start time of instructions as early as possible..
|
24
|
-
|
25
|
-
See :class:`~qiskit.transpiler.passes.scheduling.base_scheduler.BaseSchedulerTransform` for the
|
26
|
-
detailed behavior of the control flow operation, i.e. ``c_if``.
|
27
|
-
|
28
|
-
.. note::
|
29
|
-
|
30
|
-
This base class has been superseded by :class:`~.ASAPScheduleAnalysis` and
|
31
|
-
the new scheduling workflow. It will be deprecated and subsequently
|
32
|
-
removed in a future release.
|
33
|
-
"""
|
34
|
-
|
35
|
-
@deprecate_func(
|
36
|
-
additional_msg=(
|
37
|
-
"Instead, use :class:`~.ASAPScheduleAnalysis`, which is an "
|
38
|
-
"analysis pass that requires a padding pass to later modify the circuit."
|
39
|
-
),
|
40
|
-
since="1.1.0",
|
41
|
-
)
|
42
|
-
def __init__(self, *args, **kwargs):
|
43
|
-
super().__init__(*args, **kwargs)
|
44
|
-
|
45
|
-
def run(self, dag):
|
46
|
-
"""Run the ASAPSchedule pass on `dag`.
|
47
|
-
|
48
|
-
Args:
|
49
|
-
dag (DAGCircuit): DAG to schedule.
|
50
|
-
|
51
|
-
Returns:
|
52
|
-
DAGCircuit: A scheduled DAG.
|
53
|
-
|
54
|
-
Raises:
|
55
|
-
TranspilerError: if the circuit is not mapped on physical qubits.
|
56
|
-
TranspilerError: if conditional bit is added to non-supported instruction.
|
57
|
-
"""
|
58
|
-
if len(dag.qregs) != 1 or dag.qregs.get("q", None) is None:
|
59
|
-
raise TranspilerError("ASAP schedule runs on physical circuits only")
|
60
|
-
|
61
|
-
time_unit = self.property_set["time_unit"]
|
62
|
-
|
63
|
-
new_dag = DAGCircuit()
|
64
|
-
for qreg in dag.qregs.values():
|
65
|
-
new_dag.add_qreg(qreg)
|
66
|
-
for creg in dag.cregs.values():
|
67
|
-
new_dag.add_creg(creg)
|
68
|
-
|
69
|
-
idle_after = {q: 0 for q in dag.qubits + dag.clbits}
|
70
|
-
for node in dag.topological_op_nodes():
|
71
|
-
op_duration = self._get_node_duration(node, dag)
|
72
|
-
|
73
|
-
# compute t0, t1: instruction interval, note that
|
74
|
-
# t0: start time of instruction
|
75
|
-
# t1: end time of instruction
|
76
|
-
if isinstance(node.op, self.CONDITIONAL_SUPPORTED):
|
77
|
-
t0q = max(idle_after[q] for q in node.qargs)
|
78
|
-
if node.op.condition_bits:
|
79
|
-
# conditional is bit tricky due to conditional_latency
|
80
|
-
t0c = max(idle_after[bit] for bit in node.op.condition_bits)
|
81
|
-
if t0q > t0c:
|
82
|
-
# This is situation something like below
|
83
|
-
#
|
84
|
-
# |t0q
|
85
|
-
# Q ▒▒▒▒▒▒▒▒▒░░
|
86
|
-
# C ▒▒▒░░░░░░░░
|
87
|
-
# |t0c
|
88
|
-
#
|
89
|
-
# In this case, you can insert readout access before tq0
|
90
|
-
#
|
91
|
-
# |t0q
|
92
|
-
# Q ▒▒▒▒▒▒▒▒▒▒▒
|
93
|
-
# C ▒▒▒░░░▒▒░░░
|
94
|
-
# |t0q - conditional_latency
|
95
|
-
#
|
96
|
-
t0c = max(t0q - self.conditional_latency, t0c)
|
97
|
-
t1c = t0c + self.conditional_latency
|
98
|
-
for bit in node.op.condition_bits:
|
99
|
-
# Lock clbit until state is read
|
100
|
-
idle_after[bit] = t1c
|
101
|
-
# It starts after register read access
|
102
|
-
t0 = max(t0q, t1c)
|
103
|
-
else:
|
104
|
-
t0 = t0q
|
105
|
-
t1 = t0 + op_duration
|
106
|
-
else:
|
107
|
-
if node.op.condition_bits:
|
108
|
-
raise TranspilerError(
|
109
|
-
f"Conditional instruction {node.op.name} is not supported in ASAP scheduler."
|
110
|
-
)
|
111
|
-
|
112
|
-
if isinstance(node.op, Measure):
|
113
|
-
# measure instruction handling is bit tricky due to clbit_write_latency
|
114
|
-
t0q = max(idle_after[q] for q in node.qargs)
|
115
|
-
t0c = max(idle_after[c] for c in node.cargs)
|
116
|
-
# Assume following case (t0c > t0q)
|
117
|
-
#
|
118
|
-
# |t0q
|
119
|
-
# Q ▒▒▒▒░░░░░░░░░░░░
|
120
|
-
# C ▒▒▒▒▒▒▒▒░░░░░░░░
|
121
|
-
# |t0c
|
122
|
-
#
|
123
|
-
# In this case, there is no actual clbit access until clbit_write_latency.
|
124
|
-
# The node t0 can be push backward by this amount.
|
125
|
-
#
|
126
|
-
# |t0q' = t0c - clbit_write_latency
|
127
|
-
# Q ▒▒▒▒░░▒▒▒▒▒▒▒▒▒▒
|
128
|
-
# C ▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
|
129
|
-
# |t0c' = t0c
|
130
|
-
#
|
131
|
-
# rather than naively doing
|
132
|
-
#
|
133
|
-
# |t0q' = t0c
|
134
|
-
# Q ▒▒▒▒░░░░▒▒▒▒▒▒▒▒
|
135
|
-
# C ▒▒▒▒▒▒▒▒░░░▒▒▒▒▒
|
136
|
-
# |t0c' = t0c + clbit_write_latency
|
137
|
-
#
|
138
|
-
t0 = max(t0q, t0c - self.clbit_write_latency)
|
139
|
-
t1 = t0 + op_duration
|
140
|
-
for clbit in node.cargs:
|
141
|
-
idle_after[clbit] = t1
|
142
|
-
else:
|
143
|
-
# It happens to be directives such as barrier
|
144
|
-
t0 = max(idle_after[bit] for bit in node.qargs + node.cargs)
|
145
|
-
t1 = t0 + op_duration
|
146
|
-
|
147
|
-
# Add delay to qubit wire
|
148
|
-
for bit in node.qargs:
|
149
|
-
delta = t0 - idle_after[bit]
|
150
|
-
if (
|
151
|
-
delta > 0
|
152
|
-
and isinstance(bit, Qubit)
|
153
|
-
and self._delay_supported(dag.find_bit(bit).index)
|
154
|
-
):
|
155
|
-
new_dag.apply_operation_back(Delay(delta, time_unit), [bit], [])
|
156
|
-
idle_after[bit] = t1
|
157
|
-
|
158
|
-
new_dag.apply_operation_back(node.op, node.qargs, node.cargs)
|
159
|
-
|
160
|
-
circuit_duration = max(idle_after.values())
|
161
|
-
for bit, after in idle_after.items():
|
162
|
-
delta = circuit_duration - after
|
163
|
-
if not (delta > 0 and isinstance(bit, Qubit)):
|
164
|
-
continue
|
165
|
-
if self._delay_supported(dag.find_bit(bit).index):
|
166
|
-
new_dag.apply_operation_back(Delay(delta, time_unit), [bit], [])
|
167
|
-
|
168
|
-
new_dag.name = dag.name
|
169
|
-
new_dag.metadata = dag.metadata
|
170
|
-
new_dag._calibrations_prop = dag._calibrations_prop
|
171
|
-
|
172
|
-
# set circuit duration and unit to indicate it is scheduled
|
173
|
-
new_dag.duration = circuit_duration
|
174
|
-
new_dag.unit = time_unit
|
175
|
-
return new_dag
|