-
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
Fix SparsePauliOp
initialization with dense Y
labels
#13580
base: main
Are you sure you want to change the base?
Conversation
Pull Request Test Coverage Report for Build 12581628855Details
💛 - Coveralls |
Hi @trigpolynom - thanks for fixing this bug! |
Hi @ShellyGarion and @Cryoris thanks for taking a look at this! I'll make the updates and requested changes tonight EST. |
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 following people are relevant to this code:
|
test/python/quantum_info/operators/symplectic/test_sparse_pauli_op.py
Outdated
Show resolved
Hide resolved
releasenotes/notes/sparse-pauli-op-heavy-weight-fix-aa822428643d642a.yaml
Outdated
Show resolved
Hide resolved
SparsePauliOp
initialization with dense Y
labels
test/python/quantum_info/operators/symplectic/test_sparse_pauli_op.py
Outdated
Show resolved
Hide resolved
there are some formatting issues. other than that, I think this PR is ready to go! |
Summary
Fixes #13522
"When a SparsePauliOp object is instantiated with a long string of Y's (greater than 100), the imaginary component of the coefficients is non-zero (but trivially small, ~1e-15). This results in errors when submitting jobs using qiskit-ibm-runtime which throws an error when using the SparsePauliOp as the expectation value to estimate."
The fix to the above problem involved using modular arithmetic to calculate coeffs for the SparsePauliOp when coeffs is None. This avoids the floating point error that occurs for instantiating heavy-weight SparsePauliOps.
Details and comments
Added a test method
test_sparse_pauli_op_init_long_ys
to ensure that the error causing PauliList ('Y"*100) results with the same coeffs as PauliList ("Y"*99)