@@ -209,6 +209,11 @@ easily run existing programs, and future programming languages automatically gai
...
@@ -209,6 +209,11 @@ easily run existing programs, and future programming languages automatically gai
\paragraph{Baseline of knowledge and skills:}
\paragraph{Baseline of knowledge and skills:}
\label{sec:basel-knowl-skills}
\label{sec:basel-knowl-skills}
\newt{%
Several powerful high-level languages (HLLs) have been proposed for quantum programs, such as Quipper~\cite{Alexander-S.-Green:2013fk} and \Qsharp~\cite{qsharp}.
As with classical HLLs, these languages are not designed to be run directly on quantum hardware: instead, their compilers typically output quantum circuit descriptions, which are not tailored well to run on any particular hardware platform.
}%
\newt{%
\newt{%
Our proposal is to develop an analogue of the LLVM compiler system, for quantum computation.
Our proposal is to develop an analogue of the LLVM compiler system, for quantum computation.
The LLVM compiler system is a modularised collection of libraries for hardware realisation and optimisation for classical programming, providing the functionality which is expected of a well-designed modern compiler.
The LLVM compiler system is a modularised collection of libraries for hardware realisation and optimisation for classical programming, providing the functionality which is expected of a well-designed modern compiler.
...
@@ -448,14 +453,14 @@ multiple options and to address high scientific and technological
...
@@ -448,14 +453,14 @@ multiple options and to address high scientific and technological
risks.
risks.
}
}
Our proposed \newt{quantum compiler technology} is an advanced \textsc{zx}-style system
Our proposed \newt{quantum compiler technology}, which we call the \dzxc (``\emph{deep ZX compilation}'') system, is an advanced \textsc{zx}-style system
augmented with features needed for applications.
augmented with features needed for applications.
The \zxcalculus occupies a place in quantum computation similar to the
The \zxcalculus occupies a place in quantum computation similar to the
$\lambda$-calculus in classical computing: it provides a solid but
$\lambda$-calculus in classical computing: it provides a solid but
austere theoretical foundation, without any niceties for practical
austere theoretical foundation, without any niceties for practical
usage.
usage.
\newt{%
\newt{%
We will augment this basic formal system with a second layer of
The \dzxc system will augment this basic formal system with a second layer of
}%
}%
\emph{annotations} on the tensor graph, describing program parameters
\emph{annotations} on the tensor graph, describing program parameters
and architectural constraints of a specific hardware configuration.
and architectural constraints of a specific hardware configuration.
...
@@ -464,7 +469,7 @@ the implementation (annotation layer) of the program, and is the key
...
@@ -464,7 +469,7 @@ the implementation (annotation layer) of the program, and is the key
to achieving our goal of supporting multiple targets.
to achieving our goal of supporting multiple targets.
\newt{%
\newt{%
Our quantum compiler system}
The \dzxc system}
will retain the mature and effective formal tensor language of
will retain the mature and effective formal tensor language of
the \zxcalculus at its heart, ensuring semantic soundness, logical
the \zxcalculus at its heart, ensuring semantic soundness, logical
We propose to generalise this concept to encompass other sorts of information which would inform how to transform (i.e.,~to re-write) a generic representation of a quantum computational procedure.
\newt{%
For example, we would develop a system which specifies both how to represent logical operations in a particular error correcting code, and how the operations are constrained in order to satisfy basic precautions to keep the realisation fault-tolerant (\ref{task:ECC}).
The \dzxc system
We may then attempt to re-write procedures, to minimise the number of operations subject to the constraints described by those annotations.
}%
We may further elaborate such a system of annotations by a description of the constraints and the costs involved for operations within a particular hardware platform (\ref{task:runnable}).
would generalise this concept to encompass other sorts of information which would inform how to transform (i.e.,~to re-write) a generic representation of a quantum computational procedure.
For example,
\newt{%
the \dzxc system could encorporate
}%
a system which specifies both how to represent logical operations in a particular error correcting code, and how the operations are constrained in order to satisfy basic precautions to keep the realisation fault-tolerant (\ref{task:ECC}).
\newt{%
This would enable the \dzxc system
}%
to re-write procedures, to minimise the number of operations subject to the constraints described by those annotations.
\newt{%
The \dzxc system would be modular, and allow for several different systems of annotations, for different hardware platforms or constraints one might impose on a computation.
One such system of annotations would be to describe
}%
the constraints and the costs involved for operations within a particular hardware platform (\ref{task:runnable}).
%%For example, in
%%For example, in
% Other
% Other
%examples of annotations might include paths in the graph corresponding
%examples of annotations might include paths in the graph corresponding
...
@@ -536,8 +556,11 @@ specific annotations (\ref{wp:backends}), and rewrite strategies which exploit t
...
@@ -536,8 +556,11 @@ specific annotations (\ref{wp:backends}), and rewrite strategies which exploit t
Concrete tensor networks have a fixed finite size, whereas algorithms
Concrete tensor networks have a fixed finite size, whereas algorithms
are described in parametric fashion, \eg varying according the
are described in parametric fashion, \eg varying according the
input size. To accommodate this we introduce a second class of
input size.
annotations to represent limited forms of iteration and recursion, yielding
\newt{%
To accommodate this, the \dzxc system would incorporate
}%
a second class of annotations to represent limited forms of iteration and recursion, yielding
\newt{%
\newt{%
\emph{parametric}\zx terms.}
\emph{parametric}\zx terms.}
While the hardware-derived annotations are inferred in a bottom-up fashion, the parametric structure is produced top-down, based on the original
While the hardware-derived annotations are inferred in a bottom-up fashion, the parametric structure is produced top-down, based on the original
\texttt{\bfseries\color{red!70!black} [apropos to refer to PyZX here?]}
\texttt{\bfseries\color{red!70!black} [apropos to refer to PyZX here?]}
Early in the project, we will implement translations from existing
Early in the development of
\newt{%
the \dzxc system,
}%
we will implement translations from existing
quantum programming languages~(\ref{task:trans1}). These will provide
quantum programming languages~(\ref{task:trans1}). These will provide
examples and test cases, and allow comparative
examples and test cases, and allow comparative
evaluation. % of the \azx system. %We will adapt an existing compiler to generate parameterised \azx terms (\ref{task:trans2}).
evaluation. % of the \azx system. %We will adapt an existing compiler to generate parameterised \azx terms (\ref{task:trans2}).
...
@@ -624,8 +651,8 @@ various themes: the relation between \zx and other quantum computing representat
...
@@ -624,8 +651,8 @@ various themes: the relation between \zx and other quantum computing representat
}%
}%
\newt{%
\newt{%
As with classical HLLs, these languages are not designed to be run directly on quantum hardware: instead, their compilers typically output quantum circuit descriptions, which are not tailored well to run on any particular hardware platform.
As with classical HLLs, these languages are not designed to be run directly on quantum hardware: instead, their compilers typically output quantum circuit descriptions, which are not tailored well to run on any particular hardware platform.
Rather than designing a new programming language, we propose a compiler system for quantum computers, which could serve as an interface between multiple different HLLs for quantum procedures, and various quantum hardware platforms.
Our proposed \dzxc system would represent an interface between multiple different HLLs for quantum procedures, and various quantum hardware platforms.
This system would use the \zxcalculus as an internal representation of the procedure as it undergoes optimisations and translations to fit a particular hardware architecture.
This system would use terms of the \zxcalculus as an internal representation of the procedure as it undergoes optimisations and translations to fit a particular hardware architecture.
This representation would not be required from or exposed to the user,\footnote{This said, the \zxcalculus has proved a very useful notation for mathematical proofs.}
This representation would not be required from or exposed to the user,\footnote{This said, the \zxcalculus has proved a very useful notation for mathematical proofs.}
but would be generated by a compiler front-end from programs written in existing high-level languages.
but would be generated by a compiler front-end from programs written in existing high-level languages.
Therefore it is essential to provide a robust, general framework for compilation of HLLs to \zx terms.
Therefore it is essential to provide a robust, general framework for compilation of HLLs to \zx terms.
...
@@ -636,7 +663,7 @@ various themes: the relation between \zx and other quantum computing representat
...
@@ -636,7 +663,7 @@ various themes: the relation between \zx and other quantum computing representat
}%
}%
we first focus on a simple front end for the circuit language QASM~\cite{Cross2017Open-Quantum-As} in \ref{task:HHL} before moving towards more expressive HHLs.
we first focus on a simple front end for the circuit language QASM~\cite{Cross2017Open-Quantum-As} in \ref{task:HHL} before moving towards more expressive HHLs.
\newt{%
\newt{%
This will allow virtually any extant quantum HLL to interface with our quantum compiler system, albeit rather naively at first.
This will allow virtually any extant quantum HLL to interface with the \dzxc system, albeit rather naively at first.
}%
}%
Later, we will perform concrete front-end
Later, we will perform concrete front-end
experiments using more sophisticated existing HLLs in, for example
experiments using more sophisticated existing HLLs in, for example
...
@@ -650,7 +677,7 @@ will also be made available to the community for rating and testing
...
@@ -650,7 +677,7 @@ will also be made available to the community for rating and testing
future compilers or optimisation techniques. To encourage interaction
future compilers or optimisation techniques. To encourage interaction
from other research groups, and to support other languages,
from other research groups, and to support other languages,
\newt{%
\newt{%
the interfaces and functionality for our quantum compiler system will be made public.
the interfaces and functionality for the \dzxc system will be made public.
}%
}%
Proposed and existing quantum devices differ along a variety of axes.
Proposed and existing quantum devices differ along a variety of axes.
...
@@ -664,12 +691,12 @@ restrictions on which qubits may interact directly.
...
@@ -664,12 +691,12 @@ restrictions on which qubits may interact directly.
Primitive operations will require different amounts of time,
Primitive operations will require different amounts of time,
different qubit implementations have different failure
different qubit implementations have different failure
modes.\REM{noise,fidelitY}
modes.\REM{noise,fidelitY}
%
Due to the novelty of our proposal, we adopt an exploratory approach with respect to back-end models.
Due to the novelty of our proposal, we adopt an exploratory approach with respect to back-end models.
Initially, and in parallel, we study the circuit model (\ref{task:circuit-model}) and
Initially, and in parallel, we study the circuit model (\ref{task:circuit-model}) and
the 1-way model (\ref{task:mbqc-model}) because these models are well understood, stable, and have been extensively treated in the \zxcalculus literature.
the 1-way model (\ref{task:mbqc-model}) because these models are well understood, stable, and have been extensively treated in the \zxcalculus literature.
\newt{%
\newt{%
These models will provide the prototypes for the use of annotations on top of\zx terms which will be used by our compiler system.
These models will allow us to prototype the development of hardware annotations for the\dzxc system.
In both cases, this involves three tightly related tasks:
In both cases, this involves three tightly related tasks:
\begin{enumerate}[label=(\roman*)]
\begin{enumerate}[label=(\roman*)]
\item
\item
...
@@ -685,12 +712,13 @@ This experience will inform the later work in \ref{wp:theory} and
...
@@ -685,12 +712,13 @@ This experience will inform the later work in \ref{wp:theory} and
Although we will provide specific modules for the tasks described above,
Although we will provide specific modules for the tasks described above,
\newt{%
\newt{%
our quantum compiler system
the \dzxc system
}%
}%
is intended to extensible, so we will also publish an open
is intended to extensible, so we will also publish an open
API and specification language to simplify the task of adding new
API and specification language to simplify the task of adding new
architectures and error correcting schemes to the system
architectures and error correcting schemes to the system
(\ref{task:backendapi}).
(\ref{task:backendapi}).
\texttt{\bfseries\color{red!70!black}[is this redundant to a paragraph above about \ref{task:testBench}?]}