Blackbird is a quantum assembly language for continuous-variable quantum computation, that can be used to program Xanadu's quantum photonics hardware and Strawberry Fields simulator.
The Blackbird repository contains three separate packages:
src
: The Blackbird grammar specification in enhanced Brackus-Naur formblackbird_python
: to develop Blackbird parsers for integration with Python programsblackbird_cpp
: libraries and header files needed to develop Blackbird parsers for integration with C++ programs
All of these packages are independent, and can be installed separately without depending on one-another. However, if the grammar is ever modified, there is a command for updating the autogenerated parts of the Python and C++ parsers.
In addition, this repository contains:
example
: Example Blackbird scriptsapps
: Example Python/C++ applications using the above parsers
Blackbird is a development library, designed to easily integrate Blackbird code into applications and interfaces.
To get the Blackbird grammar installed and running on your system, begin at the grammar installation guide. Then, familiarize yourself with the Blackbird's syntax and grammar for specifying photonic quantum circuits. You can even generate Blackbird parsers for any target language supported by ANTLR, including Java, C#, JavaScript, Go, and Swift.
If you only want to develop an application that makes use of the Python parser or the C++ parser, you can go directly to those sections and their corresponding installation guides.
If you are doing research using Blackbird, please cite
Nathan Killoran, Josh Izaac, Nicolás Quesada, Ville Bergholm, Matthew Amy, and Christian Weedbrook. Strawberry Fields: A Software Platform for Photonic Quantum Computing 2018. arXiv:1804.03159
- Source Code: https://github.com/XanaduAI/Blackbird
- Issue Tracker: https://github.com/XanaduAI/Blackbird/issues
If you are having issues, please let us know by posting the issue on our Github issue tracker.
Blackbird is free and open source, released under the Apache License, Version 2.0.