math-abs.js 2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
// Copyright 2014 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

function Module(stdlib) {
  "use asm";

  var abs = stdlib.Math.abs;

  // f: double -> double
  function f(a) {
    a = +a;
    return +abs(a);
  }

  // g: unsigned -> double
  function g(a) {
18 19
    a = a | 0;
    return +abs(+(a >>> 0));
20 21 22 23 24
  }

  // h: signed -> double
  function h(a) {
    a = a|0;
25
    return +abs(+(a | 0));
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
  }

  return { f: f, g: g, h: h };
}

var m = Module({ Math: Math });
var f = m.f;
var g = m.g;
var h = m.h;

assertTrue(isNaN(f(NaN)));
assertTrue(isNaN(f(undefined)));
assertTrue(isNaN(f(function() {})));

assertEquals("Infinity", String(1/f(0)));
assertEquals("Infinity", String(1/f(-0)));
assertEquals("Infinity", String(f(Infinity)));
assertEquals("Infinity", String(f(-Infinity)));

assertEquals(0,   f(0));
assertEquals(0.1, f(0.1));
assertEquals(0.5, f(0.5));
assertEquals(0.1, f(-0.1));
assertEquals(0.5, f(-0.5));
assertEquals(1,   f(1));
assertEquals(1.1, f(1.1));
assertEquals(1.5, f(1.5));
assertEquals(1,   f(-1));
assertEquals(1.1, f(-1.1));
assertEquals(1.5, f(-1.5));

assertEquals(0,          g(0));
assertEquals(0,          g(0.1));
assertEquals(0,          g(0.5));
assertEquals(0,          g(-0.1));
assertEquals(0,          g(-0.5));
assertEquals(1,          g(1));
assertEquals(1,          g(1.1));
assertEquals(1,          g(1.5));
assertEquals(4294967295, g(-1));
assertEquals(4294967295, g(-1.1));
assertEquals(4294967295, g(-1.5));

assertEquals(0, h(0));
assertEquals(0, h(0.1));
assertEquals(0, h(0.5));
assertEquals(0, h(-0.1));
assertEquals(0, h(-0.5));
assertEquals(1, h(1));
assertEquals(1, h(1.1));
assertEquals(1, h(1.5));
assertEquals(1, h(-1));
assertEquals(1, h(-1.1));
assertEquals(1, h(-1.5));

assertEquals(Number.MIN_VALUE, f(Number.MIN_VALUE));
assertEquals(Number.MIN_VALUE, f(-Number.MIN_VALUE));
assertEquals(Number.MAX_VALUE, f(Number.MAX_VALUE));
assertEquals(Number.MAX_VALUE, f(-Number.MAX_VALUE));