2007-03-29 22:09:25 +00:00
|
|
|
var abs = func(n) { n < 0 ? -n : n }
|
|
|
|
|
2009-05-05 18:34:53 +00:00
|
|
|
var sgn = func(x) { x < 0 ? -1 : x > 0 }
|
|
|
|
|
2011-04-20 23:25:41 +00:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2007-03-29 22:09:25 +00:00
|
|
|
var pow = func(x, y) { exp(y * ln(x)) }
|
|
|
|
|
|
|
|
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 asin = func(y) { atan2(y, sqrt(1-y*y)) }
|
|
|
|
|
|
|
|
var acos = func(x) { atan2(sqrt(1-x*x), x) }
|
|
|
|
|
2009-05-05 18:34:53 +00:00
|
|
|
var tan = func(x) { sin(x) / (cos(x) or die("tangens infinity")) }
|
2009-03-25 17:52:43 +00:00
|
|
|
|
2007-03-29 22:09:25 +00:00
|
|
|
var _iln10 = 1/ln(10);
|
2009-05-05 18:34:53 +00:00
|
|
|
var log10 = func(x) { ln(x) * _iln10 }
|