# Quil QuiL is the classic example of a language written specifically for a quantum machine. The full document on the Quil language is [found here. ](https://quil-lang.github.io/#1Preamble) # 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. - [QVM](https://github.com/quil-lang/qvm) is what runs on the backend and is the high-performance Quil simulator