-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add basic routine visualization and update README (#4)
* Implement rendering to graphviz DAG * Minor style fixes * Add script for rendering serialized diagram * Rename: hqar.experimental.visualization -> hqar.experimental.rendering * Add flake8-copyright to pre-commit hooks * Move loading of valid test programs to fixture * Fix typo * Add tests for rendering * Add graphviz to dependencies * Add GH action step with graphviz setup * Make mypy ignore graphviz errors * Add good-enough initial README * Expand README * Explain hierarchy and DAG in README * Remove unnecessary comment * List visualization tool as one of features * Reword tricky -> hacky --------- Co-authored-by: Konrad Jałowiecki <kjalowiecki@psiquantum.com>
- Loading branch information
Showing
20 changed files
with
694 additions
and
125 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -20,4 +20,4 @@ repos: | |
rev: 6.0.0 | ||
hooks: | ||
- id: flake8 | ||
|
||
additional_dependencies: [flake8-copyright] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,141 @@ | ||
# hqar | ||
Hierarchical Quantum Algorithms Representation | ||
# HQAR | ||
Hierarchical Quantum Algorithms Representation is an open format for representing | ||
quantum algorithms, optimized for usage in quantum resource estimation (QRE). | ||
|
||
HQAR comprises: | ||
|
||
- Definition of data format, formalized as a JSON schema. | ||
- A Python library for validation of quantum programs written in HQAR format using [Pydantic](https://docs.pydantic.dev/). | ||
- Rudimentary visualization tool `hqar-render`. | ||
|
||
## Installation | ||
|
||
Using HQAR data format does not require installation - you can easily write quantum | ||
programs in YAML or JSON. | ||
|
||
To install HQAR Python package, clone this repository and install it as usual with `pip`: | ||
|
||
```bash | ||
# Clone HQAR repo (you can use HTTP link as well) | ||
git clone git@github.com:PsiQ/hqar.git | ||
cd hqar | ||
pip install . | ||
``` | ||
|
||
## HQAR format | ||
|
||
HQAR format represents quantum programs as a hierarchical directed acyclic graphs (DAGs). | ||
That's a mouthful, so let us unpack what it means: | ||
|
||
- *hierarchical*: each node can contain subgraphs, i.e. routines can be nested inside | ||
larger routines. | ||
- *directed*: information flow is unidirectional, and the direction is unambiguous. | ||
- *acyclic*: meaning there are no loops. | ||
|
||
Consider the following hierarchical DAG of a hypothetical quantum program: | ||
|
||
![program example](example_routine.svg) | ||
|
||
It can be succinctly written in HQAR format as: | ||
|
||
|
||
```yaml | ||
version: v1 | ||
program: | ||
name: my_algorithm | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 2 | ||
- direction: input | ||
name: in_1 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 4 | ||
children: | ||
- name: subroutine_1 | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 3 | ||
- name: subroutine_2 | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 1 | ||
- direction: output | ||
name: out_1 | ||
size: 1 | ||
- name: merge | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 1 | ||
- direction: input | ||
name: in_1 | ||
size: 1 | ||
- direction: input | ||
name: in_2 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 4 | ||
connections: | ||
- source: in_0 | ||
target: subroutine_1.in_0 | ||
- source: in_1 | ||
target: subroutine_2.in_0 | ||
- source: subroutine_1.out_0 | ||
target: merge.in_2 | ||
- source: subroutine_2.out_0 | ||
target: merge.in_0 | ||
- source: subroutine_2.out_1 | ||
target: merge.in_1 | ||
- source: merge.out_0 | ||
target: out_0 | ||
``` | ||
For full description of HQAR format, check our [docs](https://example.com). | ||
## Using HQAR package | ||
### Using JSON schema for validating data in HQAR format | ||
JSON schema for HQAR format can be obtained by calling `generate_program_schema` function. | ||
Such schema can be then used for validating user's input, e.g. using `jsonschema` package: | ||
|
||
```python | ||
from jsonschema import validate | ||
from hqar import generate_program_schema | ||
# Hypothetical function loading your data as native Python dictionary. | ||
data = load_some_program() | ||
schema = generate_program_schema() | ||
# This will raise if there are some validation errors. | ||
validate(schema, data) | ||
``` | ||
|
||
### Validation using Pydantic models | ||
|
||
If you are familiar with Pydantic, you might find it easier to work with HQAR Pydantic | ||
models instead of interacting with JSON schema directly. In the example below, we create | ||
an instance of `SchemaV1` model from validated data stored in HQAR format: | ||
|
||
```python | ||
from hqar import SchemaV1 | ||
data = load_some_program() | ||
# This will raise if data is not valid | ||
program = SchemaV1.model_validate(data) | ||
``` | ||
|
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
version: v1 | ||
program: | ||
name: my_algorithm | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 2 | ||
- direction: input | ||
name: in_1 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 4 | ||
children: | ||
- name: subroutine_1 | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 3 | ||
- name: subroutine_2 | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 1 | ||
- direction: output | ||
name: out_1 | ||
size: 1 | ||
- name: merge | ||
ports: | ||
- direction: input | ||
name: in_0 | ||
size: 1 | ||
- direction: input | ||
name: in_1 | ||
size: 1 | ||
- direction: input | ||
name: in_2 | ||
size: 2 | ||
- direction: output | ||
name: out_0 | ||
size: 4 | ||
connections: | ||
- source: in_0 | ||
target: subroutine_1.in_0 | ||
- source: in_1 | ||
target: subroutine_2.in_0 | ||
- source: subroutine_1.out_0 | ||
target: merge.in_2 | ||
- source: subroutine_2.out_0 | ||
target: merge.in_0 | ||
- source: subroutine_2.out_1 | ||
target: merge.in_1 | ||
- source: merge.out_0 | ||
target: out_0 |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.