UNPKG

testrumenter

Version:

Command-line utility to test JavaScript code instrumenter

59 lines (49 loc) 1.03 kB
// The Great Computer Language Shootout // http://shootout.alioth.debian.org/ // // contributed by Ian Osgood function A(i,j) { return 1/((i+j)*(i+j+1)/2+i+1); } function Au(u,v) { for (var i=0; i<u.length; ++i) { var t = 0; for (var j=0; j<u.length; ++j) t += A(i,j) * u[j]; v[i] = t; } } function Atu(u,v) { for (var i=0; i<u.length; ++i) { var t = 0; for (var j=0; j<u.length; ++j) t += A(j,i) * u[j]; v[i] = t; } } function AtAu(u,v,w) { Au(u,w); Atu(w,v); } function spectralnorm(n) { var i, u=[], v=[], w=[], vv=0, vBv=0; for (i=0; i<n; ++i) { u[i] = 1; v[i] = w[i] = 0; } for (i=0; i<10; ++i) { AtAu(u,v,w); AtAu(v,u,w); } for (i=0; i<n; ++i) { vBv += u[i]*v[i]; vv += v[i]*v[i]; } return Math.sqrt(vBv/vv); } var total = 0; for (var i = 6; i <= 48; i *= 2) { total += spectralnorm(i); } var expected = 5.086694231303284; if (total != expected) throw "ERROR: bad result: expected " + expected + " but got " + total;