Change to expectation calculation to accept hamiltonian object
This commit is contained in:
@@ -1,9 +1,10 @@
|
||||
import numpy as np
|
||||
from qibo.backends import NumpyBackend
|
||||
from qibo.config import raise_error
|
||||
from qibo.result import QuantumState
|
||||
from qibotn.result import TensorNetworkResult
|
||||
|
||||
from qibotn.backends.abstract import QibotnBackend
|
||||
from qibo import hamiltonians
|
||||
|
||||
CUDA_TYPES = {}
|
||||
|
||||
@@ -28,15 +29,17 @@ class CuTensorNet(QibotnBackend, NumpyBackend): # pragma: no cover
|
||||
expectation_enabled_value = runcard.get("expectation_enabled")
|
||||
if expectation_enabled_value is True:
|
||||
self.expectation_enabled = True
|
||||
self.pauli_string_pattern = "XXXZ"
|
||||
self.observable = None
|
||||
elif expectation_enabled_value is False:
|
||||
self.expectation_enabled = False
|
||||
elif isinstance(expectation_enabled_value, dict):
|
||||
self.expectation_enabled = True
|
||||
expectation_enabled_dict = runcard.get("expectation_enabled", {})
|
||||
self.pauli_string_pattern = expectation_enabled_dict.get(
|
||||
"pauli_string_pattern", None
|
||||
)
|
||||
self.observable = runcard.get("expectation_enabled", {})
|
||||
elif isinstance(
|
||||
expectation_enabled_value, hamiltonians.SymbolicHamiltonian
|
||||
):
|
||||
self.expectation_enabled = True
|
||||
self.observable = expectation_enabled_value
|
||||
else:
|
||||
raise TypeError("expectation_enabled has an unexpected type")
|
||||
|
||||
@@ -158,17 +161,15 @@ class CuTensorNet(QibotnBackend, NumpyBackend): # pragma: no cover
|
||||
and self.NCCL_enabled == False
|
||||
and self.expectation_enabled == True
|
||||
):
|
||||
state = eval.expectation_pauli_tn(
|
||||
circuit, self.dtype, self.pauli_string_pattern
|
||||
)
|
||||
state = eval.expectation_tn(circuit, self.dtype, self.observable)
|
||||
elif (
|
||||
self.MPI_enabled == True
|
||||
and self.MPS_enabled == False
|
||||
and self.NCCL_enabled == False
|
||||
and self.expectation_enabled == True
|
||||
):
|
||||
state, rank = eval.expectation_pauli_tn_MPI(
|
||||
circuit, self.dtype, self.pauli_string_pattern, 32
|
||||
state, rank = eval.expectation_tn_MPI(
|
||||
circuit, self.dtype, self.observable, 32
|
||||
)
|
||||
if rank > 0:
|
||||
state = np.array(0)
|
||||
@@ -178,15 +179,27 @@ class CuTensorNet(QibotnBackend, NumpyBackend): # pragma: no cover
|
||||
and self.NCCL_enabled == True
|
||||
and self.expectation_enabled == True
|
||||
):
|
||||
state, rank = eval.expectation_pauli_tn_nccl(
|
||||
circuit, self.dtype, self.pauli_string_pattern, 32
|
||||
state, rank = eval.expectation_tn_nccl(
|
||||
circuit, self.dtype, self.observable, 32
|
||||
)
|
||||
if rank > 0:
|
||||
state = np.array(0)
|
||||
else:
|
||||
raise_error(NotImplementedError, "Compute type not supported.")
|
||||
|
||||
if return_array:
|
||||
return state.flatten()
|
||||
if self.expectation_enabled:
|
||||
return state.flatten().real
|
||||
else:
|
||||
return QuantumState(state.flatten())
|
||||
if return_array:
|
||||
statevector = state.flatten()
|
||||
else:
|
||||
statevector = state
|
||||
|
||||
return TensorNetworkResult(
|
||||
nqubits=circuit.nqubits,
|
||||
backend=self,
|
||||
measures=None,
|
||||
measured_probabilities=None,
|
||||
prob_type=None,
|
||||
statevector=statevector,
|
||||
)
|
||||
|
||||
Reference in New Issue
Block a user