Skip to content
This repository has been archived by the owner on Jul 22, 2020. It is now read-only.

Commit

Permalink
Browse files Browse the repository at this point in the history
Landing the last 3 SunSpider tests (Cordic, RegExp DNA, TagCloud).
  • Loading branch information
John Resig committed Dec 3, 2008
1 parent 1913ba2 commit 3fa73e7
Show file tree
Hide file tree
Showing 4 changed files with 2,133 additions and 0 deletions.
24 changes: 24 additions & 0 deletions tests/MANIFEST.json
Expand Up @@ -215,6 +215,14 @@
category: "SunSpider JavaScript Tests",
tags: ["date","string"]
},
"sunspider-math-cordic": {
file: "sunspider-math-cordic.js",
name: "Trigonometric Calculation",
origin: ["SunSpider", "http://www2.webkit.org/perf/sunspider-0.9/sunspider.html"],
desc: "Calculate values from hyperbolic and trigonometric functions.",
category: "SunSpider JavaScript Tests",
tags: ["math","looping"]
},
"sunspider-math-partial-sums": {
file: "sunspider-math-partial-sums.js",
name: "Partial Sum Calculation",
Expand All @@ -231,6 +239,14 @@
category: "SunSpider JavaScript Tests",
tags: ["array","looping","math"]
},
"sunspider-regexp-dna": {
file: "sunspider-regexp-dna.js",
name: "DNA Conversion",
origin: ["SunSpider", "http://www2.webkit.org/perf/sunspider-0.9/sunspider.html"],
desc: "Convert one DNA sequence to another.",
category: "SunSpider JavaScript Tests",
tags: ["string","regexp"]
},
"sunspider-string-fasta": {
file: "sunspider-string-fasta.js",
name: "DNA Sequence Alignment",
Expand All @@ -239,6 +255,14 @@
category: "SunSpider JavaScript Tests",
tags: ["string","object","looping"]
},
"sunspider-string-tagcloud": {
file: "sunspider-string-tagcloud.html",
name: "Tag Cloud Creation",
origin: ["SunSpider", "http://www2.webkit.org/perf/sunspider-0.9/sunspider.html"],
desc: "Convert a JSON structure into an HTML tag cloud.",
category: "SunSpider JavaScript Tests",
tags: ["string","regexp"]
},
"sunspider-string-unpack-code": {
file: "sunspider-string-unpack-code.js",
name: "Script Unpacking",
Expand Down
95 changes: 95 additions & 0 deletions tests/sunspider-math-cordic.js
@@ -0,0 +1,95 @@
/*
* Copyright (C) Rich Moore. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY CONTRIBUTORS ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/

/////. Start CORDIC

var AG_CONST = 0.6072529350;

function FIXED(X)
{
return X * 65536.0;
}

function FLOAT(X)
{
return X / 65536.0;
}

function DEG2RAD(X)
{
return 0.017453 * (X);
}

var Angles = [
FIXED(45.0), FIXED(26.565), FIXED(14.0362), FIXED(7.12502),
FIXED(3.57633), FIXED(1.78991), FIXED(0.895174), FIXED(0.447614),
FIXED(0.223811), FIXED(0.111906), FIXED(0.055953),
FIXED(0.027977)
];


function cordicsincos() {
var X;
var Y;
var TargetAngle;
var CurrAngle;
var Step;

X = FIXED(AG_CONST); /* AG_CONST * cos(0) */
Y = 0; /* AG_CONST * sin(0) */

TargetAngle = FIXED(28.027);
CurrAngle = 0;
for (Step = 0; Step < 12; Step++) {
var NewX;
if (TargetAngle > CurrAngle) {
NewX = X - (Y >> Step);
Y = (X >> Step) + Y;
X = NewX;
CurrAngle += Angles[Step];
} else {
NewX = X + (Y >> Step);
Y = -(X >> Step) + Y;
X = NewX;
CurrAngle -= Angles[Step];
}
}
}

///// End CORDIC

function cordic( runs ) {
for ( var i = 0 ; i < runs ; i++ ) {
cordicsincos();
}
}

startTest("sunspider-math-cordic");

test("Cordic", function(){
cordic(2500);
});

endTest();

0 comments on commit 3fa73e7

Please sign in to comment.