Skip to content

Latest commit

 

History

History
40 lines (30 loc) · 1.9 KB

README.md

File metadata and controls

40 lines (30 loc) · 1.9 KB

inconspiquous

Important

This repository is a mirror of https://github.com/xdslproject/inconspiquous. There is no guarantee this up to date with upstream and issues/pull requests should not be submitted here.

A testing ground for quantum computing compilation ideas in xdsl

Installation

This tool uses uv to build. The tool can be installed by cloning and running:

uv sync

The cli tool can be run by uv run quopt or by entering the generated virtual environment.

source .venv\bin\activate

For tests to work the dev dependencies should be installed:

uv sync --dev

To run tests:

make tests

Usage

Inconspiquous is built on top of xdsl, which is itself based on (and broadly compatible with) the MLIR compiler framework. Tutorials for this framework can be found at these respective projects.

This repository adds extra dialects and transformations for working with quantum programs. The repository is primarily tested using filecheck tests, found in the test directory. These tests also serve as examples of the intermediate representations defined by this tool. The examples can be run using quopt, which can be run via uv run quopt, or by entering the virtual environment created by uv. It is also possible to view transformations using the interactive quopt-gui tool.

Contributing

Contributions should be submitted by github pull requests. Code must be formatted and linted by ruff, typecheckable by pyright, and have accompanying tests. We recommend installing pre-commit (which can be done by make precommit-install) to ensure code remains properly formatted.

Discussion

For any discussion or help, feel free to create a topic/send a message on the xdsl zulip.