-
Notifications
You must be signed in to change notification settings - Fork 2.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Oxidize parameter calculation for OneQubitEulerDecomposer #9185
Conversation
Thank you for opening a new pull request. Before your PR can be merged it will first need to pass continuous integration tests and be reviewed. Sometimes the review process can be slow, so please be patient. While you're waiting, please feel free to review other open PRs. While only a subset of people are authorized to approve pull requests for merging, everyone is encouraged to review open pull requests. Doing reviews helps reduce the burden on the core team and helps make the project's code better for everyone. One or more of the the following people are requested to review this:
|
This commit ports the per basis parameter calculation from python to rust. In looking at the runtime performance regression caused by Qiskit#8917 the majority is just that we're doing more work synthesizing to more available basis to potentially produce better quality results. Profiling the transpiler pass shows we're spending a non-trivial amount of time in numpy/scipy (depending on whether it's before or after Qiskit#9179) computing the determinant of the unitary. This is likely because those determinant functions are designed to work with an arbitrarily large square matrix while for the 1 qubit decomposer we're only ever working with a 2x2. To remove this overhead this commit writes a dedicated rust function to compute the determinant of a 2x2 complex matrix and then also adds dedicated functions to calculate the angles for given basis to rust as we can easily just return the end result from rust. Related Qiskit#8774
b5a1412
to
6dd8c22
Compare
Pull Request Test Coverage Report for Build 3603996058
💛 - Coveralls |
This commit adds a new option to the euler one qubit decomposer class, use_dag, which when set to True will return a DAGCircuit object for the decomposed matrix instead of a QuantumCircuit object. This is useful for transpiler passes that call the decomposer so that they don't have to convert from a circuit to a dag. The passes that use the decomposer are also updated to use this new option. This was originally attempted before in Qiskit#5926 but was abandoned because at the time there was no real performance improvement from doing this. However, since then this class has changed quite a bit, and after Qiskit#9185 the overhead of conversion between QuantumCircuit and DAGCircuit is a more critical component of the runtime performance of the 1 qubit optimization pass. By operating natively in DAGCircuit from the decomposer we're able to remove this overhead and directly substitute the output of the decomposer in the pass.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In principle this looks fine to me, and I'd be happy to merge as-is. Do you want a performance-related release note?
pub fn params_xzx(unitary: PyReadonlyArray2<Complex64>) -> [f64; 4] { | ||
let umat = unitary.as_array(); | ||
let det = det_one_qubit(umat); | ||
let phase = (Complex64::new(0., -1.) * det.ln()).re / 2.; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I checked, and both Rust's complex ln
and Numpy's log
take the same branch here (although in this case I don't think it would matter if they didn't, in practice).
I didn't bother for this because really all the gains I saw in practice with this were mitigating the regression from #8917 so I don't think anyone will notice come 0.23.0 |
This commit removes one layer of function calls for the OneQubitEulerDecomposer's staticmethods for calculating parameters. Previously, there was a python function which called an inner rust function, this eliminates one layer and attaches the rust function directly as a static method to the class definition.
This commit adds a new option to the euler one qubit decomposer class, use_dag, which when set to True will return a DAGCircuit object for the decomposed matrix instead of a QuantumCircuit object. This is useful for transpiler passes that call the decomposer so that they don't have to convert from a circuit to a dag. The passes that use the decomposer are also updated to use this new option. This was originally attempted before in Qiskit#5926 but was abandoned because at the time there was no real performance improvement from doing this. However, since then this class has changed quite a bit, and after Qiskit#9185 the overhead of conversion between QuantumCircuit and DAGCircuit is a more critical component of the runtime performance of the 1 qubit optimization pass. By operating natively in DAGCircuit from the decomposer we're able to remove this overhead and directly substitute the output of the decomposer in the pass.
* Add DAGCircuit output option to OneQubitEulerDecomposer This commit adds a new option to the euler one qubit decomposer class, use_dag, which when set to True will return a DAGCircuit object for the decomposed matrix instead of a QuantumCircuit object. This is useful for transpiler passes that call the decomposer so that they don't have to convert from a circuit to a dag. The passes that use the decomposer are also updated to use this new option. This was originally attempted before in #5926 but was abandoned because at the time there was no real performance improvement from doing this. However, since then this class has changed quite a bit, and after #9185 the overhead of conversion between QuantumCircuit and DAGCircuit is a more critical component of the runtime performance of the 1 qubit optimization pass. By operating natively in DAGCircuit from the decomposer we're able to remove this overhead and directly substitute the output of the decomposer in the pass. * Use a dataclass for internal gate list and phase tracking This commit updates the internal psx circuit generator function to pass a dataclass with a field for the gates and phase instead of using 2 lists. This provides a cleaner interface for using a mutable reference between the different functions used to add gates to the circuit. * Directly combine op node lists in optimize_1q_commutation
* Oxidize parameter calculation for OneQubitEulerDecomposer This commit ports the per basis parameter calculation from python to rust. In looking at the runtime performance regression caused by Qiskit#8917 the majority is just that we're doing more work synthesizing to more available basis to potentially produce better quality results. Profiling the transpiler pass shows we're spending a non-trivial amount of time in numpy/scipy (depending on whether it's before or after Qiskit#9179) computing the determinant of the unitary. This is likely because those determinant functions are designed to work with an arbitrarily large square matrix while for the 1 qubit decomposer we're only ever working with a 2x2. To remove this overhead this commit writes a dedicated rust function to compute the determinant of a 2x2 complex matrix and then also adds dedicated functions to calculate the angles for given basis to rust as we can easily just return the end result from rust. Related Qiskit#8774 * Eliminate python function for staticmethod definition This commit removes one layer of function calls for the OneQubitEulerDecomposer's staticmethods for calculating parameters. Previously, there was a python function which called an inner rust function, this eliminates one layer and attaches the rust function directly as a static method to the class definition.
* Add DAGCircuit output option to OneQubitEulerDecomposer This commit adds a new option to the euler one qubit decomposer class, use_dag, which when set to True will return a DAGCircuit object for the decomposed matrix instead of a QuantumCircuit object. This is useful for transpiler passes that call the decomposer so that they don't have to convert from a circuit to a dag. The passes that use the decomposer are also updated to use this new option. This was originally attempted before in Qiskit#5926 but was abandoned because at the time there was no real performance improvement from doing this. However, since then this class has changed quite a bit, and after Qiskit#9185 the overhead of conversion between QuantumCircuit and DAGCircuit is a more critical component of the runtime performance of the 1 qubit optimization pass. By operating natively in DAGCircuit from the decomposer we're able to remove this overhead and directly substitute the output of the decomposer in the pass. * Use a dataclass for internal gate list and phase tracking This commit updates the internal psx circuit generator function to pass a dataclass with a field for the gates and phase instead of using 2 lists. This provides a cleaner interface for using a mutable reference between the different functions used to add gates to the circuit. * Directly combine op node lists in optimize_1q_commutation
This commit rewrites the internals of the Optimize1qGatesDecomposition transpiler pass to leverage more Rust. As the size of circuits are growing the amount of time the transpiler typically spends in Optimize1qGatesDecomposition grows linearly with the number of circuits. Since Qiskit#9185 (which converted the angle calculation in the synthesis routine to Rust) the time spent constructing intermediate DAGCircuit objects for each possible decomposition has been dominating the total runtime of the pass. To attempt to alleviate this bottleneck this commit mvoes as much of the circuit construction to rust as possible. The one qubit euler decomposition is now done in Rust and a sequence of gate names along with their corresponding angles are returned to the pass with the lowest error rate is returned. The pass will then convert that sequence into a DAGCircuit object if the decomposition will be substituted into the output dag. This has the advantage of both speeding up the computation of the output circuit and also deferring the creation of DAGCircuit and Gate objects until they're actually needed.
* Oxidize the internals of Optimize1qGatesDecomposition This commit rewrites the internals of the Optimize1qGatesDecomposition transpiler pass to leverage more Rust. As the size of circuits are growing the amount of time the transpiler typically spends in Optimize1qGatesDecomposition grows linearly with the number of circuits. Since #9185 (which converted the angle calculation in the synthesis routine to Rust) the time spent constructing intermediate DAGCircuit objects for each possible decomposition has been dominating the total runtime of the pass. To attempt to alleviate this bottleneck this commit mvoes as much of the circuit construction to rust as possible. The one qubit euler decomposition is now done in Rust and a sequence of gate names along with their corresponding angles are returned to the pass with the lowest error rate is returned. The pass will then convert that sequence into a DAGCircuit object if the decomposition will be substituted into the output dag. This has the advantage of both speeding up the computation of the output circuit and also deferring the creation of DAGCircuit and Gate objects until they're actually needed. * Move all error calculation to rust This commit makes 2 changes to the split between python and rust in the transpiler pass code. First the error mapping is converted to a rust native pyclass that increases the efficiency of getting the error rates for gates into the rust side. The second is any intermediate error scoring is done in rust. This is primarily to simplify the code as we're already doing the calculation with the new class in Rust. * Remove parallel iteration over multiple target basis This commit removes the usage of rayon for parallel iteration over the multiple target basis. In local benchmarking the overhead of using rayon to spawn a threadpool and divide the work over multiple threads hurts performance. The execution of the decomposition is sufficiently fast that iterating serially will be faster than spawning the threadpool for basis from current backends. So it's better to just remove the overhead. We can revisit parallelism in the future if it makes sense * Fix small oversights in internal pass usage This commit fixes the majority (if not all) the test failures that occured in earlier test failures. The primary cause of the failures were places that were calling private functions of the Optimize1qGatesDecomposition pass internally and not accounting for the new return types from some of those methods. This has been updated to handle these edge cases correctly now. Additionally, there was a small oversight in the porting of the numerics for the psx basis circuit generator function which was causing incorrect decompositions in some cases that has been fixed (the missing abs() call was added). * Add release note * Simplify logic to construct error map Co-authored-by: John Lapeyre <[email protected]> * Update comments, docstrings, and variable names in optimize_1q_decomposition * Make constant list of valid bases more local * Remove clippy unwrap suppression and use match syntax * Update releasenotes/notes/speedup-one-qubit-optimize-pass-483429af948a415e.yaml Co-authored-by: Jake Lishman <[email protected]> * Use to_object() instead of clone().into_py() * Remove out of date comment * Use FnOnce for X type in circuit_psx_gen * Add rem_euclid comment * Fix u3/u321 condition in _possible_decomposers --------- Co-authored-by: John Lapeyre <[email protected]> Co-authored-by: Jake Lishman <[email protected]> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
The python version of the OneQubitEulerDecomposer class had atol clamping on it's output from mod_2pi, when this function was ported to rust this was not included. At the time it was because nothing set the atol parameter when calling mod_2pi (the angle calculation in Qiskit#9185 did not have atol and the expansion to construct circuits for Optimize1qGatesDecomposition always used the default value). However, now that we're expanding OneQubitEulerDecomposer to internally do all the calculations in rust we need to support an adjustable atol which includes the missing endpoint clamping in mod_2pi. This commit adds this missing functionality to the function.
…ser` (#9583) * Leverage Rust circuit sequence construction for OneQubitEulerDecomposer This commit is a follow-up to #9578 which added a rust implementation of the second half of the single qubit euler decomposition routines and leveraged them for the Optimize1qGatesDecomposition transpiler pass. With that PR the Optimize1qGatesDecomposition no longer was dependent on the OneQubitEulerDecomposer class. This commit continues from that PR and updates the OneQubitEulerDecomposer to leverage the same Rust implementation internally. Calling a decomposer object will internally call the rust function to generate a circuit sequence and then return either a QuantumCircuit or DAGCircuit (depending on the options). Similarly all the angle computation is done directly in Rust. * Add missing atol clamping to mod_2pi The python version of the OneQubitEulerDecomposer class had atol clamping on it's output from mod_2pi, when this function was ported to rust this was not included. At the time it was because nothing set the atol parameter when calling mod_2pi (the angle calculation in #9185 did not have atol and the expansion to construct circuits for Optimize1qGatesDecomposition always used the default value). However, now that we're expanding OneQubitEulerDecomposer to internally do all the calculations in rust we need to support an adjustable atol which includes the missing endpoint clamping in mod_2pi. This commit adds this missing functionality to the function. * Add docstring to mod_2pi rust function * Remove mod_2pi python function
commit 43a9dce Author: Eric Arellano <[email protected]> Date: Tue Mar 28 15:27:07 2023 -0600 Apply new deprecation decorators to algorithms folder (Qiskit#9864) * Apply new deprecation decorators to algorithms folder * Fix docstring starting on first line * Fix test due to positional args not triggering warning * Improve test further commit 67eaa4b Author: a-matsuo <[email protected]> Date: Wed Mar 29 04:50:41 2023 +0900 Rearrange the gradient result based on the order of the input parameters (Qiskit#9503) * finite diff and spsa estimator gradient * for param shift, lin_comb, and reverse gradients * reverse estimator gradient * implemented the new feature * fix lint * fix test * fix and add reno * fix * fix style commit 7e09125 Author: Eric Arellano <[email protected]> Date: Tue Mar 28 08:33:08 2023 -0600 Add `@deprecate_func` and `@deprecate_arg` decorators (Qiskit#9676) * Add `@deprecate_func` and `@deprecate_arg` decorators * Update the release note * Apply suggestions from code review Co-authored-by: Luciano Bello <[email protected]> * lint * Use PyPI package_name rather than loose English --------- Co-authored-by: Luciano Bello <[email protected]> commit 90b2439 Author: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue Mar 28 07:44:45 2023 -0400 Bump indexmap from 1.9.2 to 1.9.3 (Qiskit#9858) Bumps [indexmap](https://github.com/bluss/indexmap) from 1.9.2 to 1.9.3. - [Release notes](https://github.com/bluss/indexmap/releases) - [Changelog](https://github.com/bluss/indexmap/blob/master/RELEASES.md) - [Commits](indexmap-rs/indexmap@1.9.2...1.9.3) --- updated-dependencies: - dependency-name: indexmap dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> commit be8eeff Author: Evgenii Zheltonozhskii <[email protected]> Date: Tue Mar 28 12:59:41 2023 +0300 Fix mypy errors (circuit) (Qiskit#8267) * Fix circuit mypy errors * Fix 2 * Remove ignores * Remove ignores for sure * Remove TODO * fix for docs * Add annotation * Fix control bug, remove unnecessary annotation * Add test and fix description * Fix test * Reformat * Fix test description * Update releasenotes/notes/fix-control-with-string-parameter-4eb8a308170e08db.yaml Co-authored-by: Julien Gacon <[email protected]> * More minor fixes * Fix callable import * Fix Instruction import for sphinx * Replace list[Any] with list --------- Co-authored-by: Julien Gacon <[email protected]> commit 3118683 Author: Elena Peña Tapia <[email protected]> Date: Tue Mar 28 11:51:20 2023 +0200 Fix examples (Qiskit#9860) commit a36416b Author: Elena Peña Tapia <[email protected]> Date: Tue Mar 28 10:27:43 2023 +0200 Remove factorizers and linear solvers from `algorithms` (Qiskit#9832) * Remove factorizers and linear solvers * Add reno * Remove shor from backend tests * Fix reno * Apply suggestions from code review Co-authored-by: Steve Wood <[email protected]> * Apply review reno --------- Co-authored-by: Steve Wood <[email protected]> commit aacbc66 Author: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon Mar 27 19:13:15 2023 +0000 Bump pyo3 from 0.18.1 to 0.18.2 (Qiskit#9854) Bumps [pyo3](https://github.com/pyo3/pyo3) from 0.18.1 to 0.18.2. - [Release notes](https://github.com/pyo3/pyo3/releases) - [Changelog](https://github.com/PyO3/pyo3/blob/main/CHANGELOG.md) - [Commits](PyO3/pyo3@v0.18.1...v0.18.2) --- updated-dependencies: - dependency-name: pyo3 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> commit abfb53e Author: Jake Lishman <[email protected]> Date: Mon Mar 27 15:06:28 2023 +0100 Ensure up-to-date `pip`, `setuptools` and `wheel` in CI (Qiskit#9850) Up-to-date Python packages should not require this step, however there are several packages, especially those that are optional for Terra functionality, that do not yet contain `pyproject.toml` files when building them from source. In these cases, `pip` will begin erroring out from version 23.1 if `wheel` is not installed. This commit proactively ensures that the minimum build dependencies for legacy Python packages is prepared and up-to-date before attempting installations; this includes ensuring that these are updated _inside_ any created venvs as well as outside them. commit 03473bd Author: Elena Peña Tapia <[email protected]> Date: Mon Mar 27 12:23:12 2023 +0200 pin symengine to `<0.10.0` (Qiskit#9857) * pin symengine * Avoid specific version commit a1a67a1 Author: Matthew Treinish <[email protected]> Date: Fri Mar 24 14:34:53 2023 -0400 Add support to CouplingMap for disjoint qubits (Qiskit#9710) * Add support to CouplingMap for disjoint qubits Previously the CouplingMap class only supported graphs which were fully connected. This prevented us from modeling potential hardware which didn't have a path between all qubits. This isn't an inherent limitation of the underlying graph data structure but was a limitation put on the CouplingMap class because several pieces of the transpiler assume a path always exists between 2 qubits (mainly in layout and routing). This commit removes this limitation and also adds a method to get a subgraph CouplingMap for all the components of the CouplingMap. This enables us to model these devices with a CouplingMap, which is the first step towards supporting these devices in the transpiler. One limitation with this PR is most fo the layout and routing algorithms do not support disjoint connectivity. The primary exception being TrivialLayout (although the output might be invalid) VF2Layout and VF2PostLayout which inherently support this already. This commit lays the groundwork to fix this limitation in a follow-up PR but for the time being it just raises an error in those passes if a disconnected CouplingMap is being used. The intent here is to follow up to this commit soon for adding support for SabreLayout, SabreSwap, DenseLayout, and StochasticSwap to leverage the method get_component_subgraphs added here to make them usable on such coupling maps. * Remove coupling map connected check from NoiseAdaptiveLayout Noise adaptive layout doesn't use a CouplingMap so we can't check for a disconnected coupling map in it. * Change DenseLayout guard to only prevent running when it won't work * Rename get_component_subgraphs to components and cache result This commit renames the get_component_subgraphs() method to components() which is much more consise name. At the same time this adds caching to the return just in case building the component subgraphs is expensive to compute we only need to ever do it once. * Drop caching of connected components * Fix check for dense layout to do a valid comparison * Ensure self loops in CouplingMap.distance() return 0 In a previous commit the distance() method was updated to handle disjoint graphs correctly. Prior to this PR it was expected to raise when a path didn't exist between 2 qubits by nature of the distance matrix construction failing if there was a disconnected coupling map. Since that isn't the case after this PR the error condition was changed to check explicitly that there is no path available and then error. However, there was an issue in this case and self loops would incorrectly error as well when instead they should return 0. This commit updates the error check to ignore self loops so they return correctly. * Fix lint * Update CouplingMap.components() docstring Co-authored-by: Kevin Krsulich <[email protected]> * Expand test coverage * Remove unused option for strongly connected components * Expand docstring to explain return list order * Use infinity for disconnected nodes in distance matrix * Update releasenotes/notes/add-cmap-componets-7ed56cdf294150f1.yaml * Rename CouplingMap.components to connected_components() THis commit renames the CouplingMap.components() method to connected_components(). It also adds an example to the docstring to better explain what a connected component is. * Fix typo in relaese note * Update method name in release note * Restore previous reduce() behavior The current reduce() error behavior of raising on trying to reduce to a disconnected coupling map is being depended on in other locations. To avoid a potentially breaking change this commit reverts the removal of that limitation in the method. We can look at doing that in the future independently of this PR because removing this specific restriction on the reduce() method is not 100% tied to generally allowing disconnected coupling map objects. * Add missing import --------- Co-authored-by: Kevin Krsulich <[email protected]> commit 0bd4cfd Author: Matthew Treinish <[email protected]> Date: Fri Mar 24 10:48:21 2023 -0400 Add option to skip deepcopy on dag_to_circuit (Qiskit#9825) * Add option to skip deepcopy on dag_to_circuit This commit adds a new option, copy_operations, which allows to disable the deepcopy on dag_to_circuit(). Previously the dag to circuit converter would always deep copy the operations, however in the transpiler we don't need this extra overhead because the DAGCircuits are temporary internal artifacts and will not be resused outside of the transpiler. So we can avoid the copy overhead in these situations, however in general the converter needs to default to copying. This new argument enables this workflow by keeping the current behavior by default but enabling the transpiler to skip copying operations in the output conversion. * Fix docs typo * Fix docs typo again * Use copy_operations=False in more locations commit dfcfa4a Author: Jake Lishman <[email protected]> Date: Fri Mar 24 13:16:58 2023 +0000 Remove dependency on sphinx-autodoc-typehints (Qiskit#9705) * Remove dependency on sphinx-autodoc-typehints This replaces the whole usage of the separate package `sphinx-autodoc-typehints` with the built-in support from `autodoc`, available (with this combination of options) since Sphinx 5.0. This removes a docs dependency that has caused us significant problems before due to its instability, and the built-in handling in `autodoc` is much cleaner as well; rather than trying to textually modify the docstring, this version (correctly) mutates the parsed rST structure, which also naturally it 100% compatible with the Napoleon processing. * Maintain previous type-hint behaviour commit 4a63b17 Author: Jake Lishman <[email protected]> Date: Fri Mar 24 13:14:07 2023 +0000 Move OQ3 exporter tests to qasm3 module (Qiskit#9844) * Move OQ3 exporter tests to qasm3 module These previously lived in `test/python/circuit` just for historical reasons (the OQ2 exporter lives there because it's a method on `QuantumCircuit`). Since we have a dedicated `qasm3` module now, including in the test suite, it makes sense to move the file there. * Add missing __init__.py commit 9c8eb06 Author: Julien Gacon <[email protected]> Date: Fri Mar 24 08:46:38 2023 +0100 Improve ``Parameter`` handling in ``SparsePauliOp`` (Qiskit#9796) * add reno * Add assign_parameters and parameter in init * add SPO.parameters and remove utils * fix ParameterValueType typehint * Update qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py Co-authored-by: Ikko Hamamura <[email protected]> * remove trailing print * Elena's comments Co-authored-by: Elena Peña Tapia <[email protected]> * fix line length --------- Co-authored-by: Ikko Hamamura <[email protected]> Co-authored-by: Elena Peña Tapia <[email protected]> commit 7bb4af9 Author: Eric Arellano <[email protected]> Date: Thu Mar 23 09:24:43 2023 -0600 Remove tweedledum from requirements-dev.txt (Qiskit#9759) commit 5a19f8a Author: Jake Lishman <[email protected]> Date: Thu Mar 23 13:57:23 2023 +0000 Fix missing handling of no-synthesis case in `UnitarySynthesis` (Qiskit#9843) Since moving `Optimize1qDecomposition` down to the Rust level, some of its use in the default `UnitarySynthesis` plugin was allowing `None` to be passed to an internal function unchecked. This correctly returns the "could not synthesise" value when appropriate. commit 84a0fdd Author: Takashi Imamichi <[email protected]> Date: Thu Mar 23 10:37:34 2023 +0900 Performance improvement of `SparsePauliOp.to_matrix` (Qiskit#9620) * optimize SparsePauliOp.to_matrix * optimize dense * proper vectorize * update copyright year * small opt * update a comment commit 262cf08 Author: Jake Lishman <[email protected]> Date: Wed Mar 22 16:11:35 2023 +0000 Revert "Start deprecation of complex parameters in Qiskit Pulse (Qiskit#9735)" (Qiskit#9838) This reverts commit eb4c5cb. This is currently causing flaky CI on Windows, so is being temporarily reverted while a fix can be made. commit 789d588 Author: Steve Wood <[email protected]> Date: Wed Mar 22 09:28:19 2023 -0400 Update codeowners (Qiskit#9835) commit eb4c5cb Author: TsafrirA <[email protected]> Date: Tue Mar 21 03:10:59 2023 +0200 Start deprecation of complex parameters in Qiskit Pulse (Qiskit#9735) * Add warning and update tests * Release notes * Move warning to all Pulse objects. * Fix releasenote typo * Move warning to format_parameter_value commit 6cec912 Author: Matthew Treinish <[email protected]> Date: Mon Mar 20 13:26:41 2023 -0400 Fix non-complex dtypes in OneQubitEulerDecomposer methods (Qiskit#9828) * Fix non-complex dtypes in OneQubitEulerDecomposer methods This commit fixes a regression introduced in the rewrite of the internals of the OneQubitEulerDecomposer class to be in rust. Previously the angles() and angles_and_phase() methods of OneQubitEulerDecomposer would work with a non-complex dtype in the input, however because the rust component of the module is strictly typed to only work with a complex128 dtype passing the array to rust to compute the angles and phase of the unitary would fail. To address this limitation this commit casts the input matrix to be complex before passing it to the rust function. Fixes Qiskit#9827 * Cleanup release note * Update test/python/quantum_info/test_synthesis.py Co-authored-by: Jake Lishman <[email protected]> --------- Co-authored-by: Jake Lishman <[email protected]> commit 9500f42 Author: Etienne Wodey <[email protected]> Date: Mon Mar 20 15:30:55 2023 +0100 transpile: narrow the return type depending on the circuits argument (Qiskit#9799) * transpile: narrow the return type depending on the circuits argument * Fixup release note --------- Co-authored-by: Jake Lishman <[email protected]> commit 8ceb57d Author: Takashi Imamichi <[email protected]> Date: Mon Mar 20 22:38:07 2023 +0900 fix qasm with reset (Qiskit#9819) commit e2f6606 Author: Eric Arellano <[email protected]> Date: Fri Mar 17 11:36:27 2023 -0600 Consolidate `pip install` calls in CI (Qiskit#9757) * Remove unnecessary `pip install` in CI * Consolidate `pip install` calls in CI * Add back `-U` * Go back to editable install so Rust is in debug mode * Add RUST_DEBUG env var so we can avoid editable install * Remove SETUPTOOLS_ENABLE_FEATURES and also Aer from lint job * See if editable install fixes Pylint * Give up on not using editable installs in CI I don't know why they're causing issues with loading the Rust extension. But it's not a priority to figure that out. This PR is still some forward progress. commit 2afcebc Author: Eric Arellano <[email protected]> Date: Fri Mar 17 11:34:25 2023 -0600 Fix Tox installing Terra from PyPI (Qiskit#9758) * Fix Tox installing Terra from PyPI * Don't use editable mode commit b00a8de Author: Matthew Treinish <[email protected]> Date: Thu Mar 16 18:32:14 2023 -0400 Stop using mergify merge queue feature (Qiskit#9807) Due to recent changes in the mergify configuration/service the merge queue feature of mergify is no longer working as expected. It's not clear if this just a temporary bug in mergify, a longer term change in behavior (which requires all PR authors to be registered on mergify), or some incompatibility between the github api and mergify. However, because we're no longer able to rely on it we've moved to using github's native merge queue feature [1][2] instead. Since this new merge queue would conflict with mergify's this commit removes the merge queue configuration from the mergify configuration. The configuration for stable backporting is left in place because github doesn't natively offer that feature and it appears to still work fine. [1] https://github.blog/changelog/2023-02-08-pull-request-merge-queue-public-beta/ [2] https://docs.github.com/en/repositories/configuring-branches-and-merges-in-your-repository/configuring-pull-request-merges/managing-a-merge-queue commit 07ca200 Author: Julien Gacon <[email protected]> Date: Thu Mar 16 20:20:04 2023 +0100 Clip probabilities in ``QuantumState`` (Qiskit#9762) * Clip probabilities * clip implictly * add reno * add tests * add renormalization * use sum, not norm * ensure round still works * normalizing seems to re-introduce errors * Tighten floating-point tests In cases of rounding and clipping, it's important that the floating-point output is bit-for-bit correct, so the fuzzy tests weren't ideal (some of these were strict, but it was inconsistent). It's better to use `assertEqual` rather than `assertTrue` where possible so we get better errors on failure. --------- Co-authored-by: Jake Lishman <[email protected]> commit 5a9d041 Author: Jake Lishman <[email protected]> Date: Thu Mar 16 18:50:07 2023 +0000 Remove useless `into_iter()` on `Range` (Qiskit#9806) Clippy has started complaining about this on the stable branch, and it's probably correct to do so. commit bbd023b Author: Matthew Treinish <[email protected]> Date: Thu Mar 16 14:44:44 2023 -0400 Leverage Rust circuit sequence construction for `OneQubitEulerDecomposer` (Qiskit#9583) * Leverage Rust circuit sequence construction for OneQubitEulerDecomposer This commit is a follow-up to Qiskit#9578 which added a rust implementation of the second half of the single qubit euler decomposition routines and leveraged them for the Optimize1qGatesDecomposition transpiler pass. With that PR the Optimize1qGatesDecomposition no longer was dependent on the OneQubitEulerDecomposer class. This commit continues from that PR and updates the OneQubitEulerDecomposer to leverage the same Rust implementation internally. Calling a decomposer object will internally call the rust function to generate a circuit sequence and then return either a QuantumCircuit or DAGCircuit (depending on the options). Similarly all the angle computation is done directly in Rust. * Add missing atol clamping to mod_2pi The python version of the OneQubitEulerDecomposer class had atol clamping on it's output from mod_2pi, when this function was ported to rust this was not included. At the time it was because nothing set the atol parameter when calling mod_2pi (the angle calculation in Qiskit#9185 did not have atol and the expansion to construct circuits for Optimize1qGatesDecomposition always used the default value). However, now that we're expanding OneQubitEulerDecomposer to internally do all the calculations in rust we need to support an adjustable atol which includes the missing endpoint clamping in mod_2pi. This commit adds this missing functionality to the function. * Add docstring to mod_2pi rust function * Remove mod_2pi python function commit 0d15506 Author: sg495 <[email protected]> Date: Thu Mar 16 18:40:33 2023 +0000 new parameters in `plot_bloch_multivector`: `figsize`, `font_size`, and `title_font_size` (Qiskit#7264) * Update state_visualization.py Closes Qiskit#7263 * Introduced font size, title font size and title padding to plot_bloch_multivector * Update state_visualization.py Documented new kwargs. * Fixed code formatting issues in previous commits of Qiskit#7264. * Update qiskit/visualization/bloch.py Co-authored-by: Luciano Bello <[email protected]> * Update qiskit/visualization/bloch.py Co-authored-by: Luciano Bello <[email protected]> * Update qiskit/visualization/state_visualization.py Co-authored-by: Luciano Bello <[email protected]> * Update qiskit/visualization/state_visualization.py Co-authored-by: Luciano Bello <[email protected]> * Create update-state-visualization-6836bd53e3a24891.yaml Added release notes. * Update test_graph_matplotlib_drawer.py Included a test for the new features. * fix test * blacking --------- Co-authored-by: Luciano Bello <[email protected]> commit a85456d Author: Jim Garrison <[email protected]> Date: Thu Mar 16 14:40:16 2023 -0400 Remove shared `black`/`lint/`lint-incr` `envdir` in `tox.ini` (Qiskit#9800) Under tox3, it was faster to have the `black`, `lint`, and `lint-incr` environments share an `envdir`. However, tox4 recreates the environment every time one switches from one to another when they share an `envdir`, leading to much slower execution. Here I've changed these environments to all use the default (unique) directory rather than a shared one. Closes Qiskit#9782 commit b047a7c Author: Matthew Treinish <[email protected]> Date: Thu Mar 16 17:29:12 2023 -0400 Attempt to trigger Azure pipelines on merge queue events (Qiskit#9809) * Attempt to trigger Azure pipelines on merge queue events This commit attempts to add a trigger condition to our azure pipelines job to trigger on commits to the gh merge queue branch. * Only trigger PR CI in queue, not push CI --------- Co-authored-by: Jake Lishman <[email protected]> commit b4bc559 Author: Luciano Bello <[email protected]> Date: Thu Mar 16 15:56:55 2023 +0100 Some doc formatting and link, mostly on quantumcircuit.py file (Qiskit#9771) * some doc formating and link, mostly on quantumcircuit.py file * Update qiskit/circuit/quantumcircuit.py Co-authored-by: Julien Gacon <[email protected]> * ident * more typos * more typos * another iteration * Bit and Register * notes on Register and Bit * Update qiskit/circuit/bit.py Co-authored-by: Eric Arellano <[email protected]> * Update qiskit/circuit/register.py Co-authored-by: Eric Arellano <[email protected]> --------- Co-authored-by: Julien Gacon <[email protected]> Co-authored-by: Eric Arellano <[email protected]> Co-authored-by: Jake Lishman <[email protected]> commit c37cec2 Author: Jim Garrison <[email protected]> Date: Thu Mar 16 00:26:01 2023 -0400 Remove implicit broadcasting from `Pauli`/label construction of `PauliList` (Qiskit#9779) * Remove implicit broadcasting from `Pauli`/label construction of `PauliList` * Update releasenotes/notes/paulilist-do-not-broadcast-from-paulis-96de3832fba21b94.yaml Co-authored-by: Jake Lishman <[email protected]> --------- Co-authored-by: Jake Lishman <[email protected]> Co-authored-by: Jake Lishman <[email protected]> commit b0b5541 Author: Eric Arellano <[email protected]> Date: Wed Mar 15 14:09:13 2023 -0600 `@deprecate_arguments` and `@deprecate_function` add deprecation to docstring (Qiskit#9790) commit fa4a136 Author: Alexander Ivrii <[email protected]> Date: Wed Mar 15 00:21:35 2023 +0200 Alternative construction mechanism for HLS config (Qiskit#9413) * Alternative construction mechanism for HLS config * improved how synthesis methods can be specified * fixes * pass over release notes * adding tests for short form * Updating the documentation of HLSConfig and HighLevelSynthesis * removing unnecessary import in documentation --------- Co-authored-by: Luciano Bello <[email protected]> commit 6bb4957 Author: Luciano Bello <[email protected]> Date: Tue Mar 14 21:41:02 2023 +0100 extend the documentation for qiskit.circuit.QuantumCircuit.measure (Qiskit#9698) * extend the documentation for qiskit.circuit.QuantumCircuit.measure * spelling * H * qregs and cregs * spelling * Update qiskit/circuit/quantumcircuit.py * Update qiskit/circuit/quantumcircuit.py * Update qiskit/circuit/quantumcircuit.py * Update qiskit/circuit/quantumcircuit.py * examples after Args/Return/Raises * Update qiskit/circuit/quantumcircuit.py Co-authored-by: Jake Lishman <[email protected]> * short description * better description * as equivalence * shorten it a bit * :: * raw string * lvert * Tweak grammar --------- Co-authored-by: Junye Huang <[email protected]> Co-authored-by: Jake Lishman <[email protected]> commit bf3bb96 Author: Matthew Treinish <[email protected]> Date: Tue Mar 14 10:18:45 2023 -0400 Fix basis_gates and coupling_map backend override in transpile() (Qiskit#9789) This commit fixes an issue in the transpile() function when a user specified the `backend` argument with a BackendV2 based backend along with `basis_gates` or `coupling_map`. In this case the `transpile()` was generating the preset pass manager with a target, coupling map, and basis gates list. However, most individual passes that take basis gates and a Target will prefer to use the target if both are specified. This is generally sane behavior at the pass level because the target contains more rich data and tighter constraints that a transpiler pass will need to worry about. To fix this limitation this commit updates transpile() to not use the backend's target if either basis_gates or coupling_map are specified. Longer term this should no longer be an issue when Qiskit#9256 is implemented and we'll be relying solely on a target internally. But this fix is needed until Qiskit#9256 is started. Fixes Qiskit#9781 Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit 648da26 Author: Jake Lishman <[email protected]> Date: Tue Mar 14 13:25:52 2023 +0000 Improve error messages in `Target`-based `GateDirection` pass (Qiskit#9787) * Improve error messages in `Target`-based `GateDirection` pass The `Target` version of `GateDirection` has more information available to make better error messages. It can distinguish cases where the failure is because a gate would be valid if flipped but the pass doesn't know how to do it, and the case where the gate wouldn't be valid in either direction. * Reword error message on failed flip --------- Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit 3005806 Author: Eric Arellano <[email protected]> Date: Mon Mar 13 13:30:26 2023 -0600 Add `add_deprecation_to_docstring` for docsite deprecation support (Qiskit#9685) * Add deprecations to function docstring * Work around issue with multiline strings * Better variable name * Jake's review feedback * Make Napoleon check case-insensitive * Promote add_deprecation_to_docstring to be public It may be useful for Applications/Ecosystem, when they want this functionality but want to keep using their own deprecation decorators * Properly error when metadata line is the first line * Tests feedback: don't use helper function and simplify instructions to generate tests * Don't use the function with @deprecate_function and @deprecate_arguments yet This makes the PR a smaller diff, so easier to review and also less risk when we land that it breaks something. Now, this PR only adds new functionality, the public `add_deprecation_to_docstring` function * Update qiskit/utils/deprecation.py Co-authored-by: Luciano Bello <[email protected]> * Update qiskit/utils/deprecation.py Co-authored-by: Luciano Bello <[email protected]> * Add release note --------- Co-authored-by: Luciano Bello <[email protected]> commit c2affb1 Author: Jake Lishman <[email protected]> Date: Mon Mar 13 16:38:36 2023 +0000 Fix explicitly calibrated gates in `GateDirection` (Qiskit#9786) If there is an explicit calibration given, this overrides the generic information from the `CouplingMap` or the `Target` for that particular instance, since one can use pulse-level control to define gates on a circuit-by-circuit basis that are not generically available in a way that can be specified in the coupling or target. commit 2ce129a Author: Naoki Kanazawa <[email protected]> Date: Mon Mar 13 22:08:35 2023 +0900 Fix unitary synthesis module to get proper error value when it's empty. (Qiskit#9774) Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit 6829bb1 Author: Kazuki Tsuoka <[email protected]> Date: Sun Mar 12 16:27:55 2023 +0900 Fix `Parameter.is_real()` (Qiskit#9664) * fix bug * add reno * Update releasenotes/notes/fix-parameter-is_real-8b8f99811e58075e.yaml --------- Co-authored-by: Julien Gacon <[email protected]> commit 5a62949 Author: Luciano Bello <[email protected]> Date: Fri Mar 10 23:40:07 2023 +0100 Qiskit gates not `qelib1.inc` are now defined when dumped (Qiskit#9777) * non-standard gates * Qiskit gates not qelib1.inc are now defined when dumped --------- Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit 5ce80ab Author: Daniel Puzzuoli <[email protected]> Date: Fri Mar 10 11:49:56 2023 -0800 Implementing CouplingMap.__eq__ (Qiskit#9766) * implementing Coupling.__eq__ * Update qiskit/transpiler/coupling.py Co-authored-by: Matthew Treinish <[email protected]> * adding comments to test, and adding release note * black formatting * updating CouplingMap.__eq__ to check edge list equality instead of isomorphism * updating release notes * updating test doc string * Update test/python/transpiler/test_coupling.py Co-authored-by: Matthew Treinish <[email protected]> * Update test/python/transpiler/test_coupling.py Co-authored-by: Matthew Treinish <[email protected]> * Update test/python/transpiler/test_coupling.py Co-authored-by: Matthew Treinish <[email protected]> * Update test/python/transpiler/test_coupling.py Co-authored-by: Matthew Treinish <[email protected]> --------- Co-authored-by: Matthew Treinish <[email protected]> commit 332f4b2 Author: Jake Lishman <[email protected]> Date: Fri Mar 10 08:31:36 2023 +0000 Fix zero-qubit `Pauli` label strings (Qiskit#9726) It was previously possible to construct a zero-qubit Pauli operator using the array form (`Pauli(([], []))`), or by empty-slicing an existing Pauli (`Pauli("IXZ")[[]]`). This commit completes the set by making labels with no qubits work as well, for consistency. Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit 3284ea0 Author: Eric Arellano <[email protected]> Date: Thu Mar 9 17:56:54 2023 -0600 Fix `tox -e docs` for macOS (Qiskit#9765) * Fix `tox -e docs` for macOS Co-authored-by: Jake Lishman <[email protected]> * Fix two issues. Duh, thanks Jake * Update Azure job to set RUST_DEBUG Not strictly necessary since Tox already sets it. But makes things consistent and avoids accidentally removing this in the future --------- Co-authored-by: Jake Lishman <[email protected]> commit d272919 Author: Matthew Treinish <[email protected]> Date: Thu Mar 9 18:11:05 2023 -0500 Suppress PulseSimulator deprecation warning in tests (Qiskit#9767) In the recently released qiskit-aer 0.12.0 the PulseSimulator backend (used as its name implies to simulate pulse schedules) was deprecated in favor of the actively maintained qiskit-dynamcis package. This deprecation is causing test failures when running our test suite with qiskit-aer installed because a single test was opportunistically using the PulseSimulator backend when aer was installed. This commit adds an assertion to catch the DeprecationWarning and adds a comment to rewrite the test to use dynamics. Although we may not wish to add the optional bidirectional dependency for a single test, in which case we should just delete the test. But that is a discussion for a follow up PR when CI is not blocked by an upstream package's release. This commit is just a short term workaround to unblock forward progress. commit fa7ac68 Author: Eric Arellano <[email protected]> Date: Wed Mar 8 12:05:55 2023 -0600 Don't require Tweedledum for `qiskit.circuit.classicalfunction` on import (Qiskit#9754) * Don't require Tweedledum for `qiskit.circuit.classicalfunction` on import * Review feedback commit 9d33618 Author: Jake Lishman <[email protected]> Date: Wed Mar 8 15:47:39 2023 +0000 Fix docs build on case-insensitive systems (Qiskit#9748) During the switchover of the `SymbolicPulse` classes in the pulse library, there are several objects documented under `qiskit.library.pulse` that differ only by capitalisation. Under `autosummary`, these therefore generate files with names that differ only by capitalisation, which causes naming clashes on systems that have case-insensitive semantics, such as macOS. This then causes warnings to be emitted from the Sphinx build, failing it. Autosummary has this setting that can be used as a workaround. I went this route rather than converting the documentation to use more inline documentation for the library for now, because I expect the clash to be more short-lived, and I didn't want to make a change that meaningful impacts the style of the documentation without knowing the full context around it. Co-authored-by: Eric Arellano <[email protected]> commit 16f6adb Author: Junye Huang <[email protected]> Date: Wed Mar 8 14:09:39 2023 +0100 Remove non-existent files from MANIFEST.in (Qiskit#9752) * remove qiskit/schemas * remove include cython files * remove include pickle files commit fe12c26 Author: Eric Arellano <[email protected]> Date: Tue Mar 7 18:44:38 2023 -0600 Tag Eric in Rust changes (Qiskit#9749) commit c6cd0d5 Author: Jake Lishman <[email protected]> Date: Tue Mar 7 23:12:39 2023 +0000 Add structure for multiple Rust crates (Qiskit#9742) * Add structure for multiplie Rust extension crates This is a precursor to adding an entirely separate and self-contained crate to handle parsing of OpenQASM 2 (not 3 - this is kind of like a trial run for that). It could conceivably still live within `qiskit._accelerate`, but having separate crates helps us enforce more sane API barriers, and has improvements in the incremental build time when working on only one of the Rust extensions. The intent after this commit is still to have `qiskit._accelerate` as an easy catch-all for accelerators for Python. Developers should not need to be concerned with defining a new crate for every new feature, and for the most part `_accelerate` is still logically interoperative within itself (for example, `NLayout` is used all over). This is just laying out the groundwork so more complex crate additions _can_ also be made. Some of the niceties to do with Cargo workspaces only became stabilised in Rust 1.64. In particular, inheritance from the workspace root for things like the package version, Rust version, and dependencies only came in then. For now, the `workspace.packages` key in the root `Cargo.toml` is ignored with a small warning during the build, but I've put it in place mostly to keep track of what we can change once the MSRV becomes 1.64 or greater (likely not til at least Terra 0.26). * Add README.md to crates/accelerate * Correct licence metadata commit 2553376 Author: Julien Gacon <[email protected]> Date: Tue Mar 7 13:15:22 2023 +0100 Fix bitstring padding in the `BackendSampler` (Qiskit#9744) * fix padding * add reno commit 5c49d14 Author: Etienne Wodey <[email protected]> Date: Mon Mar 6 20:25:02 2023 +0100 test/transpiler: add regression tests for Qiskit#9701 (Qiskit#9739) commit 80ca1f3 Author: Shelly Garion <[email protected]> Date: Mon Mar 6 19:23:14 2023 +0200 Add inverse method to ECRGate (Qiskit#9733) * add inverse method to ECRGate * add release notes * Fix sphinx tags * Recategorise as bugfix --------- Co-authored-by: Julien Gacon <[email protected]> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> Co-authored-by: Jake Lishman <[email protected]> commit 126c9ba Author: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon Mar 6 14:12:24 2023 +0000 Bump rayon from 1.6.1 to 1.7.0 (Qiskit#9737) Bumps [rayon](https://github.com/rayon-rs/rayon) from 1.6.1 to 1.7.0. - [Release notes](https://github.com/rayon-rs/rayon/releases) - [Changelog](https://github.com/rayon-rs/rayon/blob/master/RELEASES.md) - [Commits](rayon-rs/rayon@rayon-core-v1.6.1...rayon-core-v1.7.0) --- updated-dependencies: - dependency-name: rayon dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <[email protected]> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit 6d12cdd Author: Junye Huang <[email protected]> Date: Mon Mar 6 13:57:14 2023 +0100 Update slack invite link to https://qisk.it/join-slack (Qiskit#9736) commit b99ef32 Author: Jake Lishman <[email protected]> Date: Sun Mar 5 15:59:19 2023 +0000 Add docs team to tag list for docs configuation changes (Qiskit#9714) This adds the current docs team to the qiskit-bot configuration to get automatically tagged when changes to the `docs` folder are made. For the most part, this should just be about the documentation build itself, which is under their umbrella, rather than the text of the API docs which is largely generated from Terra's Python source code. Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com> commit dbdf867 Author: John Lapeyre <[email protected]> Date: Sat Mar 4 13:43:06 2023 -0500 Fix typo in docstring (Qiskit#9730)
* Oxidize the internals of Optimize1qGatesDecomposition This commit rewrites the internals of the Optimize1qGatesDecomposition transpiler pass to leverage more Rust. As the size of circuits are growing the amount of time the transpiler typically spends in Optimize1qGatesDecomposition grows linearly with the number of circuits. Since Qiskit#9185 (which converted the angle calculation in the synthesis routine to Rust) the time spent constructing intermediate DAGCircuit objects for each possible decomposition has been dominating the total runtime of the pass. To attempt to alleviate this bottleneck this commit mvoes as much of the circuit construction to rust as possible. The one qubit euler decomposition is now done in Rust and a sequence of gate names along with their corresponding angles are returned to the pass with the lowest error rate is returned. The pass will then convert that sequence into a DAGCircuit object if the decomposition will be substituted into the output dag. This has the advantage of both speeding up the computation of the output circuit and also deferring the creation of DAGCircuit and Gate objects until they're actually needed. * Move all error calculation to rust This commit makes 2 changes to the split between python and rust in the transpiler pass code. First the error mapping is converted to a rust native pyclass that increases the efficiency of getting the error rates for gates into the rust side. The second is any intermediate error scoring is done in rust. This is primarily to simplify the code as we're already doing the calculation with the new class in Rust. * Remove parallel iteration over multiple target basis This commit removes the usage of rayon for parallel iteration over the multiple target basis. In local benchmarking the overhead of using rayon to spawn a threadpool and divide the work over multiple threads hurts performance. The execution of the decomposition is sufficiently fast that iterating serially will be faster than spawning the threadpool for basis from current backends. So it's better to just remove the overhead. We can revisit parallelism in the future if it makes sense * Fix small oversights in internal pass usage This commit fixes the majority (if not all) the test failures that occured in earlier test failures. The primary cause of the failures were places that were calling private functions of the Optimize1qGatesDecomposition pass internally and not accounting for the new return types from some of those methods. This has been updated to handle these edge cases correctly now. Additionally, there was a small oversight in the porting of the numerics for the psx basis circuit generator function which was causing incorrect decompositions in some cases that has been fixed (the missing abs() call was added). * Add release note * Simplify logic to construct error map Co-authored-by: John Lapeyre <[email protected]> * Update comments, docstrings, and variable names in optimize_1q_decomposition * Make constant list of valid bases more local * Remove clippy unwrap suppression and use match syntax * Update releasenotes/notes/speedup-one-qubit-optimize-pass-483429af948a415e.yaml Co-authored-by: Jake Lishman <[email protected]> * Use to_object() instead of clone().into_py() * Remove out of date comment * Use FnOnce for X type in circuit_psx_gen * Add rem_euclid comment * Fix u3/u321 condition in _possible_decomposers --------- Co-authored-by: John Lapeyre <[email protected]> Co-authored-by: Jake Lishman <[email protected]> Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
…ser` (Qiskit#9583) * Leverage Rust circuit sequence construction for OneQubitEulerDecomposer This commit is a follow-up to Qiskit#9578 which added a rust implementation of the second half of the single qubit euler decomposition routines and leveraged them for the Optimize1qGatesDecomposition transpiler pass. With that PR the Optimize1qGatesDecomposition no longer was dependent on the OneQubitEulerDecomposer class. This commit continues from that PR and updates the OneQubitEulerDecomposer to leverage the same Rust implementation internally. Calling a decomposer object will internally call the rust function to generate a circuit sequence and then return either a QuantumCircuit or DAGCircuit (depending on the options). Similarly all the angle computation is done directly in Rust. * Add missing atol clamping to mod_2pi The python version of the OneQubitEulerDecomposer class had atol clamping on it's output from mod_2pi, when this function was ported to rust this was not included. At the time it was because nothing set the atol parameter when calling mod_2pi (the angle calculation in Qiskit#9185 did not have atol and the expansion to construct circuits for Optimize1qGatesDecomposition always used the default value). However, now that we're expanding OneQubitEulerDecomposer to internally do all the calculations in rust we need to support an adjustable atol which includes the missing endpoint clamping in mod_2pi. This commit adds this missing functionality to the function. * Add docstring to mod_2pi rust function * Remove mod_2pi python function
Summary
This commit ports the per basis parameter calculation from python to rust. In looking at the runtime performance regression caused by #8917 the majority is just that we're doing more work synthesizing to more available basis to potentially produce better quality results. Profiling the transpiler pass shows we're spending a non-trivial amount of time in numpy/scipy (depending on whether it's before or after #9179) computing the determinant of the unitary. This is likely because those determinant functions are designed to work with an arbitrarily large square matrix while for the 1 qubit decomposer we're only ever working with a 2x2. To remove this overhead this commit writes a dedicated rust function to compute the determinant of a 2x2 complex matrix and then also adds dedicated functions to calculate the angles for given basis to rust as we can easily just return the end result from rust.
Details and comments
Related #8774