-
Notifications
You must be signed in to change notification settings - Fork 67
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
Support CUDA-Q kernels for CircuitToEinsum #141
Comments
@zohim ***@***.***> When is the upcoming demo and what is it for?
For the cuQuantum team: how does the conversation work, i.e. when you get a circuit object, what do you do with it?
From: Zohim Chandani ***@***.***>
Sent: Saturday, 15 June 2024 16:09
To: NVIDIA/cuQuantum ***@***.***>
Cc: Bettina Heim ***@***.***>; Mention ***@***.***>
Subject: [NVIDIA/cuQuantum] Support CUDA-Q kernels for CircuitToEinsum (Issue #141)
For an upcoming demo, we need cuQuantum to accept CUDA-Q circuits into the CircuitToEinsum function here<https://docs.nvidia.com/cuda/cuquantum/latest/python/api/generated/cuquantum.CircuitToEinsum.html?highlight=circuittoeinsum#:~:text=The%20supported%20circuit%20types%20include%20cirq.Circuit%20and%20qiskit.QuantumCircuit.%20The%20input%20circuit%20must%20be%20fully%20parameterized%20and%20can%20not%20contain%20operations%20that%20are%20not%20well-defined%20in%20tensor%20network%20simulation%2C%20for%20instance%2C%20resetting%20the%20quantum%20state%20or%20performing%20any%20intermediate%20measurement.>.
Here is an example of how to do this in Qiskit:
from cuquantum import cutensornet as cutn
from cuquantum import contract, CircuitToEinsum
import torch
from qiskit.circuit import QuantumCircuit, Parameter
num_qubits = 1
measurement_ops = 'Z'
light_cone = True
# Define the quantum circuit with one qubit and two parameters
theta = Parameter('θ')
phi = Parameter('φ')
circuit = QuantumCircuit(num_qubits)
circuit.rx(theta, 0)
circuit.ry(phi, 0)
parameters = [1,2]
circuit = circuit.bind_parameters({theta: parameters[0], phi: parameters[1]})
converter = CircuitToEinsum(circuit, backend='torch')
einsum_expression, tensor_operands = converter.expectation(measurement_ops, light_cone)
Note that you have to provide a bound circuit (circuit with values supplied for the variational gates).
It would be nice if we could support CircuitToEinsum to take in variational circuits that are unbound but I'm guessing that the einsum expression will look different for different parameter values and hence this is not feasible?
In CUDA-Q, the corresponding code looks like this:
import cudaq
from typing import List
cudaq.set_target("nvidia")
@cudaq.kernel
def kernel(angles: List[float]):
qubit = cudaq.qubit()
rx(angles[0], qubit)
ry(angles[1], qubit)
hamiltonian = cudaq.spin.z(0)
parameters = [1, 2]
expectation_value = cudaq.observe(kernel, hamiltonian, parameters).expectation()
Note how the binding of the parameters happens in the observe call. How do we deal with this? @1tnguyen<https://github.com/1tnguyen> @bettinaheim<https://github.com/bettinaheim>
—
Reply to this email directly, view it on GitHub<#141>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AIFGON4JTEEFEXYLCQ6QK2TZHRDJLAVCNFSM6AAAAABJLXFCLCVHI2DSMVQWIX3LMV43ASLTON2WKOZSGM2TIOBYGIZDGMQ>.
You are receiving this because you were mentioned.Message ID: ***@***.******@***.***>>
|
Demo is scheduled for 15th August, we need to give this feature to our collaborators so that they can implement the workflow ahead of this. Thanks team. |
@bettinaheim @zohimchandani In circuitToEinsum we go over a circuit object and extract a sequence of gates with their matrix representations and qubits that act on. We tried to add cudaq but seems there is not explicit python API to get the matrices. Even we can not directly get the gate names and it is required to parse strings from kernel.to_qir(). Is it possible to add this functionality to get the matrix for each gate? |
@bettinaheim pinging as a reminder, thanks. |
For an upcoming demo, we need cuQuantum to accept CUDA-Q circuits into the CircuitToEinsum function here.
Here is an example of how to do this in Qiskit:
Note that you have to provide a bound circuit (circuit with values supplied for the variational gates).
It would be nice if we could support
CircuitToEinsum
to take in variational circuits that are unbound but I'm guessing that the einsum expression will look different for different parameter values and hence this is not feasible?In CUDA-Q, the corresponding code looks like this:
Note how the binding of the parameters happens in the
observe
call. How do we deal with this? @1tnguyen @bettinaheimThe text was updated successfully, but these errors were encountered: