Skip to content

Commit

Permalink
Add @aq.hybrid_job decorator implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
rmshaffer committed May 28, 2024
1 parent ecce2bc commit 9a3633a
Show file tree
Hide file tree
Showing 6 changed files with 713 additions and 2 deletions.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,8 @@ result = task.result()

Read more about AutoQASM decorators like `@aq.main` [here](doc/decorators.md).

Read more about using AutoQASM with Amazon Braket Hybrid Jobs [here](doc/hybrid_jobs.md).

For more example usage of AutoQASM, visit the [example notebooks](examples).

## Architecture
Expand Down
80 changes: 80 additions & 0 deletions doc/hybrid_jobs.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
# AutoQASM with Amazon Braket Hybrid Jobs

Amazon Braket Hybrid Jobs provides a solution for executing hybrid quantum-classical algorithms that utilize both classical computing resources and Quantum Processing Units (QPUs). This service efficiently manages allocating classical compute resources, executing your algorithm, and then freeing up those resources upon completion, ensuring cost-effectiveness by charging only for the resources used. It's perfectly suited for iterative algorithms that span lengthy durations and require the integration of classical and quantum computing.

## Using `AwsQuantumJob.create`

This [documentation page](https://docs.aws.amazon.com/braket/latest/developerguide/braket-jobs-first.html#braket-jobs-first-create) shows you how to create a hybrid job with `AwsQuantumJob.create`. To use a hybrid job with AutoQASM, simply use AutoQASM in your algorithm script. Because AutoQASM is currently not installed in the default job container, be sure to include the AutoQASM feature branch in the requirements.txt of your source module, or add AutoQASM as a dependency when you build your own container. Below is an example algorithm script to get you started.
```
import os
from braket.devices import LocalSimulator
from braket.circuits import Circuit
import autoqasm as aq
from autoqasm.instructions import measure, h, cnot
def start_here():
print("Test job started!")
# Use the device declared in the job script
device = LocalSimulator("autoqasm")
@aq.main
def bell():
h(0)
cnot(0, 1)
c = measure([0, 1])
for count in range(5):
task = device.run(bell, shots=100)
print(task.result().measurements)
print("Test job completed!")
```

Save this algorithm script as "algorithm_script.py" and run this code snippet below to create your first hybrid job with AutoQASM!
```
from braket.aws import AwsQuantumJob
job = AwsQuantumJob.create(
device="local:braket_simulator",
dependencies=["autoqasm"],
source_module="algorithm_script.py",
entry_point="algorithm_script:start_here",
wait_until_complete=True
)
```

## Using the `@aq.hybrid_job` decorator

Alternatively, you can use the `@aq.hybrid_job` decorator to create a hybrid job with AutoQASM. Because AutoQASM is currently not installed in the default job container, be sure to include AutoQASM in the `dependencies` keyword of the `@aq.hybrid_job` decorator, or add AutoQASM as a dependency when you build your own container.

One of the core mechanisms of AutoQASM is source code analysis. When calling an AutoQASM decorated function, the source code of the function is analyzed and converted into a transformed Python function by AutoGraph. The source code of a function defined inside the `@aq.hybrid_job` decorated function is then separately saved as input data to the job. When [AutoQASM decorators](decorators.md) wrap these functions, the source code is retrieved from the input data. Because of this, if you use an AutoQASM decorator to convert a function that is defined outside of the `@aq.hybrid_job` decorated function, it may not work properly. If your application requires AutoQASM decorated functions to be defined outside of the `@aq.hybrid_job` decorated function, we recommend that you use the option described in "Using `AwsQuantumJob.create`" to create the hybrid job.

Below is a working example to create an AutoQASM job with the `@aq.hybrid_job` decorator.
```
from braket.jobs import hybrid_job
from braket.devices import LocalSimulator
import autoqasm as aq
from autoqasm.instructions import measure, h, cnot
@aq.hybrid_job(
device="local:braket_simulator",
dependencies=["autoqasm"],
)
def bell_circuit_job():
@aq.main
def bell():
h(0)
cnot(0, 1)
c = measure([0, 1])
device = LocalSimulator("autoqasm")
for count in range(5):
task = device.run(bell, shots=100)
print(task.result().measurements)
bell_circuit_job()
```
8 changes: 6 additions & 2 deletions doc/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,12 @@ readme at https://github.com/amazon-braket/autoqasm/blob/main/README.md.
AutoQASM Decorators
*******************

For details on usage of AutoQASM decorators such as `@aq.main`, see
the decorators documentation at https://github.com/amazon-braket/autoqasm/blob/main/doc/decorators.md
For details on usage of AutoQASM decorators such as `@aq.main`, `@aq.subroutine`, `@aq.gate`,
and `@aq.gate_calibration`, see the decorators documentation at
https://github.com/amazon-braket/autoqasm/blob/main/doc/decorators.md.

For details on using AutoQASM with Amazon Braket Hybrid Jobs with the `@aq.hybrid_job` decorator,
see the documentation at https://github.com/amazon-braket/autoqasm/blob/main/doc/hybrid_jobs.md


********
Expand Down
1 change: 1 addition & 0 deletions src/autoqasm/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ def my_program():
"""
from . import errors, instructions, operators # noqa: F401
from .api import gate, gate_calibration, main, subroutine # noqa: F401
from .hybrid_job import hybrid_job # noqa: F401
from .instructions import QubitIdentifierType as Qubit # noqa: F401
from .program import Program, build_program, verbatim # noqa: F401
from .transpiler import transpiler # noqa: F401
Expand Down
Loading

0 comments on commit 9a3633a

Please sign in to comment.