HAL Commands Format Specification
Introduction
The HAL commands should have a format that provides the best generality and expressivity whilst keeping the decoding logic (and consequently its latency) to the minimum. Before describing the format, the considerations that have motivated the choice of this format are outlined. We will touch on the two main sets of implications that relate to the command format.
Commands must be transmitted to the QPU
Commands must be parsed and decoded. If errors occur in any of the two processes they should be returned.
Considerations on transmission
The transmission of the HAL commands occurs via physical wires (electrical or optical) and/or via internal on-chip traces (e.g. FPGA routing resources)
We will assume error-free (or classically error-corrected) transmission of the commands in this version of this proposal.
We will assume that different quantum hardware will have different requirements in terms of connectivity, required bandwidth (of commands), and link-latencies. For this reason, we have tentatively listed in Table 7.1 some metrics related to standard (public) interfaces.
It is important to point out that:
Most transmission protocols listed in the physical layer could be adapted to handle arbitrary packet sizes. It is worth pointing out that this will require a custom implementation of the link-layer logic for both transmitter and receiver.
Ad-hoc protocols might use generic parallel-busses of any width (i.e., not standard interfaces). We think that addressing these specific scenarios might lead to a loss of generality for this set of specifications.
Protocol |
Minimum Packet Size/Increments |
Technology Supported |
Notes |
---|---|---|---|
Ethernet (raw) |
46 bytes/1 byte (up to 1500 bytes) |
CPU, FPGA, ASIC |
Large transmission overhead |
PCIe3.0/4.0 |
128/256/512 bytes (Root complex dependant) |
CPU, FPGA, ASIC |
Short reach |
USB3.x |
1 byte/1 byte (up to 1024 bytes) |
CPU, FPGA[*], ASIC |
Transmission overhead (protocol defined transmission timeslots) |
Intra-chip communication (AMBA-AXI) |
4 bytes/4 bytes (up to 128 bytes[**]) |
FPGA, ASIC, CPU[***] |
Ultra-short reach |
Serial Peripheral Interface (SPI) |
1 byte/1 byte (up to 1024 bytes[****]) |
FPGA, ASIC, CPU |
Low bandwidth |
[*] USB3.2 2x2 might require special cards to implement the initial speed negotiation (10 Gbps mode) that might not be commercially available. [**] The AMBA protocol does not set an upper limit on the size of the bus but the physical routing of the logic normally limits this value to be 1024 bits threshold. [***] Hard/Soft-CPU only. Only CPU that are integrated into the same die as the ASIC/FPGA (either permanently or in a reconfigurable fashion). [****] Generally, controller limited. Some controllers support up to 65535 bytes.
Considerations on decoding
To guarantee the portability of applications, we recommend for the HAL specification to define a consistent representation for all the commands in terms of the number of bits and their significance.
Bit shifts and bit masking can be implemented with limited effort and low latency on CPU, FPGA and ASICs
Command size should be limited to 64 bits to benefit from CPU ISAs and facilitate software development
Commands to be executed in parallel can be sent to the Quantum Processing Unit in any order. This allows the usage of concepts like paging to index large number of qubits by decoupling it into two separate entities: BASE_OFFSET and a RELATIVE_OFFSET. The RELATIVE_OFFSET shall be embedded in all commands that require an index to operate while the BASE_OFFSET can be sent as a separate field to minimise overhead while keeping large addressability.
The identifier of the command (OPCODE) can be of:
Fixed-length (i.e. all OPCODES are implemented using the same number of bits)
Variable-length (i.e. OPCODES can use a different number of bits)
(1) provides the fastest decoding (e.g. look-up tables based) while (2) can increase the content of information transmitted via better usage of the available bits
Qubit indexing can be implemented as:
a combination of one-hot encoding (e.g. 1001 indicates that index 0 and 3 are active)
or in a binary format (e.g. 1001 indicates that the index 9 is active).
(1) enables the addressing of multiple qubits via a single command while (2) provides a much larger qubit addressing space (N vs 2N)
Commands that do not fit in a single word can be split and transmitted as a sequence of parts (multi-word commands). We envision three possible scenarios here:
The list of commands that require more than one word (multi-word commands) is fixed and predefined. Their OPCODE is sufficient to inform the decoding logic that they are composed of multiple words.
The list of multi-word commands is not known a priori. A field/flag can be set to indicate that the command is composed of extra words. This field/flag will require at least one extra bit to be always dedicated to this specific purpose.
The list of multi-word commands is not known a priori. A special command needs to be issued to indicate that what follows is a sequence of multi-word commands. One possible implementation uses the first command argument to indicate the number of words composing the real multi-word command to execute.
(1) provides the simplest decoding logic (fixed-length commands with deterministic latency), (2) and (3) have slightly more complex logic with at least one extra conditional branch. If statistically, the likelihood of multi-word commands is low, (3) provides a lower bit requirement overhead than (2).
Two-qubit commands (e.g. CNOT) require (a) the definition of two indexes as well as (b) the execution of two parallel sequences of control. While (a) is in line with previous considerations, (b) requires additional considerations. The decoder logic should effectively extract both the indexes (ideally in a single instruction) and inform the associated branches of the control logic (if independent). We identified the following options:
Single-word command with halved addressing space. We preserve the format of the command but consider the lower half of the index field pertaining to qubit 0 and the upper part to qubit 1
Longer command. We append a second indexing field to the end of the command to address the second index.
Double-word command. We extend the command with the second index and padding.
Two-words command. We split the command into two portions, and we send them as two separate tokens. e.g., we split a CNOT into in a “Control” and “Controlled” set of commands (CNOT_CTRL, CNOT_DATA).
(1)-(4) require almost no changes to the architecture for 1 qubit commands in storage and decoding. (4) though does introduces a barrier on execution. Because now the two commands are independent, the transport layer can delay the transmission of the second one, requiring buffering of the command. (2) - (3) require an extra buffer/register to store the second portion of the command and potentially forces us to decouple the command width from the transport layer width, but they do enforce the command’s atomicity.
Proposed command format
We would like to conclude this Section by proposing at least one possible format for the HAL commands. This has been investigated and tentatively validated on different integrations on both FPGA and CPUs for different quantum architectures. The table that follows contains three representations, respectively for “control commands”, “single qubit commands” and “two qubits commands”. All of them are encoded in 64 bits words. The goals of this format are (a) low complexity decoding logic (with buffering), (b) no significant performance penalty.
Command type |
OPCODE (command to execute) bits |
ARGUMENT (argument for the command) bits |
RELATIVE_QUBIT_IDX (Relative index of the QUBIT) bits |
---|---|---|---|
CONTROL COMMANDS |
[63-52] |
[51-36]
|
[35-0]: BASE_QUBIT0/1_IDX
|
SINGLE QUBIT COMMANDS |
[63-52] |
[51-36]: padding
[35-20]: qubit0
|
[19-10]: padding
[9-0]: RELATIVE_QUBIT0_IDX
|
DUAL QUBIT COMMANDS |
[63-52] |
[51-36]: qubit1
[35-20]: qubit0
|
[19-10]: RELATIVE_QUBIT1_IDX
[9-0]: RELATIVE_QUBIT0_IDX
|
The following considerations have been made:
By fixing the OPCODE length, the decoder logic can use lookup tables. We consider 4096 codes (12 bits) to be more than sufficient. Note: It might be possible to reduce them to 256 (8 bits) by intelligent usage of special commands that allow an exception to the format (MODIFIERS, two examples will follow).
The RELATIVE_QUBIT_IDX is used in associate with the SET_PAGE_QUBIT0 and SET_PAGE_QUBIT1 commands to allow for extremely large addressability (246). Two registers in the quantum backend keep track of the addresses by applying the formulas: (BASE_QUBIT0_IDX << 10) + RELATIVE_QUBIT0_IDX and (BASE_QUBIT1_IDX << 10) + RELATIVE_QUBIT1_IDX for qubit0 and qubit1 respectively.
The BASE_QUBIT0_IDX and BASE_QUBIT1_IDX registers are preserved after being written. In other words, when a page is open it remains the same up to the next write to it. A START Session Command closes (resets to 0) both BASE_QUBIT0_IDX and BASE_QUBIT1_IDX values.
The OPCODE requires shifting and masking (12 bits) but we believe that the benefits of having a more compact word outnumber the additional complexity. Further optimisations can be enabled by using an additional bit (bit 11 of 12) to indicate a long OPCODE (length > 8).
The OPCODE space is segmented into 4 ranges based on the values of bits 9 and 8 in the 12-bit opcode. Codes where bit 9 is 0 and bit 8 is 1 belong to the private OPCODE range (see below) and are reserved for vendor internal use.
No field has been allocated to support multi-word commands.
The DUAL QUBIT COMMANDS can be clearly identified by the OPCODE (we suggest using the MSB bit to indicate whether it is a SINGLE or DUAL WORD command).
The MEASURE_QUBIT command is an exception to the other SINGLE QUBIT COMMANDS, as it takes two arguments, both relating to qubit0. Argument 0 (stored in bits [35-20]) is the polar angle, and argument 1 (stored in bits [51-36]) is the azimuthal angle.
Private OPCODE range
Codes where bits 9 and 8 are set to ‘01’ are reserved codes that are guaranteed to never collide with formally defined HAL commands. Codes in this range are intended for internal use by vendors for testing and experimentation. Hardware vendors can assign codes in this range using any scheme.
Example: Vendor wishes to define a custom command for a special operation on their system. A possible opcode could be: 11 01 00001111.