2023-09-01 14:10:54 +00:00
# Quil
QuiL is the classic example of a language written specifically for a quantum machine.
2023-09-01 14:16:18 +00:00
The full document on the Quil language is [found here. ](https://quil-lang.github.io/#1Preamble )
2023-09-01 15:04:39 +00:00
# Quil Specification
**Authors:** Robert S. Smith; Rigetti & Co. Inc.; and contributors
**Language Version:** 2021.1 (DRAFT)
## Table of Contents
- [1. Preamble ](https://quil-lang.github.io/#1Preamble )
- [1.1. An Introduction to Quil ](https://quil-lang.github.io/#1-1An-Introduction-to-Quil )
- [1.2. Annexes ](https://quil-lang.github.io/#1-2Annexes )
- [2. Operational Semantic Devices ](https://quil-lang.github.io/#2Operational-Semantic-Devices )
- [2.1. Mathematical Preliminaries ](https://quil-lang.github.io/#2-1Mathematical-Preliminaries )
- [2.2. The Quantum Abstract Machine ](https://quil-lang.github.io/#2-2The-Quantum-Abstract-Machine )
- [3. Structure of a Quil Program ](https://quil-lang.github.io/#3Structure-of-a-Quil-Program )
- [3.1. Meta-Syntax ](https://quil-lang.github.io/#3-1Meta-Syntax )
- [3.2. Syntactic Rudiments ](https://quil-lang.github.io/#3-2Syntactic-Rudiments )
- [3.2.1. Arithmetic Expressions ](https://quil-lang.github.io/#3-2-1Arithmetic-Expressions )
- [3.3. Main Program Elements ](https://quil-lang.github.io/#3-3Main-Program-Elements )
- [3.4. Comments ](https://quil-lang.github.io/#3-4Comments )
- [4. Quantum Gates ](https://quil-lang.github.io/#4Quantum-Gates )
- [4.1. Qubits and Quantum State ](https://quil-lang.github.io/#4-1Qubits-and-Quantum-State )
- [4.2. Quantum Gate Definitions ](https://quil-lang.github.io/#4-2Quantum-Gate-Definitions )
- [4.2.1. Structure of a Gate Definition ](https://quil-lang.github.io/#4-2-1Structure-of-a-Gate-Definition )
- [4.2.2. Definition by Matrix ](https://quil-lang.github.io/#4-2-2Definition-by-Matrix )
- [4.2.3. Definition by Permutation ](https://quil-lang.github.io/#4-2-3Definition-by-Permutation )
- [4.2.4. Definition by Pauli Sum ](https://quil-lang.github.io/#4-2-4Definition-by-Pauli-Sum )
- [4.2.4.1. Semantics ](https://quil-lang.github.io/#4-2-4-1Semantics )
- [4.2.4.2. Example Syntax ](https://quil-lang.github.io/#4-2-4-2Example-Syntax )
- [4.2.4.3. Example Semantic Reduction of CPHASE ](https://quil-lang.github.io/#4-2-4-3Example-Semantic-Reduction-of-CPHASE )
- [4.3. Standard Gate Definitions ](https://quil-lang.github.io/#4-3Standard-Gate-Definitions )
- [4.3.1. Pauli Gates ](https://quil-lang.github.io/#4-3-1Pauli-Gates )
- [4.3.2. Hadamard Gate ](https://quil-lang.github.io/#4-3-2Hadamard-Gate )
- [4.3.3. Phase Gates ](https://quil-lang.github.io/#4-3-3Phase-Gates )
- [4.3.4. Controlled-Phase Gates ](https://quil-lang.github.io/#4-3-4Controlled-Phase-Gates )
- [4.3.5. Cartesian Rotation Gates ](https://quil-lang.github.io/#4-3-5Cartesian-Rotation-Gates )
- [4.3.6. Controlled-X Gates ](https://quil-lang.github.io/#4-3-6Controlled-X-Gates )
- [4.3.7. Swap Gates ](https://quil-lang.github.io/#4-3-7Swap-Gates )
- [4.3.8. Other Gates ](https://quil-lang.github.io/#4-3-8Other-Gates )
- [4.4. Quantum Gate Applications ](https://quil-lang.github.io/#4-4Quantum-Gate-Applications )
- [4.4.1. Syntax and Semantics ](https://quil-lang.github.io/#4-4-1Syntax-and-Semantics )
- [4.4.2. DAGGER Gate Modifier ](https://quil-lang.github.io/#4-4-2DAGGER-Gate-Modifier )
- [4.4.3. CONTROLLED Gate Modifier ](https://quil-lang.github.io/#4-4-3CONTROLLED-Gate-Modifier )
- [4.4.4. FORKED Gate Modifier ](https://quil-lang.github.io/#4-4-4FORKED-Gate-Modifier )
- [4.4.5. Chaining Modifiers ](https://quil-lang.github.io/#4-4-5Chaining-Modifiers )
- [5. Quantum State Reset ](https://quil-lang.github.io/#5Quantum-State-Reset )
- [6. Classical Memory ](https://quil-lang.github.io/#6Classical-Memory )
- [6.1. Design Considerations ](https://quil-lang.github.io/#6-1Design-Considerations )
- [6.2. Types ](https://quil-lang.github.io/#6-2Types )
- [6.3. Declaring Memory ](https://quil-lang.github.io/#6-3Declaring-Memory )
- [6.3.1. Declaring Memory ](https://quil-lang.github.io/#6-3-1Declaring-Memory )
- [6.3.2. Declaring Aliased Memory ](https://quil-lang.github.io/#6-3-2Declaring-Aliased-Memory )
- [6.3.3. Declaring Aliased Memory Declaration with an Offset ](https://quil-lang.github.io/#6-3-3Declaring-Aliased-Memory-Declaration-with-an-Offset )
- [6.3.4. Portability of Aliased Declarations ](https://quil-lang.github.io/#6-3-4Portability-of-Aliased-Declarations )
- [6.3.5. Duplicate Declaration Identifiers ](https://quil-lang.github.io/#6-3-5Duplicate-Declaration-Identifiers )
- [6.3.6. Examples ](https://quil-lang.github.io/#6-3-6Examples )
- [6.3.6.1. Register Machine with a Condition Bit ](https://quil-lang.github.io/#6-3-6-1Register-Machine-with-a-Condition-Bit )
- [6.3.6.2. Memory-Mapped RAM ](https://quil-lang.github.io/#6-3-6-2Memory-Mapped-RAM )
- [6.3.6.3. Computing Bits of an Angle ](https://quil-lang.github.io/#6-3-6-3Computing-Bits-of-an-Angle )
- [6.4. Memory Access and Dereferencing ](https://quil-lang.github.io/#6-4Memory-Access-and-Dereferencing )
- [6.5. Classical Instructions ](https://quil-lang.github.io/#6-5Classical-Instructions )
- [7. Measurement ](https://quil-lang.github.io/#7Measurement )
- [8. Classical Control ](https://quil-lang.github.io/#8Classical-Control )
- [8.1. Halting the Program ](https://quil-lang.github.io/#8-1Halting-the-Program )
- [8.2. Program Labels and Branching ](https://quil-lang.github.io/#8-2Program-Labels-and-Branching )
- [9. Other Instructions and Directives ](https://quil-lang.github.io/#9Other-Instructions-and-Directives )
- [9.1. No-Operation Instruction ](https://quil-lang.github.io/#9-1No-Operation-Instruction )
- [9.2. Pragmas ](https://quil-lang.github.io/#9-2Pragmas )
- [9.3. File Inclusion ](https://quil-lang.github.io/#9-3File-Inclusion )
- [10. Circuits ](https://quil-lang.github.io/#10Circuits )
- [10.1. Circuit Syntax ](https://quil-lang.github.io/#10-1Circuit-Syntax )
- [10.2. Circuit Expansion ](https://quil-lang.github.io/#10-2Circuit-Expansion )
- [11. History and Changes ](https://quil-lang.github.io/#11History-and-Changes )
- [11.1. A History of Quil ](https://quil-lang.github.io/#11-1A-History-of-Quil )
- [11.2. Changes ](https://quil-lang.github.io/#11-2Changes )
- [12. Annex T: Pulse-Level Control ](https://quil-lang.github.io/#12Annex-T--Pulse-Level-Control )
- [12.1. Frames ](https://quil-lang.github.io/#12-1Frames )
- [12.1.1. DEFFRAME ](https://quil-lang.github.io/#12-1-1DEFFRAME )
- [12.1.1.1. Frame Attributes ](https://quil-lang.github.io/#12-1-1-1Frame-Attributes )
- [12.2. Waveforms ](https://quil-lang.github.io/#12-2Waveforms )
- [12.2.1. Defining new waveforms ](https://quil-lang.github.io/#12-2-1Defining-new-waveforms )
- [12.3. Pulses ](https://quil-lang.github.io/#12-3Pulses )
- [12.4. Frame Mutations ](https://quil-lang.github.io/#12-4Frame-Mutations )
- [12.4.1. Frequency ](https://quil-lang.github.io/#12-4-1Frequency )
- [12.4.2. Phase ](https://quil-lang.github.io/#12-4-2Phase )
- [12.4.3. Scale ](https://quil-lang.github.io/#12-4-3Scale )
- [12.5. Capture ](https://quil-lang.github.io/#12-5Capture )
- [12.6. Defining Calibrations ](https://quil-lang.github.io/#12-6Defining-Calibrations )
- [12.7. Timing and Synchronization ](https://quil-lang.github.io/#12-7Timing-and-Synchronization )
**Note:** This document is in _DRAFT STATUS_ and is for review purposes only. It is being developed by the [Quil-Lang group](https://github.com/quil-lang/) on GitHub.
## 1. Preamble
### 1.1. An Introduction to Quil
This is the language specification for Quil, a language for hybrid classical/quantum computations.
Quil is an instruction-based language; each line of a Quil program generally corresponds to a single, discrete action. Despite its resemblance, Quil is _not_ an assembly language.
2023-09-01 14:16:18 +00:00
- [QVM ](https://github.com/quil-lang/qvm ) is what runs on the backend and is the high-performance Quil simulator