qiskit 2.0.3__cp39-abi3-manylinux2014_aarch64.manylinux_2_17_aarch64.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 +141 -0
- qiskit/_accelerate.abi3.so +0 -0
- qiskit/_numpy_compat.py +73 -0
- qiskit/circuit/__init__.py +1343 -0
- qiskit/circuit/_add_control.py +312 -0
- qiskit/circuit/_classical_resource_map.py +150 -0
- qiskit/circuit/_standard_gates_commutations.py +3849 -0
- qiskit/circuit/_utils.py +167 -0
- qiskit/circuit/annotated_operation.py +279 -0
- qiskit/circuit/barrier.py +46 -0
- qiskit/circuit/classical/__init__.py +41 -0
- qiskit/circuit/classical/expr/__init__.py +266 -0
- qiskit/circuit/classical/expr/constructors.py +764 -0
- qiskit/circuit/classical/expr/expr.py +498 -0
- qiskit/circuit/classical/expr/visitors.py +375 -0
- qiskit/circuit/classical/types/__init__.py +113 -0
- qiskit/circuit/classical/types/ordering.py +229 -0
- qiskit/circuit/classical/types/types.py +153 -0
- qiskit/circuit/commutation_checker.py +133 -0
- qiskit/circuit/commutation_library.py +20 -0
- qiskit/circuit/controlflow/__init__.py +59 -0
- qiskit/circuit/controlflow/_builder_utils.py +211 -0
- qiskit/circuit/controlflow/box.py +163 -0
- qiskit/circuit/controlflow/break_loop.py +56 -0
- qiskit/circuit/controlflow/builder.py +791 -0
- qiskit/circuit/controlflow/continue_loop.py +56 -0
- qiskit/circuit/controlflow/control_flow.py +94 -0
- qiskit/circuit/controlflow/for_loop.py +218 -0
- qiskit/circuit/controlflow/if_else.py +498 -0
- qiskit/circuit/controlflow/switch_case.py +411 -0
- qiskit/circuit/controlflow/while_loop.py +166 -0
- qiskit/circuit/controlledgate.py +274 -0
- qiskit/circuit/delay.py +157 -0
- qiskit/circuit/duration.py +80 -0
- qiskit/circuit/equivalence.py +94 -0
- qiskit/circuit/equivalence_library.py +18 -0
- qiskit/circuit/exceptions.py +19 -0
- qiskit/circuit/gate.py +261 -0
- qiskit/circuit/instruction.py +564 -0
- qiskit/circuit/instructionset.py +132 -0
- qiskit/circuit/library/__init__.py +984 -0
- qiskit/circuit/library/arithmetic/__init__.py +40 -0
- qiskit/circuit/library/arithmetic/adders/__init__.py +18 -0
- qiskit/circuit/library/arithmetic/adders/adder.py +235 -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 +131 -0
- qiskit/circuit/library/arithmetic/functional_pauli_rotations.py +114 -0
- qiskit/circuit/library/arithmetic/integer_comparator.py +200 -0
- qiskit/circuit/library/arithmetic/linear_amplitude_function.py +363 -0
- qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +243 -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 +201 -0
- qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +108 -0
- qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +502 -0
- qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +387 -0
- qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +493 -0
- qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +389 -0
- qiskit/circuit/library/arithmetic/quadratic_form.py +364 -0
- qiskit/circuit/library/arithmetic/weighted_adder.py +409 -0
- qiskit/circuit/library/basis_change/__init__.py +15 -0
- qiskit/circuit/library/basis_change/qft.py +316 -0
- qiskit/circuit/library/bit_flip_oracle.py +130 -0
- qiskit/circuit/library/blueprintcircuit.py +316 -0
- qiskit/circuit/library/boolean_logic/__init__.py +18 -0
- qiskit/circuit/library/boolean_logic/inner_product.py +157 -0
- qiskit/circuit/library/boolean_logic/quantum_and.py +204 -0
- qiskit/circuit/library/boolean_logic/quantum_or.py +206 -0
- qiskit/circuit/library/boolean_logic/quantum_xor.py +167 -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 +160 -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 +175 -0
- qiskit/circuit/library/generalized_gates/gr.py +219 -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 +84 -0
- qiskit/circuit/library/generalized_gates/permutation.py +198 -0
- qiskit/circuit/library/generalized_gates/rv.py +96 -0
- qiskit/circuit/library/generalized_gates/uc.py +303 -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 +217 -0
- qiskit/circuit/library/graph_state.py +172 -0
- qiskit/circuit/library/grover_operator.py +583 -0
- qiskit/circuit/library/hamiltonian_gate.py +142 -0
- qiskit/circuit/library/hidden_linear_function.py +163 -0
- qiskit/circuit/library/iqp.py +180 -0
- qiskit/circuit/library/n_local/__init__.py +45 -0
- qiskit/circuit/library/n_local/efficient_su2.py +282 -0
- qiskit/circuit/library/n_local/evolved_operator_ansatz.py +520 -0
- qiskit/circuit/library/n_local/excitation_preserving.py +303 -0
- qiskit/circuit/library/n_local/n_local.py +1477 -0
- qiskit/circuit/library/n_local/pauli_two_design.py +246 -0
- qiskit/circuit/library/n_local/qaoa_ansatz.py +367 -0
- qiskit/circuit/library/n_local/real_amplitudes.py +312 -0
- qiskit/circuit/library/n_local/two_local.py +289 -0
- qiskit/circuit/library/overlap.py +183 -0
- qiskit/circuit/library/pauli_evolution.py +201 -0
- qiskit/circuit/library/phase_estimation.py +177 -0
- qiskit/circuit/library/phase_oracle.py +239 -0
- qiskit/circuit/library/quantum_volume.py +180 -0
- qiskit/circuit/library/standard_gates/__init__.py +141 -0
- qiskit/circuit/library/standard_gates/dcx.py +77 -0
- qiskit/circuit/library/standard_gates/ecr.py +129 -0
- qiskit/circuit/library/standard_gates/equivalence_library.py +1800 -0
- qiskit/circuit/library/standard_gates/global_phase.py +84 -0
- qiskit/circuit/library/standard_gates/h.py +253 -0
- qiskit/circuit/library/standard_gates/i.py +76 -0
- qiskit/circuit/library/standard_gates/iswap.py +133 -0
- qiskit/circuit/library/standard_gates/p.py +422 -0
- qiskit/circuit/library/standard_gates/r.py +114 -0
- qiskit/circuit/library/standard_gates/rx.py +293 -0
- qiskit/circuit/library/standard_gates/rxx.py +180 -0
- qiskit/circuit/library/standard_gates/ry.py +286 -0
- qiskit/circuit/library/standard_gates/ryy.py +180 -0
- qiskit/circuit/library/standard_gates/rz.py +307 -0
- qiskit/circuit/library/standard_gates/rzx.py +226 -0
- qiskit/circuit/library/standard_gates/rzz.py +193 -0
- qiskit/circuit/library/standard_gates/s.py +419 -0
- qiskit/circuit/library/standard_gates/swap.py +281 -0
- qiskit/circuit/library/standard_gates/sx.py +310 -0
- qiskit/circuit/library/standard_gates/t.py +178 -0
- qiskit/circuit/library/standard_gates/u.py +395 -0
- qiskit/circuit/library/standard_gates/u1.py +490 -0
- qiskit/circuit/library/standard_gates/u2.py +145 -0
- qiskit/circuit/library/standard_gates/u3.py +428 -0
- qiskit/circuit/library/standard_gates/x.py +1481 -0
- qiskit/circuit/library/standard_gates/xx_minus_yy.py +202 -0
- qiskit/circuit/library/standard_gates/xx_plus_yy.py +236 -0
- qiskit/circuit/library/standard_gates/y.py +257 -0
- qiskit/circuit/library/standard_gates/z.py +338 -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 +53 -0
- qiskit/circuit/operation.py +68 -0
- qiskit/circuit/parameter.py +179 -0
- qiskit/circuit/parameterexpression.py +703 -0
- qiskit/circuit/parametertable.py +119 -0
- qiskit/circuit/parametervector.py +140 -0
- qiskit/circuit/quantumcircuit.py +7540 -0
- qiskit/circuit/quantumcircuitdata.py +136 -0
- qiskit/circuit/random/__init__.py +15 -0
- qiskit/circuit/random/utils.py +366 -0
- qiskit/circuit/reset.py +37 -0
- qiskit/circuit/singleton.py +600 -0
- qiskit/circuit/store.py +89 -0
- qiskit/circuit/tools/__init__.py +16 -0
- qiskit/circuit/tools/pi_check.py +193 -0
- qiskit/circuit/twirling.py +145 -0
- qiskit/compiler/__init__.py +27 -0
- qiskit/compiler/transpiler.py +375 -0
- qiskit/converters/__init__.py +74 -0
- qiskit/converters/circuit_to_dag.py +80 -0
- qiskit/converters/circuit_to_dagdependency.py +49 -0
- qiskit/converters/circuit_to_dagdependency_v2.py +46 -0
- qiskit/converters/circuit_to_gate.py +107 -0
- qiskit/converters/circuit_to_instruction.py +142 -0
- qiskit/converters/dag_to_circuit.py +79 -0
- qiskit/converters/dag_to_dagdependency.py +54 -0
- qiskit/converters/dag_to_dagdependency_v2.py +43 -0
- qiskit/converters/dagdependency_to_circuit.py +40 -0
- qiskit/converters/dagdependency_to_dag.py +48 -0
- qiskit/dagcircuit/__init__.py +55 -0
- qiskit/dagcircuit/collect_blocks.py +407 -0
- qiskit/dagcircuit/dagcircuit.py +24 -0
- qiskit/dagcircuit/dagdependency.py +612 -0
- qiskit/dagcircuit/dagdependency_v2.py +566 -0
- qiskit/dagcircuit/dagdepnode.py +160 -0
- qiskit/dagcircuit/dagnode.py +188 -0
- qiskit/dagcircuit/exceptions.py +42 -0
- qiskit/exceptions.py +153 -0
- qiskit/passmanager/__init__.py +258 -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 +353 -0
- qiskit/primitives/__init__.py +490 -0
- qiskit/primitives/backend_estimator_v2.py +530 -0
- qiskit/primitives/backend_sampler_v2.py +339 -0
- qiskit/primitives/base/__init__.py +20 -0
- qiskit/primitives/base/base_estimator.py +247 -0
- qiskit/primitives/base/base_primitive_job.py +78 -0
- qiskit/primitives/base/base_primitive_v1.py +45 -0
- qiskit/primitives/base/base_result_v1.py +65 -0
- qiskit/primitives/base/base_sampler.py +196 -0
- qiskit/primitives/base/estimator_result_v1.py +46 -0
- qiskit/primitives/base/sampler_result_v1.py +45 -0
- qiskit/primitives/base/validation_v1.py +250 -0
- qiskit/primitives/containers/__init__.py +26 -0
- qiskit/primitives/containers/bindings_array.py +391 -0
- qiskit/primitives/containers/bit_array.py +764 -0
- qiskit/primitives/containers/data_bin.py +175 -0
- qiskit/primitives/containers/estimator_pub.py +222 -0
- qiskit/primitives/containers/object_array.py +94 -0
- qiskit/primitives/containers/observables_array.py +296 -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/primitive_job.py +81 -0
- qiskit/primitives/statevector_estimator.py +175 -0
- qiskit/primitives/statevector_sampler.py +290 -0
- qiskit/primitives/utils.py +72 -0
- qiskit/providers/__init__.py +677 -0
- qiskit/providers/backend.py +364 -0
- qiskit/providers/basic_provider/__init__.py +47 -0
- qiskit/providers/basic_provider/basic_provider.py +121 -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 +693 -0
- qiskit/providers/basic_provider/exceptions.py +30 -0
- qiskit/providers/exceptions.py +33 -0
- qiskit/providers/fake_provider/__init__.py +69 -0
- qiskit/providers/fake_provider/generic_backend_v2.py +374 -0
- qiskit/providers/fake_provider/utils/__init__.py +15 -0
- qiskit/providers/job.py +147 -0
- qiskit/providers/jobstatus.py +30 -0
- qiskit/providers/options.py +273 -0
- qiskit/providers/providerutils.py +110 -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 +669 -0
- qiskit/qasm2/exceptions.py +27 -0
- qiskit/qasm2/export.py +364 -0
- qiskit/qasm2/parse.py +438 -0
- qiskit/qasm3/__init__.py +372 -0
- qiskit/qasm3/ast.py +782 -0
- qiskit/qasm3/exceptions.py +27 -0
- qiskit/qasm3/experimental.py +70 -0
- qiskit/qasm3/exporter.py +1340 -0
- qiskit/qasm3/printer.py +608 -0
- qiskit/qpy/__init__.py +1965 -0
- qiskit/qpy/binary_io/__init__.py +35 -0
- qiskit/qpy/binary_io/circuits.py +1455 -0
- qiskit/qpy/binary_io/parse_sympy_repr.py +121 -0
- qiskit/qpy/binary_io/schedules.py +308 -0
- qiskit/qpy/binary_io/value.py +1165 -0
- qiskit/qpy/common.py +353 -0
- qiskit/qpy/exceptions.py +53 -0
- qiskit/qpy/formats.py +442 -0
- qiskit/qpy/interface.py +344 -0
- qiskit/qpy/type_keys.py +409 -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 +104 -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 +373 -0
- qiskit/quantum_info/operators/channel/transformations.py +490 -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 +511 -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 +869 -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 +1032 -0
- qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
- qiskit/quantum_info/operators/symplectic/pauli.py +755 -0
- qiskit/quantum_info/operators/symplectic/pauli_list.py +1242 -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 +1239 -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 +857 -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 +805 -0
- qiskit/quantum_info/states/statevector.py +977 -0
- qiskit/quantum_info/states/utils.py +247 -0
- qiskit/result/__init__.py +61 -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/models.py +241 -0
- qiskit/result/postprocess.py +239 -0
- qiskit/result/result.py +385 -0
- qiskit/result/sampled_expval.py +74 -0
- qiskit/result/utils.py +294 -0
- qiskit/synthesis/__init__.py +240 -0
- qiskit/synthesis/arithmetic/__init__.py +18 -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/comparators/__init__.py +16 -0
- qiskit/synthesis/arithmetic/comparators/compare_2s.py +112 -0
- qiskit/synthesis/arithmetic/comparators/compare_greedy.py +66 -0
- qiskit/synthesis/arithmetic/multipliers/__init__.py +16 -0
- qiskit/synthesis/arithmetic/multipliers/hrs_cumulative_multiplier.py +103 -0
- qiskit/synthesis/arithmetic/multipliers/rg_qft_multiplier.py +100 -0
- qiskit/synthesis/arithmetic/weighted_sum.py +155 -0
- qiskit/synthesis/boolean/__init__.py +13 -0
- 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/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 +265 -0
- qiskit/synthesis/discrete_basis/gate_sequence.py +421 -0
- qiskit/synthesis/discrete_basis/generate_basis_approximations.py +165 -0
- qiskit/synthesis/discrete_basis/solovay_kitaev.py +240 -0
- qiskit/synthesis/evolution/__init__.py +21 -0
- qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
- qiskit/synthesis/evolution/lie_trotter.py +120 -0
- qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
- qiskit/synthesis/evolution/pauli_network.py +80 -0
- qiskit/synthesis/evolution/product_formula.py +313 -0
- qiskit/synthesis/evolution/qdrift.py +130 -0
- qiskit/synthesis/evolution/suzuki_trotter.py +224 -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 +61 -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 +61 -0
- qiskit/synthesis/linear_phase/cz_depth_lnn.py +58 -0
- qiskit/synthesis/multi_controlled/__init__.py +25 -0
- qiskit/synthesis/multi_controlled/mcmt_vchain.py +52 -0
- qiskit/synthesis/multi_controlled/mcx_synthesis.py +359 -0
- qiskit/synthesis/multi_controlled/multi_control_rotation_gates.py +206 -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 +20 -0
- qiskit/synthesis/two_qubit/local_invariance.py +63 -0
- qiskit/synthesis/two_qubit/two_qubit_decompose.py +583 -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 +1345 -0
- qiskit/transpiler/basepasses.py +190 -0
- qiskit/transpiler/coupling.py +500 -0
- qiskit/transpiler/exceptions.py +59 -0
- qiskit/transpiler/instruction_durations.py +281 -0
- qiskit/transpiler/layout.py +740 -0
- qiskit/transpiler/passes/__init__.py +276 -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 +138 -0
- qiskit/transpiler/passes/basis/decompose.py +137 -0
- qiskit/transpiler/passes/basis/translate_parameterized.py +175 -0
- qiskit/transpiler/passes/basis/unroll_3q_or_more.py +84 -0
- qiskit/transpiler/passes/basis/unroll_custom_definitions.py +110 -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 +128 -0
- qiskit/transpiler/passes/layout/csp_layout.py +132 -0
- qiskit/transpiler/passes/layout/dense_layout.py +177 -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 +116 -0
- qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
- qiskit/transpiler/passes/layout/sabre_layout.py +506 -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 +256 -0
- qiskit/transpiler/passes/layout/vf2_post_layout.py +376 -0
- qiskit/transpiler/passes/layout/vf2_utils.py +235 -0
- qiskit/transpiler/passes/optimization/__init__.py +42 -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 +117 -0
- qiskit/transpiler/passes/optimization/collect_cliffords.py +109 -0
- qiskit/transpiler/passes/optimization/collect_linear_functions.py +85 -0
- qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +242 -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 +176 -0
- qiskit/transpiler/passes/optimization/contract_idle_wires_in_control_flow.py +104 -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/light_cone.py +135 -0
- qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +267 -0
- qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +250 -0
- qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
- qiskit/transpiler/passes/optimization/optimize_annotated.py +449 -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 +70 -0
- qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
- qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +50 -0
- qiskit/transpiler/passes/optimization/split_2q_unitaries.py +63 -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 +639 -0
- qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
- qiskit/transpiler/passes/routing/__init__.py +21 -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 +397 -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 +463 -0
- qiskit/transpiler/passes/routing/star_prerouting.py +408 -0
- qiskit/transpiler/passes/routing/utils.py +35 -0
- qiskit/transpiler/passes/scheduling/__init__.py +21 -0
- qiskit/transpiler/passes/scheduling/alignments/__init__.py +79 -0
- qiskit/transpiler/passes/scheduling/alignments/check_durations.py +70 -0
- qiskit/transpiler/passes/scheduling/alignments/reschedule.py +251 -0
- qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
- qiskit/transpiler/passes/scheduling/padding/base_padding.py +284 -0
- qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +415 -0
- qiskit/transpiler/passes/scheduling/padding/pad_delay.py +90 -0
- qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
- qiskit/transpiler/passes/scheduling/scheduling/alap.py +93 -0
- qiskit/transpiler/passes/scheduling/scheduling/asap.py +100 -0
- qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +88 -0
- qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
- qiskit/transpiler/passes/scheduling/time_unit_conversion.py +237 -0
- qiskit/transpiler/passes/synthesis/__init__.py +20 -0
- qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
- qiskit/transpiler/passes/synthesis/default_unitary_synth_plugin.py +653 -0
- qiskit/transpiler/passes/synthesis/high_level_synthesis.py +429 -0
- qiskit/transpiler/passes/synthesis/hls_plugins.py +1963 -0
- qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +41 -0
- qiskit/transpiler/passes/synthesis/plugin.py +738 -0
- qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +313 -0
- qiskit/transpiler/passes/synthesis/unitary_synthesis.py +425 -0
- qiskit/transpiler/passes/utils/__init__.py +32 -0
- qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +41 -0
- qiskit/transpiler/passes/utils/check_gate_direction.py +60 -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 +61 -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 +66 -0
- qiskit/transpiler/passes/utils/fixed_point.py +48 -0
- qiskit/transpiler/passes/utils/gate_direction.py +93 -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 +50 -0
- qiskit/transpiler/passes/utils/remove_final_measurements.py +121 -0
- qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
- qiskit/transpiler/passmanager.py +503 -0
- qiskit/transpiler/passmanager_config.py +151 -0
- qiskit/transpiler/preset_passmanagers/__init__.py +93 -0
- qiskit/transpiler/preset_passmanagers/builtin_plugins.py +993 -0
- qiskit/transpiler/preset_passmanagers/common.py +672 -0
- qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +437 -0
- qiskit/transpiler/preset_passmanagers/level0.py +104 -0
- qiskit/transpiler/preset_passmanagers/level1.py +108 -0
- qiskit/transpiler/preset_passmanagers/level2.py +109 -0
- qiskit/transpiler/preset_passmanagers/level3.py +110 -0
- qiskit/transpiler/preset_passmanagers/plugin.py +346 -0
- qiskit/transpiler/target.py +905 -0
- qiskit/transpiler/timing_constraints.py +59 -0
- qiskit/user_config.py +266 -0
- qiskit/utils/__init__.py +90 -0
- qiskit/utils/classtools.py +146 -0
- qiskit/utils/deprecation.py +382 -0
- qiskit/utils/lazy_tester.py +363 -0
- qiskit/utils/optionals.py +354 -0
- qiskit/utils/parallel.py +318 -0
- qiskit/utils/units.py +146 -0
- qiskit/version.py +84 -0
- qiskit/visualization/__init__.py +290 -0
- qiskit/visualization/array.py +207 -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 +735 -0
- qiskit/visualization/circuit/latex.py +661 -0
- qiskit/visualization/circuit/matplotlib.py +2019 -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 +1849 -0
- qiskit/visualization/circuit_visualization.py +19 -0
- qiskit/visualization/counts_visualization.py +487 -0
- qiskit/visualization/dag_visualization.py +318 -0
- qiskit/visualization/exceptions.py +21 -0
- qiskit/visualization/gate_map.py +1424 -0
- qiskit/visualization/library.py +40 -0
- qiskit/visualization/pass_manager_visualization.py +312 -0
- qiskit/visualization/state_visualization.py +1546 -0
- qiskit/visualization/timeline/__init__.py +21 -0
- qiskit/visualization/timeline/core.py +495 -0
- qiskit/visualization/timeline/drawings.py +260 -0
- qiskit/visualization/timeline/generators.py +506 -0
- qiskit/visualization/timeline/interface.py +444 -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 +195 -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-2.0.3.dist-info/METADATA +220 -0
- qiskit-2.0.3.dist-info/RECORD +690 -0
- qiskit-2.0.3.dist-info/WHEEL +6 -0
- qiskit-2.0.3.dist-info/entry_points.txt +82 -0
- qiskit-2.0.3.dist-info/licenses/LICENSE.txt +203 -0
- qiskit-2.0.3.dist-info/top_level.txt +1 -0
@@ -0,0 +1,525 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 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
|
+
"""
|
14
|
+
Multi-partite matrix and vector shape class
|
15
|
+
"""
|
16
|
+
|
17
|
+
from __future__ import annotations
|
18
|
+
import copy
|
19
|
+
from functools import reduce
|
20
|
+
from operator import mul
|
21
|
+
from math import log2
|
22
|
+
from numbers import Integral
|
23
|
+
|
24
|
+
from qiskit.exceptions import QiskitError
|
25
|
+
|
26
|
+
|
27
|
+
class OpShape:
|
28
|
+
"""Multipartite matrix and vector shape class."""
|
29
|
+
|
30
|
+
def __init__(self, dims_l=None, dims_r=None, num_qargs_l=None, num_qargs_r=None):
|
31
|
+
"""Initialize an operator object."""
|
32
|
+
# The number of left and right qargs
|
33
|
+
self._num_qargs_l = 0 # the number of left (output) subsystems
|
34
|
+
self._num_qargs_r = 0 # the number of right (input) subsystems
|
35
|
+
|
36
|
+
# Subsystem dimensions
|
37
|
+
# This is a tuple of dimensions for each subsystem
|
38
|
+
# If None each subsystem is assumed to be a dim=2 (qubit)
|
39
|
+
self._dims_l = None # Tuple of left (output) dimensions
|
40
|
+
self._dims_r = None # tuple of right (input) dimensions
|
41
|
+
|
42
|
+
# Set attributes
|
43
|
+
if num_qargs_r:
|
44
|
+
self._num_qargs_r = int(num_qargs_r)
|
45
|
+
if dims_r:
|
46
|
+
self._dims_r = tuple(dims_r)
|
47
|
+
self._num_qargs_r = len(self._dims_r)
|
48
|
+
if num_qargs_l:
|
49
|
+
self._num_qargs_l = int(num_qargs_l)
|
50
|
+
if dims_l:
|
51
|
+
self._dims_l = tuple(dims_l)
|
52
|
+
self._num_qargs_l = len(self._dims_l)
|
53
|
+
|
54
|
+
@property
|
55
|
+
def settings(self):
|
56
|
+
"""Return the settings of the ``OpShape`` as dictionary."""
|
57
|
+
return {
|
58
|
+
"dims_l": self._dims_l,
|
59
|
+
"dims_r": self._dims_r,
|
60
|
+
"num_qargs_l": self._num_qargs_l,
|
61
|
+
"num_qargs_r": self._num_qargs_r,
|
62
|
+
}
|
63
|
+
|
64
|
+
def __repr__(self):
|
65
|
+
if self._dims_l:
|
66
|
+
left = f"dims_l={self._dims_l}"
|
67
|
+
elif self._num_qargs_l:
|
68
|
+
left = f"num_qargs_l={self._num_qargs_l}"
|
69
|
+
else:
|
70
|
+
left = ""
|
71
|
+
if self._dims_r:
|
72
|
+
right = f"dims_r={self._dims_r}"
|
73
|
+
elif self._num_qargs_r:
|
74
|
+
right = f"num_qargs_r={self._num_qargs_r}"
|
75
|
+
else:
|
76
|
+
right = ""
|
77
|
+
if left and right:
|
78
|
+
inner = f"{left}, {right}"
|
79
|
+
elif left:
|
80
|
+
inner = left
|
81
|
+
else:
|
82
|
+
inner = right
|
83
|
+
return f"OpShape({inner})"
|
84
|
+
|
85
|
+
def __eq__(self, other):
|
86
|
+
"""Check types and subsystem dimensions are equal"""
|
87
|
+
if not isinstance(other, OpShape):
|
88
|
+
return False
|
89
|
+
return (
|
90
|
+
self._num_qargs_r == other._num_qargs_r
|
91
|
+
and self._num_qargs_l == other._num_qargs_l
|
92
|
+
and self._dims_r == other._dims_r
|
93
|
+
and self._dims_l == other._dims_l
|
94
|
+
)
|
95
|
+
|
96
|
+
def copy(self):
|
97
|
+
"""Make a deep copy of current operator."""
|
98
|
+
return copy.copy(self)
|
99
|
+
|
100
|
+
@property
|
101
|
+
def size(self):
|
102
|
+
"""Return the combined dimensions of the object"""
|
103
|
+
return self._dim_l * self._dim_r
|
104
|
+
|
105
|
+
@property
|
106
|
+
def num_qubits(self):
|
107
|
+
"""Return number of qubits if shape is N-qubit.
|
108
|
+
|
109
|
+
If Shape is not N-qubit return None
|
110
|
+
"""
|
111
|
+
if self._dims_l or self._dims_r:
|
112
|
+
return None
|
113
|
+
if self._num_qargs_l:
|
114
|
+
if self._num_qargs_r and self._num_qargs_l != self._num_qargs_r:
|
115
|
+
return None
|
116
|
+
return self._num_qargs_l
|
117
|
+
return self._num_qargs_r
|
118
|
+
|
119
|
+
@property
|
120
|
+
def num_qargs(self):
|
121
|
+
"""Return a tuple of the number of left and right wires"""
|
122
|
+
return self._num_qargs_l, self._num_qargs_r
|
123
|
+
|
124
|
+
@property
|
125
|
+
def shape(self):
|
126
|
+
"""Return a tuple of the matrix shape"""
|
127
|
+
if self._num_qargs_l == self._num_qargs_r == 0:
|
128
|
+
# Scalar shape is op-like
|
129
|
+
return (1, 1)
|
130
|
+
if not self._num_qargs_r:
|
131
|
+
# Vector shape
|
132
|
+
return (self._dim_l,)
|
133
|
+
# Matrix shape
|
134
|
+
return self._dim_l, self._dim_r
|
135
|
+
|
136
|
+
@property
|
137
|
+
def tensor_shape(self):
|
138
|
+
"""Return a tuple of the tensor shape"""
|
139
|
+
return tuple(reversed(self.dims_l())) + tuple(reversed(self.dims_r()))
|
140
|
+
|
141
|
+
@property
|
142
|
+
def is_square(self):
|
143
|
+
"""Return True if the left and right dimensions are equal."""
|
144
|
+
return self._num_qargs_l == self._num_qargs_r and self._dims_l == self._dims_r
|
145
|
+
|
146
|
+
def dims_r(self, qargs=None):
|
147
|
+
"""Return tuple of input dimension for specified subsystems."""
|
148
|
+
if self._dims_r:
|
149
|
+
if qargs:
|
150
|
+
return tuple(self._dims_r[i] for i in qargs)
|
151
|
+
return self._dims_r
|
152
|
+
num = self._num_qargs_r if qargs is None else len(qargs)
|
153
|
+
return num * (2,)
|
154
|
+
|
155
|
+
def dims_l(self, qargs=None):
|
156
|
+
"""Return tuple of output dimension for specified subsystems."""
|
157
|
+
if self._dims_l:
|
158
|
+
if qargs:
|
159
|
+
return tuple(self._dims_l[i] for i in qargs)
|
160
|
+
return self._dims_l
|
161
|
+
num = self._num_qargs_l if qargs is None else len(qargs)
|
162
|
+
return num * (2,)
|
163
|
+
|
164
|
+
@property
|
165
|
+
def _dim_r(self):
|
166
|
+
"""Return the total input dimension."""
|
167
|
+
if self._dims_r:
|
168
|
+
return reduce(mul, self._dims_r)
|
169
|
+
return 2**self._num_qargs_r
|
170
|
+
|
171
|
+
@property
|
172
|
+
def _dim_l(self):
|
173
|
+
"""Return the total input dimension."""
|
174
|
+
if self._dims_l:
|
175
|
+
return reduce(mul, self._dims_l)
|
176
|
+
return 2**self._num_qargs_l
|
177
|
+
|
178
|
+
def validate_shape(self, shape):
|
179
|
+
"""Raise an exception if shape is not valid for the OpShape"""
|
180
|
+
return self._validate(shape, raise_exception=True)
|
181
|
+
|
182
|
+
def _validate(self, shape, raise_exception=False):
|
183
|
+
"""Validate OpShape against a matrix or vector shape."""
|
184
|
+
# pylint: disable=too-many-return-statements
|
185
|
+
ndim = len(shape)
|
186
|
+
if ndim > 2:
|
187
|
+
if raise_exception:
|
188
|
+
raise QiskitError(f"Input shape is not 1 or 2-dimensional (shape = {shape})")
|
189
|
+
return False
|
190
|
+
|
191
|
+
if self._dims_l:
|
192
|
+
if reduce(mul, self._dims_l) != shape[0]:
|
193
|
+
if raise_exception:
|
194
|
+
raise QiskitError(
|
195
|
+
"Output dimensions do not match matrix shape "
|
196
|
+
f"({reduce(mul, self._dims_l)} != {shape[0]})"
|
197
|
+
)
|
198
|
+
return False
|
199
|
+
elif shape[0] != 2**self._num_qargs_l:
|
200
|
+
if raise_exception:
|
201
|
+
raise QiskitError("Number of left qubits does not match matrix shape")
|
202
|
+
return False
|
203
|
+
|
204
|
+
if ndim == 2:
|
205
|
+
if self._dims_r:
|
206
|
+
if reduce(mul, self._dims_r) != shape[1]:
|
207
|
+
if raise_exception:
|
208
|
+
raise QiskitError(
|
209
|
+
"Input dimensions do not match matrix shape "
|
210
|
+
f"({reduce(mul, self._dims_r)} != {shape[1]})"
|
211
|
+
)
|
212
|
+
return False
|
213
|
+
elif shape[1] != 2**self._num_qargs_r:
|
214
|
+
if raise_exception:
|
215
|
+
raise QiskitError("Number of right qubits does not match matrix shape")
|
216
|
+
return False
|
217
|
+
elif self._dims_r or self._num_qargs_r:
|
218
|
+
if raise_exception:
|
219
|
+
raise QiskitError("Input dimension should be empty for vector shape.")
|
220
|
+
return False
|
221
|
+
|
222
|
+
return True
|
223
|
+
|
224
|
+
@classmethod
|
225
|
+
def auto(
|
226
|
+
cls,
|
227
|
+
shape=None,
|
228
|
+
dims_l=None,
|
229
|
+
dims_r=None,
|
230
|
+
dims=None,
|
231
|
+
num_qubits_l=None,
|
232
|
+
num_qubits_r=None,
|
233
|
+
num_qubits=None,
|
234
|
+
):
|
235
|
+
"""Construct TensorShape with automatic checking of qubit dimensions"""
|
236
|
+
if dims and (dims_l or dims_r):
|
237
|
+
raise QiskitError("`dims` kwarg cannot be used with `dims_l` or `dims_r`")
|
238
|
+
if num_qubits and (num_qubits_l or num_qubits_r):
|
239
|
+
raise QiskitError(
|
240
|
+
"`num_qubits` kwarg cannot be used with `num_qubits_l` or `num_qubits_r`"
|
241
|
+
)
|
242
|
+
|
243
|
+
if num_qubits:
|
244
|
+
num_qubits_l = num_qubits
|
245
|
+
num_qubits_r = num_qubits
|
246
|
+
if dims:
|
247
|
+
dims_l = dims
|
248
|
+
dims_r = dims
|
249
|
+
|
250
|
+
if num_qubits_r and num_qubits_l:
|
251
|
+
matrix_shape = cls(num_qargs_l=num_qubits_r, num_qargs_r=num_qubits_l)
|
252
|
+
else:
|
253
|
+
ndim = len(shape) if shape else 0
|
254
|
+
if dims_r is None and num_qubits_r is None and ndim > 1:
|
255
|
+
dims_r = shape[1]
|
256
|
+
|
257
|
+
if dims_l is None and num_qubits_l is None and ndim > 0:
|
258
|
+
dims_l = shape[0]
|
259
|
+
|
260
|
+
if num_qubits_r is None:
|
261
|
+
if isinstance(dims_r, Integral):
|
262
|
+
if dims_r != 0 and (dims_r & (dims_r - 1) == 0):
|
263
|
+
num_qubits_r = int(log2(dims_r))
|
264
|
+
dims_r = None
|
265
|
+
else:
|
266
|
+
dims_r = (dims_r,)
|
267
|
+
elif dims_r is not None:
|
268
|
+
if set(dims_r) == {2}:
|
269
|
+
num_qubits_r = len(dims_r)
|
270
|
+
dims_r = None
|
271
|
+
else:
|
272
|
+
dims_r = tuple(dims_r)
|
273
|
+
|
274
|
+
if num_qubits_l is None:
|
275
|
+
if isinstance(dims_l, Integral):
|
276
|
+
if dims_l != 0 and (dims_l & (dims_l - 1) == 0):
|
277
|
+
num_qubits_l = int(log2(dims_l))
|
278
|
+
dims_l = None
|
279
|
+
else:
|
280
|
+
dims_l = (dims_l,)
|
281
|
+
elif dims_l is not None:
|
282
|
+
if set(dims_l) == {2}:
|
283
|
+
num_qubits_l = len(dims_l)
|
284
|
+
dims_l = None
|
285
|
+
else:
|
286
|
+
dims_l = tuple(dims_l)
|
287
|
+
|
288
|
+
matrix_shape = cls(
|
289
|
+
dims_l=dims_l, dims_r=dims_r, num_qargs_l=num_qubits_l, num_qargs_r=num_qubits_r
|
290
|
+
)
|
291
|
+
# Validate shape
|
292
|
+
if shape:
|
293
|
+
matrix_shape.validate_shape(shape)
|
294
|
+
return matrix_shape
|
295
|
+
|
296
|
+
def subset(self, qargs=None, qargs_l=None, qargs_r=None):
|
297
|
+
"""Return the reduced OpShape of the specified qargs"""
|
298
|
+
if qargs:
|
299
|
+
# Convert qargs to left and right qargs
|
300
|
+
if qargs_l or qargs_r:
|
301
|
+
raise QiskitError("qargs cannot be specified with qargs_l or qargs_r")
|
302
|
+
if self._num_qargs_l:
|
303
|
+
qargs_l = qargs
|
304
|
+
if self._num_qargs_r:
|
305
|
+
qargs_r = qargs
|
306
|
+
|
307
|
+
# Format integer qargs
|
308
|
+
if isinstance(qargs_l, Integral):
|
309
|
+
qargs_l = (qargs_l,)
|
310
|
+
if isinstance(qargs_r, Integral):
|
311
|
+
qargs_r = (qargs_r,)
|
312
|
+
|
313
|
+
# Validate qargs
|
314
|
+
if qargs_l and max(qargs_l) >= self._num_qargs_l:
|
315
|
+
raise QiskitError("Max qargs_l is larger than number of left qargs")
|
316
|
+
|
317
|
+
if qargs_r and max(qargs_r) >= self._num_qargs_r:
|
318
|
+
raise QiskitError("Max qargs_r is larger than number of right qargs")
|
319
|
+
|
320
|
+
num_qargs_l = 0
|
321
|
+
dims_l = None
|
322
|
+
if qargs_l:
|
323
|
+
num_qargs_l = len(qargs_l)
|
324
|
+
if self._dims_l:
|
325
|
+
dims_l = self.dims_l(qargs)
|
326
|
+
|
327
|
+
num_qargs_r = 0
|
328
|
+
dims_r = None
|
329
|
+
if qargs_r:
|
330
|
+
num_qargs_r = len(qargs_r)
|
331
|
+
if self._dims_r:
|
332
|
+
dims_l = self.dims_r(qargs)
|
333
|
+
|
334
|
+
return OpShape(
|
335
|
+
dims_l=dims_l, dims_r=dims_r, num_qargs_l=num_qargs_l, num_qargs_r=num_qargs_r
|
336
|
+
)
|
337
|
+
|
338
|
+
def remove(self, qargs=None, qargs_l=None, qargs_r=None):
|
339
|
+
"""Return a new :class:`OpShape` with the specified qargs removed"""
|
340
|
+
if qargs:
|
341
|
+
# Convert qargs to left and right qargs
|
342
|
+
if qargs_l or qargs_r:
|
343
|
+
raise QiskitError("qargs cannot be specified with qargs_l or qargs_r")
|
344
|
+
if self._num_qargs_l:
|
345
|
+
qargs_l = qargs
|
346
|
+
if self._num_qargs_r:
|
347
|
+
qargs_r = qargs
|
348
|
+
if qargs_l is None and qargs_r is None:
|
349
|
+
return self.copy()
|
350
|
+
|
351
|
+
# Format integer qargs
|
352
|
+
if isinstance(qargs_l, Integral):
|
353
|
+
qargs_l = (qargs_l,)
|
354
|
+
if isinstance(qargs_r, Integral):
|
355
|
+
qargs_r = (qargs_r,)
|
356
|
+
|
357
|
+
# Validate qargs
|
358
|
+
if qargs_l and max(qargs_l) >= self._num_qargs_l:
|
359
|
+
raise QiskitError("Max qargs_l is larger than number of left qargs")
|
360
|
+
|
361
|
+
if qargs_r and max(qargs_r) >= self._num_qargs_r:
|
362
|
+
raise QiskitError("Max qargs_r is larger than number of right qargs")
|
363
|
+
|
364
|
+
num_qargs_l = 0
|
365
|
+
dims_l = None
|
366
|
+
if qargs_l:
|
367
|
+
num_qargs_l = self._num_qargs_l - len(qargs_l)
|
368
|
+
if self._dims_l:
|
369
|
+
dims_l = self.dims_l(tuple(i for i in range(self._num_qargs_l) if i not in qargs_l))
|
370
|
+
|
371
|
+
num_qargs_r = 0
|
372
|
+
dims_r = None
|
373
|
+
if qargs_r:
|
374
|
+
num_qargs_r = self._num_qargs_r - len(qargs_r)
|
375
|
+
if self._dims_r:
|
376
|
+
dims_l = self.dims_r(tuple(i for i in range(self._num_qargs_r) if i not in qargs_r))
|
377
|
+
|
378
|
+
return OpShape(
|
379
|
+
dims_l=dims_l, dims_r=dims_r, num_qargs_l=num_qargs_l, num_qargs_r=num_qargs_r
|
380
|
+
)
|
381
|
+
|
382
|
+
def reverse(self):
|
383
|
+
"""Reverse order of left and right qargs"""
|
384
|
+
ret = copy.copy(self)
|
385
|
+
if self._dims_r:
|
386
|
+
ret._dims_r = tuple(reversed(self._dims_r))
|
387
|
+
if self._dims_l:
|
388
|
+
ret._dims_l = tuple(reversed(self._dims_l))
|
389
|
+
return ret
|
390
|
+
|
391
|
+
def transpose(self):
|
392
|
+
"""Return the transposed OpShape."""
|
393
|
+
ret = copy.copy(self)
|
394
|
+
ret._dims_l = self._dims_r
|
395
|
+
ret._dims_r = self._dims_l
|
396
|
+
ret._num_qargs_l = self._num_qargs_r
|
397
|
+
ret._num_qargs_r = self._num_qargs_l
|
398
|
+
return ret
|
399
|
+
|
400
|
+
def tensor(self, other):
|
401
|
+
"""Return the tensor product OpShape"""
|
402
|
+
return self._tensor(self, other)
|
403
|
+
|
404
|
+
def expand(self, other):
|
405
|
+
"""Return the expand product OpShape"""
|
406
|
+
return self._tensor(other, self)
|
407
|
+
|
408
|
+
@classmethod
|
409
|
+
def _tensor(cls, a, b):
|
410
|
+
"""Return the tensor product OpShape"""
|
411
|
+
if a._dims_l or b._dims_l:
|
412
|
+
dims_l = b.dims_l() + a.dims_l()
|
413
|
+
num_qargs_l = None
|
414
|
+
else:
|
415
|
+
dims_l = None
|
416
|
+
num_qargs_l = b._num_qargs_l + a._num_qargs_l
|
417
|
+
if a._dims_r or b._dims_r:
|
418
|
+
dims_r = b.dims_r() + a.dims_r()
|
419
|
+
num_qargs_r = None
|
420
|
+
else:
|
421
|
+
dims_r = None
|
422
|
+
num_qargs_r = b._num_qargs_r + a._num_qargs_r
|
423
|
+
return cls(dims_l=dims_l, dims_r=dims_r, num_qargs_l=num_qargs_l, num_qargs_r=num_qargs_r)
|
424
|
+
|
425
|
+
def compose(self, other, qargs=None, front=False):
|
426
|
+
"""Return composed OpShape."""
|
427
|
+
ret = OpShape()
|
428
|
+
if qargs is None:
|
429
|
+
if front:
|
430
|
+
if self._num_qargs_r != other._num_qargs_l or self._dims_r != other._dims_l:
|
431
|
+
raise QiskitError(
|
432
|
+
"Left and right compose dimensions don't match "
|
433
|
+
f"({self.dims_r()} != {other.dims_l()})"
|
434
|
+
)
|
435
|
+
ret._dims_l = self._dims_l
|
436
|
+
ret._dims_r = other._dims_r
|
437
|
+
ret._num_qargs_l = self._num_qargs_l
|
438
|
+
ret._num_qargs_r = other._num_qargs_r
|
439
|
+
else:
|
440
|
+
if self._num_qargs_l != other._num_qargs_r or self._dims_l != other._dims_r:
|
441
|
+
raise QiskitError(
|
442
|
+
"Left and right compose dimensions don't match "
|
443
|
+
f"({self.dims_l()} != {other.dims_r()})"
|
444
|
+
)
|
445
|
+
ret._dims_l = other._dims_l
|
446
|
+
ret._dims_r = self._dims_r
|
447
|
+
ret._num_qargs_l = other._num_qargs_l
|
448
|
+
ret._num_qargs_r = self._num_qargs_r
|
449
|
+
return ret
|
450
|
+
|
451
|
+
if front:
|
452
|
+
ret._dims_l = self._dims_l
|
453
|
+
ret._num_qargs_l = self._num_qargs_l
|
454
|
+
if len(qargs) != other._num_qargs_l:
|
455
|
+
raise QiskitError(
|
456
|
+
f"Number of qargs does not match ({len(qargs)} != {other._num_qargs_l})"
|
457
|
+
)
|
458
|
+
if self._dims_r or other._dims_r:
|
459
|
+
if self.dims_r(qargs) != other.dims_l():
|
460
|
+
raise QiskitError(
|
461
|
+
"Subsystem dimension do not match on specified qargs "
|
462
|
+
f"{self.dims_r(qargs)} != {other.dims_l()}"
|
463
|
+
)
|
464
|
+
dims_r = list(self.dims_r())
|
465
|
+
for i, dim in zip(qargs, other.dims_r()):
|
466
|
+
dims_r[i] = dim
|
467
|
+
ret._dims_r = tuple(dims_r)
|
468
|
+
ret._num_qargs_r = len(ret._dims_r)
|
469
|
+
else:
|
470
|
+
ret._num_qargs_r = self._num_qargs_r
|
471
|
+
else:
|
472
|
+
ret._dims_r = self._dims_r
|
473
|
+
ret._num_qargs_r = self._num_qargs_r
|
474
|
+
if len(qargs) != other._num_qargs_r:
|
475
|
+
raise QiskitError(
|
476
|
+
f"Number of qargs does not match ({len(qargs)} != {other._num_qargs_r})"
|
477
|
+
)
|
478
|
+
if self._dims_l or other._dims_l:
|
479
|
+
if self.dims_l(qargs) != other.dims_r():
|
480
|
+
raise QiskitError(
|
481
|
+
"Subsystem dimension do not match on specified qargs "
|
482
|
+
f"{self.dims_l(qargs)} != {other.dims_r()}"
|
483
|
+
)
|
484
|
+
dims_l = list(self.dims_l())
|
485
|
+
for i, dim in zip(qargs, other.dims_l()):
|
486
|
+
dims_l[i] = dim
|
487
|
+
ret._dims_l = tuple(dims_l)
|
488
|
+
ret._num_qargs_l = len(ret._dims_l)
|
489
|
+
else:
|
490
|
+
ret._num_qargs_l = self._num_qargs_l
|
491
|
+
return ret
|
492
|
+
|
493
|
+
def dot(self, other, qargs=None):
|
494
|
+
"""Return the dot product operator OpShape"""
|
495
|
+
return self.compose(other, qargs, front=True)
|
496
|
+
|
497
|
+
def _validate_add(self, other, qargs=None):
|
498
|
+
# Validate shapes can be added
|
499
|
+
if qargs:
|
500
|
+
if self._num_qargs_l != self._num_qargs_r:
|
501
|
+
raise QiskitError(
|
502
|
+
"Cannot add using qargs if number of left and right qargs are not equal."
|
503
|
+
)
|
504
|
+
if self.dims_l(qargs) != other.dims_l():
|
505
|
+
raise QiskitError(
|
506
|
+
"Cannot add shapes width different left "
|
507
|
+
f"dimension on specified qargs {self.dims_l(qargs)} != {other.dims_l()}"
|
508
|
+
)
|
509
|
+
if self.dims_r(qargs) != other.dims_r():
|
510
|
+
raise QiskitError(
|
511
|
+
"Cannot add shapes width different total right "
|
512
|
+
f"dimension on specified qargs{self.dims_r(qargs)} != {other.dims_r()}"
|
513
|
+
)
|
514
|
+
elif self != other:
|
515
|
+
if self._dim_l != other._dim_l:
|
516
|
+
raise QiskitError(
|
517
|
+
"Cannot add shapes width different total left "
|
518
|
+
f"dimension {self._dim_l} != {other._dim_l}"
|
519
|
+
)
|
520
|
+
if self._dim_r != other._dim_r:
|
521
|
+
raise QiskitError(
|
522
|
+
"Cannot add shapes width different total right "
|
523
|
+
f"dimension {self._dim_r} != {other._dim_r}"
|
524
|
+
)
|
525
|
+
return self
|