qiskit 2.1.0rc1__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 +159 -0
- qiskit/_accelerate.abi3.so +0 -0
- qiskit/_numpy_compat.py +73 -0
- qiskit/circuit/__init__.py +1335 -0
- qiskit/circuit/_add_control.py +338 -0
- qiskit/circuit/_classical_resource_map.py +154 -0
- qiskit/circuit/_standard_gates_commutations.py +3849 -0
- qiskit/circuit/_utils.py +167 -0
- qiskit/circuit/annotated_operation.py +279 -0
- qiskit/circuit/annotation.py +404 -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 +156 -0
- qiskit/circuit/classical/expr/visitors.py +381 -0
- qiskit/circuit/classical/types/__init__.py +113 -0
- qiskit/circuit/classical/types/ordering.py +229 -0
- qiskit/circuit/classical/types/types.py +30 -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 +188 -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 +159 -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 +506 -0
- qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +395 -0
- qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +501 -0
- qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +389 -0
- qiskit/circuit/library/arithmetic/quadratic_form.py +370 -0
- qiskit/circuit/library/arithmetic/weighted_adder.py +428 -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 +322 -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 +163 -0
- qiskit/circuit/library/generalized_gates/gms.py +179 -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 +202 -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 +236 -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 +301 -0
- qiskit/circuit/library/n_local/n_local.py +1478 -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 +202 -0
- qiskit/circuit/library/phase_estimation.py +177 -0
- qiskit/circuit/library/phase_oracle.py +239 -0
- qiskit/circuit/library/quantum_volume.py +179 -0
- qiskit/circuit/library/standard_gates/__init__.py +141 -0
- qiskit/circuit/library/standard_gates/dcx.py +76 -0
- qiskit/circuit/library/standard_gates/ecr.py +126 -0
- qiskit/circuit/library/standard_gates/equivalence_library.py +1936 -0
- qiskit/circuit/library/standard_gates/global_phase.py +83 -0
- qiskit/circuit/library/standard_gates/h.py +230 -0
- qiskit/circuit/library/standard_gates/i.py +76 -0
- qiskit/circuit/library/standard_gates/iswap.py +115 -0
- qiskit/circuit/library/standard_gates/p.py +415 -0
- qiskit/circuit/library/standard_gates/r.py +108 -0
- qiskit/circuit/library/standard_gates/rx.py +269 -0
- qiskit/circuit/library/standard_gates/rxx.py +165 -0
- qiskit/circuit/library/standard_gates/ry.py +268 -0
- qiskit/circuit/library/standard_gates/ryy.py +165 -0
- qiskit/circuit/library/standard_gates/rz.py +290 -0
- qiskit/circuit/library/standard_gates/rzx.py +211 -0
- qiskit/circuit/library/standard_gates/rzz.py +181 -0
- qiskit/circuit/library/standard_gates/s.py +424 -0
- qiskit/circuit/library/standard_gates/swap.py +268 -0
- qiskit/circuit/library/standard_gates/sx.py +303 -0
- qiskit/circuit/library/standard_gates/t.py +169 -0
- qiskit/circuit/library/standard_gates/u.py +379 -0
- qiskit/circuit/library/standard_gates/u1.py +466 -0
- qiskit/circuit/library/standard_gates/u2.py +145 -0
- qiskit/circuit/library/standard_gates/u3.py +412 -0
- qiskit/circuit/library/standard_gates/x.py +1335 -0
- qiskit/circuit/library/standard_gates/xx_minus_yy.py +164 -0
- qiskit/circuit/library/standard_gates/xx_plus_yy.py +197 -0
- qiskit/circuit/library/standard_gates/y.py +253 -0
- qiskit/circuit/library/standard_gates/z.py +331 -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 +188 -0
- qiskit/circuit/parameterexpression.py +737 -0
- qiskit/circuit/parametertable.py +119 -0
- qiskit/circuit/parametervector.py +140 -0
- qiskit/circuit/quantumcircuit.py +7610 -0
- qiskit/circuit/quantumcircuitdata.py +137 -0
- qiskit/circuit/random/__init__.py +50 -0
- qiskit/circuit/random/utils.py +755 -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 +185 -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 +44 -0
- qiskit/dagcircuit/collect_blocks.py +403 -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 +193 -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 +172 -0
- qiskit/primitives/containers/estimator_pub.py +222 -0
- qiskit/primitives/containers/object_array.py +94 -0
- qiskit/primitives/containers/observables_array.py +380 -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 +100 -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 +376 -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 +466 -0
- qiskit/qasm3/ast.py +796 -0
- qiskit/qasm3/exceptions.py +27 -0
- qiskit/qasm3/experimental.py +70 -0
- qiskit/qasm3/exporter.py +1363 -0
- qiskit/qasm3/printer.py +620 -0
- qiskit/qpy/__init__.py +2141 -0
- qiskit/qpy/binary_io/__init__.py +35 -0
- qiskit/qpy/binary_io/circuits.py +1687 -0
- qiskit/qpy/binary_io/parse_sympy_repr.py +126 -0
- qiskit/qpy/binary_io/schedules.py +288 -0
- qiskit/qpy/binary_io/value.py +1183 -0
- qiskit/qpy/common.py +361 -0
- qiskit/qpy/exceptions.py +53 -0
- qiskit/qpy/formats.py +458 -0
- qiskit/qpy/interface.py +384 -0
- qiskit/qpy/type_keys.py +415 -0
- qiskit/quantum_info/__init__.py +172 -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 +29 -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 +24 -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 +584 -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 +76 -0
- qiskit/result/utils.py +294 -0
- qiskit/synthesis/__init__.py +250 -0
- qiskit/synthesis/arithmetic/__init__.py +18 -0
- qiskit/synthesis/arithmetic/adders/__init__.py +18 -0
- qiskit/synthesis/arithmetic/adders/cdkm_ripple_carry_adder.py +154 -0
- qiskit/synthesis/arithmetic/adders/draper_qft_adder.py +107 -0
- qiskit/synthesis/arithmetic/adders/rv_ripple_carry_adder.py +156 -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/generate_basis_approximations.py +53 -0
- qiskit/synthesis/discrete_basis/solovay_kitaev.py +280 -0
- qiskit/synthesis/evolution/__init__.py +21 -0
- qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
- qiskit/synthesis/evolution/lie_trotter.py +123 -0
- qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
- qiskit/synthesis/evolution/pauli_network.py +80 -0
- qiskit/synthesis/evolution/product_formula.py +316 -0
- qiskit/synthesis/evolution/qdrift.py +133 -0
- qiskit/synthesis/evolution/suzuki_trotter.py +227 -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 +29 -0
- qiskit/synthesis/multi_controlled/mcmt_vchain.py +52 -0
- qiskit/synthesis/multi_controlled/mcx_synthesis.py +583 -0
- qiskit/synthesis/multi_controlled/multi_control_rotation_gates.py +205 -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 +61 -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 +359 -0
- qiskit/transpiler/__init__.py +1352 -0
- qiskit/transpiler/basepasses.py +190 -0
- qiskit/transpiler/coupling.py +500 -0
- qiskit/transpiler/exceptions.py +59 -0
- qiskit/transpiler/instruction_durations.py +263 -0
- qiskit/transpiler/layout.py +740 -0
- qiskit/transpiler/passes/__init__.py +278 -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 +197 -0
- qiskit/transpiler/passes/layout/disjoint_utils.py +54 -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 +525 -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 +292 -0
- qiskit/transpiler/passes/layout/vf2_post_layout.py +376 -0
- qiskit/transpiler/passes/layout/vf2_utils.py +245 -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 +251 -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_clifford_t.py +68 -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 +633 -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 +465 -0
- qiskit/transpiler/passes/routing/star_prerouting.py +433 -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 +17 -0
- qiskit/transpiler/passes/scheduling/padding/base_padding.py +284 -0
- qiskit/transpiler/passes/scheduling/padding/context_aware_dynamical_decoupling.py +876 -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 +21 -0
- qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
- qiskit/transpiler/passes/synthesis/clifford_unitary_synth_plugin.py +123 -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 +2338 -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 +318 -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 +154 -0
- qiskit/transpiler/preset_passmanagers/__init__.py +93 -0
- qiskit/transpiler/preset_passmanagers/builtin_plugins.py +1114 -0
- qiskit/transpiler/preset_passmanagers/common.py +773 -0
- qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +443 -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 +355 -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 +677 -0
- qiskit/visualization/circuit/circuit_visualization.py +735 -0
- qiskit/visualization/circuit/latex.py +668 -0
- qiskit/visualization/circuit/matplotlib.py +2041 -0
- qiskit/visualization/circuit/qcstyle.py +130 -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/__init__.py +13 -0
- qiskit/visualization/dag/dagstyle.py +103 -0
- qiskit/visualization/dag/styles/__init__.py +13 -0
- qiskit/visualization/dag/styles/color.json +10 -0
- qiskit/visualization/dag/styles/plain.json +5 -0
- qiskit/visualization/dag_visualization.py +389 -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/style.py +223 -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.1.0rc1.dist-info/METADATA +221 -0
- qiskit-2.1.0rc1.dist-info/RECORD +699 -0
- qiskit-2.1.0rc1.dist-info/WHEEL +6 -0
- qiskit-2.1.0rc1.dist-info/entry_points.txt +88 -0
- qiskit-2.1.0rc1.dist-info/licenses/LICENSE.txt +203 -0
- qiskit-2.1.0rc1.dist-info/top_level.txt +1 -0
@@ -0,0 +1,104 @@
|
|
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
|
+
"""A collection of discrete probability metrics."""
|
14
|
+
from __future__ import annotations
|
15
|
+
import math
|
16
|
+
|
17
|
+
|
18
|
+
def hellinger_distance(dist_p: dict, dist_q: dict) -> float:
|
19
|
+
"""Computes the Hellinger distance between
|
20
|
+
two counts distributions.
|
21
|
+
|
22
|
+
Parameters:
|
23
|
+
dist_p (dict): First dict of counts.
|
24
|
+
dist_q (dict): Second dict of counts.
|
25
|
+
|
26
|
+
Returns:
|
27
|
+
float: Distance
|
28
|
+
|
29
|
+
References:
|
30
|
+
`Hellinger Distance @ wikipedia <https://en.wikipedia.org/wiki/Hellinger_distance>`_
|
31
|
+
"""
|
32
|
+
p_sum = sum(dist_p.values())
|
33
|
+
q_sum = sum(dist_q.values())
|
34
|
+
|
35
|
+
p_normed = {}
|
36
|
+
for key, val in dist_p.items():
|
37
|
+
p_normed[key] = val / p_sum
|
38
|
+
|
39
|
+
q_normed = {}
|
40
|
+
for key, val in dist_q.items():
|
41
|
+
q_normed[key] = val / q_sum
|
42
|
+
|
43
|
+
total = 0
|
44
|
+
for key, val in p_normed.items():
|
45
|
+
if key in q_normed:
|
46
|
+
total += (math.sqrt(val) - math.sqrt(q_normed[key])) ** 2
|
47
|
+
del q_normed[key]
|
48
|
+
else:
|
49
|
+
total += val
|
50
|
+
total += sum(q_normed.values())
|
51
|
+
|
52
|
+
dist = math.sqrt(total) / math.sqrt(2)
|
53
|
+
|
54
|
+
return dist
|
55
|
+
|
56
|
+
|
57
|
+
def hellinger_fidelity(dist_p: dict, dist_q: dict) -> float:
|
58
|
+
"""Computes the Hellinger fidelity between
|
59
|
+
two counts distributions.
|
60
|
+
|
61
|
+
The fidelity is defined as :math:`\\left(1-H^{2}\\right)^{2}` where H is the
|
62
|
+
Hellinger distance. This value is bounded in the range [0, 1].
|
63
|
+
|
64
|
+
This is equivalent to the standard classical fidelity
|
65
|
+
:math:`F(Q,P)=\\left(\\sum_{i}\\sqrt{p_{i}q_{i}}\\right)^{2}` that in turn
|
66
|
+
is equal to the quantum state fidelity for diagonal density matrices.
|
67
|
+
|
68
|
+
Parameters:
|
69
|
+
dist_p (dict): First dict of counts.
|
70
|
+
dist_q (dict): Second dict of counts.
|
71
|
+
|
72
|
+
Returns:
|
73
|
+
float: Fidelity
|
74
|
+
|
75
|
+
Example:
|
76
|
+
|
77
|
+
.. plot::
|
78
|
+
:include-source:
|
79
|
+
:nofigs:
|
80
|
+
|
81
|
+
from qiskit import QuantumCircuit
|
82
|
+
from qiskit.quantum_info.analysis import hellinger_fidelity
|
83
|
+
from qiskit.providers.basic_provider import BasicSimulator
|
84
|
+
|
85
|
+
qc = QuantumCircuit(5, 5)
|
86
|
+
qc.h(2)
|
87
|
+
qc.cx(2, 1)
|
88
|
+
qc.cx(2, 3)
|
89
|
+
qc.cx(3, 4)
|
90
|
+
qc.cx(1, 0)
|
91
|
+
qc.measure(range(5), range(5))
|
92
|
+
|
93
|
+
sim = BasicSimulator()
|
94
|
+
res1 = sim.run(qc).result()
|
95
|
+
res2 = sim.run(qc).result()
|
96
|
+
|
97
|
+
hellinger_fidelity(res1.get_counts(), res2.get_counts())
|
98
|
+
|
99
|
+
References:
|
100
|
+
`Quantum Fidelity @ wikipedia <https://en.wikipedia.org/wiki/Fidelity_of_quantum_states>`_
|
101
|
+
`Hellinger Distance @ wikipedia <https://en.wikipedia.org/wiki/Hellinger_distance>`_
|
102
|
+
"""
|
103
|
+
dist = hellinger_distance(dist_p, dist_q)
|
104
|
+
return (1 - dist**2) ** 2
|
@@ -0,0 +1,44 @@
|
|
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
|
+
"""Helper functions for building dictionaries from matrices and lists."""
|
14
|
+
|
15
|
+
from __future__ import annotations
|
16
|
+
import math
|
17
|
+
import numpy as np
|
18
|
+
|
19
|
+
|
20
|
+
def make_dict_observable(matrix_observable: list | np.ndarray) -> dict:
|
21
|
+
"""Convert an observable in matrix form to dictionary form.
|
22
|
+
|
23
|
+
Takes in a diagonal observable as a matrix and converts it to a dictionary
|
24
|
+
form. Can also handle a list sorted of the diagonal elements.
|
25
|
+
|
26
|
+
Args:
|
27
|
+
matrix_observable (list): The observable to be converted to dictionary
|
28
|
+
form. Can be a matrix or just an ordered list of observed values
|
29
|
+
|
30
|
+
Returns:
|
31
|
+
Dict: A dictionary with all observable states as keys, and corresponding
|
32
|
+
values being the observed value for that state
|
33
|
+
"""
|
34
|
+
dict_observable = {}
|
35
|
+
observable = np.array(matrix_observable)
|
36
|
+
observable_size = len(observable)
|
37
|
+
observable_bits = math.ceil(math.log2(observable_size))
|
38
|
+
binary_formatter = f"0{observable_bits}b"
|
39
|
+
if observable.ndim == 2:
|
40
|
+
observable = observable.diagonal()
|
41
|
+
for state_no in range(observable_size):
|
42
|
+
state_str = format(state_no, binary_formatter)
|
43
|
+
dict_observable[state_str] = observable[state_no]
|
44
|
+
return dict_observable
|
@@ -0,0 +1,484 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2022.
|
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
|
+
"""Z2Symmetries for SparsePauliOp."""
|
14
|
+
|
15
|
+
from __future__ import annotations
|
16
|
+
|
17
|
+
import itertools
|
18
|
+
from collections.abc import Iterable
|
19
|
+
from copy import deepcopy
|
20
|
+
import math
|
21
|
+
from typing import Union, cast
|
22
|
+
|
23
|
+
import numpy as np
|
24
|
+
|
25
|
+
from qiskit.exceptions import QiskitError
|
26
|
+
from ..operators import Pauli, SparsePauliOp
|
27
|
+
|
28
|
+
|
29
|
+
class Z2Symmetries:
|
30
|
+
r"""
|
31
|
+
The $Z_2$ symmetry converter identifies symmetries from the problem hamiltonian and uses them to
|
32
|
+
provide a tapered - more efficient - representation of operators as Paulis for this problem. For each
|
33
|
+
identified symmetry, one qubit can be eliminated in the Pauli representation at the cost of having to
|
34
|
+
test two symmetry sectors (for the two possible eigenvalues - tapering values - of the symmetry).
|
35
|
+
In certain problems such as the finding of the main operator's ground state, one can a priori
|
36
|
+
identify the symmetry sector of the solution and thus effectively reduce the computational overhead.
|
37
|
+
|
38
|
+
The following attributes can be read and updated once the ``Z2Symmetries`` object has been
|
39
|
+
constructed.
|
40
|
+
|
41
|
+
Attributes:
|
42
|
+
tapering_values (list[int] or None): Values determining the sector.
|
43
|
+
tol (float): The tolerance threshold for ignoring real and complex parts of a coefficient.
|
44
|
+
|
45
|
+
References:
|
46
|
+
[1]: Bravyi, S., et al, "Tapering off qubits to simulate fermionic Hamiltonians"
|
47
|
+
`arXiv:1701.08213 <https://arxiv.org/abs/1701.08213>`__
|
48
|
+
"""
|
49
|
+
|
50
|
+
def __init__(
|
51
|
+
self,
|
52
|
+
symmetries: Iterable[Pauli],
|
53
|
+
sq_paulis: Iterable[Pauli],
|
54
|
+
sq_list: Iterable[int],
|
55
|
+
tapering_values: Iterable[int] | None = None,
|
56
|
+
*,
|
57
|
+
tol: float = 1e-14,
|
58
|
+
):
|
59
|
+
r"""
|
60
|
+
Args:
|
61
|
+
symmetries: Object representing the list of $Z_2$ symmetries. These correspond to
|
62
|
+
the generators of the symmetry group $\langle \tau_1, \tau_2\dots \rangle>$.
|
63
|
+
sq_paulis: Object representing the list of single-qubit Pauli $\sigma^x_{q(i)}$
|
64
|
+
anti-commuting with the symmetry $\tau_i$ and commuting with all the other symmetries
|
65
|
+
$\tau_{j\neq i}$. These operators are used to construct the unitary Clifford operators.
|
66
|
+
sq_list: The list of indices $q(i)$ of the single-qubit Pauli operators used to build the
|
67
|
+
Clifford operators.
|
68
|
+
tapering_values: List of eigenvalues determining the symmetry sector for each symmetry.
|
69
|
+
tol: Tolerance threshold for ignoring real and complex parts of a coefficient.
|
70
|
+
|
71
|
+
Raises:
|
72
|
+
QiskitError: Invalid paulis. The lists of symmetries, single-qubit paulis support paulis
|
73
|
+
and tapering values must be of equal length. This length is the number of applied
|
74
|
+
symmetries and translates directly to the number of eliminated qubits.
|
75
|
+
"""
|
76
|
+
symmetries = list(symmetries)
|
77
|
+
sq_paulis = list(sq_paulis)
|
78
|
+
sq_list = list(sq_list)
|
79
|
+
tapering_values = None if tapering_values is None else list(tapering_values)
|
80
|
+
|
81
|
+
if len(symmetries) != len(sq_paulis):
|
82
|
+
raise QiskitError(
|
83
|
+
f"The number of Z2 symmetries, {len(symmetries)}, has to match the number \
|
84
|
+
of single-qubit pauli operators, {len(sq_paulis)}."
|
85
|
+
)
|
86
|
+
|
87
|
+
if len(sq_paulis) != len(sq_list):
|
88
|
+
raise QiskitError(
|
89
|
+
f"The number of single-qubit pauli operators, {len(sq_paulis)}, has to match the length \
|
90
|
+
of the of single-qubit list, {len(sq_list)}."
|
91
|
+
)
|
92
|
+
|
93
|
+
if tapering_values is not None:
|
94
|
+
if len(sq_list) != len(tapering_values):
|
95
|
+
raise QiskitError(
|
96
|
+
f"The length of the single-qubit list, {len(sq_list)}, must match the length of the \
|
97
|
+
tapering values, {len(tapering_values)} ."
|
98
|
+
)
|
99
|
+
|
100
|
+
self._symmetries = symmetries
|
101
|
+
self._sq_paulis = sq_paulis
|
102
|
+
self._sq_list = sq_list
|
103
|
+
self.tapering_values = tapering_values
|
104
|
+
self.tol = tol
|
105
|
+
|
106
|
+
@property
|
107
|
+
def symmetries(self) -> list[Pauli]:
|
108
|
+
"""Return symmetries."""
|
109
|
+
return self._symmetries
|
110
|
+
|
111
|
+
@property
|
112
|
+
def sq_paulis(self) -> list[Pauli]:
|
113
|
+
"""Return sq paulis."""
|
114
|
+
return self._sq_paulis
|
115
|
+
|
116
|
+
@property
|
117
|
+
def cliffords(self) -> list[SparsePauliOp]:
|
118
|
+
"""
|
119
|
+
Get clifford operators, built based on symmetries and single-qubit X.
|
120
|
+
|
121
|
+
Returns:
|
122
|
+
A list of unitaries used to diagonalize the Hamiltonian.
|
123
|
+
"""
|
124
|
+
cliffords = [
|
125
|
+
(SparsePauliOp(pauli_symm) + SparsePauliOp(sq_pauli)) / math.sqrt(2)
|
126
|
+
for pauli_symm, sq_pauli in zip(self._symmetries, self._sq_paulis)
|
127
|
+
]
|
128
|
+
return cliffords
|
129
|
+
|
130
|
+
@property
|
131
|
+
def sq_list(self) -> list[int]:
|
132
|
+
"""Return sq list."""
|
133
|
+
return self._sq_list
|
134
|
+
|
135
|
+
@property
|
136
|
+
def settings(self) -> dict:
|
137
|
+
"""Return operator settings."""
|
138
|
+
return {
|
139
|
+
"symmetries": self._symmetries,
|
140
|
+
"sq_paulis": self._sq_paulis,
|
141
|
+
"sq_list": self._sq_list,
|
142
|
+
"tapering_values": self.tapering_values,
|
143
|
+
}
|
144
|
+
|
145
|
+
def __str__(self):
|
146
|
+
ret = ["Z2 symmetries:"]
|
147
|
+
ret.append("Symmetries:")
|
148
|
+
for symmetry in self._symmetries:
|
149
|
+
ret.append(symmetry.to_label())
|
150
|
+
ret.append("Single-Qubit Pauli X:")
|
151
|
+
for x in self._sq_paulis:
|
152
|
+
ret.append(x.to_label())
|
153
|
+
ret.append("Cliffords:")
|
154
|
+
for c in self.cliffords:
|
155
|
+
ret.append(str(c))
|
156
|
+
ret.append("Qubit index:")
|
157
|
+
ret.append(str(self._sq_list))
|
158
|
+
ret.append("Tapering values:")
|
159
|
+
if self.tapering_values is None:
|
160
|
+
possible_values = [
|
161
|
+
str(list(coeff)) for coeff in itertools.product([1, -1], repeat=len(self._sq_list))
|
162
|
+
]
|
163
|
+
possible_values = ", ".join(x for x in possible_values)
|
164
|
+
ret.append(" - Possible values: " + possible_values)
|
165
|
+
else:
|
166
|
+
ret.append(str(self.tapering_values))
|
167
|
+
|
168
|
+
ret = "\n".join(ret)
|
169
|
+
return ret
|
170
|
+
|
171
|
+
def is_empty(self) -> bool:
|
172
|
+
"""
|
173
|
+
Check the z2_symmetries is empty or not.
|
174
|
+
|
175
|
+
Returns:
|
176
|
+
Empty or not.
|
177
|
+
"""
|
178
|
+
return len(self._symmetries) == 0 or len(self._sq_paulis) == 0 or len(self._sq_list) == 0
|
179
|
+
|
180
|
+
@classmethod
|
181
|
+
def find_z2_symmetries(cls, operator: SparsePauliOp) -> Z2Symmetries:
|
182
|
+
"""
|
183
|
+
Finds Z2 Pauli-type symmetries of a :class:`.SparsePauliOp`.
|
184
|
+
|
185
|
+
Returns:
|
186
|
+
A ``Z2Symmetries`` instance.
|
187
|
+
"""
|
188
|
+
pauli_symmetries = []
|
189
|
+
sq_paulis = []
|
190
|
+
sq_list = []
|
191
|
+
|
192
|
+
stacked_paulis = []
|
193
|
+
|
194
|
+
test_idx = {
|
195
|
+
"X_or_I": [(0, 0), (1, 0)],
|
196
|
+
"Y_or_I": [(0, 0), (1, 1)],
|
197
|
+
"Z_or_I": [(0, 0), (0, 1)],
|
198
|
+
}
|
199
|
+
test_row = {
|
200
|
+
"Z_or_I": [(1, 0), (1, 1)],
|
201
|
+
"X_or_I": [(0, 1), (1, 1)],
|
202
|
+
"Y_or_I": [(0, 1), (1, 0)],
|
203
|
+
}
|
204
|
+
|
205
|
+
pauli_bool = {
|
206
|
+
"Z_or_I": [False, True],
|
207
|
+
"X_or_I": [True, False],
|
208
|
+
"Y_or_I": [True, True],
|
209
|
+
}
|
210
|
+
|
211
|
+
if _sparse_pauli_op_is_zero(operator):
|
212
|
+
return cls([], [], [], None)
|
213
|
+
|
214
|
+
for pauli in iter(operator):
|
215
|
+
stacked_paulis.append(
|
216
|
+
np.concatenate((pauli.paulis.x[0], pauli.paulis.z[0]), axis=0).astype(int)
|
217
|
+
)
|
218
|
+
|
219
|
+
stacked_matrix = np.stack(stacked_paulis)
|
220
|
+
symmetries = _kernel_f2(stacked_matrix)
|
221
|
+
|
222
|
+
if not symmetries:
|
223
|
+
return cls([], [], [], None)
|
224
|
+
|
225
|
+
stacked_symmetries = np.stack(symmetries)
|
226
|
+
symm_shape = stacked_symmetries.shape
|
227
|
+
half_symm_shape = symm_shape[1] // 2
|
228
|
+
stacked_symm_del = [
|
229
|
+
np.delete(stacked_symmetries, row, axis=0) for row in range(symm_shape[0])
|
230
|
+
]
|
231
|
+
|
232
|
+
def _test_symmetry_row_col(row: int, col: int, idx_test: list, row_test: list) -> bool:
|
233
|
+
"""
|
234
|
+
Utility method that determines how to build the list of single-qubit Pauli X operators and
|
235
|
+
the list of corresponding qubit indices from the stacked symmetries.
|
236
|
+
This method is successively applied to Z type, X type and Y type symmetries (in this order)
|
237
|
+
to build the letter at position (col) of the Pauli word corresponding to the symmetry at
|
238
|
+
position (row).
|
239
|
+
|
240
|
+
Args:
|
241
|
+
row (int): Index of the symmetry for which the single-qubit Pauli X operator is being
|
242
|
+
built.
|
243
|
+
col (int): Index of the letter in the Pauli word corresponding to the single-qubit Pauli
|
244
|
+
X operator.
|
245
|
+
idx_test (list): List of possibilities for the stacked symmetries at all other rows
|
246
|
+
than row.
|
247
|
+
row_test (list): List of possibilities for the stacked symmetries at row.
|
248
|
+
|
249
|
+
Returns:
|
250
|
+
Whether or not this symmetry type should be used to build this letter of this
|
251
|
+
single-qubit Pauli X operator.
|
252
|
+
"""
|
253
|
+
stacked_symm_idx_tests = np.array(
|
254
|
+
[
|
255
|
+
(
|
256
|
+
stacked_symm_del[row][symm_idx, col],
|
257
|
+
stacked_symm_del[row][symm_idx, col + half_symm_shape],
|
258
|
+
)
|
259
|
+
in idx_test
|
260
|
+
for symm_idx in range(symm_shape[0] - 1)
|
261
|
+
]
|
262
|
+
)
|
263
|
+
|
264
|
+
stacked_symm_row_test = (
|
265
|
+
stacked_symmetries[row, col],
|
266
|
+
stacked_symmetries[row, col + half_symm_shape],
|
267
|
+
) in row_test
|
268
|
+
|
269
|
+
return bool(np.all(stacked_symm_idx_tests)) and stacked_symm_row_test
|
270
|
+
|
271
|
+
for row in range(symm_shape[0]):
|
272
|
+
pauli_symmetries.append(
|
273
|
+
Pauli(
|
274
|
+
(
|
275
|
+
stacked_symmetries[row, :half_symm_shape],
|
276
|
+
stacked_symmetries[row, half_symm_shape:],
|
277
|
+
)
|
278
|
+
)
|
279
|
+
)
|
280
|
+
# Try all cases for the symmetries other than row: Z or I, Y or I, X or I on col qubit.
|
281
|
+
# One test will return true.
|
282
|
+
# Build the single-qubit Pauli accordingly.
|
283
|
+
# Build the index list accordingly.
|
284
|
+
for col in range(half_symm_shape):
|
285
|
+
for key in ("Z_or_I", "X_or_I", "Y_or_I"):
|
286
|
+
current_test_result = _test_symmetry_row_col(
|
287
|
+
row, col, test_idx[key], test_row[key]
|
288
|
+
)
|
289
|
+
if current_test_result:
|
290
|
+
sq_paulis.append(
|
291
|
+
Pauli((np.zeros(half_symm_shape), np.zeros(half_symm_shape)))
|
292
|
+
)
|
293
|
+
sq_paulis[row].z[col] = pauli_bool[key][0]
|
294
|
+
sq_paulis[row].x[col] = pauli_bool[key][1]
|
295
|
+
sq_list.append(col)
|
296
|
+
break
|
297
|
+
if current_test_result:
|
298
|
+
# We break out of the loop over columns only when one valid test is identified.
|
299
|
+
break
|
300
|
+
|
301
|
+
return cls(pauli_symmetries, sq_paulis, sq_list, None)
|
302
|
+
|
303
|
+
def convert_clifford(self, operator: SparsePauliOp) -> SparsePauliOp:
|
304
|
+
"""This method operates the first part of the tapering.
|
305
|
+
It converts the operator by composing it with the clifford unitaries defined in the current
|
306
|
+
symmetry.
|
307
|
+
|
308
|
+
Args:
|
309
|
+
operator: The to-be-tapered operator.
|
310
|
+
|
311
|
+
Returns:
|
312
|
+
``SparsePauliOp`` corresponding to the converted operator.
|
313
|
+
|
314
|
+
"""
|
315
|
+
|
316
|
+
if not self.is_empty() and not _sparse_pauli_op_is_zero(operator):
|
317
|
+
# If the operator is zero then we can skip the following.
|
318
|
+
for clifford in self.cliffords:
|
319
|
+
operator = cast(SparsePauliOp, clifford @ operator @ clifford)
|
320
|
+
operator = operator.simplify(atol=0.0)
|
321
|
+
|
322
|
+
return operator
|
323
|
+
|
324
|
+
def taper_clifford(self, operator: SparsePauliOp) -> Union[SparsePauliOp, list[SparsePauliOp]]:
|
325
|
+
"""Operate the second part of the tapering.
|
326
|
+
This function assumes that the input operators have already been transformed using
|
327
|
+
:meth:`convert_clifford`. The redundant qubits due to the symmetries are dropped and
|
328
|
+
replaced by their two possible eigenvalues.
|
329
|
+
|
330
|
+
Args:
|
331
|
+
operator: Partially tapered operator resulting from a call to :meth:`convert_clifford`.
|
332
|
+
|
333
|
+
Returns:
|
334
|
+
If tapering_values is None: [:class:`SparsePauliOp`]; otherwise, :class:`SparsePauliOp`.
|
335
|
+
|
336
|
+
"""
|
337
|
+
|
338
|
+
tapered_ops: Union[SparsePauliOp, list[SparsePauliOp]]
|
339
|
+
if self.is_empty():
|
340
|
+
tapered_ops = operator
|
341
|
+
else:
|
342
|
+
# If the operator is zero we still need to taper the operator to reduce its size i.e. the
|
343
|
+
# number of qubits so for example 0*"IIII" could taper to 0*"II" when symmetries remove
|
344
|
+
# two qubits.
|
345
|
+
if self.tapering_values is None:
|
346
|
+
tapered_ops = [
|
347
|
+
self._taper(operator, list(coeff))
|
348
|
+
for coeff in itertools.product([1, -1], repeat=len(self._sq_list))
|
349
|
+
]
|
350
|
+
else:
|
351
|
+
tapered_ops = self._taper(operator, self.tapering_values)
|
352
|
+
|
353
|
+
return tapered_ops
|
354
|
+
|
355
|
+
def taper(self, operator: SparsePauliOp) -> Union[SparsePauliOp, list[SparsePauliOp]]:
|
356
|
+
"""
|
357
|
+
Taper an operator based on the z2_symmetries info and sector defined by `tapering_values`.
|
358
|
+
Returns operator if the symmetry object is empty.
|
359
|
+
|
360
|
+
The tapering is a two-step algorithm which first converts the operator into a
|
361
|
+
:class:`SparsePauliOp` with same eigenvalues but where some qubits are only acted upon
|
362
|
+
with the Pauli operators I or X.
|
363
|
+
The number M of these redundant qubits is equal to the number M of identified symmetries.
|
364
|
+
|
365
|
+
The second step of the reduction consists in replacing these qubits with the possible
|
366
|
+
eigenvalues of the corresponding Pauli X, giving 2^M new operators with M less qubits.
|
367
|
+
If an eigenvalue sector was previously identified for the solution, then this reduces to
|
368
|
+
1 new operator with M less qubits.
|
369
|
+
|
370
|
+
Args:
|
371
|
+
operator: The to-be-tapered operator.
|
372
|
+
|
373
|
+
Returns:
|
374
|
+
If tapering_values is None: [:class:`SparsePauliOp`]; otherwise, :class:`SparsePauliOp`.
|
375
|
+
|
376
|
+
"""
|
377
|
+
|
378
|
+
converted_ops = self.convert_clifford(operator)
|
379
|
+
tapered_ops = self.taper_clifford(converted_ops)
|
380
|
+
|
381
|
+
return tapered_ops
|
382
|
+
|
383
|
+
def _taper(self, op: SparsePauliOp, curr_tapering_values: list[int]) -> SparsePauliOp:
|
384
|
+
pauli_list = []
|
385
|
+
for pauli_term in iter(op):
|
386
|
+
coeff_out = pauli_term.coeffs[0]
|
387
|
+
for idx, qubit_idx in enumerate(self._sq_list):
|
388
|
+
if pauli_term.paulis.z[0, qubit_idx] or pauli_term.paulis.x[0, qubit_idx]:
|
389
|
+
coeff_out = curr_tapering_values[idx] * coeff_out
|
390
|
+
z_temp = np.delete(pauli_term.paulis.z[0].copy(), np.asarray(self._sq_list))
|
391
|
+
x_temp = np.delete(pauli_term.paulis.x[0].copy(), np.asarray(self._sq_list))
|
392
|
+
pauli_list.append((Pauli((z_temp, x_temp)).to_label(), coeff_out))
|
393
|
+
|
394
|
+
spo = SparsePauliOp.from_list(pauli_list).simplify(atol=0.0)
|
395
|
+
spo = spo.chop(self.tol)
|
396
|
+
return spo
|
397
|
+
|
398
|
+
def __eq__(self, other: Z2Symmetries) -> bool:
|
399
|
+
"""
|
400
|
+
Overload `==` operation to evaluate equality between Z2Symmetries.
|
401
|
+
|
402
|
+
Args:
|
403
|
+
other: The `Z2Symmetries` to compare to self.
|
404
|
+
|
405
|
+
Returns:
|
406
|
+
A bool equal to the equality of self and other.
|
407
|
+
"""
|
408
|
+
if not isinstance(other, Z2Symmetries):
|
409
|
+
return False
|
410
|
+
|
411
|
+
return (
|
412
|
+
self.symmetries == other.symmetries
|
413
|
+
and self.sq_paulis == other.sq_paulis
|
414
|
+
and self.sq_list == other.sq_list
|
415
|
+
and self.tapering_values == other.tapering_values
|
416
|
+
)
|
417
|
+
|
418
|
+
|
419
|
+
def _kernel_f2(matrix_in):
|
420
|
+
"""
|
421
|
+
Compute the kernel of a binary matrix on the binary finite field.
|
422
|
+
|
423
|
+
Args:
|
424
|
+
matrix_in (numpy.ndarray): Binary matrix.
|
425
|
+
|
426
|
+
Returns:
|
427
|
+
The list of kernel vectors.
|
428
|
+
"""
|
429
|
+
size = matrix_in.shape
|
430
|
+
kernel = []
|
431
|
+
matrix_in_id = np.vstack((matrix_in, np.identity(size[1])))
|
432
|
+
matrix_in_id_ech = (_row_echelon_f2(matrix_in_id.transpose())).transpose()
|
433
|
+
|
434
|
+
for col in range(size[1]):
|
435
|
+
if np.array_equal(
|
436
|
+
matrix_in_id_ech[0 : size[0], col], np.zeros(size[0])
|
437
|
+
) and not np.array_equal(matrix_in_id_ech[size[0] :, col], np.zeros(size[1])):
|
438
|
+
kernel.append(matrix_in_id_ech[size[0] :, col])
|
439
|
+
|
440
|
+
return kernel
|
441
|
+
|
442
|
+
|
443
|
+
def _row_echelon_f2(matrix_in):
|
444
|
+
"""
|
445
|
+
Compute the row Echelon form of a binary matrix on the binary finite field.
|
446
|
+
|
447
|
+
Args:
|
448
|
+
matrix_in (numpy.ndarray): Binary matrix.
|
449
|
+
|
450
|
+
Returns:
|
451
|
+
Matrix_in in Echelon row form.
|
452
|
+
"""
|
453
|
+
size = matrix_in.shape
|
454
|
+
|
455
|
+
for i in range(size[0]):
|
456
|
+
pivot_index = 0
|
457
|
+
for j in range(size[1]):
|
458
|
+
if matrix_in[i, j] == 1:
|
459
|
+
pivot_index = j
|
460
|
+
break
|
461
|
+
for k in range(size[0]):
|
462
|
+
if k != i and matrix_in[k, pivot_index] == 1:
|
463
|
+
matrix_in[k, :] = np.mod(matrix_in[k, :] + matrix_in[i, :], 2)
|
464
|
+
|
465
|
+
matrix_out_temp = deepcopy(matrix_in)
|
466
|
+
indices = []
|
467
|
+
matrix_out = np.zeros(size)
|
468
|
+
|
469
|
+
for i in range(size[0] - 1):
|
470
|
+
if np.array_equal(matrix_out_temp[i, :], np.zeros(size[1])):
|
471
|
+
indices.append(i)
|
472
|
+
for row in np.sort(indices)[::-1]:
|
473
|
+
matrix_out_temp = np.delete(matrix_out_temp, (row), axis=0)
|
474
|
+
|
475
|
+
matrix_out[0 : size[0] - len(indices), :] = matrix_out_temp
|
476
|
+
matrix_out = matrix_out.astype(int)
|
477
|
+
|
478
|
+
return matrix_out
|
479
|
+
|
480
|
+
|
481
|
+
def _sparse_pauli_op_is_zero(op: SparsePauliOp) -> bool:
|
482
|
+
"""Returns whether or not this operator represents a zero operation."""
|
483
|
+
op = op.simplify()
|
484
|
+
return len(op.coeffs) == 1 and op.coeffs[0] == 0
|
@@ -0,0 +1,29 @@
|
|
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
|
+
"""Quantum Operators."""
|
14
|
+
|
15
|
+
from __future__ import annotations
|
16
|
+
from .channel import PTM, Chi, Choi, Kraus, Stinespring, SuperOp
|
17
|
+
from .dihedral import CNOTDihedral
|
18
|
+
from .measures import average_gate_fidelity, diamond_norm, gate_error, process_fidelity
|
19
|
+
from .operator import Operator
|
20
|
+
from .scalar_op import ScalarOp
|
21
|
+
from .symplectic import (
|
22
|
+
Clifford,
|
23
|
+
Pauli,
|
24
|
+
PauliList,
|
25
|
+
SparsePauliOp,
|
26
|
+
pauli_basis,
|
27
|
+
get_clifford_gate_names,
|
28
|
+
)
|
29
|
+
from .utils import anti_commutator, commutator, double_commutator
|