qiskit 1.3.0b1__cp39-abi3-macosx_10_9_x86_64.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 +127 -0
- qiskit/_accelerate.abi3.so +0 -0
- qiskit/_numpy_compat.py +73 -0
- qiskit/assembler/__init__.py +42 -0
- qiskit/assembler/assemble_circuits.py +451 -0
- qiskit/assembler/assemble_schedules.py +365 -0
- qiskit/assembler/disassemble.py +310 -0
- qiskit/assembler/run_config.py +77 -0
- qiskit/circuit/__init__.py +1270 -0
- qiskit/circuit/_classical_resource_map.py +148 -0
- qiskit/circuit/_standard_gates_commutations.py +3264 -0
- qiskit/circuit/_utils.py +167 -0
- qiskit/circuit/add_control.py +274 -0
- qiskit/circuit/annotated_operation.py +279 -0
- qiskit/circuit/barrier.py +48 -0
- qiskit/circuit/bit.py +94 -0
- qiskit/circuit/classical/__init__.py +41 -0
- qiskit/circuit/classical/expr/__init__.py +238 -0
- qiskit/circuit/classical/expr/constructors.py +556 -0
- qiskit/circuit/classical/expr/expr.py +397 -0
- qiskit/circuit/classical/expr/visitors.py +300 -0
- qiskit/circuit/classical/types/__init__.py +109 -0
- qiskit/circuit/classical/types/ordering.py +222 -0
- qiskit/circuit/classical/types/types.py +117 -0
- qiskit/circuit/classicalfunction/__init__.py +140 -0
- qiskit/circuit/classicalfunction/boolean_expression.py +129 -0
- qiskit/circuit/classicalfunction/classical_element.py +54 -0
- qiskit/circuit/classicalfunction/classical_function_visitor.py +155 -0
- qiskit/circuit/classicalfunction/classicalfunction.py +173 -0
- qiskit/circuit/classicalfunction/exceptions.py +35 -0
- qiskit/circuit/classicalfunction/types.py +18 -0
- qiskit/circuit/classicalfunction/utils.py +91 -0
- qiskit/circuit/classicalregister.py +57 -0
- qiskit/circuit/commutation_checker.py +106 -0
- qiskit/circuit/commutation_library.py +20 -0
- qiskit/circuit/controlflow/__init__.py +28 -0
- qiskit/circuit/controlflow/_builder_utils.py +207 -0
- qiskit/circuit/controlflow/break_loop.py +56 -0
- qiskit/circuit/controlflow/builder.py +691 -0
- qiskit/circuit/controlflow/continue_loop.py +58 -0
- qiskit/circuit/controlflow/control_flow.py +84 -0
- qiskit/circuit/controlflow/for_loop.py +217 -0
- qiskit/circuit/controlflow/if_else.py +503 -0
- qiskit/circuit/controlflow/switch_case.py +417 -0
- qiskit/circuit/controlflow/while_loop.py +163 -0
- qiskit/circuit/controlledgate.py +274 -0
- qiskit/circuit/delay.py +106 -0
- qiskit/circuit/duration.py +95 -0
- qiskit/circuit/equivalence.py +295 -0
- qiskit/circuit/equivalence_library.py +18 -0
- qiskit/circuit/exceptions.py +19 -0
- qiskit/circuit/gate.py +261 -0
- qiskit/circuit/instruction.py +676 -0
- qiskit/circuit/instructionset.py +177 -0
- qiskit/circuit/library/__init__.py +572 -0
- qiskit/circuit/library/arithmetic/__init__.py +27 -0
- qiskit/circuit/library/arithmetic/adders/__init__.py +17 -0
- qiskit/circuit/library/arithmetic/adders/adder.py +58 -0
- qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py +159 -0
- qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py +116 -0
- qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py +165 -0
- qiskit/circuit/library/arithmetic/exact_reciprocal.py +88 -0
- qiskit/circuit/library/arithmetic/functional_pauli_rotations.py +114 -0
- qiskit/circuit/library/arithmetic/integer_comparator.py +243 -0
- qiskit/circuit/library/arithmetic/linear_amplitude_function.py +196 -0
- qiskit/circuit/library/arithmetic/linear_pauli_rotations.py +189 -0
- qiskit/circuit/library/arithmetic/multipliers/__init__.py +16 -0
- qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py +138 -0
- qiskit/circuit/library/arithmetic/multipliers/multiplier.py +101 -0
- qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py +101 -0
- qiskit/circuit/library/arithmetic/piecewise_chebyshev.py +353 -0
- qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py +277 -0
- qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py +317 -0
- qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py +335 -0
- qiskit/circuit/library/arithmetic/quadratic_form.py +198 -0
- qiskit/circuit/library/arithmetic/weighted_adder.py +337 -0
- qiskit/circuit/library/basis_change/__init__.py +15 -0
- qiskit/circuit/library/basis_change/qft.py +331 -0
- qiskit/circuit/library/blueprintcircuit.py +216 -0
- qiskit/circuit/library/boolean_logic/__init__.py +18 -0
- qiskit/circuit/library/boolean_logic/inner_product.py +78 -0
- qiskit/circuit/library/boolean_logic/quantum_and.py +97 -0
- qiskit/circuit/library/boolean_logic/quantum_or.py +98 -0
- qiskit/circuit/library/boolean_logic/quantum_xor.py +71 -0
- qiskit/circuit/library/data_preparation/__init__.py +54 -0
- qiskit/circuit/library/data_preparation/initializer.py +107 -0
- qiskit/circuit/library/data_preparation/pauli_feature_map.py +343 -0
- qiskit/circuit/library/data_preparation/state_preparation.py +336 -0
- qiskit/circuit/library/data_preparation/z_feature_map.py +104 -0
- qiskit/circuit/library/data_preparation/zz_feature_map.py +118 -0
- qiskit/circuit/library/fourier_checking.py +97 -0
- qiskit/circuit/library/generalized_gates/__init__.py +30 -0
- qiskit/circuit/library/generalized_gates/diagonal.py +165 -0
- qiskit/circuit/library/generalized_gates/gms.py +121 -0
- qiskit/circuit/library/generalized_gates/gr.py +215 -0
- qiskit/circuit/library/generalized_gates/isometry.py +370 -0
- qiskit/circuit/library/generalized_gates/linear_function.py +312 -0
- qiskit/circuit/library/generalized_gates/mcg_up_to_diagonal.py +143 -0
- qiskit/circuit/library/generalized_gates/mcmt.py +256 -0
- qiskit/circuit/library/generalized_gates/pauli.py +85 -0
- qiskit/circuit/library/generalized_gates/permutation.py +192 -0
- qiskit/circuit/library/generalized_gates/rv.py +97 -0
- qiskit/circuit/library/generalized_gates/uc.py +213 -0
- qiskit/circuit/library/generalized_gates/uc_pauli_rot.py +164 -0
- qiskit/circuit/library/generalized_gates/ucrx.py +32 -0
- qiskit/circuit/library/generalized_gates/ucry.py +32 -0
- qiskit/circuit/library/generalized_gates/ucrz.py +32 -0
- qiskit/circuit/library/generalized_gates/unitary.py +215 -0
- qiskit/circuit/library/graph_state.py +86 -0
- qiskit/circuit/library/grover_operator.py +311 -0
- qiskit/circuit/library/hamiltonian_gate.py +142 -0
- qiskit/circuit/library/hidden_linear_function.py +98 -0
- qiskit/circuit/library/iqp.py +96 -0
- qiskit/circuit/library/n_local/__init__.py +33 -0
- qiskit/circuit/library/n_local/efficient_su2.py +164 -0
- qiskit/circuit/library/n_local/evolved_operator_ansatz.py +256 -0
- qiskit/circuit/library/n_local/excitation_preserving.py +173 -0
- qiskit/circuit/library/n_local/n_local.py +1071 -0
- qiskit/circuit/library/n_local/pauli_two_design.py +141 -0
- qiskit/circuit/library/n_local/qaoa_ansatz.py +287 -0
- qiskit/circuit/library/n_local/real_amplitudes.py +186 -0
- qiskit/circuit/library/n_local/two_local.py +282 -0
- qiskit/circuit/library/overlap.py +117 -0
- qiskit/circuit/library/pauli_evolution.py +184 -0
- qiskit/circuit/library/phase_estimation.py +99 -0
- qiskit/circuit/library/phase_oracle.py +153 -0
- qiskit/circuit/library/quantum_volume.py +115 -0
- qiskit/circuit/library/standard_gates/__init__.py +123 -0
- qiskit/circuit/library/standard_gates/dcx.py +77 -0
- qiskit/circuit/library/standard_gates/ecr.py +130 -0
- qiskit/circuit/library/standard_gates/equivalence_library.py +1800 -0
- qiskit/circuit/library/standard_gates/global_phase.py +85 -0
- qiskit/circuit/library/standard_gates/h.py +257 -0
- qiskit/circuit/library/standard_gates/i.py +75 -0
- qiskit/circuit/library/standard_gates/iswap.py +134 -0
- qiskit/circuit/library/standard_gates/multi_control_rotation_gates.py +405 -0
- qiskit/circuit/library/standard_gates/p.py +433 -0
- qiskit/circuit/library/standard_gates/r.py +117 -0
- qiskit/circuit/library/standard_gates/rx.py +302 -0
- qiskit/circuit/library/standard_gates/rxx.py +183 -0
- qiskit/circuit/library/standard_gates/ry.py +297 -0
- qiskit/circuit/library/standard_gates/ryy.py +183 -0
- qiskit/circuit/library/standard_gates/rz.py +318 -0
- qiskit/circuit/library/standard_gates/rzx.py +229 -0
- qiskit/circuit/library/standard_gates/rzz.py +196 -0
- qiskit/circuit/library/standard_gates/s.py +428 -0
- qiskit/circuit/library/standard_gates/swap.py +288 -0
- qiskit/circuit/library/standard_gates/sx.py +314 -0
- qiskit/circuit/library/standard_gates/t.py +179 -0
- qiskit/circuit/library/standard_gates/u.py +395 -0
- qiskit/circuit/library/standard_gates/u1.py +451 -0
- qiskit/circuit/library/standard_gates/u2.py +146 -0
- qiskit/circuit/library/standard_gates/u3.py +408 -0
- qiskit/circuit/library/standard_gates/x.py +1527 -0
- qiskit/circuit/library/standard_gates/xx_minus_yy.py +235 -0
- qiskit/circuit/library/standard_gates/xx_plus_yy.py +239 -0
- qiskit/circuit/library/standard_gates/y.py +261 -0
- qiskit/circuit/library/standard_gates/z.py +348 -0
- qiskit/circuit/library/templates/__init__.py +92 -0
- qiskit/circuit/library/templates/clifford/__init__.py +33 -0
- qiskit/circuit/library/templates/clifford/clifford_2_1.py +33 -0
- qiskit/circuit/library/templates/clifford/clifford_2_2.py +34 -0
- qiskit/circuit/library/templates/clifford/clifford_2_3.py +32 -0
- qiskit/circuit/library/templates/clifford/clifford_2_4.py +33 -0
- qiskit/circuit/library/templates/clifford/clifford_3_1.py +34 -0
- qiskit/circuit/library/templates/clifford/clifford_4_1.py +37 -0
- qiskit/circuit/library/templates/clifford/clifford_4_2.py +36 -0
- qiskit/circuit/library/templates/clifford/clifford_4_3.py +37 -0
- qiskit/circuit/library/templates/clifford/clifford_4_4.py +36 -0
- qiskit/circuit/library/templates/clifford/clifford_5_1.py +39 -0
- qiskit/circuit/library/templates/clifford/clifford_6_1.py +39 -0
- qiskit/circuit/library/templates/clifford/clifford_6_2.py +39 -0
- qiskit/circuit/library/templates/clifford/clifford_6_3.py +39 -0
- qiskit/circuit/library/templates/clifford/clifford_6_4.py +37 -0
- qiskit/circuit/library/templates/clifford/clifford_6_5.py +39 -0
- qiskit/circuit/library/templates/clifford/clifford_8_1.py +41 -0
- qiskit/circuit/library/templates/clifford/clifford_8_2.py +41 -0
- qiskit/circuit/library/templates/clifford/clifford_8_3.py +40 -0
- qiskit/circuit/library/templates/nct/__init__.py +67 -0
- qiskit/circuit/library/templates/nct/template_nct_2a_1.py +32 -0
- qiskit/circuit/library/templates/nct/template_nct_2a_2.py +33 -0
- qiskit/circuit/library/templates/nct/template_nct_2a_3.py +35 -0
- qiskit/circuit/library/templates/nct/template_nct_4a_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_4a_2.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_4a_3.py +37 -0
- qiskit/circuit/library/templates/nct/template_nct_4b_1.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_4b_2.py +37 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_1.py +38 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_2.py +38 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_3.py +38 -0
- qiskit/circuit/library/templates/nct/template_nct_5a_4.py +37 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_1.py +38 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_2.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_3.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_6a_4.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_6b_1.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_6b_2.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_6c_1.py +39 -0
- qiskit/circuit/library/templates/nct/template_nct_7a_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_7b_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_7c_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_7d_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_7e_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_9a_1.py +43 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_10.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_11.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_12.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_2.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_3.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_4.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_5.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_6.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_7.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_8.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9c_9.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_1.py +41 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_10.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_2.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_3.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_4.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_5.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_6.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_7.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_8.py +42 -0
- qiskit/circuit/library/templates/nct/template_nct_9d_9.py +42 -0
- qiskit/circuit/library/templates/rzx/__init__.py +25 -0
- qiskit/circuit/library/templates/rzx/rzx_cy.py +46 -0
- qiskit/circuit/library/templates/rzx/rzx_xz.py +53 -0
- qiskit/circuit/library/templates/rzx/rzx_yz.py +43 -0
- qiskit/circuit/library/templates/rzx/rzx_zz1.py +67 -0
- qiskit/circuit/library/templates/rzx/rzx_zz2.py +58 -0
- qiskit/circuit/library/templates/rzx/rzx_zz3.py +57 -0
- qiskit/circuit/measure.py +44 -0
- qiskit/circuit/operation.py +67 -0
- qiskit/circuit/parameter.py +174 -0
- qiskit/circuit/parameterexpression.py +559 -0
- qiskit/circuit/parametertable.py +119 -0
- qiskit/circuit/parametervector.py +120 -0
- qiskit/circuit/quantumcircuit.py +6793 -0
- qiskit/circuit/quantumcircuitdata.py +136 -0
- qiskit/circuit/quantumregister.py +75 -0
- qiskit/circuit/random/__init__.py +15 -0
- qiskit/circuit/random/utils.py +358 -0
- qiskit/circuit/register.py +233 -0
- qiskit/circuit/reset.py +34 -0
- qiskit/circuit/singleton.py +604 -0
- qiskit/circuit/store.py +95 -0
- qiskit/circuit/tools/__init__.py +16 -0
- qiskit/circuit/tools/pi_check.py +190 -0
- qiskit/compiler/__init__.py +33 -0
- qiskit/compiler/assembler.py +668 -0
- qiskit/compiler/scheduler.py +107 -0
- qiskit/compiler/sequencer.py +69 -0
- qiskit/compiler/transpiler.py +478 -0
- qiskit/converters/__init__.py +74 -0
- qiskit/converters/circuit_to_dag.py +78 -0
- qiskit/converters/circuit_to_dagdependency.py +51 -0
- qiskit/converters/circuit_to_dagdependency_v2.py +47 -0
- qiskit/converters/circuit_to_gate.py +107 -0
- qiskit/converters/circuit_to_instruction.py +155 -0
- qiskit/converters/dag_to_circuit.py +77 -0
- qiskit/converters/dag_to_dagdependency.py +55 -0
- qiskit/converters/dag_to_dagdependency_v2.py +44 -0
- qiskit/converters/dagdependency_to_circuit.py +42 -0
- qiskit/converters/dagdependency_to_dag.py +49 -0
- qiskit/dagcircuit/__init__.py +44 -0
- qiskit/dagcircuit/collect_blocks.py +391 -0
- qiskit/dagcircuit/dagcircuit.py +24 -0
- qiskit/dagcircuit/dagdependency.py +633 -0
- qiskit/dagcircuit/dagdependency_v2.py +641 -0
- qiskit/dagcircuit/dagdepnode.py +160 -0
- qiskit/dagcircuit/dagnode.py +176 -0
- qiskit/dagcircuit/exceptions.py +42 -0
- qiskit/exceptions.py +153 -0
- qiskit/passmanager/__init__.py +240 -0
- qiskit/passmanager/base_tasks.py +230 -0
- qiskit/passmanager/compilation_status.py +74 -0
- qiskit/passmanager/exceptions.py +19 -0
- qiskit/passmanager/flow_controllers.py +116 -0
- qiskit/passmanager/passmanager.py +333 -0
- qiskit/primitives/__init__.py +481 -0
- qiskit/primitives/backend_estimator.py +483 -0
- qiskit/primitives/backend_estimator_v2.py +434 -0
- qiskit/primitives/backend_sampler.py +222 -0
- qiskit/primitives/backend_sampler_v2.py +296 -0
- qiskit/primitives/base/__init__.py +20 -0
- qiskit/primitives/base/base_estimator.py +252 -0
- qiskit/primitives/base/base_primitive.py +45 -0
- qiskit/primitives/base/base_primitive_job.py +78 -0
- qiskit/primitives/base/base_result.py +65 -0
- qiskit/primitives/base/base_sampler.py +204 -0
- qiskit/primitives/base/estimator_result.py +46 -0
- qiskit/primitives/base/sampler_result.py +45 -0
- qiskit/primitives/base/validation.py +231 -0
- qiskit/primitives/containers/__init__.py +26 -0
- qiskit/primitives/containers/bindings_array.py +389 -0
- qiskit/primitives/containers/bit_array.py +741 -0
- qiskit/primitives/containers/data_bin.py +165 -0
- qiskit/primitives/containers/estimator_pub.py +222 -0
- qiskit/primitives/containers/object_array.py +94 -0
- qiskit/primitives/containers/observables_array.py +279 -0
- qiskit/primitives/containers/primitive_result.py +53 -0
- qiskit/primitives/containers/pub_result.py +51 -0
- qiskit/primitives/containers/sampler_pub.py +193 -0
- qiskit/primitives/containers/sampler_pub_result.py +74 -0
- qiskit/primitives/containers/shape.py +129 -0
- qiskit/primitives/estimator.py +172 -0
- qiskit/primitives/primitive_job.py +81 -0
- qiskit/primitives/sampler.py +162 -0
- qiskit/primitives/statevector_estimator.py +174 -0
- qiskit/primitives/statevector_sampler.py +292 -0
- qiskit/primitives/utils.py +247 -0
- qiskit/providers/__init__.py +803 -0
- qiskit/providers/backend.py +656 -0
- qiskit/providers/backend_compat.py +452 -0
- qiskit/providers/basic_provider/__init__.py +45 -0
- qiskit/providers/basic_provider/basic_provider.py +101 -0
- qiskit/providers/basic_provider/basic_provider_job.py +65 -0
- qiskit/providers/basic_provider/basic_provider_tools.py +218 -0
- qiskit/providers/basic_provider/basic_simulator.py +811 -0
- qiskit/providers/basic_provider/exceptions.py +30 -0
- qiskit/providers/exceptions.py +45 -0
- qiskit/providers/fake_provider/__init__.py +105 -0
- qiskit/providers/fake_provider/backends_v1/__init__.py +22 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/conf_washington.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/defs_washington.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/fake_127q_pulse_v1.py +37 -0
- qiskit/providers/fake_provider/backends_v1/fake_127q_pulse/props_washington.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/conf_singapore.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/fake_20q.py +43 -0
- qiskit/providers/fake_provider/backends_v1/fake_20q/props_singapore.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/conf_hanoi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/defs_hanoi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/fake_27q_pulse_v1.py +50 -0
- qiskit/providers/fake_provider/backends_v1/fake_27q_pulse/props_hanoi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/conf_yorktown.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/fake_5q_v1.py +41 -0
- qiskit/providers/fake_provider/backends_v1/fake_5q/props_yorktown.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/__init__.py +18 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/conf_nairobi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/defs_nairobi.json +1 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/fake_7q_pulse_v1.py +44 -0
- qiskit/providers/fake_provider/backends_v1/fake_7q_pulse/props_nairobi.json +1 -0
- qiskit/providers/fake_provider/fake_1q.py +91 -0
- qiskit/providers/fake_provider/fake_backend.py +165 -0
- qiskit/providers/fake_provider/fake_openpulse_2q.py +391 -0
- qiskit/providers/fake_provider/fake_openpulse_3q.py +340 -0
- qiskit/providers/fake_provider/fake_pulse_backend.py +44 -0
- qiskit/providers/fake_provider/fake_qasm_backend.py +77 -0
- qiskit/providers/fake_provider/generic_backend_v2.py +1019 -0
- qiskit/providers/fake_provider/utils/__init__.py +15 -0
- qiskit/providers/fake_provider/utils/backend_converter.py +150 -0
- qiskit/providers/fake_provider/utils/json_decoder.py +109 -0
- qiskit/providers/job.py +147 -0
- qiskit/providers/jobstatus.py +30 -0
- qiskit/providers/models/__init__.py +89 -0
- qiskit/providers/models/backendconfiguration.py +1040 -0
- qiskit/providers/models/backendproperties.py +517 -0
- qiskit/providers/models/backendstatus.py +94 -0
- qiskit/providers/models/jobstatus.py +66 -0
- qiskit/providers/models/pulsedefaults.py +303 -0
- qiskit/providers/options.py +273 -0
- qiskit/providers/provider.py +95 -0
- qiskit/providers/providerutils.py +110 -0
- qiskit/pulse/__init__.py +158 -0
- qiskit/pulse/builder.py +2213 -0
- qiskit/pulse/calibration_entries.py +378 -0
- qiskit/pulse/channels.py +225 -0
- qiskit/pulse/configuration.py +245 -0
- qiskit/pulse/exceptions.py +43 -0
- qiskit/pulse/filters.py +309 -0
- qiskit/pulse/instruction_schedule_map.py +409 -0
- qiskit/pulse/instructions/__init__.py +67 -0
- qiskit/pulse/instructions/acquire.py +148 -0
- qiskit/pulse/instructions/delay.py +69 -0
- qiskit/pulse/instructions/directives.py +146 -0
- qiskit/pulse/instructions/frequency.py +132 -0
- qiskit/pulse/instructions/instruction.py +268 -0
- qiskit/pulse/instructions/phase.py +149 -0
- qiskit/pulse/instructions/play.py +97 -0
- qiskit/pulse/instructions/reference.py +98 -0
- qiskit/pulse/instructions/snapshot.py +80 -0
- qiskit/pulse/library/__init__.py +97 -0
- qiskit/pulse/library/continuous.py +430 -0
- qiskit/pulse/library/pulse.py +146 -0
- qiskit/pulse/library/samplers/__init__.py +15 -0
- qiskit/pulse/library/samplers/decorators.py +295 -0
- qiskit/pulse/library/samplers/strategies.py +71 -0
- qiskit/pulse/library/symbolic_pulses.py +1960 -0
- qiskit/pulse/library/waveform.py +134 -0
- qiskit/pulse/macros.py +262 -0
- qiskit/pulse/parameter_manager.py +445 -0
- qiskit/pulse/parser.py +314 -0
- qiskit/pulse/reference_manager.py +58 -0
- qiskit/pulse/schedule.py +1855 -0
- qiskit/pulse/transforms/__init__.py +106 -0
- qiskit/pulse/transforms/alignments.py +404 -0
- qiskit/pulse/transforms/base_transforms.py +71 -0
- qiskit/pulse/transforms/canonicalization.py +498 -0
- qiskit/pulse/transforms/dag.py +115 -0
- qiskit/pulse/utils.py +149 -0
- qiskit/qasm/libs/dummy/stdgates.inc +75 -0
- qiskit/qasm/libs/qelib1.inc +266 -0
- qiskit/qasm/libs/stdgates.inc +82 -0
- qiskit/qasm2/__init__.py +654 -0
- qiskit/qasm2/exceptions.py +27 -0
- qiskit/qasm2/export.py +370 -0
- qiskit/qasm2/parse.py +408 -0
- qiskit/qasm3/__init__.py +366 -0
- qiskit/qasm3/ast.py +630 -0
- qiskit/qasm3/exceptions.py +27 -0
- qiskit/qasm3/experimental.py +70 -0
- qiskit/qasm3/exporter.py +1273 -0
- qiskit/qasm3/printer.py +577 -0
- qiskit/qobj/__init__.py +75 -0
- qiskit/qobj/common.py +81 -0
- qiskit/qobj/converters/__init__.py +18 -0
- qiskit/qobj/converters/lo_config.py +177 -0
- qiskit/qobj/converters/pulse_instruction.py +895 -0
- qiskit/qobj/pulse_qobj.py +709 -0
- qiskit/qobj/qasm_qobj.py +708 -0
- qiskit/qobj/utils.py +46 -0
- qiskit/qpy/__init__.py +1641 -0
- qiskit/qpy/binary_io/__init__.py +36 -0
- qiskit/qpy/binary_io/circuits.py +1460 -0
- qiskit/qpy/binary_io/schedules.py +636 -0
- qiskit/qpy/binary_io/value.py +728 -0
- qiskit/qpy/common.py +306 -0
- qiskit/qpy/exceptions.py +53 -0
- qiskit/qpy/formats.py +394 -0
- qiskit/qpy/interface.py +341 -0
- qiskit/qpy/type_keys.py +572 -0
- qiskit/quantum_info/__init__.py +158 -0
- qiskit/quantum_info/analysis/__init__.py +17 -0
- qiskit/quantum_info/analysis/average.py +47 -0
- qiskit/quantum_info/analysis/distance.py +102 -0
- qiskit/quantum_info/analysis/make_observable.py +44 -0
- qiskit/quantum_info/analysis/z2_symmetries.py +484 -0
- qiskit/quantum_info/operators/__init__.py +28 -0
- qiskit/quantum_info/operators/base_operator.py +145 -0
- qiskit/quantum_info/operators/channel/__init__.py +29 -0
- qiskit/quantum_info/operators/channel/chi.py +191 -0
- qiskit/quantum_info/operators/channel/choi.py +218 -0
- qiskit/quantum_info/operators/channel/kraus.py +337 -0
- qiskit/quantum_info/operators/channel/ptm.py +204 -0
- qiskit/quantum_info/operators/channel/quantum_channel.py +348 -0
- qiskit/quantum_info/operators/channel/stinespring.py +296 -0
- qiskit/quantum_info/operators/channel/superop.py +377 -0
- qiskit/quantum_info/operators/channel/transformations.py +468 -0
- qiskit/quantum_info/operators/custom_iterator.py +48 -0
- qiskit/quantum_info/operators/dihedral/__init__.py +18 -0
- qiskit/quantum_info/operators/dihedral/dihedral.py +509 -0
- qiskit/quantum_info/operators/dihedral/dihedral_circuits.py +216 -0
- qiskit/quantum_info/operators/dihedral/polynomial.py +313 -0
- qiskit/quantum_info/operators/dihedral/random.py +64 -0
- qiskit/quantum_info/operators/linear_op.py +25 -0
- qiskit/quantum_info/operators/measures.py +418 -0
- qiskit/quantum_info/operators/mixins/__init__.py +52 -0
- qiskit/quantum_info/operators/mixins/adjoint.py +52 -0
- qiskit/quantum_info/operators/mixins/group.py +171 -0
- qiskit/quantum_info/operators/mixins/linear.py +84 -0
- qiskit/quantum_info/operators/mixins/multiply.py +62 -0
- qiskit/quantum_info/operators/mixins/tolerances.py +72 -0
- qiskit/quantum_info/operators/op_shape.py +525 -0
- qiskit/quantum_info/operators/operator.py +819 -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 +727 -0
- qiskit/quantum_info/operators/symplectic/clifford.py +1030 -0
- qiskit/quantum_info/operators/symplectic/clifford_circuits.py +558 -0
- qiskit/quantum_info/operators/symplectic/pauli.py +751 -0
- qiskit/quantum_info/operators/symplectic/pauli_list.py +1230 -0
- qiskit/quantum_info/operators/symplectic/pauli_utils.py +40 -0
- qiskit/quantum_info/operators/symplectic/random.py +117 -0
- qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py +1175 -0
- qiskit/quantum_info/operators/utils/__init__.py +20 -0
- qiskit/quantum_info/operators/utils/anti_commutator.py +36 -0
- qiskit/quantum_info/operators/utils/commutator.py +36 -0
- qiskit/quantum_info/operators/utils/double_commutator.py +76 -0
- qiskit/quantum_info/quaternion.py +156 -0
- qiskit/quantum_info/random.py +26 -0
- qiskit/quantum_info/states/__init__.py +28 -0
- qiskit/quantum_info/states/densitymatrix.py +845 -0
- qiskit/quantum_info/states/measures.py +288 -0
- qiskit/quantum_info/states/quantum_state.py +503 -0
- qiskit/quantum_info/states/random.py +157 -0
- qiskit/quantum_info/states/stabilizerstate.py +773 -0
- qiskit/quantum_info/states/statevector.py +958 -0
- qiskit/quantum_info/states/utils.py +247 -0
- qiskit/result/__init__.py +73 -0
- qiskit/result/counts.py +189 -0
- qiskit/result/distributions/__init__.py +17 -0
- qiskit/result/distributions/probability.py +100 -0
- qiskit/result/distributions/quasi.py +154 -0
- qiskit/result/exceptions.py +40 -0
- qiskit/result/mitigation/__init__.py +13 -0
- qiskit/result/mitigation/base_readout_mitigator.py +79 -0
- qiskit/result/mitigation/correlated_readout_mitigator.py +269 -0
- qiskit/result/mitigation/local_readout_mitigator.py +320 -0
- qiskit/result/mitigation/utils.py +160 -0
- qiskit/result/models.py +234 -0
- qiskit/result/postprocess.py +239 -0
- qiskit/result/result.py +392 -0
- qiskit/result/sampled_expval.py +75 -0
- qiskit/result/utils.py +295 -0
- qiskit/scheduler/__init__.py +40 -0
- qiskit/scheduler/config.py +35 -0
- qiskit/scheduler/lowering.py +187 -0
- qiskit/scheduler/methods/__init__.py +15 -0
- qiskit/scheduler/methods/basic.py +137 -0
- qiskit/scheduler/schedule_circuit.py +67 -0
- qiskit/scheduler/sequence.py +102 -0
- qiskit/synthesis/__init__.py +195 -0
- qiskit/synthesis/clifford/__init__.py +19 -0
- qiskit/synthesis/clifford/clifford_decompose_ag.py +178 -0
- qiskit/synthesis/clifford/clifford_decompose_bm.py +47 -0
- qiskit/synthesis/clifford/clifford_decompose_full.py +64 -0
- qiskit/synthesis/clifford/clifford_decompose_greedy.py +57 -0
- qiskit/synthesis/clifford/clifford_decompose_layers.py +446 -0
- qiskit/synthesis/cnotdihedral/__init__.py +17 -0
- qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py +52 -0
- qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py +141 -0
- qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py +266 -0
- qiskit/synthesis/discrete_basis/__init__.py +16 -0
- qiskit/synthesis/discrete_basis/commutator_decompose.py +241 -0
- qiskit/synthesis/discrete_basis/gate_sequence.py +415 -0
- qiskit/synthesis/discrete_basis/generate_basis_approximations.py +163 -0
- qiskit/synthesis/discrete_basis/solovay_kitaev.py +217 -0
- qiskit/synthesis/evolution/__init__.py +20 -0
- qiskit/synthesis/evolution/evolution_synthesis.py +48 -0
- qiskit/synthesis/evolution/lie_trotter.py +143 -0
- qiskit/synthesis/evolution/matrix_synthesis.py +47 -0
- qiskit/synthesis/evolution/product_formula.py +384 -0
- qiskit/synthesis/evolution/qdrift.py +131 -0
- qiskit/synthesis/evolution/suzuki_trotter.py +155 -0
- qiskit/synthesis/linear/__init__.py +26 -0
- qiskit/synthesis/linear/cnot_synth.py +69 -0
- qiskit/synthesis/linear/linear_circuits_utils.py +128 -0
- qiskit/synthesis/linear/linear_depth_lnn.py +276 -0
- qiskit/synthesis/linear/linear_matrix_utils.py +27 -0
- qiskit/synthesis/linear_phase/__init__.py +17 -0
- qiskit/synthesis/linear_phase/cnot_phase_synth.py +206 -0
- qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py +262 -0
- qiskit/synthesis/linear_phase/cz_depth_lnn.py +58 -0
- qiskit/synthesis/multi_controlled/__init__.py +23 -0
- qiskit/synthesis/multi_controlled/mcx_synthesis.py +356 -0
- qiskit/synthesis/one_qubit/__init__.py +15 -0
- qiskit/synthesis/one_qubit/one_qubit_decompose.py +288 -0
- qiskit/synthesis/permutation/__init__.py +18 -0
- qiskit/synthesis/permutation/permutation_full.py +78 -0
- qiskit/synthesis/permutation/permutation_lnn.py +54 -0
- qiskit/synthesis/permutation/permutation_reverse_lnn.py +93 -0
- qiskit/synthesis/permutation/permutation_utils.py +16 -0
- qiskit/synthesis/qft/__init__.py +16 -0
- qiskit/synthesis/qft/qft_decompose_full.py +79 -0
- qiskit/synthesis/qft/qft_decompose_lnn.py +78 -0
- qiskit/synthesis/stabilizer/__init__.py +16 -0
- qiskit/synthesis/stabilizer/stabilizer_circuit.py +149 -0
- qiskit/synthesis/stabilizer/stabilizer_decompose.py +193 -0
- qiskit/synthesis/two_qubit/__init__.py +19 -0
- qiskit/synthesis/two_qubit/local_invariance.py +63 -0
- qiskit/synthesis/two_qubit/two_qubit_decompose.py +759 -0
- qiskit/synthesis/two_qubit/weyl.py +97 -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 +1283 -0
- qiskit/transpiler/basepasses.py +221 -0
- qiskit/transpiler/coupling.py +500 -0
- qiskit/transpiler/exceptions.py +59 -0
- qiskit/transpiler/instruction_durations.py +281 -0
- qiskit/transpiler/layout.py +737 -0
- qiskit/transpiler/passes/__init__.py +310 -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 +693 -0
- qiskit/transpiler/passes/basis/decompose.py +98 -0
- qiskit/transpiler/passes/basis/translate_parameterized.py +175 -0
- qiskit/transpiler/passes/basis/unroll_3q_or_more.py +88 -0
- qiskit/transpiler/passes/basis/unroll_custom_definitions.py +109 -0
- qiskit/transpiler/passes/calibration/__init__.py +17 -0
- qiskit/transpiler/passes/calibration/base_builder.py +79 -0
- qiskit/transpiler/passes/calibration/builders.py +20 -0
- qiskit/transpiler/passes/calibration/exceptions.py +22 -0
- qiskit/transpiler/passes/calibration/pulse_gate.py +98 -0
- qiskit/transpiler/passes/calibration/rx_builder.py +160 -0
- qiskit/transpiler/passes/calibration/rzx_builder.py +395 -0
- qiskit/transpiler/passes/calibration/rzx_templates.py +51 -0
- qiskit/transpiler/passes/layout/__init__.py +26 -0
- qiskit/transpiler/passes/layout/_csp_custom_solver.py +65 -0
- qiskit/transpiler/passes/layout/apply_layout.py +123 -0
- qiskit/transpiler/passes/layout/csp_layout.py +132 -0
- qiskit/transpiler/passes/layout/dense_layout.py +202 -0
- qiskit/transpiler/passes/layout/disjoint_utils.py +217 -0
- qiskit/transpiler/passes/layout/enlarge_with_ancilla.py +49 -0
- qiskit/transpiler/passes/layout/full_ancilla_allocation.py +117 -0
- qiskit/transpiler/passes/layout/layout_2q_distance.py +77 -0
- qiskit/transpiler/passes/layout/sabre_layout.py +482 -0
- qiskit/transpiler/passes/layout/sabre_pre_layout.py +220 -0
- qiskit/transpiler/passes/layout/set_layout.py +69 -0
- qiskit/transpiler/passes/layout/trivial_layout.py +66 -0
- qiskit/transpiler/passes/layout/vf2_layout.py +263 -0
- qiskit/transpiler/passes/layout/vf2_post_layout.py +419 -0
- qiskit/transpiler/passes/layout/vf2_utils.py +260 -0
- qiskit/transpiler/passes/optimization/__init__.py +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 +115 -0
- qiskit/transpiler/passes/optimization/collect_cliffords.py +88 -0
- qiskit/transpiler/passes/optimization/collect_linear_functions.py +80 -0
- qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py +227 -0
- qiskit/transpiler/passes/optimization/commutation_analysis.py +44 -0
- qiskit/transpiler/passes/optimization/commutative_cancellation.py +82 -0
- qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py +140 -0
- qiskit/transpiler/passes/optimization/consolidate_blocks.py +232 -0
- qiskit/transpiler/passes/optimization/cx_cancellation.py +65 -0
- qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py +160 -0
- qiskit/transpiler/passes/optimization/elide_permutations.py +114 -0
- qiskit/transpiler/passes/optimization/hoare_opt.py +420 -0
- qiskit/transpiler/passes/optimization/inverse_cancellation.py +93 -0
- qiskit/transpiler/passes/optimization/normalize_rx_angle.py +149 -0
- qiskit/transpiler/passes/optimization/optimize_1q_commutation.py +268 -0
- qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py +260 -0
- qiskit/transpiler/passes/optimization/optimize_1q_gates.py +384 -0
- qiskit/transpiler/passes/optimization/optimize_annotated.py +448 -0
- qiskit/transpiler/passes/optimization/optimize_cliffords.py +89 -0
- qiskit/transpiler/passes/optimization/optimize_swap_before_measure.py +71 -0
- qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py +41 -0
- qiskit/transpiler/passes/optimization/remove_final_reset.py +37 -0
- qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py +37 -0
- qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py +47 -0
- qiskit/transpiler/passes/optimization/split_2q_unitaries.py +40 -0
- qiskit/transpiler/passes/optimization/template_matching/__init__.py +19 -0
- qiskit/transpiler/passes/optimization/template_matching/backward_match.py +749 -0
- qiskit/transpiler/passes/optimization/template_matching/forward_match.py +452 -0
- qiskit/transpiler/passes/optimization/template_matching/maximal_matches.py +77 -0
- qiskit/transpiler/passes/optimization/template_matching/template_matching.py +370 -0
- qiskit/transpiler/passes/optimization/template_matching/template_substitution.py +638 -0
- qiskit/transpiler/passes/optimization/template_optimization.py +158 -0
- qiskit/transpiler/passes/routing/__init__.py +22 -0
- qiskit/transpiler/passes/routing/algorithms/__init__.py +33 -0
- qiskit/transpiler/passes/routing/algorithms/token_swapper.py +105 -0
- qiskit/transpiler/passes/routing/algorithms/types.py +46 -0
- qiskit/transpiler/passes/routing/algorithms/util.py +103 -0
- qiskit/transpiler/passes/routing/basic_swap.py +166 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/__init__.py +25 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_block.py +60 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py +395 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/pauli_2q_evolution_commutation.py +145 -0
- qiskit/transpiler/passes/routing/commuting_2q_gate_routing/swap_strategy.py +306 -0
- qiskit/transpiler/passes/routing/layout_transformation.py +119 -0
- qiskit/transpiler/passes/routing/lookahead_swap.py +390 -0
- qiskit/transpiler/passes/routing/sabre_swap.py +443 -0
- qiskit/transpiler/passes/routing/star_prerouting.py +392 -0
- qiskit/transpiler/passes/routing/stochastic_swap.py +532 -0
- qiskit/transpiler/passes/routing/utils.py +35 -0
- qiskit/transpiler/passes/scheduling/__init__.py +27 -0
- qiskit/transpiler/passes/scheduling/alap.py +153 -0
- qiskit/transpiler/passes/scheduling/alignments/__init__.py +81 -0
- qiskit/transpiler/passes/scheduling/alignments/align_measures.py +255 -0
- qiskit/transpiler/passes/scheduling/alignments/check_durations.py +78 -0
- qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py +105 -0
- qiskit/transpiler/passes/scheduling/alignments/reschedule.py +250 -0
- qiskit/transpiler/passes/scheduling/asap.py +175 -0
- qiskit/transpiler/passes/scheduling/base_scheduler.py +308 -0
- qiskit/transpiler/passes/scheduling/dynamical_decoupling.py +307 -0
- qiskit/transpiler/passes/scheduling/padding/__init__.py +16 -0
- qiskit/transpiler/passes/scheduling/padding/base_padding.py +256 -0
- qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py +441 -0
- qiskit/transpiler/passes/scheduling/padding/pad_delay.py +79 -0
- qiskit/transpiler/passes/scheduling/scheduling/__init__.py +17 -0
- qiskit/transpiler/passes/scheduling/scheduling/alap.py +127 -0
- qiskit/transpiler/passes/scheduling/scheduling/asap.py +131 -0
- qiskit/transpiler/passes/scheduling/scheduling/base_scheduler.py +90 -0
- qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py +64 -0
- qiskit/transpiler/passes/scheduling/time_unit_conversion.py +160 -0
- qiskit/transpiler/passes/synthesis/__init__.py +20 -0
- qiskit/transpiler/passes/synthesis/aqc_plugin.py +153 -0
- qiskit/transpiler/passes/synthesis/high_level_synthesis.py +691 -0
- qiskit/transpiler/passes/synthesis/hls_plugins.py +928 -0
- qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py +41 -0
- qiskit/transpiler/passes/synthesis/plugin.py +734 -0
- qiskit/transpiler/passes/synthesis/qubit_tracker.py +132 -0
- qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py +297 -0
- qiskit/transpiler/passes/synthesis/unitary_synthesis.py +1055 -0
- qiskit/transpiler/passes/utils/__init__.py +33 -0
- qiskit/transpiler/passes/utils/barrier_before_final_measurements.py +95 -0
- qiskit/transpiler/passes/utils/check_gate_direction.py +52 -0
- qiskit/transpiler/passes/utils/check_map.py +78 -0
- qiskit/transpiler/passes/utils/contains_instruction.py +45 -0
- qiskit/transpiler/passes/utils/control_flow.py +65 -0
- qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py +88 -0
- qiskit/transpiler/passes/utils/dag_fixed_point.py +36 -0
- qiskit/transpiler/passes/utils/error.py +69 -0
- qiskit/transpiler/passes/utils/filter_op_nodes.py +65 -0
- qiskit/transpiler/passes/utils/fixed_point.py +48 -0
- qiskit/transpiler/passes/utils/gate_direction.py +349 -0
- qiskit/transpiler/passes/utils/gates_basis.py +74 -0
- qiskit/transpiler/passes/utils/merge_adjacent_barriers.py +162 -0
- qiskit/transpiler/passes/utils/minimum_point.py +118 -0
- qiskit/transpiler/passes/utils/remove_barriers.py +49 -0
- qiskit/transpiler/passes/utils/remove_final_measurements.py +114 -0
- qiskit/transpiler/passes/utils/unroll_forloops.py +81 -0
- qiskit/transpiler/passmanager.py +490 -0
- qiskit/transpiler/passmanager_config.py +198 -0
- qiskit/transpiler/preset_passmanagers/__init__.py +73 -0
- qiskit/transpiler/preset_passmanagers/builtin_plugins.py +1019 -0
- qiskit/transpiler/preset_passmanagers/common.py +647 -0
- qiskit/transpiler/preset_passmanagers/generate_preset_pass_manager.py +543 -0
- qiskit/transpiler/preset_passmanagers/level0.py +113 -0
- qiskit/transpiler/preset_passmanagers/level1.py +120 -0
- qiskit/transpiler/preset_passmanagers/level2.py +119 -0
- qiskit/transpiler/preset_passmanagers/level3.py +119 -0
- qiskit/transpiler/preset_passmanagers/plugin.py +353 -0
- qiskit/transpiler/target.py +1261 -0
- qiskit/transpiler/timing_constraints.py +59 -0
- qiskit/user_config.py +262 -0
- qiskit/utils/__init__.py +89 -0
- qiskit/utils/classtools.py +146 -0
- qiskit/utils/deprecation.py +490 -0
- qiskit/utils/lazy_tester.py +363 -0
- qiskit/utils/multiprocessing.py +56 -0
- qiskit/utils/optionals.py +347 -0
- qiskit/utils/parallel.py +191 -0
- qiskit/utils/units.py +143 -0
- qiskit/version.py +84 -0
- qiskit/visualization/__init__.py +288 -0
- qiskit/visualization/array.py +204 -0
- qiskit/visualization/bloch.py +778 -0
- qiskit/visualization/circuit/__init__.py +15 -0
- qiskit/visualization/circuit/_utils.py +675 -0
- qiskit/visualization/circuit/circuit_visualization.py +726 -0
- qiskit/visualization/circuit/latex.py +661 -0
- qiskit/visualization/circuit/matplotlib.py +2029 -0
- qiskit/visualization/circuit/qcstyle.py +278 -0
- qiskit/visualization/circuit/styles/__init__.py +13 -0
- qiskit/visualization/circuit/styles/bw.json +202 -0
- qiskit/visualization/circuit/styles/clifford.json +202 -0
- qiskit/visualization/circuit/styles/iqp-dark.json +214 -0
- qiskit/visualization/circuit/styles/iqp.json +214 -0
- qiskit/visualization/circuit/styles/textbook.json +202 -0
- qiskit/visualization/circuit/text.py +1844 -0
- qiskit/visualization/circuit_visualization.py +19 -0
- qiskit/visualization/counts_visualization.py +481 -0
- qiskit/visualization/dag_visualization.py +316 -0
- qiskit/visualization/exceptions.py +21 -0
- qiskit/visualization/gate_map.py +1485 -0
- qiskit/visualization/library.py +37 -0
- qiskit/visualization/pass_manager_visualization.py +319 -0
- qiskit/visualization/pulse_v2/__init__.py +21 -0
- qiskit/visualization/pulse_v2/core.py +901 -0
- qiskit/visualization/pulse_v2/device_info.py +173 -0
- qiskit/visualization/pulse_v2/drawings.py +253 -0
- qiskit/visualization/pulse_v2/events.py +254 -0
- qiskit/visualization/pulse_v2/generators/__init__.py +40 -0
- qiskit/visualization/pulse_v2/generators/barrier.py +76 -0
- qiskit/visualization/pulse_v2/generators/chart.py +208 -0
- qiskit/visualization/pulse_v2/generators/frame.py +436 -0
- qiskit/visualization/pulse_v2/generators/snapshot.py +133 -0
- qiskit/visualization/pulse_v2/generators/waveform.py +645 -0
- qiskit/visualization/pulse_v2/interface.py +456 -0
- qiskit/visualization/pulse_v2/layouts.py +387 -0
- qiskit/visualization/pulse_v2/plotters/__init__.py +17 -0
- qiskit/visualization/pulse_v2/plotters/base_plotter.py +53 -0
- qiskit/visualization/pulse_v2/plotters/matplotlib.py +201 -0
- qiskit/visualization/pulse_v2/stylesheet.py +312 -0
- qiskit/visualization/pulse_v2/types.py +242 -0
- qiskit/visualization/state_visualization.py +1518 -0
- qiskit/visualization/timeline/__init__.py +21 -0
- qiskit/visualization/timeline/core.py +457 -0
- qiskit/visualization/timeline/drawings.py +260 -0
- qiskit/visualization/timeline/generators.py +506 -0
- qiskit/visualization/timeline/interface.py +424 -0
- qiskit/visualization/timeline/layouts.py +115 -0
- qiskit/visualization/timeline/plotters/__init__.py +16 -0
- qiskit/visualization/timeline/plotters/base_plotter.py +58 -0
- qiskit/visualization/timeline/plotters/matplotlib.py +192 -0
- qiskit/visualization/timeline/stylesheet.py +301 -0
- qiskit/visualization/timeline/types.py +148 -0
- qiskit/visualization/transition_visualization.py +369 -0
- qiskit/visualization/utils.py +49 -0
- qiskit-1.3.0b1.dist-info/LICENSE.txt +203 -0
- qiskit-1.3.0b1.dist-info/METADATA +221 -0
- qiskit-1.3.0b1.dist-info/RECORD +825 -0
- qiskit-1.3.0b1.dist-info/WHEEL +5 -0
- qiskit-1.3.0b1.dist-info/entry_points.txt +57 -0
- qiskit-1.3.0b1.dist-info/top_level.txt +1 -0
@@ -0,0 +1,138 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 2021.
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
"""Compute the product of two qubit registers using classical multiplication approach."""
|
14
|
+
|
15
|
+
from typing import Optional
|
16
|
+
from qiskit.circuit import QuantumRegister, AncillaRegister, QuantumCircuit
|
17
|
+
|
18
|
+
from .multiplier import Multiplier
|
19
|
+
|
20
|
+
|
21
|
+
class HRSCumulativeMultiplier(Multiplier):
|
22
|
+
r"""A multiplication circuit to store product of two input registers out-of-place.
|
23
|
+
|
24
|
+
Circuit uses the approach from [1]. As an example, a multiplier circuit that
|
25
|
+
performs a non-modular multiplication on two 3-qubit sized registers with
|
26
|
+
the default adder is as follows (where ``Adder`` denotes the
|
27
|
+
``CDKMRippleCarryAdder``):
|
28
|
+
|
29
|
+
.. parsed-literal::
|
30
|
+
|
31
|
+
a_0: ────■─────────────────────────
|
32
|
+
│
|
33
|
+
a_1: ────┼─────────■───────────────
|
34
|
+
│ │
|
35
|
+
a_2: ────┼─────────┼─────────■─────
|
36
|
+
┌───┴────┐┌───┴────┐┌───┴────┐
|
37
|
+
b_0: ┤0 ├┤0 ├┤0 ├
|
38
|
+
│ ││ ││ │
|
39
|
+
b_1: ┤1 ├┤1 ├┤1 ├
|
40
|
+
│ ││ ││ │
|
41
|
+
b_2: ┤2 ├┤2 ├┤2 ├
|
42
|
+
│ ││ ││ │
|
43
|
+
out_0: ┤3 ├┤ ├┤ ├
|
44
|
+
│ ││ ││ │
|
45
|
+
out_1: ┤4 ├┤3 ├┤ ├
|
46
|
+
│ Adder ││ Adder ││ Adder │
|
47
|
+
out_2: ┤5 ├┤4 ├┤3 ├
|
48
|
+
│ ││ ││ │
|
49
|
+
out_3: ┤6 ├┤5 ├┤4 ├
|
50
|
+
│ ││ ││ │
|
51
|
+
out_4: ┤ ├┤6 ├┤5 ├
|
52
|
+
│ ││ ││ │
|
53
|
+
out_5: ┤ ├┤ ├┤6 ├
|
54
|
+
│ ││ ││ │
|
55
|
+
aux_0: ┤7 ├┤7 ├┤7 ├
|
56
|
+
└────────┘└────────┘└────────┘
|
57
|
+
|
58
|
+
Multiplication in this circuit is implemented in a classical approach by performing
|
59
|
+
a series of shifted additions using one of the input registers while the qubits
|
60
|
+
from the other input register act as control qubits for the adders.
|
61
|
+
|
62
|
+
**References:**
|
63
|
+
|
64
|
+
[1] Häner et al., Optimizing Quantum Circuits for Arithmetic, 2018.
|
65
|
+
`arXiv:1805.12445 <https://arxiv.org/pdf/1805.12445.pdf>`_
|
66
|
+
|
67
|
+
"""
|
68
|
+
|
69
|
+
def __init__(
|
70
|
+
self,
|
71
|
+
num_state_qubits: int,
|
72
|
+
num_result_qubits: Optional[int] = None,
|
73
|
+
adder: Optional[QuantumCircuit] = None,
|
74
|
+
name: str = "HRSCumulativeMultiplier",
|
75
|
+
) -> None:
|
76
|
+
r"""
|
77
|
+
Args:
|
78
|
+
num_state_qubits: The number of qubits in either input register for
|
79
|
+
state :math:`|a\rangle` or :math:`|b\rangle`. The two input
|
80
|
+
registers must have the same number of qubits.
|
81
|
+
num_result_qubits: The number of result qubits to limit the output to.
|
82
|
+
If number of result qubits is :math:`n`, multiplication modulo :math:`2^n` is performed
|
83
|
+
to limit the output to the specified number of qubits. Default
|
84
|
+
value is ``2 * num_state_qubits`` to represent any possible
|
85
|
+
result from the multiplication of the two inputs.
|
86
|
+
adder: Half adder circuit to be used for performing multiplication. The
|
87
|
+
CDKMRippleCarryAdder is used as default if no adder is provided.
|
88
|
+
name: The name of the circuit object.
|
89
|
+
Raises:
|
90
|
+
NotImplementedError: If ``num_result_qubits`` is not default and a custom adder is provided.
|
91
|
+
"""
|
92
|
+
super().__init__(num_state_qubits, num_result_qubits, name=name)
|
93
|
+
|
94
|
+
if self.num_result_qubits != 2 * num_state_qubits and adder is not None:
|
95
|
+
raise NotImplementedError("Only default adder is supported for modular multiplication.")
|
96
|
+
|
97
|
+
# define the registers
|
98
|
+
qr_a = QuantumRegister(num_state_qubits, name="a")
|
99
|
+
qr_b = QuantumRegister(num_state_qubits, name="b")
|
100
|
+
qr_out = QuantumRegister(self.num_result_qubits, name="out")
|
101
|
+
self.add_register(qr_a, qr_b, qr_out)
|
102
|
+
|
103
|
+
# prepare adder as controlled gate
|
104
|
+
if adder is None:
|
105
|
+
from qiskit.circuit.library.arithmetic.adders import CDKMRippleCarryAdder
|
106
|
+
|
107
|
+
adder = CDKMRippleCarryAdder(num_state_qubits, kind="half")
|
108
|
+
|
109
|
+
# get the number of helper qubits needed
|
110
|
+
num_helper_qubits = adder.num_ancillas
|
111
|
+
|
112
|
+
# add helper qubits if required
|
113
|
+
if num_helper_qubits > 0:
|
114
|
+
qr_h = AncillaRegister(num_helper_qubits, name="helper") # helper/ancilla qubits
|
115
|
+
self.add_register(qr_h)
|
116
|
+
|
117
|
+
# build multiplication circuit
|
118
|
+
circuit = QuantumCircuit(*self.qregs, name=name)
|
119
|
+
|
120
|
+
for i in range(num_state_qubits):
|
121
|
+
excess_qubits = max(0, num_state_qubits + i + 1 - self.num_result_qubits)
|
122
|
+
if excess_qubits == 0:
|
123
|
+
num_adder_qubits = num_state_qubits
|
124
|
+
adder_for_current_step = adder
|
125
|
+
else:
|
126
|
+
num_adder_qubits = num_state_qubits - excess_qubits + 1
|
127
|
+
adder_for_current_step = CDKMRippleCarryAdder(num_adder_qubits, kind="fixed")
|
128
|
+
controlled_adder = adder_for_current_step.to_gate().control(1)
|
129
|
+
qr_list = (
|
130
|
+
[qr_a[i]]
|
131
|
+
+ qr_b[:num_adder_qubits]
|
132
|
+
+ qr_out[i : num_state_qubits + i + 1 - excess_qubits]
|
133
|
+
)
|
134
|
+
if num_helper_qubits > 0:
|
135
|
+
qr_list.extend(qr_h[:])
|
136
|
+
circuit.append(controlled_adder, qr_list)
|
137
|
+
|
138
|
+
self.append(circuit.to_gate(), self.qubits)
|
@@ -0,0 +1,101 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 2021.
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
"""Compute the product of two equally sized qubit registers."""
|
14
|
+
|
15
|
+
from typing import Optional
|
16
|
+
|
17
|
+
from qiskit.circuit import QuantumCircuit
|
18
|
+
|
19
|
+
|
20
|
+
class Multiplier(QuantumCircuit):
|
21
|
+
r"""Compute the product of two equally sized qubit registers into a new register.
|
22
|
+
|
23
|
+
For two input registers :math:`|a\rangle_n`, :math:`|b\rangle_n` with :math:`n` qubits each
|
24
|
+
and an output register with :math:`2n` qubits, a multiplier performs the following operation
|
25
|
+
|
26
|
+
.. math::
|
27
|
+
|
28
|
+
|a\rangle_n |b\rangle_n |0\rangle_{t} \mapsto |a\rangle_n |b\rangle_n |a \cdot b\rangle_t
|
29
|
+
|
30
|
+
where :math:`t` is the number of bits used to represent the result. To completely store the result
|
31
|
+
of the multiplication without overflow we need :math:`t = 2n` bits.
|
32
|
+
|
33
|
+
The quantum register :math:`|a\rangle_n` (analogously :math:`|b\rangle_n` and
|
34
|
+
output register)
|
35
|
+
|
36
|
+
.. math::
|
37
|
+
|
38
|
+
|a\rangle_n = |a_0\rangle \otimes \cdots \otimes |a_{n - 1}\rangle,
|
39
|
+
|
40
|
+
for :math:`a_i \in \{0, 1\}`, is associated with the integer value
|
41
|
+
|
42
|
+
.. math::
|
43
|
+
|
44
|
+
a = 2^{0}a_{0} + 2^{1}a_{1} + \cdots + 2^{n - 1}a_{n - 1}.
|
45
|
+
|
46
|
+
"""
|
47
|
+
|
48
|
+
def __init__(
|
49
|
+
self,
|
50
|
+
num_state_qubits: int,
|
51
|
+
num_result_qubits: Optional[int] = None,
|
52
|
+
name: str = "Multiplier",
|
53
|
+
) -> None:
|
54
|
+
"""
|
55
|
+
Args:
|
56
|
+
num_state_qubits: The number of qubits in each of the input registers.
|
57
|
+
num_result_qubits: The number of result qubits to limit the output to.
|
58
|
+
Default value is ``2 * num_state_qubits`` to represent any possible
|
59
|
+
result from the multiplication of the two inputs.
|
60
|
+
name: The name of the circuit.
|
61
|
+
Raises:
|
62
|
+
ValueError: If ``num_state_qubits`` is smaller than 1.
|
63
|
+
ValueError: If ``num_result_qubits`` is smaller than ``num_state_qubits``.
|
64
|
+
ValueError: If ``num_result_qubits`` is larger than ``2 * num_state_qubits``.
|
65
|
+
"""
|
66
|
+
if num_state_qubits < 1:
|
67
|
+
raise ValueError("The number of qubits must be at least 1.")
|
68
|
+
|
69
|
+
if num_result_qubits is None:
|
70
|
+
num_result_qubits = 2 * num_state_qubits
|
71
|
+
|
72
|
+
if num_result_qubits < num_state_qubits:
|
73
|
+
raise ValueError(
|
74
|
+
"Number of result qubits is smaller than number of input state qubits."
|
75
|
+
)
|
76
|
+
if num_result_qubits > 2 * num_state_qubits:
|
77
|
+
raise ValueError(
|
78
|
+
"Number of result qubits is larger than twice the number of input state qubits."
|
79
|
+
)
|
80
|
+
|
81
|
+
super().__init__(name=name)
|
82
|
+
self._num_state_qubits = num_state_qubits
|
83
|
+
self._num_result_qubits = num_result_qubits
|
84
|
+
|
85
|
+
@property
|
86
|
+
def num_state_qubits(self) -> int:
|
87
|
+
"""The number of state qubits, i.e. the number of bits in each input register.
|
88
|
+
|
89
|
+
Returns:
|
90
|
+
The number of state qubits.
|
91
|
+
"""
|
92
|
+
return self._num_state_qubits
|
93
|
+
|
94
|
+
@property
|
95
|
+
def num_result_qubits(self) -> int:
|
96
|
+
"""The number of result qubits to limit the output to.
|
97
|
+
|
98
|
+
Returns:
|
99
|
+
The number of result qubits.
|
100
|
+
"""
|
101
|
+
return self._num_result_qubits
|
@@ -0,0 +1,101 @@
|
|
1
|
+
# This code is part of Qiskit.
|
2
|
+
#
|
3
|
+
# (C) Copyright IBM 2017, 2021.
|
4
|
+
#
|
5
|
+
# This code is licensed under the Apache License, Version 2.0. You may
|
6
|
+
# obtain a copy of this license in the LICENSE.txt file in the root directory
|
7
|
+
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
|
8
|
+
#
|
9
|
+
# Any modifications or derivative works of this code must retain this
|
10
|
+
# copyright notice, and modified files need to carry a notice indicating
|
11
|
+
# that they have been altered from the originals.
|
12
|
+
|
13
|
+
"""Compute the product of two qubit registers using QFT."""
|
14
|
+
|
15
|
+
from typing import Optional
|
16
|
+
import numpy as np
|
17
|
+
|
18
|
+
from qiskit.circuit import QuantumRegister, QuantumCircuit
|
19
|
+
from qiskit.circuit.library.standard_gates import PhaseGate
|
20
|
+
from qiskit.circuit.library.basis_change import QFT
|
21
|
+
|
22
|
+
from .multiplier import Multiplier
|
23
|
+
|
24
|
+
|
25
|
+
class RGQFTMultiplier(Multiplier):
|
26
|
+
r"""A QFT multiplication circuit to store product of two input registers out-of-place.
|
27
|
+
|
28
|
+
Multiplication in this circuit is implemented using the procedure of Fig. 3 in [1], where
|
29
|
+
weighted sum rotations are implemented as given in Fig. 5 in [1]. QFT is used on the output
|
30
|
+
register and is followed by rotations controlled by input registers. The rotations
|
31
|
+
transform the state into the product of two input registers in QFT base, which is
|
32
|
+
reverted from QFT base using inverse QFT.
|
33
|
+
As an example, a circuit that performs a modular QFT multiplication on two 2-qubit
|
34
|
+
sized input registers with an output register of 2 qubits, is as follows:
|
35
|
+
|
36
|
+
.. parsed-literal::
|
37
|
+
|
38
|
+
a_0: ────────────────────────────────────────■───────■──────■──────■────────────────
|
39
|
+
│ │ │ │
|
40
|
+
a_1: ─────────■───────■───────■───────■──────┼───────┼──────┼──────┼────────────────
|
41
|
+
│ │ │ │ │ │ │ │
|
42
|
+
b_0: ─────────┼───────┼───────■───────■──────┼───────┼──────■──────■────────────────
|
43
|
+
│ │ │ │ │ │ │ │
|
44
|
+
b_1: ─────────■───────■───────┼───────┼──────■───────■──────┼──────┼────────────────
|
45
|
+
┌──────┐ │P(4π) │ │P(2π) │ │P(2π) │ │P(π) │ ┌───────┐
|
46
|
+
out_0: ┤0 ├─■───────┼───────■───────┼──────■───────┼──────■──────┼───────┤0 ├
|
47
|
+
│ qft │ │P(2π) │P(π) │P(π) │P(π/2) │ iqft │
|
48
|
+
out_1: ┤1 ├─────────■───────────────■──────────────■─────────────■───────┤1 ├
|
49
|
+
└──────┘ └───────┘
|
50
|
+
|
51
|
+
**References:**
|
52
|
+
|
53
|
+
[1] Ruiz-Perez et al., Quantum arithmetic with the Quantum Fourier Transform, 2017.
|
54
|
+
`arXiv:1411.5949 <https://arxiv.org/pdf/1411.5949.pdf>`_
|
55
|
+
|
56
|
+
"""
|
57
|
+
|
58
|
+
def __init__(
|
59
|
+
self,
|
60
|
+
num_state_qubits: int,
|
61
|
+
num_result_qubits: Optional[int] = None,
|
62
|
+
name: str = "RGQFTMultiplier",
|
63
|
+
) -> None:
|
64
|
+
r"""
|
65
|
+
Args:
|
66
|
+
num_state_qubits: The number of qubits in either input register for
|
67
|
+
state :math:`|a\rangle` or :math:`|b\rangle`. The two input
|
68
|
+
registers must have the same number of qubits.
|
69
|
+
num_result_qubits: The number of result qubits to limit the output to.
|
70
|
+
If number of result qubits is :math:`n`, multiplication modulo :math:`2^n` is performed
|
71
|
+
to limit the output to the specified number of qubits. Default
|
72
|
+
value is ``2 * num_state_qubits`` to represent any possible
|
73
|
+
result from the multiplication of the two inputs.
|
74
|
+
name: The name of the circuit object.
|
75
|
+
|
76
|
+
"""
|
77
|
+
super().__init__(num_state_qubits, num_result_qubits, name=name)
|
78
|
+
|
79
|
+
# define the registers
|
80
|
+
qr_a = QuantumRegister(num_state_qubits, name="a")
|
81
|
+
qr_b = QuantumRegister(num_state_qubits, name="b")
|
82
|
+
qr_out = QuantumRegister(self.num_result_qubits, name="out")
|
83
|
+
self.add_register(qr_a, qr_b, qr_out)
|
84
|
+
|
85
|
+
# build multiplication circuit
|
86
|
+
circuit = QuantumCircuit(*self.qregs, name=name)
|
87
|
+
|
88
|
+
circuit.append(QFT(self.num_result_qubits, do_swaps=False).to_gate(), qr_out[:])
|
89
|
+
|
90
|
+
for j in range(1, num_state_qubits + 1):
|
91
|
+
for i in range(1, num_state_qubits + 1):
|
92
|
+
for k in range(1, self.num_result_qubits + 1):
|
93
|
+
lam = (2 * np.pi) / (2 ** (i + j + k - 2 * num_state_qubits))
|
94
|
+
circuit.append(
|
95
|
+
PhaseGate(lam).control(2),
|
96
|
+
[qr_a[num_state_qubits - j], qr_b[num_state_qubits - i], qr_out[k - 1]],
|
97
|
+
)
|
98
|
+
|
99
|
+
circuit.append(QFT(self.num_result_qubits, do_swaps=False).inverse().to_gate(), qr_out[:])
|
100
|
+
|
101
|
+
self.append(circuit.to_gate(), self.qubits)
|
@@ -0,0 +1,353 @@
|
|
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
|
+
"""Piecewise polynomial Chebyshev approximation to a given f(x)."""
|
14
|
+
|
15
|
+
from __future__ import annotations
|
16
|
+
from typing import Callable
|
17
|
+
import numpy as np
|
18
|
+
from numpy.polynomial.chebyshev import Chebyshev
|
19
|
+
|
20
|
+
from qiskit.circuit import QuantumRegister, AncillaRegister
|
21
|
+
from qiskit.circuit.library.blueprintcircuit import BlueprintCircuit
|
22
|
+
from qiskit.circuit.exceptions import CircuitError
|
23
|
+
|
24
|
+
from .piecewise_polynomial_pauli_rotations import PiecewisePolynomialPauliRotations
|
25
|
+
|
26
|
+
|
27
|
+
class PiecewiseChebyshev(BlueprintCircuit):
|
28
|
+
r"""Piecewise Chebyshev approximation to an input function.
|
29
|
+
|
30
|
+
For a given function :math:`f(x)` and degree :math:`d`, this class implements a piecewise
|
31
|
+
polynomial Chebyshev approximation on :math:`n` qubits to :math:`f(x)` on the given intervals.
|
32
|
+
All the polynomials in the approximation are of degree :math:`d`.
|
33
|
+
|
34
|
+
The values of the parameters are calculated according to [1] and see [2] for a more
|
35
|
+
detailed explanation of the circuit construction and how it acts on the qubits.
|
36
|
+
|
37
|
+
Examples:
|
38
|
+
|
39
|
+
.. plot::
|
40
|
+
:include-source:
|
41
|
+
|
42
|
+
import numpy as np
|
43
|
+
from qiskit import QuantumCircuit
|
44
|
+
from qiskit.circuit.library.arithmetic.piecewise_chebyshev import PiecewiseChebyshev
|
45
|
+
f_x, degree, breakpoints, num_state_qubits = lambda x: np.arcsin(1 / x), 2, [2, 4], 2
|
46
|
+
pw_approximation = PiecewiseChebyshev(f_x, degree, breakpoints, num_state_qubits)
|
47
|
+
pw_approximation._build()
|
48
|
+
qc = QuantumCircuit(pw_approximation.num_qubits)
|
49
|
+
qc.h(list(range(num_state_qubits)))
|
50
|
+
qc.append(pw_approximation.to_instruction(), qc.qubits)
|
51
|
+
qc.draw(output='mpl')
|
52
|
+
|
53
|
+
References:
|
54
|
+
|
55
|
+
[1]: Haener, T., Roetteler, M., & Svore, K. M. (2018).
|
56
|
+
Optimizing Quantum Circuits for Arithmetic.
|
57
|
+
`arXiv:1805.12445 <http://arxiv.org/abs/1805.12445>`_
|
58
|
+
[2]: Carrera Vazquez, A., Hiptmair, H., & Woerner, S. (2022).
|
59
|
+
Enhancing the Quantum Linear Systems Algorithm Using Richardson Extrapolation.
|
60
|
+
`ACM Transactions on Quantum Computing 3, 1, Article 2 <https://doi.org/10.1145/3490631>`_
|
61
|
+
"""
|
62
|
+
|
63
|
+
def __init__(
|
64
|
+
self,
|
65
|
+
f_x: float | Callable[[int], float],
|
66
|
+
degree: int | None = None,
|
67
|
+
breakpoints: list[int] | None = None,
|
68
|
+
num_state_qubits: int | None = None,
|
69
|
+
name: str = "pw_cheb",
|
70
|
+
) -> None:
|
71
|
+
r"""
|
72
|
+
Args:
|
73
|
+
f_x: the function to be approximated. Constant functions should be specified
|
74
|
+
as f_x = constant.
|
75
|
+
degree: the degree of the polynomials.
|
76
|
+
Defaults to ``1``.
|
77
|
+
breakpoints: the breakpoints to define the piecewise-linear function.
|
78
|
+
Defaults to the full interval.
|
79
|
+
num_state_qubits: number of qubits representing the state.
|
80
|
+
name: The name of the circuit object.
|
81
|
+
"""
|
82
|
+
super().__init__(name=name)
|
83
|
+
|
84
|
+
# define internal parameters
|
85
|
+
self._num_state_qubits = None
|
86
|
+
|
87
|
+
# Store parameters
|
88
|
+
self._f_x = f_x
|
89
|
+
self._degree = degree if degree is not None else 1
|
90
|
+
self._breakpoints = breakpoints if breakpoints is not None else [0]
|
91
|
+
|
92
|
+
self._polynomials: list[list[float]] | None = None
|
93
|
+
|
94
|
+
self.num_state_qubits = num_state_qubits
|
95
|
+
|
96
|
+
def _check_configuration(self, raise_on_failure: bool = True) -> bool:
|
97
|
+
"""Check if the current configuration is valid."""
|
98
|
+
valid = True
|
99
|
+
|
100
|
+
if self._f_x is None:
|
101
|
+
valid = False
|
102
|
+
if raise_on_failure:
|
103
|
+
raise AttributeError("The function to be approximated has not been set.")
|
104
|
+
|
105
|
+
if self._degree is None:
|
106
|
+
valid = False
|
107
|
+
if raise_on_failure:
|
108
|
+
raise AttributeError("The degree of the polynomials has not been set.")
|
109
|
+
|
110
|
+
if self._breakpoints is None:
|
111
|
+
valid = False
|
112
|
+
if raise_on_failure:
|
113
|
+
raise AttributeError("The breakpoints have not been set.")
|
114
|
+
|
115
|
+
if self.num_state_qubits is None:
|
116
|
+
valid = False
|
117
|
+
if raise_on_failure:
|
118
|
+
raise AttributeError("The number of qubits has not been set.")
|
119
|
+
|
120
|
+
if self.num_qubits < self.num_state_qubits + 1:
|
121
|
+
valid = False
|
122
|
+
if raise_on_failure:
|
123
|
+
raise CircuitError(
|
124
|
+
"Not enough qubits in the circuit, need at least "
|
125
|
+
f"{self.num_state_qubits + 1}."
|
126
|
+
)
|
127
|
+
|
128
|
+
return valid
|
129
|
+
|
130
|
+
@property
|
131
|
+
def f_x(self) -> float | Callable[[int], float]:
|
132
|
+
"""The function to be approximated.
|
133
|
+
|
134
|
+
Returns:
|
135
|
+
The function to be approximated.
|
136
|
+
"""
|
137
|
+
return self._f_x
|
138
|
+
|
139
|
+
@f_x.setter
|
140
|
+
def f_x(self, f_x: float | Callable[[int], float] | None) -> None:
|
141
|
+
"""Set the function to be approximated.
|
142
|
+
|
143
|
+
Note that this may change the underlying quantum register, if the number of state qubits
|
144
|
+
changes.
|
145
|
+
|
146
|
+
Args:
|
147
|
+
f_x: The new function to be approximated.
|
148
|
+
"""
|
149
|
+
if self._f_x is None or f_x != self._f_x:
|
150
|
+
self._invalidate()
|
151
|
+
self._f_x = f_x
|
152
|
+
|
153
|
+
self._reset_registers(self.num_state_qubits)
|
154
|
+
|
155
|
+
@property
|
156
|
+
def degree(self) -> int:
|
157
|
+
"""The degree of the polynomials.
|
158
|
+
|
159
|
+
Returns:
|
160
|
+
The degree of the polynomials.
|
161
|
+
"""
|
162
|
+
return self._degree
|
163
|
+
|
164
|
+
@degree.setter
|
165
|
+
def degree(self, degree: int | None) -> None:
|
166
|
+
"""Set the error tolerance.
|
167
|
+
|
168
|
+
Note that this may change the underlying quantum register, if the number of state qubits
|
169
|
+
changes.
|
170
|
+
|
171
|
+
Args:
|
172
|
+
degree: The new degree.
|
173
|
+
"""
|
174
|
+
if self._degree is None or degree != self._degree:
|
175
|
+
self._invalidate()
|
176
|
+
self._degree = degree
|
177
|
+
|
178
|
+
self._reset_registers(self.num_state_qubits)
|
179
|
+
|
180
|
+
@property
|
181
|
+
def breakpoints(self) -> list[int]:
|
182
|
+
"""The breakpoints for the piecewise approximation.
|
183
|
+
|
184
|
+
Returns:
|
185
|
+
The breakpoints for the piecewise approximation.
|
186
|
+
"""
|
187
|
+
breakpoints = self._breakpoints
|
188
|
+
|
189
|
+
# it the state qubits are set ensure that the breakpoints match beginning and end
|
190
|
+
if self.num_state_qubits is not None:
|
191
|
+
num_states = 2**self.num_state_qubits
|
192
|
+
|
193
|
+
# If the last breakpoint is < num_states, add the identity polynomial
|
194
|
+
if breakpoints[-1] < num_states:
|
195
|
+
breakpoints = breakpoints + [num_states]
|
196
|
+
|
197
|
+
# If the first breakpoint is > 0, add the identity polynomial
|
198
|
+
if breakpoints[0] > 0:
|
199
|
+
breakpoints = [0] + breakpoints
|
200
|
+
|
201
|
+
return breakpoints
|
202
|
+
|
203
|
+
@breakpoints.setter
|
204
|
+
def breakpoints(self, breakpoints: list[int] | None) -> None:
|
205
|
+
"""Set the breakpoints for the piecewise approximation.
|
206
|
+
|
207
|
+
Note that this may change the underlying quantum register, if the number of state qubits
|
208
|
+
changes.
|
209
|
+
|
210
|
+
Args:
|
211
|
+
breakpoints: The new breakpoints for the piecewise approximation.
|
212
|
+
"""
|
213
|
+
if self._breakpoints is None or breakpoints != self._breakpoints:
|
214
|
+
self._invalidate()
|
215
|
+
self._breakpoints = breakpoints if breakpoints is not None else [0]
|
216
|
+
|
217
|
+
self._reset_registers(self.num_state_qubits)
|
218
|
+
|
219
|
+
@property
|
220
|
+
def polynomials(self) -> list[list[float]]:
|
221
|
+
"""The polynomials for the piecewise approximation.
|
222
|
+
|
223
|
+
Returns:
|
224
|
+
The polynomials for the piecewise approximation.
|
225
|
+
|
226
|
+
Raises:
|
227
|
+
TypeError: If the input function is not in the correct format.
|
228
|
+
"""
|
229
|
+
if self.num_state_qubits is None:
|
230
|
+
return [[]]
|
231
|
+
|
232
|
+
# note this must be the private attribute since we handle missing breakpoints at
|
233
|
+
# 0 and 2 ^ num_qubits here (e.g. if the function we approximate is not defined at 0
|
234
|
+
# and the user takes that into account we just add an identity)
|
235
|
+
breakpoints = self._breakpoints
|
236
|
+
# Need to take into account the case in which no breakpoints were provided in first place
|
237
|
+
if breakpoints == [0]:
|
238
|
+
breakpoints = [0, 2**self.num_state_qubits]
|
239
|
+
|
240
|
+
num_intervals = len(breakpoints)
|
241
|
+
|
242
|
+
# Calculate the polynomials
|
243
|
+
polynomials = []
|
244
|
+
for i in range(0, num_intervals - 1):
|
245
|
+
# Calculate the polynomial approximating the function on the current interval
|
246
|
+
try:
|
247
|
+
# If the function is constant don't call Chebyshev (not necessary and gives errors)
|
248
|
+
if isinstance(self.f_x, (float, int)):
|
249
|
+
# Append directly to list of polynomials
|
250
|
+
polynomials.append([self.f_x])
|
251
|
+
else:
|
252
|
+
poly = Chebyshev.interpolate(
|
253
|
+
self.f_x, self.degree, domain=[breakpoints[i], breakpoints[i + 1]]
|
254
|
+
)
|
255
|
+
# Convert polynomial to the standard basis and rescale it for the rotation gates
|
256
|
+
poly = 2 * poly.convert(kind=np.polynomial.Polynomial).coef
|
257
|
+
# Convert to list and append
|
258
|
+
polynomials.append(poly.tolist())
|
259
|
+
except ValueError as err:
|
260
|
+
raise TypeError(
|
261
|
+
" <lambda>() missing 1 required positional argument: '"
|
262
|
+
+ self.f_x.__code__.co_varnames[0]
|
263
|
+
+ "'."
|
264
|
+
+ " Constant functions should be specified as 'f_x = constant'."
|
265
|
+
) from err
|
266
|
+
|
267
|
+
# If the last breakpoint is < 2 ** num_qubits, add the identity polynomial
|
268
|
+
if breakpoints[-1] < 2**self.num_state_qubits:
|
269
|
+
polynomials = polynomials + [[2 * np.arcsin(1)]]
|
270
|
+
|
271
|
+
# If the first breakpoint is > 0, add the identity polynomial
|
272
|
+
if breakpoints[0] > 0:
|
273
|
+
polynomials = [[2 * np.arcsin(1)]] + polynomials
|
274
|
+
|
275
|
+
return polynomials
|
276
|
+
|
277
|
+
@polynomials.setter
|
278
|
+
def polynomials(self, polynomials: list[list[float]] | None) -> None:
|
279
|
+
"""Set the polynomials for the piecewise approximation.
|
280
|
+
|
281
|
+
Note that this may change the underlying quantum register, if the number of state qubits
|
282
|
+
changes.
|
283
|
+
|
284
|
+
Args:
|
285
|
+
polynomials: The new breakpoints for the piecewise approximation.
|
286
|
+
"""
|
287
|
+
if self._polynomials is None or polynomials != self._polynomials:
|
288
|
+
self._invalidate()
|
289
|
+
self._polynomials = polynomials
|
290
|
+
|
291
|
+
self._reset_registers(self.num_state_qubits)
|
292
|
+
|
293
|
+
@property
|
294
|
+
def num_state_qubits(self) -> int:
|
295
|
+
r"""The number of state qubits representing the state :math:`|x\rangle`.
|
296
|
+
|
297
|
+
Returns:
|
298
|
+
The number of state qubits.
|
299
|
+
"""
|
300
|
+
return self._num_state_qubits
|
301
|
+
|
302
|
+
@num_state_qubits.setter
|
303
|
+
def num_state_qubits(self, num_state_qubits: int | None) -> None:
|
304
|
+
"""Set the number of state qubits.
|
305
|
+
|
306
|
+
Note that this may change the underlying quantum register, if the number of state qubits
|
307
|
+
changes.
|
308
|
+
|
309
|
+
Args:
|
310
|
+
num_state_qubits: The new number of qubits.
|
311
|
+
"""
|
312
|
+
if self._num_state_qubits is None or num_state_qubits != self._num_state_qubits:
|
313
|
+
self._invalidate()
|
314
|
+
self._num_state_qubits = num_state_qubits
|
315
|
+
|
316
|
+
# Set breakpoints if they haven't been set
|
317
|
+
if num_state_qubits is not None and self._breakpoints is None:
|
318
|
+
self.breakpoints = [0, 2**num_state_qubits]
|
319
|
+
|
320
|
+
self._reset_registers(num_state_qubits)
|
321
|
+
|
322
|
+
def _reset_registers(self, num_state_qubits: int | None) -> None:
|
323
|
+
"""Reset the registers."""
|
324
|
+
self.qregs = []
|
325
|
+
|
326
|
+
if num_state_qubits is not None:
|
327
|
+
qr_state = QuantumRegister(num_state_qubits, "state")
|
328
|
+
qr_target = QuantumRegister(1, "target")
|
329
|
+
self.qregs = [qr_state, qr_target]
|
330
|
+
|
331
|
+
num_ancillas = num_state_qubits
|
332
|
+
if num_ancillas > 0:
|
333
|
+
qr_ancilla = AncillaRegister(num_ancillas)
|
334
|
+
self.add_register(qr_ancilla)
|
335
|
+
|
336
|
+
def _build(self):
|
337
|
+
"""Build the circuit if not already build. The operation is considered successful
|
338
|
+
when q_objective is :math:`|1>`"""
|
339
|
+
if self._is_built:
|
340
|
+
return
|
341
|
+
|
342
|
+
super()._build()
|
343
|
+
|
344
|
+
poly_r = PiecewisePolynomialPauliRotations(
|
345
|
+
self.num_state_qubits, self.breakpoints, self.polynomials, name=self.name
|
346
|
+
)
|
347
|
+
|
348
|
+
# qr_state = self.qubits[: self.num_state_qubits]
|
349
|
+
# qr_target = [self.qubits[self.num_state_qubits]]
|
350
|
+
# qr_ancillas = self.qubits[self.num_state_qubits + 1 :]
|
351
|
+
|
352
|
+
# Apply polynomial approximation
|
353
|
+
self.append(poly_r.to_gate(), self.qubits)
|