Skip to main content

A Tool for HDL-based Synthesis of Reversible Circuits

Project description

PyPI OS License: MIT CI Bindings codecov

[!NOTE] This project is currently in low maintenance mode. We will still fix bugs and accept pull requests, but we will not actively develop new features.

SyReC Synthesizer: A Tool for HDL-based Synthesis of Reversible Circuits

A tool for HDL-based synthesis of reversible circuits developed as part of the Munich Quantum Toolkit (MQT) by the Chair for Design Automation at the Technical University of Munich. It builds upon MQT Core, which forms the backbone of the MQT.

Documentation

If you have any questions, feel free to contact us by creating an issue on GitHub.

Getting Started

The SyReC Synthesizer is available via PyPI for Linux, macOS, and Windows.

  • In order to make the library as easy to use as possible (without compilation), we provide pre-built wheels for most common platforms (64-bit Linux, MacOS, Windows). These can be installed using
    (venv) $ pip install mqt.syrec
    
  • Once installed, start the SyReC Synthesizer GUI by running:
    (venv) $ syrec-editor
    

Detailed documentation on all available methods, options, and input formats is available at ReadTheDocs.

System Requirements and Building

The implementation is compatible with any C++17 compiler and a minimum CMake version of 3.19. Please refer to the documentation on how to build the project.

Building (and running) is continuously tested under Linux, macOS, and Windows using the latest available system versions for GitHub Actions.

References

SyReC Synthesizer has been developed based on methods proposed in the following papers:

[1] S. Adarsh, L. Burgholzer, T. Manjunath and R. Wille. SyReC Synthesizer: An MQT tool for synthesis of reversible circuits. Software Impacts, 2022.

[2] R. Wille, S. Offermann, and R. Drechsler. SyReC: A Programming Language for Synthesis of Reversible Circuits. In Forum on Specification and Design Languages (FDL), 2010.

[3] R. Wille, E. Schönborn, M. Soeken, and R. Drechsler. SyReC: A hardware description language for the specification and synthesis of reversible circuits. Integration (The VLSI Journal), 2016.

[4] R. Wille, M. Haghparast, S. Adarsh, and T. Manjunath. Towards HDL-based Synthesis of Reversible Circuits with No Additional Lines. In International Conference on Computer Aided Design (ICCAD), 2019.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mqt_syrec-1.1.2.tar.gz (1.6 MB view hashes)

Uploaded Source

Built Distributions

mqt_syrec-1.1.2-cp312-abi3-win_amd64.whl (1.7 MB view hashes)

Uploaded CPython 3.12+ Windows x86-64

mqt_syrec-1.1.2-cp312-abi3-manylinux_2_28_x86_64.manylinux_2_27_x86_64.whl (294.1 kB view hashes)

Uploaded CPython 3.12+ manylinux: glibc 2.27+ x86-64 manylinux: glibc 2.28+ x86-64

mqt_syrec-1.1.2-cp312-abi3-manylinux_2_28_aarch64.manylinux_2_27_aarch64.whl (271.2 kB view hashes)

Uploaded CPython 3.12+ manylinux: glibc 2.27+ ARM64 manylinux: glibc 2.28+ ARM64

mqt_syrec-1.1.2-cp312-abi3-macosx_11_0_arm64.whl (252.1 kB view hashes)

Uploaded CPython 3.12+ macOS 11.0+ ARM64

mqt_syrec-1.1.2-cp312-abi3-macosx_10_15_x86_64.whl (271.1 kB view hashes)

Uploaded CPython 3.12+ macOS 10.15+ x86-64

mqt_syrec-1.1.2-cp311-cp311-win_amd64.whl (1.7 MB view hashes)

Uploaded CPython 3.11 Windows x86-64

mqt_syrec-1.1.2-cp311-cp311-manylinux_2_28_x86_64.manylinux_2_27_x86_64.whl (295.8 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.27+ x86-64 manylinux: glibc 2.28+ x86-64

mqt_syrec-1.1.2-cp311-cp311-manylinux_2_28_aarch64.manylinux_2_27_aarch64.whl (272.9 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.27+ ARM64 manylinux: glibc 2.28+ ARM64

mqt_syrec-1.1.2-cp311-cp311-macosx_11_0_arm64.whl (251.9 kB view hashes)

Uploaded CPython 3.11 macOS 11.0+ ARM64

mqt_syrec-1.1.2-cp311-cp311-macosx_10_15_x86_64.whl (268.9 kB view hashes)

Uploaded CPython 3.11 macOS 10.15+ x86-64

mqt_syrec-1.1.2-cp310-cp310-win_amd64.whl (1.7 MB view hashes)

Uploaded CPython 3.10 Windows x86-64

mqt_syrec-1.1.2-cp310-cp310-manylinux_2_28_x86_64.manylinux_2_27_x86_64.whl (294.8 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.27+ x86-64 manylinux: glibc 2.28+ x86-64

mqt_syrec-1.1.2-cp310-cp310-manylinux_2_28_aarch64.manylinux_2_27_aarch64.whl (271.2 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.27+ ARM64 manylinux: glibc 2.28+ ARM64

mqt_syrec-1.1.2-cp310-cp310-macosx_11_0_arm64.whl (250.6 kB view hashes)

Uploaded CPython 3.10 macOS 11.0+ ARM64

mqt_syrec-1.1.2-cp310-cp310-macosx_10_15_x86_64.whl (267.6 kB view hashes)

Uploaded CPython 3.10 macOS 10.15+ x86-64

mqt_syrec-1.1.2-cp39-cp39-win_amd64.whl (1.7 MB view hashes)

Uploaded CPython 3.9 Windows x86-64

mqt_syrec-1.1.2-cp39-cp39-manylinux_2_28_x86_64.manylinux_2_27_x86_64.whl (294.6 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.27+ x86-64 manylinux: glibc 2.28+ x86-64

mqt_syrec-1.1.2-cp39-cp39-manylinux_2_28_aarch64.manylinux_2_27_aarch64.whl (271.8 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.27+ ARM64 manylinux: glibc 2.28+ ARM64

mqt_syrec-1.1.2-cp39-cp39-macosx_11_0_arm64.whl (250.7 kB view hashes)

Uploaded CPython 3.9 macOS 11.0+ ARM64

mqt_syrec-1.1.2-cp39-cp39-macosx_10_15_x86_64.whl (267.6 kB view hashes)

Uploaded CPython 3.9 macOS 10.15+ x86-64

mqt_syrec-1.1.2-cp38-cp38-win_amd64.whl (1.7 MB view hashes)

Uploaded CPython 3.8 Windows x86-64

mqt_syrec-1.1.2-cp38-cp38-manylinux_2_28_x86_64.manylinux_2_27_x86_64.whl (294.2 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.27+ x86-64 manylinux: glibc 2.28+ x86-64

mqt_syrec-1.1.2-cp38-cp38-manylinux_2_28_aarch64.manylinux_2_27_aarch64.whl (270.8 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.27+ ARM64 manylinux: glibc 2.28+ ARM64

mqt_syrec-1.1.2-cp38-cp38-macosx_11_0_arm64.whl (250.6 kB view hashes)

Uploaded CPython 3.8 macOS 11.0+ ARM64

mqt_syrec-1.1.2-cp38-cp38-macosx_10_15_x86_64.whl (267.5 kB view hashes)

Uploaded CPython 3.8 macOS 10.15+ x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page