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@2181: function boxplotRow(array) { nickjillings@2181: // Take an array of element values and return array of computed intervals nickjillings@2181: var result = { nickjillings@2181: median : percentile(array,50), nickjillings@2181: pct25 : percentile(array,25), nickjillings@2181: pct75 : percentile(array,75), nickjillings@2181: IQR : null, nickjillings@2181: min: null, nickjillings@2181: max: null, nickjillings@2181: outliers: new Array() nickjillings@2181: } nickjillings@2181: result.IQR = result.pct75-result.pct25; nickjillings@2181: var rest = []; nickjillings@2181: var pct75_IQR = result.pct75+1.5*result.IQR; nickjillings@2181: var pct25_IQR = result.pct25-1.5*result.IQR; nickjillings@2181: for (var i=0; i pct75_IQR || point < pct25_IQR) { nickjillings@2181: result.outliers.push(point); nickjillings@2181: } else { nickjillings@2181: rest.push(point); nickjillings@2181: } nickjillings@2181: } nickjillings@2181: result.max = arrayMax(rest); nickjillings@2181: result.min = arrayMin(rest); nickjillings@2181: return result; nickjillings@2181: nickjillings@2181: } nickjillings@2181: 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@2136: this.sortDataButton = document.createElement("button"); nickjillings@2136: this.sortDataButton.textContent = "Sort by Data"; nickjillings@2136: this.sortDataButton.addEventListener("click",this); nickjillings@2136: this.sortDataButton.setAttribute("name","sort-data"); nickjillings@2136: this.sortNameButton = document.createElement("button"); nickjillings@2136: this.sortNameButton.textContent = "Sort by Name"; nickjillings@2136: this.sortNameButton.addEventListener("click",this); nickjillings@2136: this.sortNameButton.setAttribute("name","sort-name"); nickjillings@2136: this.draw = function() { nickjillings@2136: if (this.chart == undefined) {return;} nickjillings@2136: this.tableDOM.innerHTML = null; nickjillings@2136: this.latexDOM.innerHTML = null; nickjillings@2136: this.buildTable(); nickjillings@2136: this.writeLatex(); nickjillings@2136: this.chart.draw(this.data,this.options); nickjillings@2136: } nickjillings@2136: this.sortData = function() { nickjillings@2173: this.data.sort(1); nickjillings@2136: } nickjillings@2136: this.sortName = function() { nickjillings@2173: this.data.sort(0); nickjillings@2136: } nickjillings@2135: this.handleEvent = function() { nickjillings@2135: // Only used to handle the chart.event.addListener(this,'ready') callback nickjillings@2136: switch(event.currentTarget.getAttribute("name")) nickjillings@2136: { nickjillings@2136: case "download": nickjillings@2136: window.open(this.chart.getImageURI()); nickjillings@2136: break; nickjillings@2136: case "sort-data": nickjillings@2136: this.sortData(); nickjillings@2136: this.draw(); nickjillings@2136: break; nickjillings@2136: case "sort-name": nickjillings@2136: this.sortName(); nickjillings@2136: this.draw(); nickjillings@2136: break; nickjillings@2136: } 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@2136: this.root.appendChild(this.sortDataButton); nickjillings@2136: this.root.appendChild(this.sortNameButton); nickjillings@2135: this.root.appendChild(this.print); nickjillings@2135: this.print.textContent = "Download"; nickjillings@2136: this.print.setAttribute("name","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@2172: var numRows = this.data.getNumberOfRows(); nickjillings@2172: var numColumns = this.data.getNumberOfColumns(); nickjillings@2172: for (var columnIndex=0; columnIndex