Skip to content
Snippets Groups Projects
Commit a2834b70 authored by Benoit Valiron's avatar Benoit Valiron
Browse files

Secs 1.3 & 1.3.1

parent b89edd23
No related branches found
No related tags found
No related merge requests found
...@@ -449,7 +449,9 @@ multiple options and to address high scientific and technological ...@@ -449,7 +449,9 @@ multiple options and to address high scientific and technological
risks. risks.
} }
\oldt{Our proposed \azx language is an advanced \textsc{zx}-style system \benREM{I think this part is more or less OK to keep ``as it''.}
Our proposed \azx language is an advanced \textsc{zx}-style system
augmented with features needed for applications. The \zxcalculus augmented with features needed for applications. The \zxcalculus
occupies a place in quantum computation similar to the 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
...@@ -479,7 +481,7 @@ Development of such techniques is a low-risk extension of earlier ...@@ -479,7 +481,7 @@ Development of such techniques is a low-risk extension of earlier
work, and will be done early in the project work, and will be done early in the project
(\ref{task:algorithms},\ref{task:basic-opt}). Further, at this stage (\ref{task:algorithms},\ref{task:basic-opt}). Further, at this stage
a program can be translated to a fault-tolerant equivalent with a program can be translated to a fault-tolerant equivalent with
respect to a chosen error-correcting code.} respect to a chosen error-correcting code.
% \REM{Can do useful stuff at this level! Some optimisation; ECC % \REM{Can do useful stuff at this level! Some optimisation; ECC
% simple generic optimisations. e.g. % simple generic optimisations. e.g.
...@@ -497,8 +499,7 @@ respect to a chosen error-correcting code.} ...@@ -497,8 +499,7 @@ respect to a chosen error-correcting code.}
The annotations of the second layer provide the basis of \emph{augmented
\oldt{The annotations of the second layer provide the basis of \emph{augmented
rewrites}: program transformations which are guided by the rewrites}: program transformations which are guided by the
annotations to achieve particular goals, not expressible in the basic annotations to achieve particular goals, not expressible in the basic
tensor language. For instance, there is an efficient algorithm tensor language. For instance, there is an efficient algorithm
...@@ -552,7 +553,7 @@ project~\cite{KZ:2015:aa, Kissinger2015Quantomatic:-A-}. ...@@ -552,7 +553,7 @@ project~\cite{KZ:2015:aa, Kissinger2015Quantomatic:-A-}.
Early in the project, we will implement translations from existing Early in the project, 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}).
% Due to the fact that there exist ZX-based software, additional features were added to the language e.g.~`bang-boxes' which are formal incarnations of the ``..." occurring in the above equations. % Due to the fact that there exist ZX-based software, additional features were added to the language e.g.~`bang-boxes' which are formal incarnations of the ``..." occurring in the above equations.
...@@ -563,7 +564,6 @@ evaluation.} % of the \azx system. %We will adapt an existing compiler to gener ...@@ -563,7 +564,6 @@ evaluation.} % of the \azx system. %We will adapt an existing compiler to gener
% \REM{Risk assessment: which are easy, which are hard? Dependencies.} % \REM{Risk assessment: which are easy, which are hard? Dependencies.}
\REM{WHY this is a good idea.}
...@@ -614,7 +614,7 @@ various themes: the relation between \zx and other quantum computing representat ...@@ -614,7 +614,7 @@ various themes: the relation between \zx and other quantum computing representat
\subsubsection{A quantum compiler stack} \subsubsection{A quantum compiler stack}
\label{sec:progr-lang-supp} \label{sec:progr-lang-supp}
\oldt{In the quantum setting, several powerful high-level languages In the quantum setting, several powerful high-level languages
(HLLs) such as Quipper~\cite{Alexander-S.-Green:2013fk} and Q\# (HLLs) such as Quipper~\cite{Alexander-S.-Green:2013fk} and Q\#
\cite{qsharp} have been proposed. As in the case of their \cite{qsharp} have been proposed. As in the case of their
classical counterparts, these HLLs are not designed to be run directly classical counterparts, these HLLs are not designed to be run directly
...@@ -630,24 +630,15 @@ general framework for compilation of HLLs to \azx. ...@@ -630,24 +630,15 @@ general framework for compilation of HLLs to \azx.
Since most existing quantum HLLs can output circuit descriptions, and Since most existing quantum HLLs can output circuit descriptions, and
since circuits can easily be represented in the \zxcalculus, we first since circuits can easily be represented in the \zxcalculus, we first
design a simple front end for the circuit language focus on a simple front end for the circuit language
QASM~\cite{Cross2017Open-Quantum-As} in QASM~\cite{Cross2017Open-Quantum-As} in \ref{task:testBench}. This
\ref{task:transQASM}. This will allow \azx terms to be produced from will allow \azx terms to be produced from virtually any extant quantum
virtually any extant quantum HLL, albeit rather naively. HLL, albeit rather naively. Later, we will perform concrete front-end
Later, we will perform concrete front-end experiments using more experiments using more sophisticated existing HLLs, for example
sophisticated existing HLLs, for example \emph{Quipper}, \emph{Quipper}, Q\#~\cite{qsharp}, or ProjectQ
Q\#~\cite{qsharp}, or ProjectQ \cite{Steiger2016ProjectQ:-An-Op} during the \cite{Steiger2016ProjectQ:-An-Op} during the
long running task~\ref{task:transHLL}. task~\ref{task:betterboxes}.
%
This work package consists of a back-and-forth interaction between
HLLs and \azx, which is why many of its tasks span the entire lifetime
of the project. HLL development influences \azx by providing the
control structures and other constructs that must be represented at
\azx level. Conversely, \azx developments will influence HLL, as we
analyse how information and requirements from the back-end flow upward
in a meaningful way, and how this can be translated into compilation
flags and assertions/hints to the compiler within HLL programs.
The open database of tests developed in \ref{task:testBench} will The open database of tests developed in \ref{task:testBench} will
serve as a measuring tool for the quality of the output. The database serve as a measuring tool for the quality of the output. The database
will also be made available to the community for rating and testing will also be made available to the community for rating and testing
...@@ -656,6 +647,16 @@ from other research groups, and to support other languages, both our ...@@ -656,6 +647,16 @@ from other research groups, and to support other languages, both our
interface and the \azx language will be made interface and the \azx language will be made
public. public.
%% OUTDATED
% This work package consists of a back-and-forth interaction between
% HLLs and \azx, which is why many of its tasks span the entire lifetime
% of the project. HLL development influences \azx by providing the
% control structures and other constructs that must be represented at
% \azx level. Conversely, \azx developments will influence HLL, as we
% analyse how information and requirements from the back-end flow upward
% in a meaningful way, and how this can be translated into compilation
% flags and assertions/hints to the compiler within HLL programs.
Proposed and existing quantum devices differ along a variety of axes. Proposed and existing quantum devices differ along a variety of axes.
At the most abstract level, the quantum circuit model and the At the most abstract level, the quantum circuit model and the
1-way model \cite{Raussendorf-2001} have different execution 1-way model \cite{Raussendorf-2001} have different execution
...@@ -666,9 +667,40 @@ restrictions on which qubits may interact directly. ...@@ -666,9 +667,40 @@ restrictions on which qubits may interact directly.
%Looking more closely, %Looking more closely,
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} In a hybrid architecture like NQIT, these modes.\REM{noise,fidelitY}
properties will vary across the subsystems, with concomitant
implications for the execution of the desired program. Due to its novelty, we adopt an exploratory approach. 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. We will use these examples to develop
prototypical \azx constructs expressing the relevant properties. This
consists in three tightly related tasks: decomposing the tensor
network into atomic operations; characterising runnability with
respect to the model by predicates in monadic second order logic; and
transforming the tensor network into an equivalent runnable version.
This experience will inform the later work in \ref{wp:theory} and
\ref{wp:usefulstuff}.
Although we will provide specific modules for the tasks described above, the
\azx system is intended to extensible, so we will also publish an open
API and specification language to simplify the task of adding new
architectures and error correcting schemes to the system
(\ref{task:backendapi}).
%% OUTDATED
%In a hybrid architecture like NQIT, these
%properties will vary across the subsystems, with concomitant
%implications for the execution of the desired program.
\subsubsection{Representation, reasoning, and resources}
\label{sec:machines-models}
\REM{stuff about WP 2 here}
Since the overall goal of the project is to produce a Since the overall goal of the project is to produce a
\emph{retargetable} compiler, able to generate executables for \emph{retargetable} compiler, able to generate executables for
...@@ -682,17 +714,11 @@ characteristics and architectural constraints of various idealised and ...@@ -682,17 +714,11 @@ characteristics and architectural constraints of various idealised and
realistic machines, and develop language features of \azx to express realistic machines, and develop language features of \azx to express
these properties. The goal is two-fold: to facilitate these properties. The goal is two-fold: to facilitate
\emph{code-generation} for a given machine from an \azx term; and to \emph{code-generation} for a given machine from an \azx term; and to
expose information needed by the \emph{optimiser}.} expose information needed by the \emph{optimiser}.
\subsubsection{Representation, reasoning, and resources}
\label{sec:machines-models}
\REM{stuff about WP 2 here}
\oldt{ \oldt{
A key research challenge of this work package consists in the A key research challenge of this work package consists in the
management of the {\em classical computation} and {\em classical management of the {\em classical computation} and {\em classical
information} within quantum algorithms: What computation should information} within quantum algorithms: What computation should
occur at the \azx-generation phase, and which classical parameters are occur at the \azx-generation phase, and which classical parameters are
...@@ -701,19 +727,6 @@ design a test suite (\ref{task:testBench}) to compare possible ...@@ -701,19 +727,6 @@ design a test suite (\ref{task:testBench}) to compare possible
solutions. solutions.
Due to its novelty, we adopt an exploratory approach. 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. We will use these examples to develop
prototypical \azx constructs expressing the relevant properties. This
consists in three tightly related tasks: decomposing the tensor
network into atomic operations; characterising runnability with
respect to the model by predicates in monadic second order logic; and
transforming the tensor network into an equivalent runnable version.
This experience will inform the later work in \ref{wp:theory} and
\ref{wp:usefulstuff}.
While in the early stages of the project, it will already be quite While in the early stages of the project, it will already be quite
useful to study concrete diagrams of fixed size (e.g. a quantum useful to study concrete diagrams of fixed size (e.g. a quantum
circuit on $N$ qubits for a previously-fixed $N$), in task circuit on $N$ qubits for a previously-fixed $N$), in task
...@@ -832,11 +845,6 @@ or after layout, depending on the circumstances. Layout will be handled ...@@ -832,11 +845,6 @@ or after layout, depending on the circumstances. Layout will be handled
in a similar way to this second kind of optimisation, generalising in a similar way to this second kind of optimisation, generalising
from \ref{task:delft-model} and \ref{task:NQIT-model}. from \ref{task:delft-model} and \ref{task:NQIT-model}.
Although we will provide specific modules for the tasks described above, the
\azx system is intended to extensible, so we will also publish an open
API and specification language to simplify the task of adding new
architectures and error correcting schemes to the system
(\ref{task:backendapi}).
The tasks to be performed within WP4 may be broadly described in terms of how the \azx compiler will transform \zx terms produced by the front-end to obtain instructions to be realised by a quantum computer (or software quantum simulator) at the back-end. The tasks to be performed within WP4 may be broadly described in terms of how the \azx compiler will transform \zx terms produced by the front-end to obtain instructions to be realised by a quantum computer (or software quantum simulator) at the back-end.
These stages are: (i)~an initial round of generic, hardware-independent optimisations; (ii)~application of some choice of strategy for error correction; (iii)~translation to a specialised annotation system which represents the parameters and constraints of a specific hardware implementation; and finally (iv)~another round of optimisation within the constraints imposed by the error correction and hardware models. These stages are: (i)~an initial round of generic, hardware-independent optimisations; (ii)~application of some choice of strategy for error correction; (iii)~translation to a specialised annotation system which represents the parameters and constraints of a specific hardware implementation; and finally (iv)~another round of optimisation within the constraints imposed by the error correction and hardware models.
...@@ -2413,3 +2421,8 @@ with very large graphs. ...@@ -2413,3 +2421,8 @@ with very large graphs.
} }
\end{document} \end{document}
%%% Local Variables:
%%% mode: latex
%%% TeX-master: t
%%% End:
...@@ -274,8 +274,10 @@ ...@@ -274,8 +274,10 @@
\newcommand{\zx}{\textsc{zx}\xspace} \newcommand{\zx}{\textsc{zx}\xspace}
\newcommand{\zxcalculus}{\textsc{zx}-calculus\xspace} \newcommand{\zxcalculus}{\textsc{zx}-calculus\xspace}
\newcommand{\azx}{\texttt{\bfseries\color{red!70!black} [REDEFINE \textbackslash azx MACRO]}\xspace} \newcommand{\azx}{\texttt{\bfseries\color{red!70!black}AZX}\xspace}
\newcommand{\liquid}{\texttt{\bfseries\color{red!70!black} [CONSIDER REPLACING REFERENCE TO LIQUID BY Q\#]}\xspace} \newcommand{\liquid}{\texttt{\bfseries\color{red!70!black}Q\#}\xspace}
\newcommand{\benREM}[1]{\texttt{\bfseries\color{red!70!black} [{#1}]}\xspace}
\usepackage{pgfgantt} \usepackage{pgfgantt}
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment