From 5c692469b2a473aab07b52edddd1ba34c839d797 Mon Sep 17 00:00:00 2001 From: Mark Koch Date: Fri, 19 Jan 2024 14:01:59 +0000 Subject: [PATCH 1/3] doc: Update readme --- README.md | 89 +++++++++++++++++++++++++---------- examples/1-Getting-Started.md | 7 +++ 2 files changed, 70 insertions(+), 26 deletions(-) create mode 100644 examples/1-Getting-Started.md diff --git a/README.md b/README.md index 7f57ee83..b5c66a32 100644 --- a/README.md +++ b/README.md @@ -1,29 +1,68 @@ # Guppy -## About +Guppy is a quantum programming language that is fully embedded into Python. +It allows you to write high-level hybrid quantum programs with classical control flow and mid-circuit measurements using Pythonic syntax: + +```python +from guppylang import guppy + +@guppy +def teleport(src: Qubit, tgt: Qubit) -> Qubit: + """Teleports the state in `src` to `tgt`.""" + # Create ancilla and entangle it with src and tgt + tmp = Qubit() + tmp, tgt = cx(h(tmp), tgt) + src, tmp = cx(src, tmp) + + # Apply classical corrections + if measure(h(src)): + tgt = z(tgt) + if measure(tmp): + tgt = x(tgt) + return tgt +``` + +More examples and tutorials are available [here][examples]. + +[examples]: ./examples/ + + +## Install + +Guppy can be installed via `pip`. Requires Python >= 3.10. + +```sh +pip install guppylang +``` + + +## Usage + +See the [Getting Started][getting-started] guide and the other [examples]. + +[getting-started]: ./examples/1-Getting-Started.md -TODO -## Getting Started +## Development These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. ### Prerequisites -- Python >=3.10 +- Python >= 3.10 +- [Poetry](https://python-poetry.org/docs/#installation) +- [Rust](https://www.rust-lang.org/tools/install) >= 1.75.0 (only needed for tests) ### Installing - -First make sure poetry [is -installed](https://python-poetry.org/docs/#installation). - -Then run the following to setup your virtual environment and install dependencies: +Run the following to setup your virtual environment and install dependencies: ```sh -poetry install +poetry install --with validation ``` +Note that the `--with validation` flag is optional and only needed to run integration tests. + You can then activate the virtual environment and work within it with: ```sh @@ -35,50 +74,48 @@ automate this when entering and leaving a directory. To run a single command in the shell, just prefix it with `poetry run`. +### Pre-commit -### Git blame - -You can configure Git to ignore formatting commits when using `git blame` by running +Install the pre-commit hook by running: ```sh -git config blame.ignoreRevsFile .git-blame-ignore-revs +poetry run pre-commit install ``` -## Usage - -TODO -## Testing +### Testing -First, build the PyO3 Hugr validation library from the `validator` directory using +Run tests using ```sh -maturin develop +poetry run pytest -v ``` -Run tests using +You have to install extra dependencies to test automatic circuit conversion from `pytket`: ```sh -poetry run pytest -v +poetry install --extras=pytket +poetry run pytest -v # Now rerun tests ``` + Integration test cases can be exported to a directory using ```sh poetry run pytest --export-test-cases=guppy-exports - ``` which will create a directory `./guppy-exports` populated with hugr modules serialised in msgpack. -## Packaging +### Packaging ```sh poetry build ``` + ## License -This project is licensed under Apache License, Version 2.0 ([LICENSE][] or http://www.apache.org/licenses/LICENSE-2.0). +This project is licensed under Apache License, Version 2.0 ([LICENCE][] or http://www.apache.org/licenses/LICENSE-2.0). - [LICENSE]: ./LICENSE + [LICENCE]: ./LICENCE diff --git a/examples/1-Getting-Started.md b/examples/1-Getting-Started.md new file mode 100644 index 00000000..047f1a56 --- /dev/null +++ b/examples/1-Getting-Started.md @@ -0,0 +1,7 @@ + +# 1. Getting Started + +This file explains how you can get started using Guppy. + +TODO + From 0484143a782b05e7770a9c3e04759f68bdab17ec Mon Sep 17 00:00:00 2001 From: Mark Koch Date: Fri, 19 Jan 2024 14:37:07 +0000 Subject: [PATCH 2/3] Add Qubit import --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index b5c66a32..b8a2a711 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ Guppy is a quantum programming language that is fully embedded into Python. It allows you to write high-level hybrid quantum programs with classical control flow and mid-circuit measurements using Pythonic syntax: ```python -from guppylang import guppy +from guppylang import guppy, Qubit @guppy def teleport(src: Qubit, tgt: Qubit) -> Qubit: From 5ec2071420558e08c040dd8b674d464e7c3c0f7f Mon Sep 17 00:00:00 2001 From: Mark Koch Date: Fri, 19 Jan 2024 14:37:20 +0000 Subject: [PATCH 3/3] Remove packaging section --- README.md | 6 ------ 1 file changed, 6 deletions(-) diff --git a/README.md b/README.md index b8a2a711..ecdadb81 100644 --- a/README.md +++ b/README.md @@ -107,12 +107,6 @@ poetry run pytest --export-test-cases=guppy-exports which will create a directory `./guppy-exports` populated with hugr modules serialised in msgpack. -### Packaging - -```sh -poetry build -``` - ## License