qiskit 1.3.0__cp39-abi3-win32.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 -0
- qiskit/__init__.py +146 -0
- qiskit/_accelerate.pyd +0 -0
- qiskit/_numpy_compat.py +73 -0
- qiskit/assembler/__init__.py +42 -0
- qiskit/assembler/assemble_circuits.py +451 -0
- qiskit/assembler/assemble_schedules.py +367 -0
- qiskit/assembler/disassemble.py +310 -0
- qiskit/assembler/run_config.py +77 -0
- qiskit/circuit/__init__.py +1313 -0
- qiskit/circuit/_classical_resource_map.py +148 -0
- qiskit/circuit/_standard_gates_commutations.py +3849 -0
- qiskit/circuit/_utils.py +167 -0
- qiskit/circuit/add_control.py +274 -0
- qiskit/circuit/annotated_operation.py +279 -0
- qiskit/circuit/barrier.py +50 -0
- qiskit/circuit/bit.py +94 -0
- qiskit/circuit/classical/__init__.py +41 -0
- qiskit/circuit/classical/expr/__init__.py +238 -0
- qiskit/circuit/classical/expr/constructors.py +556 -0
- qiskit/circuit/classical/expr/expr.py +397 -0
- qiskit/circuit/classical/expr/visitors.py +300 -0
- qiskit/circuit/classical/types/__init__.py +109 -0
- qiskit/circuit/classical/types/ordering.py +222 -0
- qiskit/circuit/classical/types/types.py +117 -0
- qiskit/circuit/classicalfunction/__init__.py +140 -0
- qiskit/circuit/classicalfunction/boolean_expression.py +129 -0
- qiskit/circuit/classicalfunction/classical_element.py +54 -0
- qiskit/circuit/classicalfunction/classical_function_visitor.py +155 -0
- qiskit/circuit/classicalfunction/classicalfunction.py +173 -0
- qiskit/circuit/classicalfunction/exceptions.py +35 -0
- qiskit/circuit/classicalfunction/types.py +18 -0
- qiskit/circuit/classicalfunction/utils.py +91 -0
- qiskit/circuit/classicalregister.py +57 -0
- qiskit/circuit/commutation_checker.py +106 -0
- qiskit/circuit/commutation_library.py +20 -0
- qiskit/circuit/controlflow/__init__.py +28 -0
- qiskit/circuit/controlflow/_builder_utils.py +207 -0
- qiskit/circuit/controlflow/break_loop.py +56 -0
- qiskit/circuit/controlflow/builder.py +691 -0
- qiskit/circuit/controlflow/continue_loop.py +58 -0
- qiskit/circuit/controlflow/control_flow.py +84 -0
- qiskit/circuit/controlflow/for_loop.py +217 -0
- qiskit/circuit/controlflow/if_else.py +511 -0
- qiskit/circuit/controlflow/switch_case.py +417 -0
- qiskit/circuit/controlflow/while_loop.py +171 -0
- qiskit/circuit/controlledgate.py +274 -0
- qiskit/circuit/delay.py +123 -0
- qiskit/circuit/duration.py +95 -0
- qiskit/circuit/equivalence.py +94 -0
- qiskit/circuit/equivalence_library.py +18 -0
- qiskit/circuit/exceptions.py +19 -0
- qiskit/circuit/gate.py +263 -0
- qiskit/circuit/instruction.py +697 -0
- qiskit/circuit/instructionset.py +179 -0
- qiskit/circuit/library/__init__.py +668 -0
- qiskit/circuit/library/arithmetic/__init__.py +34 -0
- qiskit/circuit/library/arithmetic/adders/__init__.py +18 -0
- qiskit/circuit/library/arithmetic/adders/adder.py +210 -0
- qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +123 -0
- qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +129 -0
- qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +95 -0
- qiskit/circuit/library/arithmetic/exact_reciprocal.py +88 -0
- qiskit/circuit/library/arithmetic/functional_pauli_rotations.py +114 -0
- qiskit/circuit/library/arithmetic/integer_comparator.py +243 -0
- qiskit/circuit/library/arithmetic/linear_amplitude_function.py +196 -0
- qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +189 -0
- qiskit/circuit/library/arithmetic/multipliers/__init__.py +17 -0
- qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py +145 -0
- qiskit/circuit/library/arithmetic/multipliers/multiplier.py +192 -0
- qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +108 -0
- qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +353 -0
- qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +277 -0
- qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +317 -0
- qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +335 -0
- qiskit/circuit/library/arithmetic/quadratic_form.py +198 -0
- qiskit/circuit/library/arithmetic/weighted_adder.py +337 -0
- qiskit/circuit/library/basis_change/__init__.py +15 -0
- qiskit/circuit/library/basis_change/qft.py +313 -0
- qiskit/circuit/library/blueprintcircuit.py +280 -0
- qiskit/circuit/library/boolean_logic/__init__.py +18 -0
- qiskit/circuit/library/boolean_logic/inner_product.py +155 -0
- qiskit/circuit/library/boolean_logic/quantum_and.py +200 -0
- qiskit/circuit/library/boolean_logic/quantum_or.py +202 -0
- qiskit/circuit/library/boolean_logic/quantum_xor.py +165 -0
- qiskit/circuit/library/data_preparation/__init__.py +57 -0
- qiskit/circuit/library/data_preparation/_z_feature_map.py +115 -0
- qiskit/circuit/library/data_preparation/_zz_feature_map.py +150 -0
- qiskit/circuit/library/data_preparation/initializer.py +107 -0
- qiskit/circuit/library/data_preparation/pauli_feature_map.py +656 -0
- qiskit/circuit/library/data_preparation/state_preparation.py +336 -0
- qiskit/circuit/library/fourier_checking.py +158 -0
- qiskit/circuit/library/generalized_gates/__init__.py +30 -0
- qiskit/circuit/library/generalized_gates/diagonal.py +159 -0
- qiskit/circuit/library/generalized_gates/gms.py +174 -0
- qiskit/circuit/library/generalized_gates/gr.py +215 -0
- qiskit/circuit/library/generalized_gates/isometry.py +370 -0
- qiskit/circuit/library/generalized_gates/linear_function.py +318 -0
- qiskit/circuit/library/generalized_gates/mcg_up_to_diagonal.py +143 -0
- qiskit/circuit/library/generalized_gates/mcmt.py +316 -0
- qiskit/circuit/library/generalized_gates/pauli.py +85 -0
- qiskit/circuit/library/generalized_gates/permutation.py +194 -0
- qiskit/circuit/library/generalized_gates/rv.py +96 -0
- qiskit/circuit/library/generalized_gates/uc.py +213 -0
- qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +164 -0
- qiskit/circuit/library/generalized_gates/ucrx.py +32 -0
- qiskit/circuit/library/generalized_gates/ucry.py +32 -0
- qiskit/circuit/library/generalized_gates/ucrz.py +32 -0
- qiskit/circuit/library/generalized_gates/unitary.py +215 -0
- qiskit/circuit/library/graph_state.py +169 -0
- qiskit/circuit/library/grover_operator.py +579 -0
- qiskit/circuit/library/hamiltonian_gate.py +142 -0
- qiskit/circuit/library/hidden_linear_function.py +161 -0
- qiskit/circuit/library/iqp.py +175 -0
- qiskit/circuit/library/n_local/__init__.py +45 -0
- qiskit/circuit/library/n_local/efficient_su2.py +277 -0
- qiskit/circuit/library/n_local/evolved_operator_ansatz.py +515 -0
- qiskit/circuit/library/n_local/excitation_preserving.py +297 -0
- qiskit/circuit/library/n_local/n_local.py +1472 -0
- qiskit/circuit/library/n_local/pauli_two_design.py +243 -0
- qiskit/circuit/library/n_local/qaoa_ansatz.py +366 -0
- qiskit/circuit/library/n_local/real_amplitudes.py +306 -0
- qiskit/circuit/library/n_local/two_local.py +289 -0
- qiskit/circuit/library/overlap.py +182 -0
- qiskit/circuit/library/pauli_evolution.py +186 -0
- qiskit/circuit/library/phase_estimation.py +175 -0
- qiskit/circuit/library/phase_oracle.py +153 -0
- qiskit/circuit/library/quantum_volume.py +167 -0
- qiskit/circuit/library/standard_gates/__init__.py +142 -0
- qiskit/circuit/library/standard_gates/dcx.py +78 -0
- qiskit/circuit/library/standard_gates/ecr.py +130 -0
- qiskit/circuit/library/standard_gates/equivalence_library.py +1800 -0
- qiskit/circuit/library/standard_gates/global_phase.py +85 -0
- qiskit/circuit/library/standard_gates/h.py +258 -0
- qiskit/circuit/library/standard_gates/i.py +76 -0
- qiskit/circuit/library/standard_gates/iswap.py +134 -0
- qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +405 -0
- qiskit/circuit/library/standard_gates/p.py +441 -0
- qiskit/circuit/library/standard_gates/r.py +117 -0
- qiskit/circuit/library/standard_gates/rx.py +303 -0
- qiskit/circuit/library/standard_gates/rxx.py +183 -0
- qiskit/circuit/library/standard_gates/ry.py +298 -0
- qiskit/circuit/library/standard_gates/ryy.py +183 -0
- qiskit/circuit/library/standard_gates/rz.py +319 -0
- qiskit/circuit/library/standard_gates/rzx.py +229 -0
- qiskit/circuit/library/standard_gates/rzz.py +196 -0
- qiskit/circuit/library/standard_gates/s.py +428 -0
- qiskit/circuit/library/standard_gates/swap.py +288 -0
- qiskit/circuit/library/standard_gates/sx.py +315 -0
- qiskit/circuit/library/standard_gates/t.py +179 -0
- qiskit/circuit/library/standard_gates/u.py +403 -0
- qiskit/circuit/library/standard_gates/u1.py +501 -0
- qiskit/circuit/library/standard_gates/u2.py +149 -0
- qiskit/circuit/library/standard_gates/u3.py +436 -0
- qiskit/circuit/library/standard_gates/x.py +1529 -0
- qiskit/circuit/library/standard_gates/xx_minus_yy.py +235 -0
- qiskit/circuit/library/standard_gates/xx_plus_yy.py +239 -0
- qiskit/circuit/library/standard_gates/y.py +262 -0
- qiskit/circuit/library/standard_gates/z.py +348 -0
- qiskit/circuit/library/templates/__init__.py +92 -0
- qiskit/circuit/library/templates/clifford/__init__.py +33 -0
- qiskit/circuit/library/templates/clifford/clifford_2_1.py +34 -0
- qiskit/circuit/library/templates/clifford/clifford_2_2.py +35 -0
- qiskit/circuit/library/templates/clifford/clifford_2_3.py +34 -0
- qiskit/circuit/library/templates/clifford/clifford_2_4.py +34 -0
- qiskit/circuit/library/templates/clifford/clifford_3_1.py +35 -0
- qiskit/circuit/library/templates/clifford/clifford_4_1.py +38 -0
- qiskit/circuit/library/templates/clifford/clifford_4_2.py +37 -0
- qiskit/circuit/library/templates/clifford/clifford_4_3.py +38 -0
- qiskit/circuit/library/templates/clifford/clifford_4_4.py +37 -0
- qiskit/circuit/library/templates/clifford/clifford_5_1.py +40 -0
- qiskit/circuit/library/templates/clifford/clifford_6_1.py +40 -0
- qiskit/circuit/library/templates/clifford/clifford_6_2.py +40 -0
- qiskit/circuit/library/templates/clifford/clifford_6_3.py +40 -0
- qiskit/circuit/library/templates/clifford/clifford_6_4.py +38 -0
- qiskit/circuit/library/templates/clifford/clifford_6_5.py +40 -0
- qiskit/circuit/library/templates/clifford/clifford_8_1.py +42 -0
- qiskit/circuit/library/templates/clifford/clifford_8_2.py +42 -0
- qiskit/circuit/library/templates/clifford/clifford_8_3.py +41 -0
- qiskit/circuit/library/templates/nct/__init__.py +67 -0
- qiskit/circuit/library/templates/nct/template_nct_2a_1.py +34 -0
- qiskit/circuit/library/templates/nct/template_nct_2a_2.py +35 -0
- qiskit/circuit/library/templates/nct/template_nct_2a_3.py +37 -0
- qiskit/circuit/library/templates/nct/template_nct_4a_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_4a_2.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_4a_3.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_4b_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_4b_2.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_1.py +40 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_2.py +40 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_3.py +40 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_4.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_1.py +40 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_2.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_3.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_4.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_6b_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_6b_2.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_6c_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_7a_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_7b_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_7c_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_7d_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_7e_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_9a_1.py +45 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_10.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_11.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_12.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_2.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_3.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_4.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_5.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_6.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_7.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_8.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_9.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_10.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_2.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_3.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_4.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_5.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_6.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_7.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_8.py +44 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_9.py +44 -0
- qiskit/circuit/library/templates/rzx/__init__.py +25 -0
- qiskit/circuit/library/templates/rzx/rzx_cy.py +47 -0
- qiskit/circuit/library/templates/rzx/rzx_xz.py +54 -0
- qiskit/circuit/library/templates/rzx/rzx_yz.py +45 -0
- qiskit/circuit/library/templates/rzx/rzx_zz1.py +69 -0
- qiskit/circuit/library/templates/rzx/rzx_zz2.py +59 -0
- qiskit/circuit/library/templates/rzx/rzx_zz3.py +59 -0
- qiskit/circuit/measure.py +44 -0
- qiskit/circuit/operation.py +67 -0
- qiskit/circuit/parameter.py +178 -0
- qiskit/circuit/parameterexpression.py +692 -0
- qiskit/circuit/parametertable.py +119 -0
- qiskit/circuit/parametervector.py +120 -0
- qiskit/circuit/quantumcircuit.py +6829 -0
- qiskit/circuit/quantumcircuitdata.py +136 -0
- qiskit/circuit/quantumregister.py +75 -0
- qiskit/circuit/random/__init__.py +15 -0
- qiskit/circuit/random/utils.py +358 -0
- qiskit/circuit/register.py +233 -0
- qiskit/circuit/reset.py +34 -0
- qiskit/circuit/singleton.py +606 -0
- qiskit/circuit/store.py +97 -0
- qiskit/circuit/tools/__init__.py +16 -0
- qiskit/circuit/tools/pi_check.py +190 -0
- qiskit/circuit/twirling.py +145 -0
- qiskit/compiler/__init__.py +33 -0
- qiskit/compiler/assembler.py +681 -0
- qiskit/compiler/scheduler.py +109 -0
- qiskit/compiler/sequencer.py +71 -0
- qiskit/compiler/transpiler.py +533 -0
- qiskit/converters/__init__.py +74 -0
- qiskit/converters/circuit_to_dag.py +78 -0
- qiskit/converters/circuit_to_dagdependency.py +51 -0
- qiskit/converters/circuit_to_dagdependency_v2.py +47 -0
- qiskit/converters/circuit_to_gate.py +107 -0
- qiskit/converters/circuit_to_instruction.py +155 -0
- qiskit/converters/dag_to_circuit.py +79 -0
- qiskit/converters/dag_to_dagdependency.py +55 -0
- qiskit/converters/dag_to_dagdependency_v2.py +44 -0
- qiskit/converters/dagdependency_to_circuit.py +46 -0
- qiskit/converters/dagdependency_to_dag.py +54 -0
- qiskit/dagcircuit/__init__.py +44 -0
- qiskit/dagcircuit/collect_blocks.py +391 -0
- qiskit/dagcircuit/dagcircuit.py +24 -0
- qiskit/dagcircuit/dagdependency.py +646 -0
- qiskit/dagcircuit/dagdependency_v2.py +641 -0
- qiskit/dagcircuit/dagdepnode.py +160 -0
- qiskit/dagcircuit/dagnode.py +176 -0
- qiskit/dagcircuit/exceptions.py +42 -0
- qiskit/exceptions.py +153 -0
- qiskit/passmanager/__init__.py +240 -0
- qiskit/passmanager/base_tasks.py +230 -0
- qiskit/passmanager/compilation_status.py +74 -0
- qiskit/passmanager/exceptions.py +19 -0
- qiskit/passmanager/flow_controllers.py +116 -0
- qiskit/passmanager/passmanager.py +333 -0
- qiskit/primitives/__init__.py +481 -0
- qiskit/primitives/backend_estimator.py +486 -0
- qiskit/primitives/backend_estimator_v2.py +434 -0
- qiskit/primitives/backend_sampler.py +222 -0
- qiskit/primitives/backend_sampler_v2.py +339 -0
- qiskit/primitives/base/__init__.py +20 -0
- qiskit/primitives/base/base_estimator.py +252 -0
- qiskit/primitives/base/base_primitive.py +45 -0
- qiskit/primitives/base/base_primitive_job.py +78 -0
- qiskit/primitives/base/base_result.py +65 -0
- qiskit/primitives/base/base_sampler.py +204 -0
- qiskit/primitives/base/estimator_result.py +46 -0
- qiskit/primitives/base/sampler_result.py +45 -0
- qiskit/primitives/base/validation.py +231 -0
- qiskit/primitives/containers/__init__.py +26 -0
- qiskit/primitives/containers/bindings_array.py +389 -0
- qiskit/primitives/containers/bit_array.py +741 -0
- qiskit/primitives/containers/data_bin.py +173 -0
- qiskit/primitives/containers/estimator_pub.py +222 -0
- qiskit/primitives/containers/object_array.py +94 -0
- qiskit/primitives/containers/observables_array.py +279 -0
- qiskit/primitives/containers/primitive_result.py +53 -0
- qiskit/primitives/containers/pub_result.py +51 -0
- qiskit/primitives/containers/sampler_pub.py +193 -0
- qiskit/primitives/containers/sampler_pub_result.py +74 -0
- qiskit/primitives/containers/shape.py +129 -0
- qiskit/primitives/estimator.py +172 -0
- qiskit/primitives/primitive_job.py +81 -0
- qiskit/primitives/sampler.py +162 -0
- qiskit/primitives/statevector_estimator.py +174 -0
- qiskit/primitives/statevector_sampler.py +292 -0
- qiskit/primitives/utils.py +247 -0
- qiskit/providers/__init__.py +803 -0
- qiskit/providers/backend.py +667 -0
- qiskit/providers/backend_compat.py +472 -0
- qiskit/providers/basic_provider/__init__.py +45 -0
- qiskit/providers/basic_provider/basic_provider.py +101 -0
- qiskit/providers/basic_provider/basic_provider_job.py +65 -0
- qiskit/providers/basic_provider/basic_provider_tools.py +218 -0
- qiskit/providers/basic_provider/basic_simulator.py +821 -0
- qiskit/providers/basic_provider/exceptions.py +30 -0
- qiskit/providers/exceptions.py +45 -0
- qiskit/providers/fake_provider/__init__.py +105 -0
- qiskit/providers/fake_provider/backends_v1/__init__.py +22 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +37 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +43 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +50 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +41 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +44 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +1 -0
- qiskit/providers/fake_provider/fake_1q.py +91 -0
- qiskit/providers/fake_provider/fake_backend.py +165 -0
- qiskit/providers/fake_provider/fake_openpulse_2q.py +391 -0
- qiskit/providers/fake_provider/fake_openpulse_3q.py +340 -0
- qiskit/providers/fake_provider/fake_pulse_backend.py +49 -0
- qiskit/providers/fake_provider/fake_qasm_backend.py +77 -0
- qiskit/providers/fake_provider/generic_backend_v2.py +1035 -0
- qiskit/providers/fake_provider/utils/__init__.py +15 -0
- qiskit/providers/fake_provider/utils/backend_converter.py +150 -0
- qiskit/providers/fake_provider/utils/json_decoder.py +109 -0
- qiskit/providers/job.py +147 -0
- qiskit/providers/jobstatus.py +30 -0
- qiskit/providers/models/__init__.py +89 -0
- qiskit/providers/models/backendconfiguration.py +1040 -0
- qiskit/providers/models/backendproperties.py +517 -0
- qiskit/providers/models/backendstatus.py +94 -0
- qiskit/providers/models/jobstatus.py +66 -0
- qiskit/providers/models/pulsedefaults.py +305 -0
- qiskit/providers/options.py +273 -0
- qiskit/providers/provider.py +95 -0
- qiskit/providers/providerutils.py +110 -0
- qiskit/pulse/__init__.py +158 -0
- qiskit/pulse/builder.py +2254 -0
- qiskit/pulse/calibration_entries.py +381 -0
- qiskit/pulse/channels.py +227 -0
- qiskit/pulse/configuration.py +245 -0
- qiskit/pulse/exceptions.py +45 -0
- qiskit/pulse/filters.py +309 -0
- qiskit/pulse/instruction_schedule_map.py +424 -0
- qiskit/pulse/instructions/__init__.py +67 -0
- qiskit/pulse/instructions/acquire.py +150 -0
- qiskit/pulse/instructions/delay.py +71 -0
- qiskit/pulse/instructions/directives.py +154 -0
- qiskit/pulse/instructions/frequency.py +135 -0
- qiskit/pulse/instructions/instruction.py +270 -0
- qiskit/pulse/instructions/phase.py +152 -0
- qiskit/pulse/instructions/play.py +99 -0
- qiskit/pulse/instructions/reference.py +100 -0
- qiskit/pulse/instructions/snapshot.py +82 -0
- qiskit/pulse/library/__init__.py +97 -0
- qiskit/pulse/library/continuous.py +430 -0
- qiskit/pulse/library/pulse.py +148 -0
- qiskit/pulse/library/samplers/__init__.py +15 -0
- qiskit/pulse/library/samplers/decorators.py +295 -0
- qiskit/pulse/library/samplers/strategies.py +71 -0
- qiskit/pulse/library/symbolic_pulses.py +1988 -0
- qiskit/pulse/library/waveform.py +136 -0
- qiskit/pulse/macros.py +262 -0
- qiskit/pulse/parameter_manager.py +445 -0
- qiskit/pulse/parser.py +314 -0
- qiskit/pulse/reference_manager.py +58 -0
- qiskit/pulse/schedule.py +1854 -0
- qiskit/pulse/transforms/__init__.py +106 -0
- qiskit/pulse/transforms/alignments.py +406 -0
- qiskit/pulse/transforms/base_transforms.py +71 -0
- qiskit/pulse/transforms/canonicalization.py +498 -0
- qiskit/pulse/transforms/dag.py +122 -0
- qiskit/pulse/utils.py +149 -0
- qiskit/qasm/libs/dummy/stdgates.inc +75 -0
- qiskit/qasm/libs/qelib1.inc +266 -0
- qiskit/qasm/libs/stdgates.inc +82 -0
- qiskit/qasm2/__init__.py +654 -0
- qiskit/qasm2/exceptions.py +27 -0
- qiskit/qasm2/export.py +372 -0
- qiskit/qasm2/parse.py +452 -0
- qiskit/qasm3/__init__.py +367 -0
- qiskit/qasm3/ast.py +738 -0
- qiskit/qasm3/exceptions.py +27 -0
- qiskit/qasm3/experimental.py +70 -0
- qiskit/qasm3/exporter.py +1299 -0
- qiskit/qasm3/printer.py +577 -0
- qiskit/qobj/__init__.py +75 -0
- qiskit/qobj/common.py +81 -0
- qiskit/qobj/converters/__init__.py +18 -0
- qiskit/qobj/converters/lo_config.py +177 -0
- qiskit/qobj/converters/pulse_instruction.py +897 -0
- qiskit/qobj/pulse_qobj.py +709 -0
- qiskit/qobj/qasm_qobj.py +708 -0
- qiskit/qobj/utils.py +46 -0
- qiskit/qpy/__init__.py +1822 -0
- qiskit/qpy/binary_io/__init__.py +36 -0
- qiskit/qpy/binary_io/circuits.py +1475 -0
- qiskit/qpy/binary_io/schedules.py +635 -0
- qiskit/qpy/binary_io/value.py +1025 -0
- qiskit/qpy/common.py +350 -0
- qiskit/qpy/exceptions.py +53 -0
- qiskit/qpy/formats.py +401 -0
- qiskit/qpy/interface.py +377 -0
- qiskit/qpy/type_keys.py +572 -0
- qiskit/quantum_info/__init__.py +162 -0
- qiskit/quantum_info/analysis/__init__.py +17 -0
- qiskit/quantum_info/analysis/average.py +47 -0
- qiskit/quantum_info/analysis/distance.py +102 -0
- qiskit/quantum_info/analysis/make_observable.py +44 -0
- qiskit/quantum_info/analysis/z2_symmetries.py +484 -0
- qiskit/quantum_info/operators/__init__.py +28 -0
- qiskit/quantum_info/operators/base_operator.py +145 -0
- qiskit/quantum_info/operators/channel/__init__.py +29 -0
- qiskit/quantum_info/operators/channel/chi.py +191 -0
- qiskit/quantum_info/operators/channel/choi.py +218 -0
- qiskit/quantum_info/operators/channel/kraus.py +337 -0
- qiskit/quantum_info/operators/channel/ptm.py +204 -0
- qiskit/quantum_info/operators/channel/quantum_channel.py +348 -0
- qiskit/quantum_info/operators/channel/stinespring.py +296 -0
- qiskit/quantum_info/operators/channel/superop.py +377 -0
- qiskit/quantum_info/operators/channel/transformations.py +475 -0
- qiskit/quantum_info/operators/custom_iterator.py +48 -0
- qiskit/quantum_info/operators/dihedral/__init__.py +18 -0
- qiskit/quantum_info/operators/dihedral/dihedral.py +509 -0
- qiskit/quantum_info/operators/dihedral/dihedral_circuits.py +216 -0
- qiskit/quantum_info/operators/dihedral/polynomial.py +313 -0
- qiskit/quantum_info/operators/dihedral/random.py +64 -0
- qiskit/quantum_info/operators/linear_op.py +25 -0
- qiskit/quantum_info/operators/measures.py +418 -0
- qiskit/quantum_info/operators/mixins/__init__.py +52 -0
- qiskit/quantum_info/operators/mixins/adjoint.py +52 -0
- qiskit/quantum_info/operators/mixins/group.py +171 -0
- qiskit/quantum_info/operators/mixins/linear.py +84 -0
- qiskit/quantum_info/operators/mixins/multiply.py +62 -0
- qiskit/quantum_info/operators/mixins/tolerances.py +72 -0
- qiskit/quantum_info/operators/op_shape.py +525 -0
- qiskit/quantum_info/operators/operator.py +865 -0
- qiskit/quantum_info/operators/operator_utils.py +76 -0
- qiskit/quantum_info/operators/predicates.py +183 -0
- qiskit/quantum_info/operators/random.py +154 -0
- qiskit/quantum_info/operators/scalar_op.py +254 -0
- qiskit/quantum_info/operators/symplectic/__init__.py +23 -0
- qiskit/quantum_info/operators/symplectic/base_pauli.py +719 -0
- qiskit/quantum_info/operators/symplectic/clifford.py +1030 -0
- qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
- qiskit/quantum_info/operators/symplectic/pauli.py +753 -0
- qiskit/quantum_info/operators/symplectic/pauli_list.py +1230 -0
- qiskit/quantum_info/operators/symplectic/pauli_utils.py +40 -0
- qiskit/quantum_info/operators/symplectic/random.py +117 -0
- qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +1196 -0
- qiskit/quantum_info/operators/utils/__init__.py +20 -0
- qiskit/quantum_info/operators/utils/anti_commutator.py +36 -0
- qiskit/quantum_info/operators/utils/commutator.py +36 -0
- qiskit/quantum_info/operators/utils/double_commutator.py +76 -0
- qiskit/quantum_info/quaternion.py +156 -0
- qiskit/quantum_info/random.py +26 -0
- qiskit/quantum_info/states/__init__.py +28 -0
- qiskit/quantum_info/states/densitymatrix.py +845 -0
- qiskit/quantum_info/states/measures.py +288 -0
- qiskit/quantum_info/states/quantum_state.py +503 -0
- qiskit/quantum_info/states/random.py +157 -0
- qiskit/quantum_info/states/stabilizerstate.py +773 -0
- qiskit/quantum_info/states/statevector.py +958 -0
- qiskit/quantum_info/states/utils.py +247 -0
- qiskit/result/__init__.py +73 -0
- qiskit/result/counts.py +189 -0
- qiskit/result/distributions/__init__.py +17 -0
- qiskit/result/distributions/probability.py +100 -0
- qiskit/result/distributions/quasi.py +154 -0
- qiskit/result/exceptions.py +40 -0
- qiskit/result/mitigation/__init__.py +13 -0
- qiskit/result/mitigation/base_readout_mitigator.py +79 -0
- qiskit/result/mitigation/correlated_readout_mitigator.py +277 -0
- qiskit/result/mitigation/local_readout_mitigator.py +328 -0
- qiskit/result/mitigation/utils.py +217 -0
- qiskit/result/models.py +234 -0
- qiskit/result/postprocess.py +239 -0
- qiskit/result/result.py +392 -0
- qiskit/result/sampled_expval.py +75 -0
- qiskit/result/utils.py +295 -0
- qiskit/scheduler/__init__.py +40 -0
- qiskit/scheduler/config.py +37 -0
- qiskit/scheduler/lowering.py +187 -0
- qiskit/scheduler/methods/__init__.py +15 -0
- qiskit/scheduler/methods/basic.py +140 -0
- qiskit/scheduler/schedule_circuit.py +69 -0
- qiskit/scheduler/sequence.py +104 -0
- qiskit/synthesis/__init__.py +220 -0
- qiskit/synthesis/arithmetic/__init__.py +16 -0
- qiskit/synthesis/arithmetic/adders/__init__.py +17 -0
- qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +154 -0
- qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +103 -0
- qiskit/synthesis/arithmetic/adders/vbe_ripple_carry_adder.py +161 -0
- qiskit/synthesis/arithmetic/multipliers/__init__.py +16 -0
- qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +102 -0
- qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +99 -0
- qiskit/synthesis/clifford/__init__.py +19 -0
- qiskit/synthesis/clifford/clifford_decompose_ag.py +178 -0
- qiskit/synthesis/clifford/clifford_decompose_bm.py +46 -0
- qiskit/synthesis/clifford/clifford_decompose_full.py +64 -0
- qiskit/synthesis/clifford/clifford_decompose_greedy.py +58 -0
- qiskit/synthesis/clifford/clifford_decompose_layers.py +447 -0
- qiskit/synthesis/cnotdihedral/__init__.py +17 -0
- qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py +52 -0
- qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py +141 -0
- qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py +266 -0
- qiskit/synthesis/discrete_basis/__init__.py +16 -0
- qiskit/synthesis/discrete_basis/commutator_decompose.py +241 -0
- qiskit/synthesis/discrete_basis/gate_sequence.py +415 -0
- qiskit/synthesis/discrete_basis/generate_basis_approximations.py +163 -0
- qiskit/synthesis/discrete_basis/solovay_kitaev.py +217 -0
- qiskit/synthesis/evolution/__init__.py +21 -0
- qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
- qiskit/synthesis/evolution/lie_trotter.py +117 -0
- qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
- qiskit/synthesis/evolution/pauli_network.py +80 -0
- qiskit/synthesis/evolution/product_formula.py +311 -0
- qiskit/synthesis/evolution/qdrift.py +138 -0
- qiskit/synthesis/evolution/suzuki_trotter.py +215 -0
- qiskit/synthesis/linear/__init__.py +26 -0
- qiskit/synthesis/linear/cnot_synth.py +69 -0
- qiskit/synthesis/linear/linear_circuits_utils.py +128 -0
- qiskit/synthesis/linear/linear_depth_lnn.py +276 -0
- qiskit/synthesis/linear/linear_matrix_utils.py +27 -0
- qiskit/synthesis/linear_phase/__init__.py +17 -0
- qiskit/synthesis/linear_phase/cnot_phase_synth.py +206 -0
- qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +262 -0
- qiskit/synthesis/linear_phase/cz_depth_lnn.py +58 -0
- qiskit/synthesis/multi_controlled/__init__.py +24 -0
- qiskit/synthesis/multi_controlled/mcmt_vchain.py +52 -0
- qiskit/synthesis/multi_controlled/mcx_synthesis.py +356 -0
- qiskit/synthesis/one_qubit/__init__.py +15 -0
- qiskit/synthesis/one_qubit/one_qubit_decompose.py +288 -0
- qiskit/synthesis/permutation/__init__.py +18 -0
- qiskit/synthesis/permutation/permutation_full.py +78 -0
- qiskit/synthesis/permutation/permutation_lnn.py +54 -0
- qiskit/synthesis/permutation/permutation_reverse_lnn.py +93 -0
- qiskit/synthesis/permutation/permutation_utils.py +16 -0
- qiskit/synthesis/qft/__init__.py +16 -0
- qiskit/synthesis/qft/qft_decompose_full.py +97 -0
- qiskit/synthesis/qft/qft_decompose_lnn.py +79 -0
- qiskit/synthesis/stabilizer/__init__.py +16 -0
- qiskit/synthesis/stabilizer/stabilizer_circuit.py +149 -0
- qiskit/synthesis/stabilizer/stabilizer_decompose.py +194 -0
- qiskit/synthesis/two_qubit/__init__.py +19 -0
- qiskit/synthesis/two_qubit/local_invariance.py +63 -0
- qiskit/synthesis/two_qubit/two_qubit_decompose.py +700 -0
- qiskit/synthesis/two_qubit/xx_decompose/__init__.py +19 -0
- qiskit/synthesis/two_qubit/xx_decompose/circuits.py +300 -0
- qiskit/synthesis/two_qubit/xx_decompose/decomposer.py +324 -0
- qiskit/synthesis/two_qubit/xx_decompose/embodiments.py +163 -0
- qiskit/synthesis/two_qubit/xx_decompose/paths.py +412 -0
- qiskit/synthesis/two_qubit/xx_decompose/polytopes.py +262 -0
- qiskit/synthesis/two_qubit/xx_decompose/utilities.py +40 -0
- qiskit/synthesis/two_qubit/xx_decompose/weyl.py +133 -0
- qiskit/synthesis/unitary/__init__.py +13 -0
- qiskit/synthesis/unitary/aqc/__init__.py +177 -0
- qiskit/synthesis/unitary/aqc/approximate.py +116 -0
- qiskit/synthesis/unitary/aqc/aqc.py +175 -0
- qiskit/synthesis/unitary/aqc/cnot_structures.py +300 -0
- qiskit/synthesis/unitary/aqc/cnot_unit_circuit.py +103 -0
- qiskit/synthesis/unitary/aqc/cnot_unit_objective.py +299 -0
- qiskit/synthesis/unitary/aqc/elementary_operations.py +108 -0
- qiskit/synthesis/unitary/aqc/fast_gradient/__init__.py +164 -0
- qiskit/synthesis/unitary/aqc/fast_gradient/fast_grad_utils.py +237 -0
- qiskit/synthesis/unitary/aqc/fast_gradient/fast_gradient.py +226 -0
- qiskit/synthesis/unitary/aqc/fast_gradient/layer.py +370 -0
- qiskit/synthesis/unitary/aqc/fast_gradient/pmatrix.py +312 -0
- qiskit/synthesis/unitary/qsd.py +288 -0
- qiskit/transpiler/__init__.py +1290 -0
- qiskit/transpiler/basepasses.py +221 -0
- qiskit/transpiler/coupling.py +500 -0
- qiskit/transpiler/exceptions.py +59 -0
- qiskit/transpiler/instruction_durations.py +281 -0
- qiskit/transpiler/layout.py +737 -0
- qiskit/transpiler/passes/__init__.py +312 -0
- qiskit/transpiler/passes/analysis/__init__.py +23 -0
- qiskit/transpiler/passes/analysis/count_ops.py +30 -0
- qiskit/transpiler/passes/analysis/count_ops_longest_path.py +26 -0
- qiskit/transpiler/passes/analysis/dag_longest_path.py +24 -0
- qiskit/transpiler/passes/analysis/depth.py +33 -0
- qiskit/transpiler/passes/analysis/num_qubits.py +26 -0
- qiskit/transpiler/passes/analysis/num_tensor_factors.py +26 -0
- qiskit/transpiler/passes/analysis/resource_estimation.py +41 -0
- qiskit/transpiler/passes/analysis/size.py +36 -0
- qiskit/transpiler/passes/analysis/width.py +27 -0
- qiskit/transpiler/passes/basis/__init__.py +19 -0
- qiskit/transpiler/passes/basis/basis_translator.py +137 -0
- qiskit/transpiler/passes/basis/decompose.py +131 -0
- qiskit/transpiler/passes/basis/translate_parameterized.py +175 -0
- qiskit/transpiler/passes/basis/unroll_3q_or_more.py +88 -0
- qiskit/transpiler/passes/basis/unroll_custom_definitions.py +109 -0
- qiskit/transpiler/passes/calibration/__init__.py +17 -0
- qiskit/transpiler/passes/calibration/base_builder.py +79 -0
- qiskit/transpiler/passes/calibration/builders.py +20 -0
- qiskit/transpiler/passes/calibration/exceptions.py +22 -0
- qiskit/transpiler/passes/calibration/pulse_gate.py +100 -0
- qiskit/transpiler/passes/calibration/rx_builder.py +164 -0
- qiskit/transpiler/passes/calibration/rzx_builder.py +411 -0
- qiskit/transpiler/passes/calibration/rzx_templates.py +51 -0
- qiskit/transpiler/passes/layout/__init__.py +26 -0
- qiskit/transpiler/passes/layout/_csp_custom_solver.py +65 -0
- qiskit/transpiler/passes/layout/apply_layout.py +123 -0
- qiskit/transpiler/passes/layout/csp_layout.py +132 -0
- qiskit/transpiler/passes/layout/dense_layout.py +202 -0
- qiskit/transpiler/passes/layout/disjoint_utils.py +219 -0
- qiskit/transpiler/passes/layout/enlarge_with_ancilla.py +49 -0
- qiskit/transpiler/passes/layout/full_ancilla_allocation.py +117 -0
- qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
- qiskit/transpiler/passes/layout/sabre_layout.py +487 -0
- qiskit/transpiler/passes/layout/sabre_pre_layout.py +225 -0
- qiskit/transpiler/passes/layout/set_layout.py +69 -0
- qiskit/transpiler/passes/layout/trivial_layout.py +66 -0
- qiskit/transpiler/passes/layout/vf2_layout.py +263 -0
- qiskit/transpiler/passes/layout/vf2_post_layout.py +419 -0
- qiskit/transpiler/passes/layout/vf2_utils.py +260 -0
- qiskit/transpiler/passes/optimization/__init__.py +43 -0
- qiskit/transpiler/passes/optimization/_gate_extension.py +80 -0
- qiskit/transpiler/passes/optimization/collect_1q_runs.py +31 -0
- qiskit/transpiler/passes/optimization/collect_2q_blocks.py +35 -0
- qiskit/transpiler/passes/optimization/collect_and_collapse.py +115 -0
- qiskit/transpiler/passes/optimization/collect_cliffords.py +104 -0
- qiskit/transpiler/passes/optimization/collect_linear_functions.py +80 -0
- qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +227 -0
- qiskit/transpiler/passes/optimization/commutation_analysis.py +44 -0
- qiskit/transpiler/passes/optimization/commutative_cancellation.py +82 -0
- qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py +140 -0
- qiskit/transpiler/passes/optimization/consolidate_blocks.py +149 -0
- qiskit/transpiler/passes/optimization/cx_cancellation.py +65 -0
- qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +162 -0
- qiskit/transpiler/passes/optimization/elide_permutations.py +91 -0
- qiskit/transpiler/passes/optimization/hoare_opt.py +420 -0
- qiskit/transpiler/passes/optimization/inverse_cancellation.py +95 -0
- qiskit/transpiler/passes/optimization/normalize_rx_angle.py +149 -0
- qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +268 -0
- qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +254 -0
- qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
- qiskit/transpiler/passes/optimization/optimize_annotated.py +448 -0
- qiskit/transpiler/passes/optimization/optimize_cliffords.py +89 -0
- qiskit/transpiler/passes/optimization/optimize_swap_before_measure.py +71 -0
- qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py +41 -0
- qiskit/transpiler/passes/optimization/remove_final_reset.py +37 -0
- qiskit/transpiler/passes/optimization/remove_identity_equiv.py +69 -0
- qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
- qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +47 -0
- qiskit/transpiler/passes/optimization/split_2q_unitaries.py +40 -0
- qiskit/transpiler/passes/optimization/template_matching/__init__.py +19 -0
- qiskit/transpiler/passes/optimization/template_matching/backward_match.py +749 -0
- qiskit/transpiler/passes/optimization/template_matching/forward_match.py +452 -0
- qiskit/transpiler/passes/optimization/template_matching/maximal_matches.py +77 -0
- qiskit/transpiler/passes/optimization/template_matching/template_matching.py +370 -0
- qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +638 -0
- qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
- qiskit/transpiler/passes/routing/__init__.py +22 -0
- qiskit/transpiler/passes/routing/algorithms/__init__.py +33 -0
- qiskit/transpiler/passes/routing/algorithms/token_swapper.py +105 -0
- qiskit/transpiler/passes/routing/algorithms/types.py +46 -0
- qiskit/transpiler/passes/routing/algorithms/util.py +103 -0
- qiskit/transpiler/passes/routing/basic_swap.py +166 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/__init__.py +25 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_block.py +60 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +395 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/pauli_2q_evolution_commutation.py +145 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/swap_strategy.py +306 -0
- qiskit/transpiler/passes/routing/layout_transformation.py +119 -0
- qiskit/transpiler/passes/routing/lookahead_swap.py +390 -0
- qiskit/transpiler/passes/routing/sabre_swap.py +447 -0
- qiskit/transpiler/passes/routing/star_prerouting.py +392 -0
- qiskit/transpiler/passes/routing/stochastic_swap.py +532 -0
- qiskit/transpiler/passes/routing/utils.py +35 -0
- qiskit/transpiler/passes/scheduling/__init__.py +27 -0
- qiskit/transpiler/passes/scheduling/alap.py +153 -0
- qiskit/transpiler/passes/scheduling/alignments/__init__.py +81 -0
- qiskit/transpiler/passes/scheduling/alignments/align_measures.py +255 -0
- qiskit/transpiler/passes/scheduling/alignments/check_durations.py +78 -0
- qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +107 -0
- qiskit/transpiler/passes/scheduling/alignments/reschedule.py +250 -0
- qiskit/transpiler/passes/scheduling/asap.py +175 -0
- qiskit/transpiler/passes/scheduling/base_scheduler.py +310 -0
- qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +312 -0
- qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
- qiskit/transpiler/passes/scheduling/padding/base_padding.py +256 -0
- qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +452 -0
- qiskit/transpiler/passes/scheduling/padding/pad_delay.py +82 -0
- qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
- qiskit/transpiler/passes/scheduling/scheduling/alap.py +127 -0
- qiskit/transpiler/passes/scheduling/scheduling/asap.py +131 -0
- qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +94 -0
- qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
- qiskit/transpiler/passes/scheduling/time_unit_conversion.py +165 -0
- qiskit/transpiler/passes/synthesis/__init__.py +20 -0
- qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
- qiskit/transpiler/passes/synthesis/high_level_synthesis.py +854 -0
- qiskit/transpiler/passes/synthesis/hls_plugins.py +1559 -0
- qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +41 -0
- qiskit/transpiler/passes/synthesis/plugin.py +734 -0
- qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +297 -0
- qiskit/transpiler/passes/synthesis/unitary_synthesis.py +1076 -0
- qiskit/transpiler/passes/utils/__init__.py +33 -0
- qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +41 -0
- qiskit/transpiler/passes/utils/check_gate_direction.py +52 -0
- qiskit/transpiler/passes/utils/check_map.py +78 -0
- qiskit/transpiler/passes/utils/contains_instruction.py +45 -0
- qiskit/transpiler/passes/utils/control_flow.py +65 -0
- qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +93 -0
- qiskit/transpiler/passes/utils/dag_fixed_point.py +36 -0
- qiskit/transpiler/passes/utils/error.py +69 -0
- qiskit/transpiler/passes/utils/filter_op_nodes.py +65 -0
- qiskit/transpiler/passes/utils/fixed_point.py +48 -0
- qiskit/transpiler/passes/utils/gate_direction.py +86 -0
- qiskit/transpiler/passes/utils/gates_basis.py +51 -0
- qiskit/transpiler/passes/utils/merge_adjacent_barriers.py +163 -0
- qiskit/transpiler/passes/utils/minimum_point.py +118 -0
- qiskit/transpiler/passes/utils/remove_barriers.py +49 -0
- qiskit/transpiler/passes/utils/remove_final_measurements.py +114 -0
- qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
- qiskit/transpiler/passmanager.py +490 -0
- qiskit/transpiler/passmanager_config.py +216 -0
- qiskit/transpiler/preset_passmanagers/__init__.py +73 -0
- qiskit/transpiler/preset_passmanagers/builtin_plugins.py +1045 -0
- qiskit/transpiler/preset_passmanagers/common.py +649 -0
- qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +626 -0
- qiskit/transpiler/preset_passmanagers/level0.py +113 -0
- qiskit/transpiler/preset_passmanagers/level1.py +120 -0
- qiskit/transpiler/preset_passmanagers/level2.py +119 -0
- qiskit/transpiler/preset_passmanagers/level3.py +119 -0
- qiskit/transpiler/preset_passmanagers/plugin.py +353 -0
- qiskit/transpiler/target.py +1319 -0
- qiskit/transpiler/timing_constraints.py +59 -0
- qiskit/user_config.py +262 -0
- qiskit/utils/__init__.py +89 -0
- qiskit/utils/classtools.py +146 -0
- qiskit/utils/deprecate_pulse.py +119 -0
- qiskit/utils/deprecation.py +490 -0
- qiskit/utils/lazy_tester.py +363 -0
- qiskit/utils/multiprocessing.py +56 -0
- qiskit/utils/optionals.py +347 -0
- qiskit/utils/parallel.py +191 -0
- qiskit/utils/units.py +143 -0
- qiskit/version.py +84 -0
- qiskit/visualization/__init__.py +288 -0
- qiskit/visualization/array.py +204 -0
- qiskit/visualization/bloch.py +778 -0
- qiskit/visualization/circuit/__init__.py +15 -0
- qiskit/visualization/circuit/_utils.py +675 -0
- qiskit/visualization/circuit/circuit_visualization.py +727 -0
- qiskit/visualization/circuit/latex.py +661 -0
- qiskit/visualization/circuit/matplotlib.py +2029 -0
- qiskit/visualization/circuit/qcstyle.py +278 -0
- qiskit/visualization/circuit/styles/__init__.py +13 -0
- qiskit/visualization/circuit/styles/bw.json +202 -0
- qiskit/visualization/circuit/styles/clifford.json +202 -0
- qiskit/visualization/circuit/styles/iqp-dark.json +214 -0
- qiskit/visualization/circuit/styles/iqp.json +214 -0
- qiskit/visualization/circuit/styles/textbook.json +202 -0
- qiskit/visualization/circuit/text.py +1844 -0
- qiskit/visualization/circuit_visualization.py +19 -0
- qiskit/visualization/counts_visualization.py +481 -0
- qiskit/visualization/dag_visualization.py +316 -0
- qiskit/visualization/exceptions.py +21 -0
- qiskit/visualization/gate_map.py +1485 -0
- qiskit/visualization/library.py +37 -0
- qiskit/visualization/pass_manager_visualization.py +308 -0
- qiskit/visualization/pulse_v2/__init__.py +21 -0
- qiskit/visualization/pulse_v2/core.py +901 -0
- qiskit/visualization/pulse_v2/device_info.py +173 -0
- qiskit/visualization/pulse_v2/drawings.py +253 -0
- qiskit/visualization/pulse_v2/events.py +254 -0
- qiskit/visualization/pulse_v2/generators/__init__.py +40 -0
- qiskit/visualization/pulse_v2/generators/barrier.py +76 -0
- qiskit/visualization/pulse_v2/generators/chart.py +208 -0
- qiskit/visualization/pulse_v2/generators/frame.py +436 -0
- qiskit/visualization/pulse_v2/generators/snapshot.py +133 -0
- qiskit/visualization/pulse_v2/generators/waveform.py +645 -0
- qiskit/visualization/pulse_v2/interface.py +458 -0
- qiskit/visualization/pulse_v2/layouts.py +387 -0
- qiskit/visualization/pulse_v2/plotters/__init__.py +17 -0
- qiskit/visualization/pulse_v2/plotters/base_plotter.py +53 -0
- qiskit/visualization/pulse_v2/plotters/matplotlib.py +201 -0
- qiskit/visualization/pulse_v2/stylesheet.py +312 -0
- qiskit/visualization/pulse_v2/types.py +242 -0
- qiskit/visualization/state_visualization.py +1518 -0
- qiskit/visualization/timeline/__init__.py +21 -0
- qiskit/visualization/timeline/core.py +480 -0
- qiskit/visualization/timeline/drawings.py +260 -0
- qiskit/visualization/timeline/generators.py +506 -0
- qiskit/visualization/timeline/interface.py +436 -0
- qiskit/visualization/timeline/layouts.py +115 -0
- qiskit/visualization/timeline/plotters/__init__.py +16 -0
- qiskit/visualization/timeline/plotters/base_plotter.py +58 -0
- qiskit/visualization/timeline/plotters/matplotlib.py +192 -0
- qiskit/visualization/timeline/stylesheet.py +301 -0
- qiskit/visualization/timeline/types.py +148 -0
- qiskit/visualization/transition_visualization.py +369 -0
- qiskit/visualization/utils.py +49 -0
- qiskit-1.3.0.dist-info/LICENSE.txt +203 -0
- qiskit-1.3.0.dist-info/METADATA +222 -0
- qiskit-1.3.0.dist-info/RECORD +836 -0
- qiskit-1.3.0.dist-info/WHEEL +5 -0
- qiskit-1.3.0.dist-info/entry_points.txt +76 -0
- qiskit-1.3.0.dist-info/top_level.txt +1 -0
@@ -0,0 +1,86 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 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
|
+
"""Rearrange the direction of the 2-qubit gate nodes to match the directed coupling map."""
|
14
|
+
|
15
|
+
from qiskit.transpiler.basepasses import TransformationPass
|
16
|
+
from qiskit._accelerate.gate_direction import fix_gate_direction_coupling, fix_gate_direction_target
|
17
|
+
|
18
|
+
|
19
|
+
class GateDirection(TransformationPass):
|
20
|
+
"""Modify asymmetric gates to match the hardware coupling direction.
|
21
|
+
|
22
|
+
This pass supports replacements for the `cx`, `cz`, `ecr`, `swap`, `rzx`, `rxx`, `ryy` and
|
23
|
+
`rzz` gates, using the following identities::
|
24
|
+
|
25
|
+
┌───┐┌───┐┌───┐
|
26
|
+
q_0: ──■── q_0: ┤ H ├┤ X ├┤ H ├
|
27
|
+
┌─┴─┐ = ├───┤└─┬─┘├───┤
|
28
|
+
q_1: ┤ X ├ q_1: ┤ H ├──■──┤ H ├
|
29
|
+
└───┘ └───┘ └───┘
|
30
|
+
|
31
|
+
|
32
|
+
global phase: 3π/2
|
33
|
+
┌──────┐ ┌───┐ ┌────┐┌─────┐┌──────┐┌───┐
|
34
|
+
q_0: ┤0 ├ q_0: ─┤ S ├─┤ √X ├┤ Sdg ├┤1 ├┤ H ├
|
35
|
+
│ ECR │ = ┌┴───┴┐├────┤└┬───┬┘│ Ecr │├───┤
|
36
|
+
q_1: ┤1 ├ q_1: ┤ Sdg ├┤ √X ├─┤ S ├─┤0 ├┤ H ├
|
37
|
+
└──────┘ └─────┘└────┘ └───┘ └──────┘└───┘
|
38
|
+
Note: This is done in terms of less-efficient S/SX/Sdg gates instead of the more natural
|
39
|
+
`RY(pi /2)` so we have a chance for basis translation to keep things in a discrete basis
|
40
|
+
during resynthesis, if that's what's being asked for.
|
41
|
+
|
42
|
+
|
43
|
+
┌──────┐ ┌───┐┌──────┐┌───┐
|
44
|
+
q_0: ┤0 ├ q_0: ┤ H ├┤1 ├┤ H ├
|
45
|
+
│ RZX │ = ├───┤│ RZX │├───┤
|
46
|
+
q_1: ┤1 ├ q_1: ┤ H ├┤0 ├┤ H ├
|
47
|
+
└──────┘ └───┘└──────┘└───┘
|
48
|
+
|
49
|
+
cz, swap, rxx, ryy and rzz directions are fixed by reversing their qargs order.
|
50
|
+
|
51
|
+
This pass assumes that the positions of the qubits in the :attr:`.DAGCircuit.qubits` attribute
|
52
|
+
are the physical qubit indices. For example if ``dag.qubits[0]`` is qubit 0 in the
|
53
|
+
:class:`.CouplingMap` or :class:`.Target`.
|
54
|
+
"""
|
55
|
+
|
56
|
+
def __init__(self, coupling_map, target=None):
|
57
|
+
"""GateDirection pass.
|
58
|
+
|
59
|
+
Args:
|
60
|
+
coupling_map (CouplingMap): Directed graph representing a coupling map.
|
61
|
+
target (Target): The backend target to use for this pass. If this is specified
|
62
|
+
it will be used instead of the coupling map
|
63
|
+
"""
|
64
|
+
super().__init__()
|
65
|
+
self.coupling_map = coupling_map
|
66
|
+
self.target = target
|
67
|
+
|
68
|
+
def run(self, dag):
|
69
|
+
"""Run the GateDirection pass on `dag`.
|
70
|
+
|
71
|
+
Flips the cx nodes to match the directed coupling map. Modifies the
|
72
|
+
input dag.
|
73
|
+
|
74
|
+
Args:
|
75
|
+
dag (DAGCircuit): DAG to map.
|
76
|
+
|
77
|
+
Returns:
|
78
|
+
DAGCircuit: The rearranged dag for the coupling map
|
79
|
+
|
80
|
+
Raises:
|
81
|
+
TranspilerError: If the circuit cannot be mapped just by flipping the
|
82
|
+
cx nodes.
|
83
|
+
"""
|
84
|
+
if self.target is None:
|
85
|
+
return fix_gate_direction_coupling(dag, set(self.coupling_map.get_edges()))
|
86
|
+
return fix_gate_direction_target(dag, self.target)
|
@@ -0,0 +1,51 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 2018.
|
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
|
+
"""Check if all gates in the DAGCircuit are in the specified basis gates."""
|
14
|
+
|
15
|
+
from qiskit.transpiler.basepasses import AnalysisPass
|
16
|
+
|
17
|
+
from qiskit._accelerate.gates_in_basis import (
|
18
|
+
any_gate_missing_from_basis,
|
19
|
+
any_gate_missing_from_target,
|
20
|
+
)
|
21
|
+
|
22
|
+
|
23
|
+
class GatesInBasis(AnalysisPass):
|
24
|
+
"""Check if all gates in a DAG are in a given set of gates"""
|
25
|
+
|
26
|
+
def __init__(self, basis_gates=None, target=None):
|
27
|
+
"""Initialize the GatesInBasis pass.
|
28
|
+
|
29
|
+
Args:
|
30
|
+
basis_gates (list): The list of strings representing the set of basis gates.
|
31
|
+
target (Target): The target representing the backend. If specified
|
32
|
+
this will be used instead of the ``basis_gates`` parameter
|
33
|
+
"""
|
34
|
+
super().__init__()
|
35
|
+
self._basis_gates = None
|
36
|
+
if basis_gates is not None:
|
37
|
+
self._basis_gates = set(basis_gates).union(
|
38
|
+
{"measure", "reset", "barrier", "snapshot", "delay", "store"}
|
39
|
+
)
|
40
|
+
self._target = target
|
41
|
+
|
42
|
+
def run(self, dag):
|
43
|
+
"""Run the GatesInBasis pass on `dag`."""
|
44
|
+
if self._basis_gates is None and self._target is None:
|
45
|
+
self.property_set["all_gates_in_basis"] = True
|
46
|
+
return
|
47
|
+
if self._target is not None:
|
48
|
+
gates_out_of_basis = any_gate_missing_from_target(dag, self._target)
|
49
|
+
else:
|
50
|
+
gates_out_of_basis = any_gate_missing_from_basis(dag, self._basis_gates)
|
51
|
+
self.property_set["all_gates_in_basis"] = not gates_out_of_basis
|
@@ -0,0 +1,163 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 2019.
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
"""Return a circuit with any adjacent barriers merged together."""
|
14
|
+
|
15
|
+
from qiskit.transpiler.basepasses import TransformationPass
|
16
|
+
from qiskit.circuit.barrier import Barrier
|
17
|
+
|
18
|
+
|
19
|
+
class MergeAdjacentBarriers(TransformationPass):
|
20
|
+
"""Return a circuit with any adjacent barriers merged together.
|
21
|
+
|
22
|
+
Only barriers which can be merged without affecting the barrier structure
|
23
|
+
of the DAG will be merged.
|
24
|
+
|
25
|
+
Not all redundant barriers will necessarily be merged, only adjacent
|
26
|
+
barriers are merged.
|
27
|
+
|
28
|
+
For example, the circuit::
|
29
|
+
|
30
|
+
qr = QuantumRegister(3, 'q')
|
31
|
+
circuit = QuantumCircuit(qr)
|
32
|
+
circuit.barrier(qr[0])
|
33
|
+
circuit.barrier(qr[1])
|
34
|
+
circuit.barrier(qr)
|
35
|
+
|
36
|
+
Will be transformed into a circuit corresponding to::
|
37
|
+
|
38
|
+
circuit.barrier(qr[0])
|
39
|
+
circuit.barrier(qr)
|
40
|
+
|
41
|
+
i.e,
|
42
|
+
|
43
|
+
.. code-block:: text
|
44
|
+
|
45
|
+
░ ░ ░ ░
|
46
|
+
q_0: ─░──░─ q_0: ─░──░─
|
47
|
+
░ ░ ░ ░
|
48
|
+
q_1: ─░──░─ => q_1: ────░─
|
49
|
+
░ ░ ░
|
50
|
+
q_2: ────░─ q_2: ────░─
|
51
|
+
░
|
52
|
+
|
53
|
+
after one iteration of the pass. These two barriers were not merged by the
|
54
|
+
first pass as they are not adjacent in the initial circuit.
|
55
|
+
|
56
|
+
The pass then can be reapplied to merge the newly adjacent barriers.
|
57
|
+
"""
|
58
|
+
|
59
|
+
def run(self, dag):
|
60
|
+
"""Run the MergeAdjacentBarriers pass on `dag`."""
|
61
|
+
indices = {qubit: index for index, qubit in enumerate(dag.qubits)}
|
62
|
+
|
63
|
+
# sorted to so that they are in the order they appear in the DAG
|
64
|
+
# so ancestors/descendants makes sense
|
65
|
+
barriers = [nd for nd in dag.topological_op_nodes() if nd.name == "barrier"]
|
66
|
+
|
67
|
+
# get dict of barrier merges
|
68
|
+
node_to_barrier_qubits = MergeAdjacentBarriers._collect_potential_merges(dag, barriers)
|
69
|
+
|
70
|
+
if not node_to_barrier_qubits:
|
71
|
+
return dag
|
72
|
+
|
73
|
+
for barrier in barriers:
|
74
|
+
if barrier in node_to_barrier_qubits:
|
75
|
+
barrier_to_add, nodes = node_to_barrier_qubits[barrier]
|
76
|
+
dag.replace_block_with_op(
|
77
|
+
nodes, barrier_to_add, wire_pos_map=indices, cycle_check=False
|
78
|
+
)
|
79
|
+
|
80
|
+
return dag
|
81
|
+
|
82
|
+
@staticmethod
|
83
|
+
def _collect_potential_merges(dag, barriers):
|
84
|
+
"""Return the potential merges.
|
85
|
+
|
86
|
+
Returns a dict of DAGOpNode: (Barrier, [DAGOpNode]) objects, where the barrier needs to be
|
87
|
+
inserted where the corresponding index DAGOpNode appears in the main DAG, in replacement of
|
88
|
+
the listed DAGOpNodes.
|
89
|
+
"""
|
90
|
+
# if only got 1 or 0 barriers then can't merge
|
91
|
+
if len(barriers) < 2:
|
92
|
+
return None
|
93
|
+
|
94
|
+
# mapping from the node that will be the main barrier to the
|
95
|
+
# barrier object that gets built up
|
96
|
+
node_to_barrier_qubits = {}
|
97
|
+
|
98
|
+
# Start from the first barrier
|
99
|
+
current_barrier = barriers[0]
|
100
|
+
end_of_barrier = current_barrier
|
101
|
+
current_barrier_nodes = [current_barrier]
|
102
|
+
|
103
|
+
current_qubits = set(current_barrier.qargs)
|
104
|
+
current_ancestors = dag.ancestors(current_barrier)
|
105
|
+
current_descendants = dag.descendants(current_barrier)
|
106
|
+
|
107
|
+
barrier_to_add = Barrier(len(current_qubits))
|
108
|
+
|
109
|
+
for next_barrier in barriers[1:]:
|
110
|
+
|
111
|
+
# Ensure barriers are adjacent before checking if they are mergeable.
|
112
|
+
if dag._has_edge(end_of_barrier._node_id, next_barrier._node_id):
|
113
|
+
|
114
|
+
# Remove all barriers that have already been included in this new barrier from the
|
115
|
+
# set of ancestors/descendants as they will be removed from the new DAG when it is
|
116
|
+
# created.
|
117
|
+
next_ancestors = {
|
118
|
+
nd for nd in dag.ancestors(next_barrier) if nd not in current_barrier_nodes
|
119
|
+
}
|
120
|
+
next_descendants = {
|
121
|
+
nd for nd in dag.descendants(next_barrier) if nd not in current_barrier_nodes
|
122
|
+
}
|
123
|
+
next_qubits = set(next_barrier.qargs)
|
124
|
+
|
125
|
+
if (
|
126
|
+
not current_qubits.isdisjoint(next_qubits)
|
127
|
+
and current_ancestors.isdisjoint(next_descendants)
|
128
|
+
and current_descendants.isdisjoint(next_ancestors)
|
129
|
+
):
|
130
|
+
|
131
|
+
# can be merged
|
132
|
+
current_ancestors = current_ancestors | next_ancestors
|
133
|
+
current_descendants = current_descendants | next_descendants
|
134
|
+
current_qubits = current_qubits | next_qubits
|
135
|
+
|
136
|
+
# update the barrier that will be added back to include this barrier
|
137
|
+
barrier_to_add = Barrier(len(current_qubits))
|
138
|
+
|
139
|
+
end_of_barrier = next_barrier
|
140
|
+
current_barrier_nodes.append(end_of_barrier)
|
141
|
+
continue
|
142
|
+
|
143
|
+
# Fallback if barriers are not adjacent or not mergeable.
|
144
|
+
|
145
|
+
# store the previously made barrier
|
146
|
+
if barrier_to_add:
|
147
|
+
node_to_barrier_qubits[end_of_barrier] = (barrier_to_add, current_barrier_nodes)
|
148
|
+
|
149
|
+
# reset the properties
|
150
|
+
current_qubits = set(next_barrier.qargs)
|
151
|
+
current_ancestors = dag.ancestors(next_barrier)
|
152
|
+
current_descendants = dag.descendants(next_barrier)
|
153
|
+
|
154
|
+
barrier_to_add = Barrier(len(current_qubits))
|
155
|
+
current_barrier_nodes = []
|
156
|
+
|
157
|
+
end_of_barrier = next_barrier
|
158
|
+
current_barrier_nodes.append(end_of_barrier)
|
159
|
+
|
160
|
+
if barrier_to_add:
|
161
|
+
node_to_barrier_qubits[end_of_barrier] = (barrier_to_add, current_barrier_nodes)
|
162
|
+
|
163
|
+
return node_to_barrier_qubits
|
@@ -0,0 +1,118 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2023
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
"""Check if the DAG has reached a relative semi-stable point over previous runs."""
|
14
|
+
|
15
|
+
from copy import deepcopy
|
16
|
+
from dataclasses import dataclass
|
17
|
+
import math
|
18
|
+
from typing import Tuple
|
19
|
+
|
20
|
+
from qiskit.dagcircuit.dagcircuit import DAGCircuit
|
21
|
+
from qiskit.transpiler.basepasses import TransformationPass
|
22
|
+
|
23
|
+
|
24
|
+
class MinimumPoint(TransformationPass):
|
25
|
+
"""Check if the DAG has reached a relative semi-stable point over previous runs
|
26
|
+
|
27
|
+
This pass is similar to the :class:`~.FixedPoint` transpiler pass and is intended
|
28
|
+
primarily to be used to set a loop break condition in the property set.
|
29
|
+
However, unlike the :class:`~.FixedPoint` class which only sets the
|
30
|
+
condition if 2 consecutive runs have the same value property set value
|
31
|
+
this pass is designed to find a local minimum and use that instead. This
|
32
|
+
pass is designed for an optimization loop where a fixed point may never
|
33
|
+
get reached (for example if synthesis is used and there are multiple
|
34
|
+
equivalent outputs for some cases).
|
35
|
+
|
36
|
+
This pass will track the state of fields in the property set over its past
|
37
|
+
executions and set a boolean field when either a fixed point is reached
|
38
|
+
over the backtracking depth or selecting the minimum value found if the
|
39
|
+
backtracking depth is reached. To do this it stores a deep copy of the
|
40
|
+
current minimum DAG in the property set and when ``backtrack_depth`` number
|
41
|
+
of executions is reached since the last minimum the output dag is set to
|
42
|
+
that copy of the earlier minimum.
|
43
|
+
|
44
|
+
Fields used by this pass in the property set are (all relative to the ``prefix``
|
45
|
+
argument):
|
46
|
+
|
47
|
+
* ``{prefix}_minimum_point_state`` - Used to track the state of the minimum point search
|
48
|
+
* ``{prefix}_minimum_point`` - This value gets set to ``True`` when either a fixed point
|
49
|
+
is reached over the ``backtrack_depth`` executions, or ``backtrack_depth`` was exceeded
|
50
|
+
and an earlier minimum is restored.
|
51
|
+
"""
|
52
|
+
|
53
|
+
def __init__(self, property_set_list, prefix, backtrack_depth=5):
|
54
|
+
"""Initialize an instance of this pass
|
55
|
+
|
56
|
+
Args:
|
57
|
+
property_set_list (list): A list of property set keys that will
|
58
|
+
be used to evaluate the local minimum. The values of these
|
59
|
+
property set keys will be used as a tuple for comparison
|
60
|
+
prefix (str): The prefix to use for the property set key that is used
|
61
|
+
for tracking previous evaluations
|
62
|
+
backtrack_depth (int): The maximum number of entries to store. If
|
63
|
+
this number is reached and the next iteration doesn't have
|
64
|
+
a decrease in the number of values the minimum of the previous
|
65
|
+
n will be set as the output dag and ``minimum_point`` will be set to
|
66
|
+
``True`` in the property set
|
67
|
+
"""
|
68
|
+
super().__init__()
|
69
|
+
self.property_set_list = property_set_list
|
70
|
+
|
71
|
+
self.backtrack_name = f"{prefix}_minimum_point_state"
|
72
|
+
self.minimum_reached = f"{prefix}_minimum_point"
|
73
|
+
self.backtrack_depth = backtrack_depth
|
74
|
+
|
75
|
+
def run(self, dag):
|
76
|
+
"""Run the MinimumPoint pass on `dag`."""
|
77
|
+
score = tuple(self.property_set[x] for x in self.property_set_list)
|
78
|
+
state = self.property_set[self.backtrack_name]
|
79
|
+
|
80
|
+
# The pass starts at None and the first iteration doesn't set a real
|
81
|
+
# score so the overall loop is treated as a do-while to ensure we have
|
82
|
+
# at least 2 iterations.
|
83
|
+
if state is None:
|
84
|
+
self.property_set[self.backtrack_name] = _MinimumPointState(
|
85
|
+
dag=None, score=(math.inf,) * len(self.property_set_list), since=0
|
86
|
+
)
|
87
|
+
# If the score of this execution is worse than the previous execution
|
88
|
+
# increment 'since' since we have not found a new minimum point
|
89
|
+
elif score > state.score:
|
90
|
+
state.since += 1
|
91
|
+
if state.since == self.backtrack_depth:
|
92
|
+
self.property_set[self.minimum_reached] = True
|
93
|
+
return self.property_set[self.backtrack_name].dag
|
94
|
+
# If the score has decreased (gotten better) then this iteration is
|
95
|
+
# better performing and this iteration should be the new minimum state.
|
96
|
+
# So update the state to be this iteration and reset counter
|
97
|
+
elif score < state.score:
|
98
|
+
state.since = 1
|
99
|
+
state.score = score
|
100
|
+
state.dag = deepcopy(dag)
|
101
|
+
# If the current execution is equal to the previous minimum value then
|
102
|
+
# we've reached an equivalent fixed point and we should use this iteration's
|
103
|
+
# dag as the output and set the property set flag that we've found a minimum
|
104
|
+
# point.
|
105
|
+
elif score == state.score:
|
106
|
+
self.property_set[self.minimum_reached] = True
|
107
|
+
return dag
|
108
|
+
|
109
|
+
return dag
|
110
|
+
|
111
|
+
|
112
|
+
@dataclass
|
113
|
+
class _MinimumPointState:
|
114
|
+
__slots__ = ("dag", "score", "since")
|
115
|
+
|
116
|
+
dag: DAGCircuit
|
117
|
+
score: Tuple[float, ...]
|
118
|
+
since: int
|
@@ -0,0 +1,49 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 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
|
+
"""Remove all barriers in a circuit"""
|
14
|
+
|
15
|
+
from qiskit.dagcircuit import DAGCircuit
|
16
|
+
from qiskit.transpiler.basepasses import TransformationPass
|
17
|
+
from qiskit.transpiler.passes.utils import control_flow
|
18
|
+
|
19
|
+
|
20
|
+
class RemoveBarriers(TransformationPass):
|
21
|
+
"""Return a circuit with any barrier removed.
|
22
|
+
|
23
|
+
This transformation is not semantics preserving.
|
24
|
+
|
25
|
+
Example:
|
26
|
+
|
27
|
+
.. plot::
|
28
|
+
:include-source:
|
29
|
+
|
30
|
+
from qiskit import QuantumCircuit
|
31
|
+
from qiskit.transpiler.passes import RemoveBarriers
|
32
|
+
|
33
|
+
circuit = QuantumCircuit(1)
|
34
|
+
circuit.x(0)
|
35
|
+
circuit.barrier()
|
36
|
+
circuit.h(0)
|
37
|
+
|
38
|
+
circuit = RemoveBarriers()(circuit)
|
39
|
+
circuit.draw('mpl')
|
40
|
+
|
41
|
+
"""
|
42
|
+
|
43
|
+
@control_flow.trivial_recurse
|
44
|
+
def run(self, dag: DAGCircuit) -> DAGCircuit:
|
45
|
+
"""Run the RemoveBarriers pass on `dag`."""
|
46
|
+
|
47
|
+
dag.remove_all_ops_named("barrier")
|
48
|
+
|
49
|
+
return dag
|
@@ -0,0 +1,114 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 2019.
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
"""Remove final measurements and barriers at the end of a circuit."""
|
14
|
+
|
15
|
+
from qiskit.transpiler.basepasses import TransformationPass
|
16
|
+
from qiskit.dagcircuit import DAGOpNode
|
17
|
+
|
18
|
+
|
19
|
+
class RemoveFinalMeasurements(TransformationPass):
|
20
|
+
"""Remove final measurements and barriers at the end of a circuit.
|
21
|
+
|
22
|
+
This pass removes final barriers and final measurements, as well as all
|
23
|
+
unused classical registers and bits they are connected to.
|
24
|
+
Measurements and barriers are considered final if they are
|
25
|
+
followed by no other operations (aside from other measurements or barriers.)
|
26
|
+
|
27
|
+
Classical registers are removed iff they reference at least one bit
|
28
|
+
that has become unused by the circuit as a result of the operation, and all
|
29
|
+
of their other bits are also unused. Separately, classical bits are removed
|
30
|
+
iff they have become unused by the circuit as a result of the operation,
|
31
|
+
or they appear in a removed classical register, but do not appear
|
32
|
+
in a classical register that will remain.
|
33
|
+
"""
|
34
|
+
|
35
|
+
def _calc_final_ops(self, dag):
|
36
|
+
final_op_types = {"measure", "barrier"}
|
37
|
+
final_ops = []
|
38
|
+
|
39
|
+
to_visit = [next(dag.predecessors(dag.output_map[qubit])) for qubit in dag.qubits]
|
40
|
+
barrier_encounters_remaining = {}
|
41
|
+
|
42
|
+
while to_visit:
|
43
|
+
node = to_visit.pop()
|
44
|
+
if not isinstance(node, DAGOpNode):
|
45
|
+
continue
|
46
|
+
if node.op.name == "barrier":
|
47
|
+
# Barrier is final if all children are final, so we track
|
48
|
+
# how many times we still need to encounter each barrier
|
49
|
+
# via a child node.
|
50
|
+
if node not in barrier_encounters_remaining:
|
51
|
+
barrier_encounters_remaining[node] = sum(
|
52
|
+
1 for _ in dag.quantum_successors(node)
|
53
|
+
)
|
54
|
+
if barrier_encounters_remaining[node] - 1 > 0:
|
55
|
+
# We've encountered the barrier, but not (yet) via all children.
|
56
|
+
# Record the encounter, and bail!
|
57
|
+
barrier_encounters_remaining[node] -= 1
|
58
|
+
continue
|
59
|
+
if node.name in final_op_types:
|
60
|
+
# Current node is either a measure, or a barrier with all final op children.
|
61
|
+
final_ops.append(node)
|
62
|
+
to_visit.extend(dag.quantum_predecessors(node))
|
63
|
+
|
64
|
+
return final_ops
|
65
|
+
|
66
|
+
def run(self, dag):
|
67
|
+
"""Run the RemoveFinalMeasurements pass on `dag`.
|
68
|
+
|
69
|
+
Args:
|
70
|
+
dag (DAGCircuit): the DAG to be optimized.
|
71
|
+
|
72
|
+
Returns:
|
73
|
+
DAGCircuit: the optimized DAG.
|
74
|
+
"""
|
75
|
+
final_ops = self._calc_final_ops(dag)
|
76
|
+
if not final_ops:
|
77
|
+
return dag
|
78
|
+
|
79
|
+
# remove final measure and barrier operations from DAG, keeping track
|
80
|
+
# of their clbits
|
81
|
+
clbits_with_final_measures = set()
|
82
|
+
for node in final_ops:
|
83
|
+
for carg in node.cargs:
|
84
|
+
clbits_with_final_measures.add(carg)
|
85
|
+
dag.remove_op_node(node)
|
86
|
+
|
87
|
+
# ignore any non-idle clbits now that all final op nodes are removed
|
88
|
+
idle_wires = set(dag.idle_wires())
|
89
|
+
clbits_with_final_measures &= idle_wires
|
90
|
+
|
91
|
+
if not clbits_with_final_measures:
|
92
|
+
# no idle wires to remove
|
93
|
+
return dag
|
94
|
+
|
95
|
+
# determine bits of all registers where register is now idle
|
96
|
+
# as a result of the removal.
|
97
|
+
idle_register_bits = set()
|
98
|
+
busy_register_bits = set()
|
99
|
+
for creg in dag.cregs.values():
|
100
|
+
clbits = set(creg)
|
101
|
+
if not clbits.isdisjoint(clbits_with_final_measures) and clbits.issubset(idle_wires):
|
102
|
+
# register contains a newly idle bit, and all other bits are idle.
|
103
|
+
idle_register_bits |= clbits
|
104
|
+
else:
|
105
|
+
# register does not contain a newly idle bit, or contains other busy bits
|
106
|
+
# and thus should not be removed.
|
107
|
+
busy_register_bits |= clbits
|
108
|
+
|
109
|
+
# note: `clbits_with_final_measure` is needed here to account for loose
|
110
|
+
# bits not in any register.
|
111
|
+
bits_to_remove = (clbits_with_final_measures | idle_register_bits) - busy_register_bits
|
112
|
+
|
113
|
+
dag.remove_clbits(*bits_to_remove)
|
114
|
+
return dag
|
@@ -0,0 +1,81 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2023.
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
""" UnrollForLoops transpilation pass """
|
14
|
+
|
15
|
+
from qiskit.circuit import ForLoopOp, ContinueLoopOp, BreakLoopOp, IfElseOp
|
16
|
+
from qiskit.transpiler.basepasses import TransformationPass
|
17
|
+
from qiskit.transpiler.passes.utils import control_flow
|
18
|
+
from qiskit.converters import circuit_to_dag
|
19
|
+
|
20
|
+
|
21
|
+
class UnrollForLoops(TransformationPass):
|
22
|
+
"""``UnrollForLoops`` transpilation pass unrolls for-loops when possible."""
|
23
|
+
|
24
|
+
def __init__(self, max_target_depth=-1):
|
25
|
+
"""Things like ``for x in {0, 3, 4} {rx(x) qr[1];}`` will turn into
|
26
|
+
``rx(0) qr[1]; rx(3) qr[1]; rx(4) qr[1];``.
|
27
|
+
|
28
|
+
.. note::
|
29
|
+
The ``UnrollForLoops`` unrolls only one level of block depth. No inner loop will
|
30
|
+
be considered by ``max_target_depth``.
|
31
|
+
|
32
|
+
Args:
|
33
|
+
max_target_depth (int): Optional. Checks if the unrolled block is over a particular
|
34
|
+
subcircuit depth. To disable the check, use ``-1`` (Default).
|
35
|
+
"""
|
36
|
+
super().__init__()
|
37
|
+
self.max_target_depth = max_target_depth
|
38
|
+
|
39
|
+
@control_flow.trivial_recurse
|
40
|
+
def run(self, dag):
|
41
|
+
"""Run the UnrollForLoops pass on ``dag``.
|
42
|
+
|
43
|
+
Args:
|
44
|
+
dag (DAGCircuit): the directed acyclic graph to run on.
|
45
|
+
|
46
|
+
Returns:
|
47
|
+
DAGCircuit: Transformed DAG.
|
48
|
+
"""
|
49
|
+
for forloop_op in dag.op_nodes(ForLoopOp):
|
50
|
+
(indexset, loop_param, body) = forloop_op.op.params
|
51
|
+
|
52
|
+
# skip unrolling if it results in bigger than max_target_depth
|
53
|
+
if 0 < self.max_target_depth < len(indexset) * body.depth():
|
54
|
+
continue
|
55
|
+
|
56
|
+
# skip unroll when break_loop or continue_loop inside body
|
57
|
+
if _body_contains_continue_or_break(body):
|
58
|
+
continue
|
59
|
+
|
60
|
+
unrolled_dag = circuit_to_dag(body).copy_empty_like()
|
61
|
+
for index_value in indexset:
|
62
|
+
bound_body = (
|
63
|
+
body.assign_parameters({loop_param: index_value}) if loop_param else body
|
64
|
+
)
|
65
|
+
unrolled_dag.compose(circuit_to_dag(bound_body), inplace=True)
|
66
|
+
dag.substitute_node_with_dag(forloop_op, unrolled_dag)
|
67
|
+
|
68
|
+
return dag
|
69
|
+
|
70
|
+
|
71
|
+
def _body_contains_continue_or_break(circuit):
|
72
|
+
"""Checks if a circuit contains ``continue``s or ``break``s. Conditional bodies are inspected."""
|
73
|
+
for inst in circuit.data:
|
74
|
+
operation = inst.operation
|
75
|
+
if isinstance(operation, (ContinueLoopOp, BreakLoopOp)):
|
76
|
+
return True
|
77
|
+
if isinstance(operation, IfElseOp):
|
78
|
+
for block in operation.params:
|
79
|
+
if _body_contains_continue_or_break(block):
|
80
|
+
return True
|
81
|
+
return False
|