Skip to content
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

Add Projector Obs to LGPU #894

Merged
merged 9 commits into from
Sep 10, 2024
3 changes: 3 additions & 0 deletions .github/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

### New features since last release

* Add `Projector` observable support via diagonalization to Lightning-GPU.
[(#894)](https://github.com/PennyLaneAI/pennylane-lightning/pull/894)

* Lightning-Kokkos migrated to the new device API.
[(#810)](https://github.com/PennyLaneAI/pennylane-lightning/pull/810)

Expand Down
1 change: 1 addition & 0 deletions doc/lightning_gpu/device.rst
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,7 @@ Supported operations and observables
~pennylane.PauliX
~pennylane.PauliY
~pennylane.PauliZ
~pennylane.Projector
~pennylane.Hermitian
~pennylane.Hamiltonian
~pennylane.SparseHamiltonian
Expand Down
2 changes: 1 addition & 1 deletion pennylane_lightning/core/_version.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,4 @@
Version number (major.minor.patch[-label])
"""

__version__ = "0.39.0-dev5"
__version__ = "0.39.0-dev6"
19 changes: 19 additions & 0 deletions pennylane_lightning/lightning_gpu/lightning_gpu.py
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,7 @@
"LinearCombination",
"Hermitian",
"Identity",
"Projector",
"Sum",
"Prod",
"SProd",
Expand Down Expand Up @@ -804,6 +805,15 @@
Returns:
Expectation value of the observable
"""
if isinstance(observable, qml.Projector):
diagonalizing_gates = observable.diagonalizing_gates()
if self.shots is None and diagonalizing_gates:
self.apply(diagonalizing_gates)
results = super().expval(observable, shot_range=shot_range, bin_size=bin_size)
if self.shots is None and diagonalizing_gates:
self.apply([qml.adjoint(g, lazy=False) for g in reversed(diagonalizing_gates)])
return results

if self.shots is not None:
# estimate the expectation value
samples = self.sample(observable, shot_range=shot_range, bin_size=bin_size)
Expand Down Expand Up @@ -887,6 +897,15 @@
Returns:
Variance of the observable
"""
if isinstance(observable, qml.Projector):
diagonalizing_gates = observable.diagonalizing_gates()
if self.shots is None and diagonalizing_gates:
self.apply(diagonalizing_gates)
results = super().var(observable, shot_range=shot_range, bin_size=bin_size)
if self.shots is None and diagonalizing_gates:
self.apply([qml.adjoint(g, lazy=False) for g in reversed(diagonalizing_gates)])
return results

Check warning on line 907 in pennylane_lightning/lightning_gpu/lightning_gpu.py

View check run for this annotation

Codecov / codecov/patch

pennylane_lightning/lightning_gpu/lightning_gpu.py#L901-L907

Added lines #L901 - L907 were not covered by tests

if self.shots is not None:
# estimate the var
# Lightning doesn't support sampling yet
Expand Down
Loading