@@ -1,3 +1,4 @@ | |||||
# Alias some stuff to make imports cleaner | # Alias some stuff to make imports cleaner | ||||
from abp.graphstate import GraphState | from abp.graphstate import GraphState | ||||
from abp.qi import CircuitModel | from abp.qi import CircuitModel | ||||
from abp.client import Client |
@@ -0,0 +1,39 @@ | |||||
import requests | |||||
import abp, json | |||||
class Client(object): | |||||
def __init__(self, host="localhost", port=5000, clear=False): | |||||
self.session = requests.Session() | |||||
self.root = "http://{}:{}".format(host, port) | |||||
if clear: | |||||
self.clear() | |||||
def get(self, endpoint): | |||||
url =self.root+endpoint | |||||
response = self.session.get(url) | |||||
assert response.status_code == 200 | |||||
return response.content | |||||
def get_state(self): | |||||
response = self.get("/state") | |||||
output = abp.GraphState() | |||||
output.from_json(json.loads(response)) | |||||
return output | |||||
def set_state(self, state): | |||||
return self.session.post(self.root+"/state", data=state.to_json()) | |||||
def add_node(self, node): | |||||
return self.get("/add_node/{}".format(node)) | |||||
def act_local_rotation(self, node, operation): | |||||
return self.get("/act_local_rotation/{}/{}".format(node, operation)) | |||||
def act_cz(self, a, b): | |||||
return self.get("/act_cz/{}/{}".format(a, b)) | |||||
def clear(self): | |||||
return self.get("/clear") | |||||
def kill(self): | |||||
self.session.close() |
@@ -164,9 +164,9 @@ class GraphState(object): | |||||
def from_json(self, data): | def from_json(self, data): | ||||
""" Reconstruct from JSON """ | """ Reconstruct from JSON """ | ||||
self.__init__([]) | self.__init__([]) | ||||
self.vops = data["nodes"] | |||||
self.meta = data["meta"] | |||||
self.ngbh = {key: set() for key in self.vops} | |||||
self.vops = {int(key): value for key, value in data["nodes"].items()} | |||||
self.meta = {int(key): value for key, value in data["meta"].items()} | |||||
self.ngbh = {int(key): set() for key in self.vops} | |||||
self.add_edges(data["edges"]) | self.add_edges(data["edges"]) | ||||
def to_networkx(self): | def to_networkx(self): | ||||
@@ -1,15 +1,10 @@ | |||||
import requests | import requests | ||||
import abp, json | import abp, json | ||||
import time | |||||
s = requests.Session() | |||||
output = s.get("http://localhost:5000/state").content | |||||
s.post("http://localhost:5000/state", output).content | |||||
client = abp.Client() | |||||
s.get("http://localhost:5000/add/99") | |||||
s.get("http://localhost:5000/add/100") | |||||
print s.get("http://localhost:5000/state").content | |||||
s.get("http://localhost:5000/clear") | |||||
s.close() | |||||
client.add_node(0) | |||||
client.add_node(1) | |||||
print client.get_state() |
@@ -1,8 +1,13 @@ | |||||
from flask import Flask, request, render_template, jsonify | from flask import Flask, request, render_template, jsonify | ||||
from werkzeug.contrib.cache import SimpleCache | |||||
import json | import json | ||||
import abp | import abp | ||||
graphstate = abp.GraphState() | |||||
#TODO: only send deltas | |||||
#graphstate = abp.GraphState() | |||||
cache=SimpleCache() | |||||
cache.set("state", abp.GraphState()) | |||||
app = Flask(__name__) | app = Flask(__name__) | ||||
@app.route("/") | @app.route("/") | ||||
@@ -12,38 +17,44 @@ def index(): | |||||
@app.route("/state", methods = ["GET", "POST"]) | @app.route("/state", methods = ["GET", "POST"]) | ||||
def state(): | def state(): | ||||
if request.method == "GET": | if request.method == "GET": | ||||
return jsonify(graphstate.to_json()) | |||||
return jsonify(cache.get("state").to_json()) | |||||
elif request.method == "POST": | elif request.method == "POST": | ||||
graphstate = abp.GraphState() | |||||
graphstate.from_json(json.loads(request.data)) | graphstate.from_json(json.loads(request.data)) | ||||
return jsonify(graphstate.to_json()) | |||||
cache.set("state", graphstate) | |||||
return jsonify({"update": "ok"}) | |||||
@app.route("/add/<int:node>") | |||||
def add(node): | |||||
@app.route("/add_node/<int:node>") | |||||
def add_node(node): | |||||
""" Add a node to the graph """ | """ Add a node to the graph """ | ||||
graphstate = cache.get("state") | |||||
graphstate.add_node(node) | graphstate.add_node(node) | ||||
return jsonify(graphstate.to_json()) | |||||
cache.set("state", graphstate) | |||||
return jsonify({"add_node": "okay"}) | |||||
@app.route("/rotate/<int:node>/<int:operation>") | |||||
def rotate(node): | |||||
@app.route("/act_local_rotation/<int:node>/<int:operation>") | |||||
def act_local_rotation(node): | |||||
""" Add a node to the graph """ | """ Add a node to the graph """ | ||||
# TODO: try to lookup the operation first | |||||
graphstate.act_local_rotation(node, operation) | graphstate.act_local_rotation(node, operation) | ||||
return jsonify(graphstate.to_json()) | |||||
return jsonify({"act_local_rotation": "okay"}) | |||||
@app.route("/cz/<int:a>/<int:b>") | |||||
def cz(a, b): | |||||
@app.route("/act_cz/<int:a>/<int:b>") | |||||
def act_cz(a, b): | |||||
""" Add a node to the graph """ | """ Add a node to the graph """ | ||||
graphstate.act_cz(a, b) | graphstate.act_cz(a, b) | ||||
return jsonify(graphstate.to_json()) | |||||
return jsonify({"act_cz": "okay"}) | |||||
@app.route("/clear") | @app.route("/clear") | ||||
def clear(): | def clear(): | ||||
""" Clear the current state """ | """ Clear the current state """ | ||||
graphstate = abp.GraphState() | graphstate = abp.GraphState() | ||||
return jsonify({"clear": "ok"}) | |||||
cache.set("state", graphstate) | |||||
return jsonify({"clear": "okay"}) | |||||
if __name__ == "__main__": | if __name__ == "__main__": | ||||
app.debug = True | |||||
app.debug = False | |||||
app.run(host="0.0.0.0") | app.run(host="0.0.0.0") | ||||
@@ -1,10 +1,37 @@ | |||||
html, body { margin: 0; padding: 0; overflow: hidden; font-size: 10pt; font-family: "courier new"; } | html, body { margin: 0; padding: 0; overflow: hidden; font-size: 10pt; font-family: "courier new"; } | ||||
#infoholder { | #infoholder { | ||||
background: black; color:white; padding: 5px; margin:0px; position: absolute; top:5px; left:5px; font-family:"courier new"; text-align: center; font-size:10pt; | |||||
background: black; | |||||
color:white; | |||||
padding: 5px; | |||||
margin:0px; | |||||
position: absolute; | |||||
top:5px; | |||||
left:5px; | |||||
font-family:"courier new"; | |||||
text-align: center; | |||||
font-size:10pt; | |||||
height:15px; | height:15px; | ||||
border-radius:3px; | border-radius:3px; | ||||
} | } | ||||
#pallette { | |||||
background-color: black; | |||||
/*border-radius:3px;*/ | |||||
color:white; | |||||
padding: 10px; | |||||
font-family:"courier new"; | |||||
position: absolute; | |||||
top: 10px; | |||||
right: 10px; | |||||
font-size: 9pt; | |||||
} | |||||
ul { | |||||
list-style-type: none; | |||||
padding: 0px; | |||||
margin: 0px; | |||||
} | |||||
.visible { | .visible { | ||||
visibility: visible; | visibility: visible; | ||||
opacity: 1; | opacity: 1; | ||||
@@ -1,46 +1,2 @@ | |||||
var url = "ws://localhost:8000/"; | |||||
function doConnect() { | |||||
websocket = new WebSocket(url); | |||||
websocket.onopen = onOpen; | |||||
websocket.onclose = onClose; | |||||
websocket.onmessage = onMessage; | |||||
websocket.onerror = onError; | |||||
} | |||||
function onOpen(evt) { | |||||
writeToScreen("connected\n"); | |||||
doSend("Hello from the browser"); | |||||
} | |||||
function onClose(evt) { | |||||
writeToScreen("disconnected\n"); | |||||
} | |||||
function onMessage(evt) { | |||||
writeToScreen("response: " + evt.data + '\n'); | |||||
} | |||||
function onError(evt) { | |||||
writeToScreen('error: ' + evt.data + '\n'); | |||||
websocket.close(); | |||||
} | |||||
function doSend(message) { | |||||
writeToScreen("sent: " + message + '\n'); | |||||
websocket.send(message); | |||||
} | |||||
function writeToScreen(message) { | |||||
console.log(message); | |||||
} | |||||
function init() { | |||||
doConnect(); | |||||
} | |||||
function doDisconnect() { | |||||
websocket.close(); | |||||
} | |||||
window.addEventListener("load", init, false); |
@@ -5,7 +5,7 @@ | |||||
<meta charset="utf-8"> | <meta charset="utf-8"> | ||||
<title>abp</title> | <title>abp</title> | ||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=1" /> | <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=1" /> | ||||
<link rel="stylesheet" href="main.css"> | |||||
<link rel="stylesheet" href="/static/main.css"> | |||||
</head> | </head> | ||||
<body> | <body> | ||||
@@ -19,8 +19,18 @@ | |||||
<img id="ball" src=""/ | <img id="ball" src=""/ | ||||
style=display:none;> | style=display:none;> | ||||
<div id=test>Hello World</div> | |||||
<div id=infoholder class=hidden> | <div id=infoholder class=hidden> | ||||
</div> | </div> | ||||
<div id=pallette> | |||||
<ul> | |||||
<li>add_qubit</li> | |||||
<li>delete_qubit</li> | |||||
<li>hadamard</li> | |||||
<li>cz</li> | |||||
<li>clear</li> | |||||
</ul> | |||||
</div> | |||||
</body> | </body> | ||||
</html> | </html> |