@@ -5,6 +5,7 @@ abj.meta = {}; | |||||
ngbh = abj.ngbh; | ngbh = abj.ngbh; | ||||
vops = abj.vops; | vops = abj.vops; | ||||
meta = abj.meta; | meta = abj.meta; | ||||
abj.add_node = function(node, m) { | abj.add_node = function(node, m) { | ||||
ngbh[node] = {}; | ngbh[node] = {}; | ||||
vops[node] = clifford.hadamard; | vops[node] = clifford.hadamard; | ||||
@@ -45,7 +46,9 @@ abj.toggle_edge = function(a, b) { | |||||
abj.get_swap = function(node, avoid) { | abj.get_swap = function(node, avoid) { | ||||
for (var i in ngbh[node]) { | for (var i in ngbh[node]) { | ||||
if (i != avoid) {return i;} | |||||
if (i != avoid) { | |||||
return i; | |||||
} | |||||
} | } | ||||
return avoid; | return avoid; | ||||
}; | }; | ||||
@@ -53,7 +56,7 @@ abj.get_swap = function(node, avoid) { | |||||
abj.remove_vop = function(node, avoid) { | abj.remove_vop = function(node, avoid) { | ||||
var swap_qubit = get_swap(node, avoid); | var swap_qubit = get_swap(node, avoid); | ||||
var decomposition = decompositions[vops[node]]; | var decomposition = decompositions[vops[node]]; | ||||
for (var i=decomposition.length-1; i >=0; --i) { | |||||
for (var i = decomposition.length - 1; i >= 0; --i) { | |||||
var v = decomposition[i]; | var v = decomposition[i]; | ||||
local_complementation(v == "x" ? a : swap_qubit); | local_complementation(v == "x" ? a : swap_qubit); | ||||
} | } | ||||
@@ -61,8 +64,8 @@ abj.remove_vop = function(node, avoid) { | |||||
abj.local_complementation = function(node) { | abj.local_complementation = function(node) { | ||||
var keys = Object.keys(ngbh[node]); | var keys = Object.keys(ngbh[node]); | ||||
for (var i=0; i < keys.length; ++i) { | |||||
for (var j=i+1; j < keys.length; ++j) { | |||||
for (var i = 0; i < keys.length; ++i) { | |||||
for (var j = i + 1; j < keys.length; ++j) { | |||||
toggle_edge(keys[i], keys[j]); | toggle_edge(keys[i], keys[j]); | ||||
} | } | ||||
vops[i] = times_table[vops[keys[i]]][sqz_h]; | vops[i] = times_table[vops[keys[i]]][sqz_h]; | ||||
@@ -75,15 +78,15 @@ abj.act_local_rotation = function(node, operation) { | |||||
vops[node] = times_table[rotation][vops[node]]; | vops[node] = times_table[rotation][vops[node]]; | ||||
}; | }; | ||||
abj.act_hadamard = function(node){ | |||||
abj.act_hadamard = function(node) { | |||||
act_local_rotation(node, 10); | act_local_rotation(node, 10); | ||||
}; | }; | ||||
abj.is_sole_member = function(node, group){ | |||||
abj.is_sole_member = function(node, group) { | |||||
return group.length == 1 && group[0] == node; | return group.length == 1 && group[0] == node; | ||||
}; | }; | ||||
abj.act_cz = function(a, b){ | |||||
abj.act_cz = function(a, b) { | |||||
if (is_sole_member(ngbh[a], b)) { | if (is_sole_member(ngbh[a], b)) { | ||||
remove_vop(a, b); | remove_vop(a, b); | ||||
} | } | ||||
@@ -97,7 +100,7 @@ abj.act_cz = function(a, b){ | |||||
var new_state = cz_table[edge ? 1 : 0][vops[a]][vops[b]]; | var new_state = cz_table[edge ? 1 : 0][vops[a]][vops[b]]; | ||||
vops[a] = new_state[1]; | vops[a] = new_state[1]; | ||||
vops[b] = new_state[2]; | vops[b] = new_state[2]; | ||||
if (new_state[0] != edge){ | |||||
if (new_state[0] != edge) { | |||||
toggle_edge(a, b); | toggle_edge(a, b); | ||||
} | } | ||||
}; | }; | ||||
@@ -107,7 +110,7 @@ abj.edgelist = function() { | |||||
var output = []; | var output = []; | ||||
for (var i in ngbh) { | for (var i in ngbh) { | ||||
for (var j in ngbh[i]) { | for (var j in ngbh[i]) { | ||||
if (!Object.prototype.hasOwnProperty.call(seen, j)){ | |||||
if (!Object.prototype.hasOwnProperty.call(seen, j)) { | |||||
output.push([i, j]); | output.push([i, j]); | ||||
} | } | ||||
} | } | ||||
@@ -120,4 +123,3 @@ abj.log_graph_state = function() { | |||||
console.log(JSON.stringify(vops)); | console.log(JSON.stringify(vops)); | ||||
console.log(JSON.stringify(ngbh)); | console.log(JSON.stringify(ngbh)); | ||||
}; | }; | ||||
@@ -1,7 +1,7 @@ | |||||
var colors = ["red", "green", "yellow", "blue", "pink", "orange", "purple"]; | var colors = ["red", "green", "yellow", "blue", "pink", "orange", "purple"]; | ||||
var ws; | var ws; | ||||
function connect_to_server() { | |||||
function connectToServer() { | |||||
ws = new WebSocket("ws://localhost:5000"); | ws = new WebSocket("ws://localhost:5000"); | ||||
ws.onopen = function() | ws.onopen = function() | ||||
{ | { | ||||
@@ -14,7 +14,6 @@ | |||||
<script type="text/javascript" src="tables.js"></script> | <script type="text/javascript" src="tables.js"></script> | ||||
<script type="text/javascript" src="anders_briegel.js"></script> | <script type="text/javascript" src="anders_briegel.js"></script> | ||||
<script type="text/javascript" src="materials.js"></script> | <script type="text/javascript" src="materials.js"></script> | ||||
<script type="text/javascript" src="api.js"></script> | |||||
<script type="text/javascript" src="graph.js"></script> | <script type="text/javascript" src="graph.js"></script> | ||||
<script type="text/javascript" src="main.js"></script> | <script type="text/javascript" src="main.js"></script> | ||||
<img id="ball" src=""/ | <img id="ball" src=""/ | ||||
@@ -10,7 +10,7 @@ window.onload = init; | |||||
function makeScene() { | function makeScene() { | ||||
var myScene = new THREE.Scene(); | var myScene = new THREE.Scene(); | ||||
var grid = new THREE.GridHelper(10, 1); | var grid = new THREE.GridHelper(10, 1); | ||||
grid.rotation.x = Math.PI/2; | |||||
grid.rotation.x = Math.PI / 2; | |||||
grid.setColors(0xdddddd, 0xeeeeee); | grid.setColors(0xdddddd, 0xeeeeee); | ||||
myScene.add(grid); | myScene.add(grid); | ||||
return myScene; | return myScene; | ||||
@@ -19,33 +19,30 @@ function makeScene() { | |||||
// Render the current frame to the screen | // Render the current frame to the screen | ||||
function render() { | function render() { | ||||
requestAnimationFrame(function () { | |||||
requestAnimationFrame(function() { | |||||
renderer.render(scene, camera); | renderer.render(scene, camera); | ||||
}); | }); | ||||
} | } | ||||
// Someone resized the window | // Someone resized the window | ||||
function onWindowResize(evt){ | |||||
function onWindowResize(evt) { | |||||
camera.aspect = window.innerWidth / window.innerHeight; | camera.aspect = window.innerWidth / window.innerHeight; | ||||
camera.updateProjectionMatrix(); | camera.updateProjectionMatrix(); | ||||
renderer.setSize(window.innerWidth, window.innerHeight); | renderer.setSize(window.innerWidth, window.innerHeight); | ||||
render(); | render(); | ||||
} | } | ||||
function bind_events() { | |||||
window.addEventListener("resize", onWindowResize, false); | |||||
controls.addEventListener("change", render); | |||||
} | |||||
// Called on startup | // Called on startup | ||||
function init() { | function init() { | ||||
// Renderer | // Renderer | ||||
renderer = new THREE.WebGLRenderer({"antialias":true}); | |||||
renderer = new THREE.WebGLRenderer({ | |||||
"antialias": true | |||||
}); | |||||
renderer.setSize(window.innerWidth, window.innerHeight); | renderer.setSize(window.innerWidth, window.innerHeight); | ||||
renderer.setClearColor(0xffffff, 1); | renderer.setClearColor(0xffffff, 1); | ||||
document.querySelector("body").appendChild(renderer.domElement); | document.querySelector("body").appendChild(renderer.domElement); | ||||
window.addEventListener("resize", onWindowResize, false); | |||||
// Time to load the materials | // Time to load the materials | ||||
loadMaterials(); | loadMaterials(); | ||||
@@ -55,11 +52,11 @@ function init() { | |||||
controls = new THREE.OrbitControls(camera); | controls = new THREE.OrbitControls(camera); | ||||
controls.center.set(0, 0, 0); | controls.center.set(0, 0, 0); | ||||
controls.rotateSpeed = 0.2; | controls.rotateSpeed = 0.2; | ||||
controls.addEventListener("change", render); | |||||
camera.position.set(0, 0, 20); | camera.position.set(0, 0, 20); | ||||
// Run | // Run | ||||
bind_events(); | |||||
scene = makeScene(); | scene = makeScene(); | ||||
connect_to_server(); | |||||
connectToServer(); | |||||
render(); | render(); | ||||
} | } |
@@ -1,5 +1,11 @@ | |||||
var textures = {}; | var textures = {}; | ||||
var materials = {}; | var materials = {}; | ||||
// Curve settings | |||||
var curveProperties = { | |||||
splineDensity: 10, | |||||
curvature: 100 | |||||
}; | |||||
// Load the site texture from the data URI | // Load the site texture from the data URI | ||||
function loadMaterials(argument) { | function loadMaterials(argument) { | ||||
@@ -33,12 +39,6 @@ function loadMaterials(argument) { | |||||
materials.qubit = new THREE.PointsMaterial(qubitStyle); | materials.qubit = new THREE.PointsMaterial(qubitStyle); | ||||
} | } | ||||
// Curve settings | |||||
var curveProperties = { | |||||
splineDensity: 10, | |||||
curvature: 100 | |||||
}; | |||||
// Add a curved edge between two points | // Add a curved edge between two points | ||||
function makeCurve(a, b) { | function makeCurve(a, b) { | ||||
// Make the geometry of the curve | // Make the geometry of the curve | ||||