core: killed all math wrappers

This commit is contained in:
Stefan Plantikow
2011-12-23 02:31:24 +01:00
parent 49d36c7f85
commit 57ac67a5aa
7 changed files with 195 additions and 796 deletions

View File

@@ -1,118 +1,95 @@
/*
Module: f32
Floating point operations and constants for `f32`
This exposes the same operations as `math`, just for `f32` even though
they do not show up in the docs right now!
*/
export t;
export
acos,
asin,
atan,
atan2,
cbrt,
ceil,
cos,
cosh,
erf,
erfc,
exp,
expm1,
exp2,
abs,
sub_pos,
floor,
mul_add,
fmax,
fmin,
nextafter,
frexp,
hypot,
ldexp,
lgamma,
ln,
logb,
ln1p,
log10,
log2,
ilogb,
modf,
pow,
rem,
rint,
round,
sin,
sinh,
sqrt,
tan,
tanh,
tgamma,
trunc;
export consts;
export radix, mantissa_digits, digits, epsilon, min_value, max_value,
min_exp, max_exp, min_10_exp, max_10_exp;
// PORT
import cops = cmath::c_float;
type t = f64;
import
cops::acos,
cops::asin,
cops::atan,
cops::atan2,
cops::cbrt,
cops::ceil,
cops::cos,
cops::cosh,
cops::erf,
cops::erfc,
cops::exp,
cops::expm1,
cops::exp2,
cops::abs,
cops::sub_pos,
cops::floor,
cops::mul_add,
cops::max,
cops::min,
cops::nextafter,
cops::fmod,
cops::frexp,
cops::hypot,
cops::ldexp,
cops::lgamma,
cops::ln,
cops::logb,
cops::ln1p,
cops::log10,
cops::log2,
cops::ilogb,
cops::modf,
cops::pow,
cops::rem,
cops::rint,
cops::round,
cops::sin,
cops::sinh,
cops::sqrt,
cops::tan,
cops::tanh,
cops::tgamma,
cops::trunc;
import cmath::c_float::*;
type t = f32;
/* Const: NaN */
const NaN: f32 = 0.0f32/0.0f32;
/* Const: infinity */
const infinity: f32 = 1.0f32/0.0f32;
/* Const: neg_infinity */
const neg_infinity: f32 = -1.0f32/0.0f32;
/* Predicate: isNaN */
pure fn isNaN(f: f32) -> bool { f != f }
/* Function: add */
pure fn add(x: f32, y: f32) -> f32 { ret x + y; }
/* Function: sub */
pure fn sub(x: f32, y: f32) -> f32 { ret x - y; }
/* Function: mul */
pure fn mul(x: f32, y: f32) -> f32 { ret x * y; }
/* Function: div */
pure fn div(x: f32, y: f32) -> f32 { ret x / y; }
/* Function: rem */
pure fn rem(x: f32, y: f32) -> f32 { ret x % y; }
/* Predicate: lt */
pure fn lt(x: f32, y: f32) -> bool { ret x < y; }
/* Predicate: le */
pure fn le(x: f32, y: f32) -> bool { ret x <= y; }
/* Predicate: eq */
pure fn eq(x: f32, y: f32) -> bool { ret x == y; }
/* Predicate: ne */
pure fn ne(x: f32, y: f32) -> bool { ret x != y; }
/* Predicate: ge */
pure fn ge(x: f32, y: f32) -> bool { ret x >= y; }
/* Predicate: gt */
pure fn gt(x: f32, y: f32) -> bool { ret x > y; }
/*
Predicate: positive
Returns true if `x` is a positive number, including +0.0f320 and +Infinity.
*/
pure fn positive(x: f32) -> bool
{ ret x > 0.0f32 || (1.0f32/x) == infinity; }
/*
Predicate: negative
Returns true if `x` is a negative number, including -0.0f320 and -Infinity.
*/
pure fn negative(x: f32) -> bool
{ ret x < 0.0f32 || (1.0f32/x) == neg_infinity; }
/*
Predicate: nonpositive
Returns true if `x` is a negative number, including -0.0f320 and -Infinity.
(This is the same as `f32::negative`.)
*/
pure fn nonpositive(x: f32) -> bool {
ret x < 0.0f32 || (1.0f32/x) == neg_infinity;
}
/*
Predicate: nonnegative
Returns true if `x` is a positive number, including +0.0f320 and +Infinity.
(This is the same as `f32::positive`.)
*/
pure fn nonnegative(x: f32) -> bool {
ret x > 0.0f32 || (1.0f32/x) == infinity;
}
/* Module: consts */
mod consts {