qiskit 1.4.0__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.
- qiskit/VERSION.txt +1 -1
- qiskit/__init__.py +2 -5
- qiskit/_accelerate.abi3.so +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 +7 -140
- 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 +168 -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 +5 -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 +27 -12
- qiskit/visualization/timeline/interface.py +23 -18
- {qiskit-1.4.0.dist-info → qiskit-2.0.0rc1.dist-info}/METADATA +2 -2
- {qiskit-1.4.0.dist-info → qiskit-2.0.0rc1.dist-info}/RECORD +297 -444
- {qiskit-1.4.0.dist-info → qiskit-2.0.0rc1.dist-info}/WHEEL +2 -1
- {qiskit-1.4.0.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.0.dist-info → qiskit-2.0.0rc1.dist-info}/LICENSE.txt +0 -0
- {qiskit-1.4.0.dist-info → qiskit-2.0.0rc1.dist-info}/top_level.txt +0 -0
@@ -1,436 +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
|
-
# pylint: disable=unused-argument
|
14
|
-
|
15
|
-
"""Frame change generators.
|
16
|
-
|
17
|
-
A collection of functions that generate drawings from formatted input data.
|
18
|
-
See py:mod:`qiskit.visualization.pulse_v2.types` for more info on the required data.
|
19
|
-
|
20
|
-
In this module the input data is `types.PulseInstruction`.
|
21
|
-
|
22
|
-
An end-user can write arbitrary functions that generate custom drawings.
|
23
|
-
Generators in this module are called with the `formatter` and `device` kwargs.
|
24
|
-
These data provides stylesheet configuration and backend system configuration.
|
25
|
-
|
26
|
-
The format of generator is restricted to:
|
27
|
-
|
28
|
-
```python
|
29
|
-
|
30
|
-
def my_object_generator(data: PulseInstruction,
|
31
|
-
formatter: Dict[str, Any],
|
32
|
-
device: DrawerBackendInfo) -> List[ElementaryData]:
|
33
|
-
pass
|
34
|
-
```
|
35
|
-
|
36
|
-
Arbitrary generator function satisfying the above format can be accepted.
|
37
|
-
Returned `ElementaryData` can be arbitrary subclasses that are implemented in
|
38
|
-
the plotter API.
|
39
|
-
"""
|
40
|
-
from fractions import Fraction
|
41
|
-
from typing import Dict, Any, List, Tuple
|
42
|
-
|
43
|
-
import numpy as np
|
44
|
-
from qiskit.pulse import instructions
|
45
|
-
from qiskit.visualization.exceptions import VisualizationError
|
46
|
-
from qiskit.visualization.pulse_v2 import drawings, types, device_info
|
47
|
-
|
48
|
-
|
49
|
-
def gen_formatted_phase(
|
50
|
-
data: types.PulseInstruction, formatter: Dict[str, Any], device: device_info.DrawerBackendInfo
|
51
|
-
) -> List[drawings.TextData]:
|
52
|
-
"""Generate the formatted virtual Z rotation label from provided frame instruction.
|
53
|
-
|
54
|
-
Rotation angle is expressed in units of pi.
|
55
|
-
If the denominator of fraction is larger than 10, the angle is expressed in units of radian.
|
56
|
-
|
57
|
-
For example:
|
58
|
-
- A value -3.14 is converted into `VZ(\\pi)`
|
59
|
-
- A value 1.57 is converted into `VZ(-\\frac{\\pi}{2})`
|
60
|
-
- A value 0.123 is converted into `VZ(-0.123 rad.)`
|
61
|
-
|
62
|
-
Stylesheets:
|
63
|
-
- The `frame_change` style is applied.
|
64
|
-
- The `annotate` style is applied for font size.
|
65
|
-
|
66
|
-
Notes:
|
67
|
-
The phase operand of `PhaseShift` instruction has opposite sign to the Z gate definition.
|
68
|
-
Thus the sign of rotation angle is inverted.
|
69
|
-
|
70
|
-
Args:
|
71
|
-
data: Frame change instruction data to draw.
|
72
|
-
formatter: Dictionary of stylesheet settings.
|
73
|
-
device: Backend configuration.
|
74
|
-
|
75
|
-
Returns:
|
76
|
-
List of `TextData` drawings.
|
77
|
-
"""
|
78
|
-
_max_denom = 10
|
79
|
-
|
80
|
-
style = {
|
81
|
-
"zorder": formatter["layer.frame_change"],
|
82
|
-
"color": formatter["color.frame_change"],
|
83
|
-
"size": formatter["text_size.annotate"],
|
84
|
-
"va": "center",
|
85
|
-
"ha": "center",
|
86
|
-
}
|
87
|
-
|
88
|
-
plain_phase, latex_phase = _phase_to_text(
|
89
|
-
formatter=formatter, phase=data.frame.phase, max_denom=_max_denom, flip=True
|
90
|
-
)
|
91
|
-
|
92
|
-
text = drawings.TextData(
|
93
|
-
data_type=types.LabelType.FRAME,
|
94
|
-
channels=data.inst[0].channel,
|
95
|
-
xvals=[data.t0],
|
96
|
-
yvals=[formatter["label_offset.frame_change"]],
|
97
|
-
text=f"VZ({plain_phase})",
|
98
|
-
latex=rf"{{\rm VZ}}({latex_phase})",
|
99
|
-
ignore_scaling=True,
|
100
|
-
styles=style,
|
101
|
-
)
|
102
|
-
|
103
|
-
return [text]
|
104
|
-
|
105
|
-
|
106
|
-
def gen_formatted_freq_mhz(
|
107
|
-
data: types.PulseInstruction, formatter: Dict[str, Any], device: device_info.DrawerBackendInfo
|
108
|
-
) -> List[drawings.TextData]:
|
109
|
-
"""Generate the formatted frequency change label from provided frame instruction.
|
110
|
-
|
111
|
-
Frequency change is expressed in units of MHz.
|
112
|
-
|
113
|
-
For example:
|
114
|
-
- A value 1,234,567 is converted into `\\Delta f = 1.23 MHz`
|
115
|
-
|
116
|
-
Stylesheets:
|
117
|
-
- The `frame_change` style is applied.
|
118
|
-
- The `annotate` style is applied for font size.
|
119
|
-
|
120
|
-
Args:
|
121
|
-
data: Frame change instruction data to draw.
|
122
|
-
formatter: Dictionary of stylesheet settings.
|
123
|
-
device: Backend configuration.
|
124
|
-
|
125
|
-
Returns:
|
126
|
-
List of `TextData` drawings.
|
127
|
-
"""
|
128
|
-
_unit = "MHz"
|
129
|
-
|
130
|
-
style = {
|
131
|
-
"zorder": formatter["layer.frame_change"],
|
132
|
-
"color": formatter["color.frame_change"],
|
133
|
-
"size": formatter["text_size.annotate"],
|
134
|
-
"va": "center",
|
135
|
-
"ha": "center",
|
136
|
-
}
|
137
|
-
|
138
|
-
plain_freq, latex_freq = _freq_to_text(formatter=formatter, freq=data.frame.freq, unit=_unit)
|
139
|
-
|
140
|
-
text = drawings.TextData(
|
141
|
-
data_type=types.LabelType.FRAME,
|
142
|
-
channels=data.inst[0].channel,
|
143
|
-
xvals=[data.t0],
|
144
|
-
yvals=[formatter["label_offset.frame_change"]],
|
145
|
-
text=f"\u0394f = {plain_freq}",
|
146
|
-
latex=rf"\Delta f = {latex_freq}",
|
147
|
-
ignore_scaling=True,
|
148
|
-
styles=style,
|
149
|
-
)
|
150
|
-
|
151
|
-
return [text]
|
152
|
-
|
153
|
-
|
154
|
-
def gen_formatted_frame_values(
|
155
|
-
data: types.PulseInstruction, formatter: Dict[str, Any], device: device_info.DrawerBackendInfo
|
156
|
-
) -> List[drawings.TextData]:
|
157
|
-
"""Generate the formatted virtual Z rotation label and the frequency change label
|
158
|
-
from provided frame instruction.
|
159
|
-
|
160
|
-
Phase value is placed on top of the symbol, and frequency value is placed below the symbol.
|
161
|
-
See :py:func:`gen_formatted_phase` and :py:func:`gen_formatted_freq_mhz` for details.
|
162
|
-
|
163
|
-
Stylesheets:
|
164
|
-
- The `frame_change` style is applied.
|
165
|
-
- The `annotate` style is applied for font size.
|
166
|
-
|
167
|
-
Args:
|
168
|
-
data: Frame change instruction data to draw.
|
169
|
-
formatter: Dictionary of stylesheet settings.
|
170
|
-
device: Backend configuration.
|
171
|
-
|
172
|
-
Returns:
|
173
|
-
List of `TextData` drawings.
|
174
|
-
"""
|
175
|
-
texts = []
|
176
|
-
|
177
|
-
_max_denom = 10
|
178
|
-
_unit = "MHz"
|
179
|
-
|
180
|
-
style = {
|
181
|
-
"zorder": formatter["layer.frame_change"],
|
182
|
-
"color": formatter["color.frame_change"],
|
183
|
-
"size": formatter["text_size.annotate"],
|
184
|
-
"ha": "center",
|
185
|
-
}
|
186
|
-
|
187
|
-
# phase value
|
188
|
-
if data.frame.phase != 0:
|
189
|
-
plain_phase, latex_phase = _phase_to_text(
|
190
|
-
formatter=formatter, phase=data.frame.phase, max_denom=_max_denom, flip=True
|
191
|
-
)
|
192
|
-
phase_style = {"va": "center"}
|
193
|
-
phase_style.update(style)
|
194
|
-
|
195
|
-
phase = drawings.TextData(
|
196
|
-
data_type=types.LabelType.FRAME,
|
197
|
-
channels=data.inst[0].channel,
|
198
|
-
xvals=[data.t0],
|
199
|
-
yvals=[formatter["label_offset.frame_change"]],
|
200
|
-
text=f"VZ({plain_phase})",
|
201
|
-
latex=rf"{{\rm VZ}}({latex_phase})",
|
202
|
-
ignore_scaling=True,
|
203
|
-
styles=phase_style,
|
204
|
-
)
|
205
|
-
texts.append(phase)
|
206
|
-
|
207
|
-
# frequency value
|
208
|
-
if data.frame.freq != 0:
|
209
|
-
plain_freq, latex_freq = _freq_to_text(
|
210
|
-
formatter=formatter, freq=data.frame.freq, unit=_unit
|
211
|
-
)
|
212
|
-
freq_style = {"va": "center"}
|
213
|
-
freq_style.update(style)
|
214
|
-
|
215
|
-
freq = drawings.TextData(
|
216
|
-
data_type=types.LabelType.FRAME,
|
217
|
-
channels=data.inst[0].channel,
|
218
|
-
xvals=[data.t0],
|
219
|
-
yvals=[2 * formatter["label_offset.frame_change"]],
|
220
|
-
text=f"\u0394f = {plain_freq}",
|
221
|
-
latex=rf"\Delta f = {latex_freq}",
|
222
|
-
ignore_scaling=True,
|
223
|
-
styles=freq_style,
|
224
|
-
)
|
225
|
-
texts.append(freq)
|
226
|
-
|
227
|
-
return texts
|
228
|
-
|
229
|
-
|
230
|
-
def gen_raw_operand_values_compact(
|
231
|
-
data: types.PulseInstruction, formatter: Dict[str, Any], device: device_info.DrawerBackendInfo
|
232
|
-
) -> List[drawings.TextData]:
|
233
|
-
"""Generate the formatted virtual Z rotation label and the frequency change label
|
234
|
-
from provided frame instruction.
|
235
|
-
|
236
|
-
Raw operand values are shown in compact form. Frequency change is expressed
|
237
|
-
in scientific notation. Values are shown in two lines.
|
238
|
-
|
239
|
-
For example:
|
240
|
-
- A phase change 1.57 and frequency change 1,234,567 are written by `1.57\\n1.2e+06`
|
241
|
-
|
242
|
-
Stylesheets:
|
243
|
-
- The `frame_change` style is applied.
|
244
|
-
- The `annotate` style is applied for font size.
|
245
|
-
|
246
|
-
Args:
|
247
|
-
data: Frame change instruction data to draw.
|
248
|
-
formatter: Dictionary of stylesheet settings.
|
249
|
-
device: Backend configuration.
|
250
|
-
|
251
|
-
Returns:
|
252
|
-
List of `TextData` drawings.
|
253
|
-
"""
|
254
|
-
|
255
|
-
style = {
|
256
|
-
"zorder": formatter["layer.frame_change"],
|
257
|
-
"color": formatter["color.frame_change"],
|
258
|
-
"size": formatter["text_size.annotate"],
|
259
|
-
"va": "center",
|
260
|
-
"ha": "center",
|
261
|
-
}
|
262
|
-
|
263
|
-
if data.frame.freq == 0:
|
264
|
-
freq_sci_notation = "0.0"
|
265
|
-
else:
|
266
|
-
abs_freq = np.abs(data.frame.freq)
|
267
|
-
base = data.frame.freq / (10 ** int(np.floor(np.log10(abs_freq))))
|
268
|
-
exponent = int(np.floor(np.log10(abs_freq)))
|
269
|
-
freq_sci_notation = f"{base:.1f}e{exponent:d}"
|
270
|
-
frame_info = f"{data.frame.phase:.2f}\n{freq_sci_notation}"
|
271
|
-
|
272
|
-
text = drawings.TextData(
|
273
|
-
data_type=types.LabelType.FRAME,
|
274
|
-
channels=data.inst[0].channel,
|
275
|
-
xvals=[data.t0],
|
276
|
-
yvals=[1.2 * formatter["label_offset.frame_change"]],
|
277
|
-
text=frame_info,
|
278
|
-
ignore_scaling=True,
|
279
|
-
styles=style,
|
280
|
-
)
|
281
|
-
|
282
|
-
return [text]
|
283
|
-
|
284
|
-
|
285
|
-
def gen_frame_symbol(
|
286
|
-
data: types.PulseInstruction, formatter: Dict[str, Any], device: device_info.DrawerBackendInfo
|
287
|
-
) -> List[drawings.TextData]:
|
288
|
-
"""Generate a frame change symbol with instruction meta data from provided frame instruction.
|
289
|
-
|
290
|
-
Stylesheets:
|
291
|
-
- The `frame_change` style is applied.
|
292
|
-
- The symbol type in unicode is specified in `formatter.unicode_symbol.frame_change`.
|
293
|
-
- The symbol type in latex is specified in `formatter.latex_symbol.frame_change`.
|
294
|
-
|
295
|
-
Args:
|
296
|
-
data: Frame change instruction data to draw.
|
297
|
-
formatter: Dictionary of stylesheet settings.
|
298
|
-
device: Backend configuration.
|
299
|
-
|
300
|
-
Returns:
|
301
|
-
List of `TextData` drawings.
|
302
|
-
"""
|
303
|
-
if data.frame.phase == 0 and data.frame.freq == 0:
|
304
|
-
return []
|
305
|
-
|
306
|
-
style = {
|
307
|
-
"zorder": formatter["layer.frame_change"],
|
308
|
-
"color": formatter["color.frame_change"],
|
309
|
-
"size": formatter["text_size.frame_change"],
|
310
|
-
"va": "center",
|
311
|
-
"ha": "center",
|
312
|
-
}
|
313
|
-
|
314
|
-
program = []
|
315
|
-
for inst in data.inst:
|
316
|
-
if isinstance(inst, (instructions.SetFrequency, instructions.ShiftFrequency)):
|
317
|
-
try:
|
318
|
-
program.append(f"{inst.__class__.__name__}({inst.frequency:.2e} Hz)")
|
319
|
-
except TypeError:
|
320
|
-
# parameter expression
|
321
|
-
program.append(f"{inst.__class__.__name__}({inst.frequency})")
|
322
|
-
elif isinstance(inst, (instructions.SetPhase, instructions.ShiftPhase)):
|
323
|
-
try:
|
324
|
-
program.append(f"{inst.__class__.__name__}({inst.phase:.2f} rad.)")
|
325
|
-
except TypeError:
|
326
|
-
# parameter expression
|
327
|
-
program.append(f"{inst.__class__.__name__}({inst.phase})")
|
328
|
-
|
329
|
-
meta = {
|
330
|
-
"total phase change": data.frame.phase,
|
331
|
-
"total frequency change": data.frame.freq,
|
332
|
-
"program": ", ".join(program),
|
333
|
-
"t0 (cycle time)": data.t0,
|
334
|
-
"t0 (sec)": data.t0 * data.dt if data.dt else "N/A",
|
335
|
-
}
|
336
|
-
|
337
|
-
text = drawings.TextData(
|
338
|
-
data_type=types.SymbolType.FRAME,
|
339
|
-
channels=data.inst[0].channel,
|
340
|
-
xvals=[data.t0],
|
341
|
-
yvals=[0],
|
342
|
-
text=formatter["unicode_symbol.frame_change"],
|
343
|
-
latex=formatter["latex_symbol.frame_change"],
|
344
|
-
ignore_scaling=True,
|
345
|
-
meta=meta,
|
346
|
-
styles=style,
|
347
|
-
)
|
348
|
-
|
349
|
-
return [text]
|
350
|
-
|
351
|
-
|
352
|
-
def _phase_to_text(
|
353
|
-
formatter: Dict[str, Any], phase: float, max_denom: int = 10, flip: bool = True
|
354
|
-
) -> Tuple[str, str]:
|
355
|
-
"""A helper function to convert a float value to text with pi.
|
356
|
-
|
357
|
-
Args:
|
358
|
-
formatter: Dictionary of stylesheet settings.
|
359
|
-
phase: A phase value in units of rad.
|
360
|
-
max_denom: Maximum denominator. Return raw value if exceed.
|
361
|
-
flip: Set `True` to flip the sign.
|
362
|
-
|
363
|
-
Returns:
|
364
|
-
Standard text and latex text of phase value.
|
365
|
-
"""
|
366
|
-
try:
|
367
|
-
phase = float(phase)
|
368
|
-
except TypeError:
|
369
|
-
# unbound parameter
|
370
|
-
return (
|
371
|
-
formatter["unicode_symbol.phase_parameter"],
|
372
|
-
formatter["latex_symbol.phase_parameter"],
|
373
|
-
)
|
374
|
-
|
375
|
-
frac = Fraction(np.abs(phase) / np.pi)
|
376
|
-
|
377
|
-
if phase == 0:
|
378
|
-
return "0", r"0"
|
379
|
-
|
380
|
-
num = frac.numerator
|
381
|
-
denom = frac.denominator
|
382
|
-
if denom > max_denom:
|
383
|
-
# denominator is too large
|
384
|
-
latex = rf"{np.abs(phase):.2f}"
|
385
|
-
plain = f"{np.abs(phase):.2f}"
|
386
|
-
else:
|
387
|
-
if num == 1:
|
388
|
-
if denom == 1:
|
389
|
-
latex = r"\pi"
|
390
|
-
plain = "pi"
|
391
|
-
else:
|
392
|
-
latex = rf"\pi/{denom:d}"
|
393
|
-
plain = f"pi/{denom:d}"
|
394
|
-
else:
|
395
|
-
latex = rf"{num:d}/{denom:d} \pi"
|
396
|
-
plain = f"{num:d}/{denom:d} pi"
|
397
|
-
|
398
|
-
if flip:
|
399
|
-
sign = "-" if phase > 0 else ""
|
400
|
-
else:
|
401
|
-
sign = "-" if phase < 0 else ""
|
402
|
-
|
403
|
-
return sign + plain, sign + latex
|
404
|
-
|
405
|
-
|
406
|
-
def _freq_to_text(formatter: Dict[str, Any], freq: float, unit: str = "MHz") -> Tuple[str, str]:
|
407
|
-
"""A helper function to convert a freq value to text with supplementary unit.
|
408
|
-
|
409
|
-
Args:
|
410
|
-
formatter: Dictionary of stylesheet settings.
|
411
|
-
freq: A frequency value in units of Hz.
|
412
|
-
unit: Supplementary unit. THz, GHz, MHz, kHz, Hz are supported.
|
413
|
-
|
414
|
-
Returns:
|
415
|
-
Standard text and latex text of phase value.
|
416
|
-
|
417
|
-
Raises:
|
418
|
-
VisualizationError: When unsupported unit is specified.
|
419
|
-
"""
|
420
|
-
try:
|
421
|
-
freq = float(freq)
|
422
|
-
except TypeError:
|
423
|
-
# unbound parameter
|
424
|
-
return formatter["unicode_symbol.freq_parameter"], formatter["latex_symbol.freq_parameter"]
|
425
|
-
|
426
|
-
unit_table = {"THz": 1e12, "GHz": 1e9, "MHz": 1e6, "kHz": 1e3, "Hz": 1}
|
427
|
-
|
428
|
-
try:
|
429
|
-
value = freq / unit_table[unit]
|
430
|
-
except KeyError as ex:
|
431
|
-
raise VisualizationError(f"Unit {unit} is not supported.") from ex
|
432
|
-
|
433
|
-
latex = rf"{value:.2f}~{{\rm {unit}}}"
|
434
|
-
plain = f"{value:.2f} {unit}"
|
435
|
-
|
436
|
-
return plain, latex
|
@@ -1,133 +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
|
-
# pylint: disable=unused-argument
|
14
|
-
|
15
|
-
"""Snapshot generators.
|
16
|
-
|
17
|
-
A collection of functions that generate drawings from formatted input data.
|
18
|
-
See py:mod:`qiskit.visualization.pulse_v2.types` for more info on the required data.
|
19
|
-
|
20
|
-
In this module the input data is `types.SnapshotInstruction`.
|
21
|
-
|
22
|
-
An end-user can write arbitrary functions that generate custom drawings.
|
23
|
-
Generators in this module are called with the `formatter` and `device` kwargs.
|
24
|
-
These data provides stylesheet configuration and backend system configuration.
|
25
|
-
|
26
|
-
The format of generator is restricted to:
|
27
|
-
|
28
|
-
```python
|
29
|
-
|
30
|
-
def my_object_generator(data: SnapshotInstruction,
|
31
|
-
formatter: Dict[str, Any],
|
32
|
-
device: DrawerBackendInfo) -> List[ElementaryData]:
|
33
|
-
pass
|
34
|
-
```
|
35
|
-
|
36
|
-
Arbitrary generator function satisfying the above format can be accepted.
|
37
|
-
Returned `ElementaryData` can be arbitrary subclasses that are implemented in
|
38
|
-
the plotter API.
|
39
|
-
"""
|
40
|
-
from typing import Dict, Any, List
|
41
|
-
|
42
|
-
from qiskit.visualization.pulse_v2 import drawings, types, device_info
|
43
|
-
|
44
|
-
|
45
|
-
def gen_snapshot_name(
|
46
|
-
data: types.SnapshotInstruction,
|
47
|
-
formatter: Dict[str, Any],
|
48
|
-
device: device_info.DrawerBackendInfo,
|
49
|
-
) -> List[drawings.TextData]:
|
50
|
-
"""Generate the name of snapshot.
|
51
|
-
|
52
|
-
Stylesheets:
|
53
|
-
- The `snapshot` style is applied for snapshot symbol.
|
54
|
-
- The `annotate` style is applied for label font size.
|
55
|
-
|
56
|
-
Args:
|
57
|
-
data: Snapshot instruction data to draw.
|
58
|
-
formatter: Dictionary of stylesheet settings.
|
59
|
-
device: Backend configuration.
|
60
|
-
|
61
|
-
Returns:
|
62
|
-
List of `TextData` drawings.
|
63
|
-
"""
|
64
|
-
style = {
|
65
|
-
"zorder": formatter["layer.snapshot"],
|
66
|
-
"color": formatter["color.snapshot"],
|
67
|
-
"size": formatter["text_size.annotate"],
|
68
|
-
"va": "center",
|
69
|
-
"ha": "center",
|
70
|
-
}
|
71
|
-
|
72
|
-
text = drawings.TextData(
|
73
|
-
data_type=types.LabelType.SNAPSHOT,
|
74
|
-
channels=data.inst.channel,
|
75
|
-
xvals=[data.t0],
|
76
|
-
yvals=[formatter["label_offset.snapshot"]],
|
77
|
-
text=data.inst.name,
|
78
|
-
ignore_scaling=True,
|
79
|
-
styles=style,
|
80
|
-
)
|
81
|
-
|
82
|
-
return [text]
|
83
|
-
|
84
|
-
|
85
|
-
def gen_snapshot_symbol(
|
86
|
-
data: types.SnapshotInstruction,
|
87
|
-
formatter: Dict[str, Any],
|
88
|
-
device: device_info.DrawerBackendInfo,
|
89
|
-
) -> List[drawings.TextData]:
|
90
|
-
"""Generate a snapshot symbol with instruction meta data from provided snapshot instruction.
|
91
|
-
|
92
|
-
Stylesheets:
|
93
|
-
- The `snapshot` style is applied for snapshot symbol.
|
94
|
-
- The symbol type in unicode is specified in `formatter.unicode_symbol.snapshot`.
|
95
|
-
- The symbol type in latex is specified in `formatter.latex_symbol.snapshot`.
|
96
|
-
|
97
|
-
Args:
|
98
|
-
data: Snapshot instruction data to draw.
|
99
|
-
formatter: Dictionary of stylesheet settings.
|
100
|
-
device: Backend configuration.
|
101
|
-
|
102
|
-
Returns:
|
103
|
-
List of `TextData` drawings.
|
104
|
-
"""
|
105
|
-
style = {
|
106
|
-
"zorder": formatter["layer.snapshot"],
|
107
|
-
"color": formatter["color.snapshot"],
|
108
|
-
"size": formatter["text_size.snapshot"],
|
109
|
-
"va": "bottom",
|
110
|
-
"ha": "center",
|
111
|
-
}
|
112
|
-
|
113
|
-
meta = {
|
114
|
-
"snapshot type": data.inst.type,
|
115
|
-
"t0 (cycle time)": data.t0,
|
116
|
-
"t0 (sec)": data.t0 * data.dt if data.dt else "N/A",
|
117
|
-
"name": data.inst.name,
|
118
|
-
"label": data.inst.label,
|
119
|
-
}
|
120
|
-
|
121
|
-
text = drawings.TextData(
|
122
|
-
data_type=types.SymbolType.SNAPSHOT,
|
123
|
-
channels=data.inst.channel,
|
124
|
-
xvals=[data.t0],
|
125
|
-
yvals=[0],
|
126
|
-
text=formatter["unicode_symbol.snapshot"],
|
127
|
-
latex=formatter["latex_symbol.snapshot"],
|
128
|
-
ignore_scaling=True,
|
129
|
-
meta=meta,
|
130
|
-
styles=style,
|
131
|
-
)
|
132
|
-
|
133
|
-
return [text]
|