Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: restore section headers for mandatory capabilities #39

Merged
merged 4 commits into from
Jan 27, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 5 additions & 27 deletions specification/under_development/profiles/Adaptive_Profile.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
well as contributors to the [targeting
stage](../Compilation_And_Targeting.md#targeting) of the QIR compiler.

The Adaptive Profile specifies supersets of the [Base

Check warning on line 10 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

Unknown word (supersets)

Check warning on line 10 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (supersets)
Profile](./Base_Profile.md) that enable control flow based on mid-circuit
measurements and classical computations while quantum resources remain coherent.
A backend can support this profile by supporting a minimum set of features
Expand All @@ -20,7 +20,7 @@
1. It can execute a sequence of quantum instructions that transform the quantum
state.
2. A backend must support applying a measurement operation at any point in the
execution of the program. Qubits not undergoing the measurement should not

Check warning on line 23 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (Qubits)
have their state affected.
3. A backend must be able to apply quantum instructions conditionally on a
measurement outcome. Specifically, forward branching using the LLVM branch
Expand Down Expand Up @@ -51,15 +51,6 @@
9. Multiple return points.
<!-- markdownlint-enable MD029 -->

<!-- Original version:
7. Backwards branching to express control flow loops. Non-terminating loops
("while"-loops) are not permitted within the Adaptive Profile, regardless of
the support for this optional feature. It is specifically not permitted to
have a loop that terminates only based on a measurement outcome.
Correspondingly, permitting for backward branching mostly makes sense when
the backend also supports computations on at least one classical data type.
-->

The use of these optional features is represented as a [module
flag](#module-flags-metadata) in the program IR. Any backend that supports
capabilities 1-4, and as many of capabilities 5-9 as it desires, is considered
Expand All @@ -72,7 +63,7 @@

## Mandatory Capabilities

**Bullet 1: Quantum transformations** <br/>
### Bullet 1: Quantum transformations

The set of available instructions that transform the quantum state may vary
depending on the targeted backend. The profile specification defines how to
Expand All @@ -87,24 +78,24 @@
the distinction between runtime functions and quantum instructions, can be found
in this [document](../Instruction_Set.md).

**Bullet 2: Measurements** <br/>
### Bullet 2: Measurements

As for the Base Profile, a measurement function is a QIS function marked with an
[`irreversible` attribute](./Base_Profile.md#quantum-instruction-set) that
populates a value of type `%Result`. The available measurement functions are
defined by the executing backend as part of the QIS. Unlike the Base Profile,
the Adaptive Profile relieves a restriction that qubits can only be measured at

Check warning on line 87 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubits)
the end of the program and that no quantum operations can be performed after or
conditionally on a measurement outcome.

Within the Adaptive Profile, there are no restrictions on when these
measurements are performed during program execution. Correspondingly, it must be
possible to measure individual qubits, or subsets of qubits depending on the

Check warning on line 93 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubits)

Check warning on line 93 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubits)
supported QIS, without impacting the state of the non-measured qubits.

Check warning on line 94 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubits)
Furthermore, it must be possible to use the measured qubit(s) afterwards and

Check warning on line 95 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubit)
apply additional quantum instructions to the same qubit(s).

Check warning on line 96 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubit)

**Bullet 3: Forward Branching** <br/>
### Bullet 3: Forward Branching

Additionally, the Adaptive Profile requires that it must be possible to take
action based on a measurement result. Specifically, it must be possible to
Expand All @@ -124,7 +115,7 @@
control flow graph and reject any program with a cycle as invalid unless support
for backward branching is enabled.

While the Adaptive Profile requires that it must be possible to use a qubit

Check warning on line 118 in specification/under_development/profiles/Adaptive_Profile.md

View workflow job for this annotation

GitHub Actions / Check spelling, linting and links

word (qubit)
after it was measured, the availability of a `reset` instruction depends on the
QIS supported by the backend. If a single-qubit measurement is supported as part
of the QIS, it is always possible to reset that qubit, if needed for qubit reuse
Expand All @@ -149,7 +140,7 @@
for example when performing real-time error-correction as part of a quantum
programs.

**Bullet 4: Program output** <br/>
### Bullet 4: Program output

The specifications of QIR and all its profiles need to accurately reflect the
program intent. This includes being able to define and customize the program
Expand Down Expand Up @@ -779,19 +770,6 @@
expected type. How such an integer value is interpreted and specifically how it
relates to hardware resources is ultimately up to the executing backend.

<!--From prior version metadata:
For non-constant integer and floating-point values the assumption is that while
a `%Result*` may point to a valid memory location in RAM or some other memory
pool, by default, instructions performed on virtual registers with these data
types correspond to these values being stored in integer or floating registers
when an instruction is executed. Before a virtual register is used in an
instruction, there is no assumption that the value in the virtual register
always corresponds to a physical register. For example, when considering
register coloring, the virtual register, `%0`, in the QIR program may refer to a
value stored in RAM for most of its lifetime before being loaded into a register
when an instruction operates on `%0`.
-->

The integer value that is cast must be either a constant, or a phi node of
integer type if [iterations](#bullet-7-backwards-branching) are used/supported.
If the cast value is a phi node, it must not directly or indirectly depend on
Expand Down Expand Up @@ -903,7 +881,7 @@
%2 = and i1 %0, %1
br i1 %2, label %then, label %continue

then:
then:
tail call void @__quantum__qis__x__body(%Qubit* nonnull inttoptr (i64 2 to %Qubit*))
br label %continue

Expand Down
8 changes: 5 additions & 3 deletions specification/under_development/profiles/Base_Profile.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,9 @@ fundamentally consist of unitary transformations of the quantum state as well as
measurements at the end of the program. More details about each of the bullets
are outlined below.

**Bullet 1: Quantum transformations** <br/>
## Mandatory Capabilities

### Bullet 1: Quantum transformations

The set of available instructions that transform the quantum state may vary
depending on the targeted backend. The profile specification defines how to
Expand All @@ -41,7 +43,7 @@ the QIS, recommendations for front- and backend providers, as well as the
distinction between runtime functions and quantum instructions can be found in
[this document](../Instruction_Set.md).

**Bullet 2: Measurements** <br/>
### Bullet 2: Measurements

The second requirement should be taken to mean that a Base Profile compliant
program does *not* apply instructions to a qubit after it has been measured;
Expand All @@ -54,7 +56,7 @@ to measure only a subset of all available qubits at a time.
- Executing a Base Profile compliant program does not require support for
applying quantum instructions dependent on measurement outcomes.

**Bullet 3: Program output** <br />
### Bullet 3: Program output

The QIR specification and its profiles describe a mechanism to accurately
reflect program intent with regard to program output. The Base Profile
Expand Down
Loading