nickjillings@2131: /*
nickjillings@2131: * Analysis script for WAET
nickjillings@2131: */
nickjillings@2131:
nickjillings@2131: var chartContext;
nickjillings@2131: window.onload = function() {
nickjillings@2131: // Load the Visualization API and the corechart package.
nickjillings@2131: google.charts.load('current', {'packages':['corechart']});
nickjillings@2131: chartContext = new Chart();
nickjillings@2131: }
nickjillings@2131:
nickjillings@2135: function arrayMean(values) {
nickjillings@2135: var mean = 0;
nickjillings@2135: for (var value of values) {
nickjillings@2135: mean += value;
nickjillings@2135: }
nickjillings@2135: mean /= values.length;
nickjillings@2135: return mean;
nickjillings@2135: }
nickjillings@2135:
nickjillings@2135: function percentile(values, n) {
nickjillings@2135: values.sort( function(a,b) {return a - b;} );
nickjillings@2135: // get ordinal rank
nickjillings@2135: var rank = Math.min(Math.floor(values.length*n/100), values.length-1);
nickjillings@2135: return values[rank];
nickjillings@2135: }
nickjillings@2135:
nickjillings@2135: function arrayMin(array) {
nickjillings@2135: // Return the minimum value of an array
nickjillings@2135: var min = array[0];
nickjillings@2135: for (var value of array) {
nickjillings@2135: if (value < min) {
nickjillings@2135: min = value;
nickjillings@2135: }
nickjillings@2135: }
nickjillings@2135: return min;
nickjillings@2135: }
nickjillings@2135:
nickjillings@2135: function arrayMax(array) {
nickjillings@2135: // Return the minimum value of an array
nickjillings@2135: var max = array[0];
nickjillings@2135: for (var value of array) {
nickjillings@2135: if (value > max) {
nickjillings@2135: max = value;
nickjillings@2135: }
nickjillings@2135: }
nickjillings@2135: return max;
nickjillings@2135: }
nickjillings@2135:
nickjillings@2135: function arrayHistogram(values,steps,min,max) {
nickjillings@2135: if (steps == undefined) {
nickjillings@2135: steps = 0.25;
nickjillings@2135: console.log("Warning: arrayHistogram called without steps size set, default to 0.25");
nickjillings@2135: }
nickjillings@2135: if (min == undefined) {min = arrayMin(values);}
nickjillings@2135: if (max == undefined) {max = arrayMax(values);}
nickjillings@2135: var histogram = [];
nickjillings@2135: var index = min;
nickjillings@2135: while(index < max) {
nickjillings@2135: histogram.push({
nickjillings@2135: marker: index,
nickjillings@2135: lt: index,
nickjillings@2135: rt: index+steps,
nickjillings@2135: count: 0
nickjillings@2135: });
nickjillings@2135: index += steps;
nickjillings@2135: }
nickjillings@2135: for (var value of values) {
nickjillings@2135: for (var entry of histogram) {
nickjillings@2135: if (value >= entry.lt && value <= entry.rt) {
nickjillings@2135: entry.count++;
nickjillings@2135: break;
nickjillings@2135: }
nickjillings@2135: }
nickjillings@2135: }
nickjillings@2135: return histogram;
nickjillings@2135: }
nickjillings@2135:
nickjillings@2131: function Chart() {
nickjillings@2134: this.valueData = null;
nickjillings@2134: this.commentData = null;
nickjillings@2134: this.loadStatus = 0;
nickjillings@2135: this.charts = [];
nickjillings@2131:
nickjillings@2134: var XMLHttp = new XMLHttpRequest();
nickjillings@2134: XMLHttp.parent = this;
nickjillings@2134: XMLHttp.open("GET","../scripts/score_parser.php?format=JSON",true);
nickjillings@2134: XMLHttp.onload = function() {
nickjillings@2134: // Now we have the JSON data, extract
nickjillings@2134: this.parent.valueData = JSON.parse(this.responseText);
nickjillings@2134: this.parent.loadStatus++;
nickjillings@2131: }
nickjillings@2134: XMLHttp.send();
nickjillings@2134: var XMLHttp2 = new XMLHttpRequest();
nickjillings@2134: XMLHttp2.parent = this;
nickjillings@2134: XMLHttp2.open("GET","../scripts/comment_parser.php?format=JSON",true);
nickjillings@2134: XMLHttp2.onload = function() {
nickjillings@2134: // Now we have the JSON data, extract
nickjillings@2134: this.parent.commentData = JSON.parse(this.responseText);
nickjillings@2134: this.parent.loadStatus++;
nickjillings@2134: }
nickjillings@2134: XMLHttp2.send();
nickjillings@2131:
nickjillings@2135: this.chartObject = function(name) {
nickjillings@2135: // Create the charting object
nickjillings@2135: this.name = name;
nickjillings@2135: this.root = document.createElement("div");
nickjillings@2135: this.root.className = "chart-holder";
nickjillings@2135: this.root.setAttribute("name",name);
nickjillings@2135: this.chartDOM = document.createElement("div");
nickjillings@2135: this.tableDOM = document.createElement("div");
nickjillings@2135: this.latexDOM = document.createElement("div");
nickjillings@2135: this.downloadDOM = document.createElement("div");
nickjillings@2135: this.chart = undefined;
nickjillings@2135: this.data = new google.visualization.DataTable();
nickjillings@2135: this.options = {};
nickjillings@2135: this.print = document.createElement("button");
nickjillings@2135: this.handleEvent = function() {
nickjillings@2135: // Only used to handle the chart.event.addListener(this,'ready') callback
nickjillings@2135: this.downloadDOM.innerHTML = 'Download';
nickjillings@2135: }
nickjillings@2135:
nickjillings@2135: this.root.appendChild(this.chartDOM);
nickjillings@2135: this.root.appendChild(this.tableDOM);
nickjillings@2135: this.root.appendChild(this.latexDOM);
nickjillings@2135: this.root.appendChild(this.print);
nickjillings@2135: this.print.textContent = "Download";
nickjillings@2135: this.print.addEventListener("click",this);
nickjillings@2135: this.root.appendChild(this.downloadDOM);
nickjillings@2135: this.buildTable = function() {
nickjillings@2135: var table = document.createElement("table");
nickjillings@2135: table.border = "1";
nickjillings@2135: for (var rowIndex=0; rowIndex