Anders and Briegel in Python
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
Pete Shadbolt f5e7727d12 Bump version: 0.4.10 → 0.4.11 il y a 8 ans
abp Add and test `GraphState.to_stabilizer()` :rage4: il y a 8 ans
bin Update server, some small docs il y a 8 ans
doc Various small requests from Mercedes il y a 8 ans
examples Various small requests from Mercedes il y a 8 ans
tests Add and test `GraphState.to_stabilizer()` :rage4: il y a 8 ans
.bumpversion.cfg Bump version: 0.4.10 → 0.4.11 il y a 8 ans
.gitignore Update version to 0.4.3 il y a 8 ans
MANIFEST.in Pratting with MANIFEST il y a 8 ans
README.md Update README.md il y a 8 ans
TODO.mkd Makefiles il y a 8 ans
makefile Makefiles il y a 8 ans
setup.py Bump version: 0.4.10 → 0.4.11 il y a 8 ans

README.md

abp

Python port of Anders and Briegel’ s method for fast simulation of Clifford circuits. You can read the full documentation here.

demo

Installation

Install with pip:

$ pip install --user abp

Or clone and install:

$ git clone https://github.com/peteshadbolt/abp.git
$ python setup.py install --user

Visualization

abp comes with a tool to visualize graph states in a WebGL compatible web browser (Chrome, Firefox, Safari etc). It uses a client-server architecture.

First, run abpserver in a terminal:

$ abpserver
Listening on port 5000 for clients..

Then browse to http://localhost:5001/ (in some circumstances abp will automatically pop a browser window).

Now, in another terminal, use abp.fancy.GraphState to run a Clifford circuit:

>>> from abp.fancy import GraphState
>>> g = GraphState(range(10))
>>> for i in range(10):
...     g.act_hadamard(i)
... 
>>> g.update()
>>> for i in range(9):
...     g.act_cz(i, i+1)
... 
>>> g.update()

And you should see a visualization of the state:

demo

Testing

abp has a bunch of tests. You can run them all with nose:

$ nosetests
53 tests run in 39.5 seconds (53 tests passed)

Currently I use some reference implementations of CHP and graphsim which you won't have installed, hence some tests will fail with ImportErrors. You can ignore those.