diff --git a/app-ng/src/package.lisp b/app-ng/src/package.lisp index a87de108..9361d9bc 100644 --- a/app-ng/src/package.lisp +++ b/app-ng/src/package.lisp @@ -6,6 +6,7 @@ (defpackage #:qvm-app-ng (:use #:cl #:qvm) + (:local-nicknames (#:quil #:cl-quil)) ;; job.lisp (:export diff --git a/app/src/api/expectation.lisp b/app/src/api/expectation.lisp index fd230c6d..017faf52 100644 --- a/app/src/api/expectation.lisp +++ b/app/src/api/expectation.lisp @@ -99,9 +99,9 @@ amplitudes in PREPARED-STATE." ;; to apply the transpose to OP-MATRIX below, since it is ;; generally smaller. Thus we compute tr(Q^T ρ^T) = tr((ρ Q)^T) = tr(ρ Q) = tr(Q ρ). (let ((op-matrix (magicl:transpose - (quil::parsed-program-to-logical-matrix op))) + (cl-quil::parsed-program-to-logical-matrix op))) (density-matrix (magicl:from-array prepared-state (list rows cols) :type '(complex double-float)))) (reduce #'+ (magicl:diag - (quil::matrix-rescale-and-multiply op-matrix density-matrix)))))) + (cl-quil::matrix-rescale-and-multiply op-matrix density-matrix)))))) diff --git a/app/src/debugger.lisp b/app/src/debugger.lisp index 462ba437..1cc1c164 100644 --- a/app/src/debugger.lisp +++ b/app/src/debugger.lisp @@ -2,12 +2,7 @@ ;;;; ;;;; Author: Juan M. Bello-Rivas -(defpackage #:qvm-app.debugger - (:use #:common-lisp #:qvm-app) - (:export #:debugger) - (:import-from #:alexandria #:assoc-value #:once-only)) - -(in-package #:qvm-app.debugger) +(in-package #:qvm-app/debugger) (defparameter *threshold* (* 1e3 double-float-epsilon) "Smallest amplitude that can be printed.") @@ -145,7 +140,7 @@ Run the next instruction and stop." ((program-finished-p) (format t "Finished program execution.~%")) (t - (format t "~/quil:instruction-fmt/~%" (qvm::current-instruction *qvm*)) + (format t "~/cl-quil:instruction-fmt/~%" (qvm::current-instruction *qvm*)) (setf *qvm* (qvm:transition *qvm* (qvm::current-instruction *qvm*))) (when *display* (print-amplitudes))))) @@ -166,7 +161,7 @@ Resume program execution from the current instruction." :until (or (program-finished-p) breakpoint-p) :do (setf *qvm* (qvm:transition *qvm* (qvm::current-instruction *qvm*))) :finally (when breakpoint-p - (format t "Stopping at breakpoint in instruction ~D:~%~/quil:instruction-fmt/~%" + (format t "Stopping at breakpoint in instruction ~D:~%~/cl-quil:instruction-fmt/~%" pc (qvm::current-instruction *qvm*))) (return *qvm*))))) @@ -176,13 +171,13 @@ Resume program execution from the current instruction." Load a program and instantiate a suitable QVM." (unless filename (error "File name not specified.")) - (let* ((program (quil:read-quil-file (string-trim " " filename))) - (number-of-qubits (quil:qubits-needed program))) + (let* ((program (cl-quil:read-quil-file (string-trim " " filename))) + (number-of-qubits (cl-quil:qubits-needed program))) (format t "Read ~A using ~D qubits.~%" filename number-of-qubits) (setf *source-filename* filename *qvm* (qvm:make-qvm number-of-qubits :classical-memory-model (qvm:memory-descriptors-to-qvm-memory-model - (quil:parsed-program-memory-definitions program))) + (cl-quil:parsed-program-memory-definitions program))) *breakpoints* nil) (qvm:load-program *qvm* program))) diff --git a/app/src/entry-point.lisp b/app/src/entry-point.lisp index af1e027f..17f097b0 100644 --- a/app/src/entry-point.lisp +++ b/app/src/entry-point.lisp @@ -530,7 +530,7 @@ Copyright (c) 2016-2019 Rigetti Computing.~2%") (start-server-app host port)) ;; Interactive debugger mode. - (debugger (qvm-app.debugger:debugger)) + (debugger (qvm-app/debugger:debugger)) ;; Batch mode. (t diff --git a/app/src/package.lisp b/app/src/package.lisp index fbfb87af..f06f43ea 100644 --- a/app/src/package.lisp +++ b/app/src/package.lisp @@ -3,4 +3,10 @@ ;;;; Author: Robert Smith (defpackage #:qvm-app - (:use #:cl #:qvm)) + (:use #:cl #:qvm) + (:local-nicknames (#:quil #:cl-quil/frontend))) + +(defpackage #:qvm-app/debugger + (:use #:cl #:qvm-app) + (:export #:debugger) + (:import-from #:alexandria #:assoc-value #:once-only)) diff --git a/bench/quil-files.lisp b/bench/quil-files.lisp index 110e94a1..7052e3b0 100644 --- a/bench/quil-files.lisp +++ b/bench/quil-files.lisp @@ -10,7 +10,7 @@ (defun timed-run (file) "Load the Quil file designated by FILE and time its execution." - (let ((quil::*allow-unresolved-applications* t)) + (let ((cl-quil::*allow-unresolved-applications* t)) (let* ((program (cl-quil:read-quil-file (merge-pathnames file *bench-files-directory*))) (qvm (qvm:make-qvm (cl-quil:qubits-needed program)))) diff --git a/examples/qaoa.lisp b/examples/qaoa.lisp index bc339a50..f63a891b 100644 --- a/examples/qaoa.lisp +++ b/examples/qaoa.lisp @@ -16,15 +16,15 @@ COST-HAM should consist of commuting Pauli terms only. (This is *not* checked.)" (check-type p (integer 1)) ;; Every Pauli in COST-HAM should have the same number of qubits. - (let* ((n (cl-quil.clifford:num-qubits - (alexandria:extremum cost-ham #'> :key #'cl-quil.clifford:num-qubits))) + (let* ((n (cl-quil/clifford:num-qubits + (alexandria:extremum cost-ham #'> :key #'cl-quil/clifford:num-qubits))) (quil (quil:parse-quil (format nil "DECLARE beta REAL[~D]; DECLARE gamma REAL[~D]" p p))) ;; Parameters (betas (loop :for i :below p :collect (quil:mref "beta" i))) (gammas (loop :for i :below p :collect (quil:mref "gamma" i))) ;; Hamiltonian (driver-ham (loop :for q :below n - :collect (cl-quil.clifford:embed cl-quil.clifford:+X+ n (list q)))) + :collect (cl-quil/clifford:embed cl-quil/clifford:+X+ n (list q)))) (isns (quil:with-inst () ;; Initialize (dotimes (q n) @@ -36,11 +36,11 @@ COST-HAM should consist of commuting Pauli terms only. (This is *not* checked.)" (gamma (quil::make-delayed-expression nil nil gamma))) ;; Cost. All the terms are assumed to commute. (dolist (pauli cost-ham) - (mapc #'quil:inst (cl-quil.clifford::exp-pauli pauli gamma))) + (mapc #'quil:inst (cl-quil/clifford::exp-pauli pauli gamma))) ;; Driver (dolist (pauli driver-ham) - (mapc #'quil:inst (cl-quil.clifford::exp-pauli pauli beta)))))))) + (mapc #'quil:inst (cl-quil/clifford::exp-pauli pauli beta)))))))) (setf (quil:parsed-program-executable-code quil) (coerce isns 'simple-vector)) (values quil betas gammas))) @@ -50,9 +50,9 @@ COST-HAM should consist of commuting Pauli terms only. (This is *not* checked.)" GRAPH should be a list of edges, each represented as a pair (A B) of integer vertices." (loop :with n := (1+ (loop :for (from to) :in graph :maximize (max from to))) - :with ZZ := (cl-quil.clifford:pauli-from-string "ZZ") + :with ZZ := (cl-quil/clifford:pauli-from-string "ZZ") :for vertex :in graph - :collect (cl-quil.clifford:embed ZZ n vertex))) + :collect (cl-quil/clifford:embed ZZ n vertex))) (defun complete-graph (n) "Build a complete graph of N vertices." diff --git a/src/classical-memory-mixin.lisp b/src/classical-memory-mixin.lisp index 24815c8f..9aa70f6c 100644 --- a/src/classical-memory-mixin.lisp +++ b/src/classical-memory-mixin.lisp @@ -36,7 +36,7 @@ :classical-memory-subsystem (make-instance 'qvm:classical-memory-subsystem) :wait-function 'warning-wait-function ;; XXX FIXME: To be superseded by some notion of environments. - :gate-definitions (copy-hash-table cl-quil.frontend::**default-gate-definitions**)) + :gate-definitions (copy-hash-table cl-quil/frontend::**default-gate-definitions**)) (:metaclass abstract-class) (:documentation "A mixin for quantum abstract machines making use of a classical memory subsystem and a program vector.")) diff --git a/src/package.lisp b/src/package.lisp index 2c3cfb87..762859fc 100644 --- a/src/package.lisp +++ b/src/package.lisp @@ -10,8 +10,7 @@ (:shadowing-import-from #:mt19937 #:random) - #+(or sbcl ecl ccl) - (:local-nicknames (:quil :cl-quil.frontend)) + (:local-nicknames (#:quil #:cl-quil/frontend)) ;; config.lisp (:export diff --git a/src/stabilizer-qvm.lisp b/src/stabilizer-qvm.lisp index 2c95c474..72698e1c 100644 --- a/src/stabilizer-qvm.lisp +++ b/src/stabilizer-qvm.lisp @@ -14,7 +14,7 @@ "Map string gate name to a CLIFFORD object.") (global-vars:define-global-var **clifford-operations** - (quil.clifford:make-clifford-hash-table) + (cl-quil/clifford:make-clifford-hash-table) "Map a CLIFFORD to a compiled tableau function.") (defclass stabilizer-qvm (classical-memory-mixin) @@ -26,13 +26,13 @@ (check-type num-qubits unsigned-byte) (check-type classical-memory-model quil:memory-model) (make-instance 'stabilizer-qvm - :tableau (cl-quil.clifford::make-tableau-zero-state num-qubits) + :tableau (cl-quil/clifford::make-tableau-zero-state num-qubits) :classical-memory-subsystem (make-instance 'classical-memory-subsystem :classical-memory-model classical-memory-model))) (defmethod number-of-qubits ((qvm stabilizer-qvm)) - (cl-quil.clifford::tableau-qubits (stabilizer-qvm-tableau qvm))) + (cl-quil/clifford::tableau-qubits (stabilizer-qvm-tableau qvm))) (defun gate-application-to-clifford (gate-app) (check-type gate-app quil:gate-application) @@ -43,17 +43,17 @@ (gethash name **cliffords**) (unless exists? (setf (gethash name **cliffords**) - (quil.clifford:matrix-to-clifford + (cl-quil/clifford:matrix-to-clifford (quil:gate-matrix (pull-teeth-to-get-a-gate gate-app)))) (setf clifford (gethash name **cliffords**))) clifford))) - (t (quil.clifford:matrix-to-clifford + (t (cl-quil/clifford:matrix-to-clifford (quil:gate-matrix (pull-teeth-to-get-a-gate gate-app)))))) (defun compile-clifford (c &key (cache t)) - (check-type c quil.clifford:clifford) + (check-type c cl-quil/clifford:clifford) (multiple-value-bind (compiled exists?) (gethash c **clifford-operations**) (cond @@ -61,7 +61,7 @@ (t (when *transition-verbose* (format *trace-output* "~&; compiling Clifford gate...~%")) - (let ((compiled (compile-lambda (cl-quil.clifford::compile-tableau-operation c)))) + (let ((compiled (compile-lambda (cl-quil/clifford::compile-tableau-operation c)))) (when cache (setf (gethash c **clifford-operations**) compiled)) compiled))))) @@ -70,10 +70,10 @@ ;;;;;;;;;;;;;;;;;;;;;;;;; TRANSITION Methods ;;;;;;;;;;;;;;;;;;;;;;;;; (defmethod measure ((qvm stabilizer-qvm) q) - (values qvm (cl-quil.clifford::tableau-measure (stabilizer-qvm-tableau qvm) q))) + (values qvm (cl-quil/clifford::tableau-measure (stabilizer-qvm-tableau qvm) q))) (defmethod transition ((qvm stabilizer-qvm) (instr quil:reset)) - (cl-quil.clifford::zero-out-tableau (stabilizer-qvm-tableau qvm)) + (cl-quil/clifford::zero-out-tableau (stabilizer-qvm-tableau qvm)) (incf (pc qvm)) qvm) @@ -104,7 +104,7 @@ (qubits (mapcar #'quil:qubit-index (quil:application-arguments instr)))) ;; Do some error checking. (let ((given-qubits (length qubits)) - (expected-qubits (quil.clifford:num-qubits clifford))) + (expected-qubits (cl-quil/clifford:num-qubits clifford))) (unless (= given-qubits expected-qubits) (error 'invalid-instruction-encountered :instruction instr @@ -132,12 +132,12 @@ (defmethod print-object ((o clifford-application) stream) (print-unreadable-object (o stream :type t :identity t) - (format stream "~Dq" (quil.clifford:num-qubits + (format stream "~Dq" (cl-quil/clifford:num-qubits (clifford-application-clifford o))))) (defun make-clifford-application (clifford &rest qubits) - (check-type clifford quil.clifford:clifford) - (assert (= (quil.clifford:num-qubits clifford) (length qubits))) + (check-type clifford cl-quil/clifford:clifford) + (assert (= (cl-quil/clifford:num-qubits clifford) (length qubits))) (make-instance 'clifford-application :clifford clifford :arguments (mapcar #'quil:qubit qubits))) @@ -161,7 +161,7 @@ (let ((arity (random-range 1 (1+ max-clifford-arity)))) (setf (aref code i) (apply #'make-clifford-application - (cl-quil.clifford:random-clifford arity) + (cl-quil/clifford:random-clifford arity) (loop :for q :from (1- arity) :downto 0 :collect q))))) (when measure (dotimes (i num-qubits) @@ -177,7 +177,7 @@ (qubits (mapcar #'quil:qubit-index (quil:application-arguments instr)))) ;; Do some error checking. (let ((given-qubits (length qubits)) - (expected-qubits (quil.clifford:num-qubits clifford))) + (expected-qubits (cl-quil/clifford:num-qubits clifford))) (unless (= given-qubits expected-qubits) (error 'invalid-instruction-encountered :instruction instr @@ -194,6 +194,6 @@ (defmethod transition ((qvm pure-state-qvm) (instr clifford-application)) (transition qvm (make-instance 'quil:gate-application :operator (quil:named-operator "dummy") - :gate (make-instance 'quil:simple-gate :matrix (cl-quil.clifford::clifford-to-matrix (clifford-application-clifford instr))) + :gate (make-instance 'quil:simple-gate :matrix (cl-quil/clifford::clifford-to-matrix (clifford-application-clifford instr))) :parameters nil :arguments (quil:application-arguments instr)))) diff --git a/tests/package.lisp b/tests/package.lisp index 15e67940..fd58dd99 100644 --- a/tests/package.lisp +++ b/tests/package.lisp @@ -4,8 +4,7 @@ (fiasco:define-test-package #:qvm-tests (:use #:qvm) - #+(or sbcl ecl ccl) - (:local-nicknames (:quil :cl-quil.frontend)) + (:local-nicknames (#:quil #:cl-quil/frontend)) ;; suite.lisp (:export diff --git a/tests/stabilizer-qvm-tests.lisp b/tests/stabilizer-qvm-tests.lisp index 45b7223f..d07da2e9 100644 --- a/tests/stabilizer-qvm-tests.lisp +++ b/tests/stabilizer-qvm-tests.lisp @@ -13,7 +13,7 @@ (stab-qvm (qvm::make-stabilizer-qvm 10))) (is (every #'quil::double~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm)))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm)))))) (deftest test-stabilizer-bell-state () (let ((pure-qvm (qvm::make-qvm 2)) @@ -25,7 +25,7 @@ S 1"))) (test-quickrun stab-qvm program) (is (every #'quil::double~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm)))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm)))))) (deftest test-stabilizer-nonclifford () (let ((pure-qvm (qvm::make-qvm 2)) @@ -38,55 +38,55 @@ S 1"))) (deftest test-random-qvm-vs-chp-small () (let ((n 3)) (dotimes (i 100) - (multiple-value-bind (chp-code quil-code) (cl-quil.clifford::random-chp-and-quil n 3) + (multiple-value-bind (chp-code quil-code) (cl-quil/clifford::random-chp-and-quil n 3) (let ((pure-qvm (qvm::make-qvm n)) - (chp-tab (cl-quil.clifford::make-tableau-zero-state n))) + (chp-tab (cl-quil/clifford::make-tableau-zero-state n))) (test-quickrun pure-qvm (cl-quil:parse-quil quil-code)) - (cl-quil.clifford::interpret-chp chp-code chp-tab :silent t) - (is (cl-quil.clifford::global-phase~ + (cl-quil/clifford::interpret-chp chp-code chp-tab :silent t) + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction chp-tab)))))))) + (cl-quil/clifford::tableau-wavefunction chp-tab)))))))) (deftest test-random-qvm-vs-chp-medium () (let ((n 10)) (dotimes (i 100) - (multiple-value-bind (chp-code quil-code) (cl-quil.clifford::random-chp-and-quil n 50) + (multiple-value-bind (chp-code quil-code) (cl-quil/clifford::random-chp-and-quil n 50) (let ((pure-qvm (qvm::make-qvm n)) - (chp-tab (cl-quil.clifford::make-tableau-zero-state n))) + (chp-tab (cl-quil/clifford::make-tableau-zero-state n))) (test-quickrun pure-qvm (cl-quil:parse-quil quil-code)) - (cl-quil.clifford::interpret-chp chp-code chp-tab :silent t) - (is (cl-quil.clifford::global-phase~ + (cl-quil/clifford::interpret-chp chp-code chp-tab :silent t) + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction chp-tab)))))))) + (cl-quil/clifford::tableau-wavefunction chp-tab)))))))) (deftest test-random-qvm-vs-chp-large () (let ((n 15)) (dotimes (i 50) - (multiple-value-bind (chp-code quil-code) (cl-quil.clifford::random-chp-and-quil n 100) + (multiple-value-bind (chp-code quil-code) (cl-quil/clifford::random-chp-and-quil n 100) (let* ((pure-qvm (qvm::make-qvm n)) - (chp-tab (cl-quil.clifford::make-tableau-zero-state n))) + (chp-tab (cl-quil/clifford::make-tableau-zero-state n))) (test-quickrun pure-qvm (cl-quil:parse-quil quil-code)) - (cl-quil.clifford::interpret-chp chp-code chp-tab :silent t) - (is (cl-quil.clifford::global-phase~ + (cl-quil/clifford::interpret-chp chp-code chp-tab :silent t) + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction chp-tab)))))))) + (cl-quil/clifford::tableau-wavefunction chp-tab)))))))) (deftest test-random-stabilizer-vs-chp () (let ((n 10)) (dotimes (i 200) - (multiple-value-bind (chp-code quil-code) (cl-quil.clifford::random-chp-and-quil n 10) + (multiple-value-bind (chp-code quil-code) (cl-quil/clifford::random-chp-and-quil n 10) (let* ((qvm (qvm::make-stabilizer-qvm n)) - (tab (cl-quil.clifford::make-tableau-zero-state n))) + (tab (cl-quil/clifford::make-tableau-zero-state n))) (test-quickrun qvm (cl-quil:parse-quil quil-code)) - (cl-quil.clifford::interpret-chp chp-code tab :silent t) + (cl-quil/clifford::interpret-chp chp-code tab :silent t) ;; Print the error-causing program (unless (every #'quil::double~ - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau qvm)) - (cl-quil.clifford::tableau-wavefunction tab)) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau qvm)) + (cl-quil/clifford::tableau-wavefunction tab)) (format t "~%~A~%" quil-code)) (is (every #'quil::double~ - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau qvm)) - (cl-quil.clifford::tableau-wavefunction tab)))))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau qvm)) + (cl-quil/clifford::tableau-wavefunction tab)))))))) (deftest test-one-qubit-one-clifford () (dotimes (i 100) @@ -96,9 +96,9 @@ S 1"))) (program (qvm::random-clifford-program 1 1 n))) (test-quickrun pure-qvm program) (test-quickrun stab-qvm program) - (is (cl-quil.clifford::global-phase~ + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) (deftest test-two-qubit-one-clifford () (dotimes (i 100) @@ -108,9 +108,9 @@ S 1"))) (program (qvm::random-clifford-program 1 2 n))) (test-quickrun pure-qvm program) (test-quickrun stab-qvm program) - (is (cl-quil.clifford::global-phase~ + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) (deftest test-one-qubit-two-clifford () (dotimes (i 100) @@ -120,9 +120,9 @@ S 1"))) (program (qvm::random-clifford-program 2 1 n))) (test-quickrun pure-qvm program) (test-quickrun stab-qvm program) - (is (cl-quil.clifford::global-phase~ + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) (deftest test-two-qubit-two-clifford () (dotimes (i 100) @@ -132,9 +132,9 @@ S 1"))) (program (qvm::random-clifford-program 2 2 n))) (test-quickrun pure-qvm program) (test-quickrun stab-qvm program) - (is (cl-quil.clifford::global-phase~ + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) (deftest test-hella-random-cliffords () (dotimes (i 100) @@ -144,14 +144,14 @@ S 1"))) (program (qvm::random-clifford-program 10 5 n))) (test-quickrun pure-qvm program) (test-quickrun stab-qvm program) - (is (cl-quil.clifford::global-phase~ + (is (cl-quil/clifford::global-phase~ (qvm::amplitudes pure-qvm) - (cl-quil.clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) + (cl-quil/clifford::tableau-wavefunction (qvm::stabilizer-qvm-tableau stab-qvm))))))) (deftest test-clifford-matrix-conversions () (loop :for i :from 1 :to 4 :do (loop :repeat 100 - :for c := (cl-quil.clifford::random-clifford i) - :for m := (cl-quil.clifford::clifford-to-matrix c) - :for d := (cl-quil.clifford::matrix-to-clifford m) - :do (is (cl-quil.clifford::clifford= c d))))) + :for c := (cl-quil/clifford::random-clifford i) + :for m := (cl-quil/clifford::clifford-to-matrix c) + :for d := (cl-quil/clifford::matrix-to-clifford m) + :do (is (cl-quil/clifford::clifford= c d)))))