Most of my publications can be found on the arXiv.
Below is a collection of my work, including extended abstracts, posters, my PhD thesis, and unpublished drafts.
This research describes a three dimensional quantum cellular automaton (QCA) which can simulate all other 3D QCA. This intrinsically universal QCA belongs to the simplest subclass of QCA: Partitioned QCA (PQCA). PQCA are QCA of a particular form, where incoming information is scattered by a fixed unitary U before being redistributed and rescattered. Our construction is minimal amongst PQCA, having block size 2 x 2 x 2 and cell dimension 2. Signals, wires and gates emerge in an elegant fashion.
There have been several non-axiomatic approaches taken to define Quantum Cellular Automata (QCA). Partitioned QCA (PQCA) are the most canonical of these non-axiomatic definitions. In this work we first show that any QCA can be put into the form of a PQCA. Our construction reconciles all the non-axiomatic definitions of QCA, showing that they can all simulate one another, and hence that they are all equivalent to the axiomatic definition. Next, we describe a simple n-dimensional QCA capable of simulating all others, in that the initial configuration and the forward evolution of any n-dimensional QCA can be encoded within the initial configuration of the intrinsically universal QCA, and that several steps of the intrinsically universal QCA then correspond to one step of the simulated QCA. Both results are made formal by defining generalised n-dimensional intrinsic simulation, i.e. a notion of simulation which preserves the topology in the sense that each cell of the simulated QCA is encoded as a group of adjacent cells in the universal QCA. We argue that this notion brings the computer science based concepts of simulation and universality one step closer to theoretical physics.
This is a journal paper incorporating material from the two publications below, 1010.2335 and 1002.1015
A Simple n-Dimensional Intrinsically Universal Quantum Cellular Automaton
There have been several non-axiomatic approaches taken to define Quantum Cellular Automata (QCA). Partitioned QCA (PQCA) are the most canonical of these non-axiomatic definitions. In this work we show that any QCA can be put into the form of a PQCA. Our construction reconciles all the non-axiomatic definitions of QCA, showing that they can all simulate one another, and hence that they are all equivalent to the axiomatic definition. This is achieved by defining generalised n-dimensional intrinsic simulation, which brings the computer science based concepts of simulation and universality closer to theoretical physics. The result is not only an important simplification of the QCA model, it also plays a key role in the identification of a minimal n-dimensional intrinsically universal QCA.
Partitioned Quantum Cellular Automata are Intrinsically Universal
Pablo Arrigh and Jonathan Grattage, Physics and Computation 2009, to appear (2010). [BibTeX]
There have been several non-axiomatic approaches taken to define Quantum Cellular Automata (QCA). Partitioned QCA (PQCA) are the most canonical of these non-axiomatic definitions. In this work we show that any QCA can be put into the form of a PQCA. Our construction reconciles all the non-axiomatic definitions of QCA, showing that they can all simulate one another, and hence that they are all equivalent to the axiomatic definition. This is achieved by defining generalised n-dimensional intrinsic simulation, which brings the computer science based concepts of simulation and universality closer to theoretical physics. The result is not only an important simplification of the QCA model, it also plays a key role in the identification of a minimal n-dimensional intrinsically universal QCA.
Quantum Programming Languages
A compiler for a quantum language
A compiler for QML, written in Haskell (including a Happy parser and lexer), with full instructions and example programs, is available from the QML compiler website.
An Overview of QML with a Concrete Implementation in Haskell
This paper gives an introduction to and overview of the functional quantum programming language QML. The syntax of this language is defined and explained, along with a new QML definition of the quantum teleport algorithm. The categorical operational semantics of QML is also briefly introduced, in the form of annotated quantum circuits. This definition leads to a denotational semantics, given in terms of superoperators. Finally, an implementation in Haskell of the semantics for QML is presented as a compiler. The compiler takes QML programs as input, which are parsed into a Haskell datatype. The output from the compiler is either a quantum circuit (operational), an isometry (pure denotational) or a superoperator (impure denotational). Orthogonality judgements and problems with coproducts in QML are also discussed.
Measurements and Confluence in Quantum Lambda Calculi with Explicit Qubits
This paper demonstrates how to add a measurement operator to quantum lambda-calculi. A proof of the consistency of the semantics is given through a proof of confluence presented in a sufficiently general way to allow this technique to be used for other languages. The method described here may be applied to probabilistic rewrite systems in general, and to add measurement to more complex languages such as QML or Lineal, which is the subject of further research.
We develop a sound and complete equational theory for the functional quantum programming language QML. The soundness and completeness of the theory are with respect to the previously-developed denotational semantics of QML. The completeness proof also gives rise to a normalisation algorithm following the normalisation by evaluation approach. The current work focuses on the pure fragment of QML omitting measurements.
A Functional Quantum Programming Language
Thorsten Altenkirch and Jonathan Grattage, 20th Annual IEEE Symposium on Logic In Computer Science (LICS 2005), June 2005, Pp. 249-258. [BibTeX]
We introduce the language QML, a functional language for quantum computations on finite types. Its design is guided by its categorical semantics: QML programs are interpreted by morphisms in the category FQC of finite quantum computations, which provides a constructive semantics of irreversible quantum computations realisable as quantum gates. QML integrates reversible and irreversible quantum computations in one language, using first order strict linear logic to make weakenings explicit. Strict programs are free from decoherence and hence preserve superpositions and entanglement - which is essential for quantum parallelism.
Note: The content of this paper has been revised and superseded by my thesis.
PhD Thesis
QML: A Functional Quantum Programming Language
Jonathan Grattage. Viva: September 2006, Graduated: July 2007 [BibTeX]
This PhD thesis contains a complete rewrite of QML, replacing the definition given in the original LICS paper above. It also formalises, using category theory and the category FQC of Finite Quantum Computation, the quantum circuit model, and gives an operational semantics for QML in terms of quantum circuits. A denotational semantics for QML, using Selinger's superoperator category Q, is also given. It also contains an introduction to reversible classical computation, quantum computation (and its history), and an implementation in Haskell of all the main ideas discussed. The appendix contains a full discussion of Shor's factoring algorithm.
The presentation accompanying the paper of the same name, above. The QuickTime version of this talk includes animated examples of the QCA tiles which implement universal quantum computation.
An introduction to QML, a functional quantum language
An introduction to most aspects of QML (the language, motivations, semantics, algebra, etc), and contains an updated version of talks I have given previously (LICS '05, BCTCS), as well as some new information. All information in this presentation is from my thesis and the paper "An Algebra of Pure Quantum Programming" above.