Browse Source

Get data into browser

master
Pete Shadbolt 8 years ago
parent
commit
9a794c9618
10 changed files with 206 additions and 177 deletions
  1. +20
    -6
      abp/server.py
  2. +24
    -0
      static/curve.js
  3. +20
    -0
      static/graph.js
  4. +23
    -0
      static/grid.js
  5. +3
    -0
      static/index.html
  6. +46
    -0
      static/interaction.js
  7. +6
    -168
      static/main.js
  8. +34
    -0
      static/materials.js
  9. +4
    -3
      static/poll.js
  10. +26
    -0
      tests/test_json.py

+ 20
- 6
abp/server.py View File

@@ -7,6 +7,7 @@ import json
import threading
import time
import os
from graph import GraphState


class VizHandler(SimpleHTTPRequestHandler):
@@ -22,7 +23,7 @@ class VizHandler(SimpleHTTPRequestHandler):
self.send_header('Content-Type', 'application/json')
self.end_headers()
state = self.server.state
self.wfile.write(json.dumps({"state": "{}".format(state)}))
self.wfile.write(state.to_json())

def do_GET(self, *args, **kwargs):
""" Someone belled the server """
@@ -62,16 +63,29 @@ class Server(SocketServer.TCPServer):
thread.start()
print "Server running at http://localhost:{}/".format(self.port)



def demograph():
""" A graph for testing with """
g = GraphState()
g.add_edge(0, 1)
g.add_edge(1, 2)
g.add_edge(2, 0)
g.add_edge(0, 3)
g.add_edge(100, 200)
return g


if __name__ == '__main__':
os.chdir(os.path.join(os.path.dirname(__file__), "../static"))
print os.curdir
os.chdir("/home/pete/physics/abp/static")
server = Server()
server.start()

i = 0
g = demograph()


while True:
server.update(i)
i += 1
server.update(g)
time.sleep(1)

server.shutdown()

+ 24
- 0
static/curve.js View File

@@ -0,0 +1,24 @@
// Curve settings
var curveProperties = {
splineDensity: 30,
curvature: 10
};

// Add a curved edge between two points
function makeEdge(e) {
// Make the geometry of the curve
var a = new THREE.Vector3(e.start[0], e.start[1], e.start[2]);
var b = new THREE.Vector3(e.end[0], e.end[1], e.end[2]);
var length = new THREE.Vector3().subVectors(a, b).length();
var bend = new THREE.Vector3(length / curveProperties.curvature, length / curveProperties.curvature, 0);
var mid = new THREE.Vector3().add(a).add(b).multiplyScalar(0.5).add(bend);
var spline = new THREE.CatmullRomCurve3([a, mid, b]);
var geometry = new THREE.Geometry();
var splinePoints = spline.getPoints(curveProperties.splineDensity);
Array.prototype.push.apply(geometry.vertices, splinePoints);

// Make the actual Object3d thing
var line = new THREE.Line(geometry, materials.edge);
return line;
}


+ 20
- 0
static/graph.js View File

@@ -0,0 +1,20 @@
function buildGraph(json) {
// Add all the qubits
var geometry = new THREE.Geometry();
var vertex = new THREE.Vector3(0, 0, 0);
geometry.vertices.push(vertex);
var nodes = new THREE.Points(geometry, materials.node);

// Add all the edges
var edges = new THREE.Object3D();
edges.add(makeEdge({
"start": [0, 0, 0],
"end": [1, 1, 1]
}));
// Construct and return
var graph = new THREE.Object3D();
graph.add(nodes);
graph.add(edges);
return graph;
}

+ 23
- 0
static/grid.js View File

@@ -0,0 +1,23 @@

// Make a grid
function makeGrid(side, n, color) {
var markers = new THREE.Object3D();
var gridStyle = {
color: color,
transparent: true,
linewidth: 1,
opacity: 0.5
};
var material = new THREE.LineBasicMaterial(gridStyle);
for (var i = -n / 2; i <= n / 2; ++i) {
var geometry = new THREE.Geometry();
geometry.vertices.push(new THREE.Vector3(side * i / n, -side / 2, 0));
geometry.vertices.push(new THREE.Vector3(side * i / n, side / 2, 0));
var line = new THREE.Line(geometry, material);
var line90 = line.clone();
line90.rotation.z = Math.PI / 2;
markers.add(line);
markers.add(line90);
}
return markers;
}

+ 3
- 0
static/index.html View File

@@ -11,7 +11,10 @@
<body>
<script type="text/javascript" src="three.js"></script>
<script type="text/javascript" src="libs.js"></script>
<script type="text/javascript" src="materials.js"></script>
<script type="text/javascript" src="poll.js"></script>
<script type="text/javascript" src="grid.js"></script>
<script type="text/javascript" src="curve.js"></script>
<script type="text/javascript" src="main.js"></script>
<img id="ball" src=""/
style=display:none;>


+ 46
- 0
static/interaction.js View File

@@ -0,0 +1,46 @@
// Gets a reference to the node nearest to the mouse cursor
function nearestNode() {
raycaster.setFromCamera(mouse, camera);
for (var i = 0; i < nodeGeometry.vertices.length; ++i) {
if (raycaster.ray.distanceSqToPoint(nodeGeometry.vertices[i]) < 0.01) {
return i;
}
}
return undefined;
}


// Find out: what is the mouse pointing at?
function checkIntersections() {
var new_selection = nearestNode();
if (new_selection != selection) {
selection = new_selection;
info.className = selection ? "visible" : "hidden";
info.innerHTML = selection ? nodeGeometry.labels[new_selection] : info.innerHTML;
render();
}
}

// Update the mouse position tracker
function onMouseMove(event) {
mouse.wasClick = false;
mouse.absx = event.clientX;
mouse.absy = event.clientY;
mouse.x = (event.clientX / window.innerWidth) * 2 - 1;
mouse.y = -(event.clientY / window.innerHeight) * 2 + 1;
w = 200;
h = 15;
info.style.top = mouse.absy - h - 40 + "px";
info.style.left = mouse.absx - w / 2 + "px";
checkIntersections();
}

// Add qubits or whatever
function onClick(event){
if (!selection){return;}
console.log(nodeGeometry.vertices[selection]);
qubits.geometry.dynamic = true;
qubits.geometry.vertices.push(nodeGeometry.vertices[selection].clone());
qubits.geometry.verticesNeedUpdate = true;
}


+ 6
- 168
static/main.js View File

@@ -5,174 +5,18 @@ if (typeof console === "undefined") {
};
}

var controls, renderer, raycaster, scene, info, nodeGeometry, selection;
var mouse = {
"x": 0,
"y": 0
};
var materials = {};
var curveProperties = {
splineDensity: 30,
curvature: 10
};
var camera;
var qubits;
var controls, renderer, raycaster, scene, selection, camera;

// Run on startup
window.onload = init;

// Add a curved edge between two points
function makeEdge(e) {
// Make the geometry of the curve
var a = new THREE.Vector3(e.start[0], e.start[1], e.start[2]);
var b = new THREE.Vector3(e.end[0], e.end[1], e.end[2]);
var length = new THREE.Vector3().subVectors(a, b).length();
var bend = new THREE.Vector3(length / curveProperties.curvature, length / curveProperties.curvature, 0);
var mid = new THREE.Vector3().add(a).add(b).multiplyScalar(0.5).add(bend);
var spline = new THREE.CatmullRomCurve3([a, mid, b]);
var geometry = new THREE.Geometry();
var splinePoints = spline.getPoints(curveProperties.splineDensity);
Array.prototype.push.apply(geometry.vertices, splinePoints);

// Make the actual Object3d thing
var line = new THREE.Line(geometry, materials.edge);
return line;
}

function makeQubits() {
qubitGeometry = new THREE.Geometry();
qubitGeometry.labels = [];
var vertex = new THREE.Vector3(0, 0, 0);
qubitGeometry.vertices.push(vertex);
particles = new THREE.Points(qubitGeometry, materials.qubit);
return particles;
}

// Clear the whole scene
function makeScene() {
// Scene, controls, camera and so on
var myScene = new THREE.Scene();

// Materials
var lineStyle = {
color: "gray",
transparent: false,
linewidth: 1
};
materials.edge = new THREE.LineBasicMaterial(lineStyle);

var pointStyle = {
color: "0xcccccc",
size: 0.1,
map: materials.sprite,
alphaTest: 0.5,
transparent: true,
};
materials.point = new THREE.PointsMaterial(pointStyle);

var qubitStyle = {
size: 0.6,
map: materials.sprite,
alphaTest: 0.5,
transparent: true,
color: "red"
};
materials.qubit = new THREE.PointsMaterial(qubitStyle);

// Build all the edges
//var edgeGroup = new THREE.Object3D();

qubits = makeQubits();
myScene.add(qubits);

// Build all the nodes
nodeGeometry = new THREE.Geometry();
nodeGeometry.labels = [];
for (var i = 0; i < 10; ++i) {
for (var j = 0; j < 10; ++j) {
var vertex = new THREE.Vector3(i - 5, j - 5, 0);
nodeGeometry.vertices.push(vertex);
nodeGeometry.labels.push("Click to add a qubit at (" + i + ", " + j + ")");
}
}

var particles = new THREE.Points(nodeGeometry, materials.point);

var grid = makeGrid(10, 10, "lightgray");
myScene.add(grid);

// Add the above stuff into the scene and return
//myScene.add(edgeGroup);
myScene.add(particles);
myScene.add(makeGrid(10, 10, "lightgray"));
return myScene;
}

// Gets a reference to the node nearest to the mouse cursor
function nearestNode() {
raycaster.setFromCamera(mouse, camera);
for (var i = 0; i < nodeGeometry.vertices.length; ++i) {
if (raycaster.ray.distanceSqToPoint(nodeGeometry.vertices[i]) < 0.01) {
return i;
}
}
return undefined;
}

// Find out: what is the mouse pointing at?
function checkIntersections() {
var new_selection = nearestNode();
if (new_selection != selection) {
selection = new_selection;
info.className = selection ? "visible" : "hidden";
info.innerHTML = selection ? nodeGeometry.labels[new_selection] : info.innerHTML;
render();
}
}

// Make a grid
function makeGrid(side, n, color) {
var markers = new THREE.Object3D();
var gridStyle = {
color: color,
transparent: true,
linewidth: 1,
opacity: 0.5
};
var material = new THREE.LineBasicMaterial(gridStyle);
for (var i = -n / 2; i < n / 2; ++i) {
var geometry = new THREE.Geometry();
geometry.vertices.push(new THREE.Vector3(side * i / n, -side / 2, 0));
geometry.vertices.push(new THREE.Vector3(side * i / n, side / 2, 0));
var line = new THREE.Line(geometry, material);
var line90 = line.clone();
line90.rotation.z = Math.PI / 2;
markers.add(line);
markers.add(line90);
}
return markers;
}

// Handle mouse movement
function onMouseMove(event) {
mouse.wasClick = false;
mouse.absx = event.clientX;
mouse.absy = event.clientY;
mouse.x = (event.clientX / window.innerWidth) * 2 - 1;
mouse.y = -(event.clientY / window.innerHeight) * 2 + 1;
w = 200;
h = 15;
info.style.top = mouse.absy - h - 40 + "px";
info.style.left = mouse.absx - w / 2 + "px";
checkIntersections();
}

function onClick(event){
if (!selection){return;}
console.log(nodeGeometry.vertices[selection]);
qubits.geometry.dynamic = true;
qubits.geometry.vertices.push(nodeGeometry.vertices[selection].clone());
qubits.geometry.verticesNeedUpdate = true;
}

// Render the current frame to the screen
function render() {
@@ -189,8 +33,6 @@ function loopForever() {
// This just organises kickoff
function startMainLoop() {
scene = makeScene();
renderer.domElement.addEventListener("mousemove", onMouseMove, false);
renderer.domElement.addEventListener("click", onClick, false);
controls.addEventListener("change", render);
loopForever();
}
@@ -201,23 +43,19 @@ function init() {
// Measure things, get references
var width = window.innerWidth;
var height = window.innerHeight;
info = document.getElementById("infoholder");

materials.sprite = new THREE.Texture(document.getElementById("ball"));
materials.sprite.needsUpdate = true;

// Renderer
renderer = new THREE.WebGLRenderer({
antialias: true
});
renderer = new THREE.WebGLRenderer();
renderer.setSize(width, height);
renderer.setClearColor(0xffffff, 1);
document.querySelector("body").appendChild(renderer.domElement);

// Time to load the materials
loadMaterials();

// Camera, controls, raycaster
camera = new THREE.PerspectiveCamera(45, width / height, 0.3, 100);
controls = new THREE.OrbitControls(camera);
raycaster = new THREE.Raycaster();

// Center the camera
controls.center.set(0, 0, 0);


+ 34
- 0
static/materials.js View File

@@ -0,0 +1,34 @@
var textures = {};
var materials = {};

// Load the site texture from the data URI
function loadMaterials(argument) {
textures.sprite = new THREE.Texture(document.getElementById("ball"));
textures.sprite.needsUpdate = true;

var lineStyle = {
color: "gray",
transparent: false,
linewidth: 1
};
materials.edge = new THREE.LineBasicMaterial(lineStyle);

var pointStyle = {
color: 0xcccccc,
size: 0.1,
map: textures.sprite,
alphaTest: 0.5,
transparent: true,
};
materials.point = new THREE.PointsMaterial(pointStyle);

var qubitStyle = {
size: 0.6,
map: textures.sprite,
alphaTest: 0.5,
transparent: true,
color: "red"
};

materials.qubit = new THREE.PointsMaterial(qubitStyle);
}

+ 4
- 3
static/poll.js View File

@@ -5,12 +5,13 @@ function poll() {
var xhr = new XMLHttpRequest();

xhr.onload = function() {
state = JSON.parse(xhr.response);
soft_console.innerHTML = "\n" + xhr.responseText;
state = JSON.parse(xhr.responseText);
console.log(state);
//soft_console.innerHTML = "\n" + xhr.responseText;
};

xhr.onerror = function(e){
soft_console.innerHTML = "\n" + "Lost connection to server";
//soft_console.innerHTML = "\n" + "Lost connection to server";
};

xhr.open("GET", "/state", true);


+ 26
- 0
tests/test_json.py View File

@@ -0,0 +1,26 @@
from abp.graph import GraphState, DiffedGraphState
from abp import clifford
import time
import json


def demograph():
""" A graph for testing with """
g = GraphState()
g.add_edge(0, 1)
g.add_edge(1, 2)
g.add_edge(2, 0)
g.add_edge(0, 3)
g.add_edge(100, 200)
return g


def test_json_basic():
""" Test that we can export to JSON """
g = demograph()
js = g.to_json()
assert "ngbh" in js
assert "vops" in js
json.loads(js)



Loading…
Cancel
Save