Hello World

Hello World

This guite is the deep dive into the Qubernetes project. The q8s toolchain is designed to simplify the deployment and execution of quantum jobs. It provides a optimised interface for handling the jobs, allowing you to focus on building quantum software rather than managing the infrastructure.

This guide will show you how to run a simple qiskit circuit in a Qubernetes cluster using the GPU infrastructure.

Create a new program

program.py
from qiskit import QuantumCircuit, transpile
from qiskit_aer import Aer, AerSimulator
 
def demo_function(shotsAmount=1000):
    simulator = AerSimulator(method='statevector', device='GPU')
 
    circuit = QuantumCircuit(2, 2)
    circuit.h(0)
    circuit.cx(0, 1)
    circuit.measure([0, 1], [0, 1])
 
    compiled_circuit = transpile(circuit, simulator)
    job = simulator.run(compiled_circuit, shots=shotsAmount)
    result = job.result()
    counts = result.get_counts()
 
    print("Total count for 00 and 11 are:", counts)
    print(circuit)
    return counts
 
result = demo_function(4000)

store the dependencies in a requirements.txt file

requirements.txt
qiskit==1.0.0
qiskit-aer-gpu==0.13.3

Create the container image

Dockerfile
FROM vstirbu/q8s-cuda12
 
COPY requirements.txt /requirements.txt
RUN pip install -r requirements.txt
 
COPY program.py /program.py
 
CMD ["python", "/program.py"]

Build and publish the container

docker build -t registry.example.com/user/program:v1.2.3 .
docker push registry.example.com/user/program:v1.2.3

Create a new job

The job specification needs to explicitly request the needed computational resources. The following example shows how to request one slot on an Nvidia GPU for a quantum computation task.

job.yaml
apiVersion: batch/v1
kind: Job
metadata:
  name: quantum-job
spec:
  template:
    metadata:
      name: quantum-job
    spec:
      containers:
      - name: quantum-task
        image: registry.example.com/user/program:v1.2.3
        resources:
          limits:
            nvidia.com/gpu: 1
      restartPolicy: Never
      runtimeClassName: nvidia

Run the job

kubectl apply -f job.yaml

Retrieve the results

kubectl logs quantum-job