1
0
Fork 0
fgdata/Nasal/math.nas
James Turner 60da2d4da8 Remove items implement natively in Nasal.
mathlib.c now defines more of these. Remaining items (abs, sgn, min, max)
are likely faster using Nasal than switching to C and back again.

Also add a comment about mod(), clarifying that a native fmod() exists.
2013-10-03 17:42:20 +01:00

39 lines
935 B
Text

var abs = func(n) { n < 0 ? -n : n }
var sgn = func(x) { x < 0 ? -1 : x > 0 }
var max = func(x) {
var n = x;
for (var i = 0; i < size(arg); i += 1) {
if (arg[i] > n) n = arg[i];
}
return n;
}
var min = func(x) {
var n = x;
for (var i = 0; i < size(arg); i += 1) {
if (arg[i] < n) n = arg[i];
}
return n;
}
var avg = func {
var x = 0;
for (var i = 0; i < size(arg); i += 1) {
x += arg[i];
}
x /= size(arg);
return x;
}
# note - mathlib defines an fmod function (added after this was written)
# It uses C-library fmod(), which has different rounding behaviour to
# this code (eg, fmod(-5, 4) gives -1, whereas this code gives 3)
var mod = func(n, m) {
var x = n - m * int(n/m); # int() truncates to zero, not -Inf
return x < 0 ? x + abs(m) : x; # ...so must handle negative n's
}
var _iln10 = 1/ln(10);
var log10 = func(x) { ln(x) * _iln10 }