add hoc
This commit is contained in:
parent
c72688efcf
commit
c5b9ff9fa8
8 changed files with 1364 additions and 4 deletions
75
src/cmd/hoc/math.c
Normal file
75
src/cmd/hoc/math.c
Normal file
|
|
@ -0,0 +1,75 @@
|
|||
#include <u.h>
|
||||
#include <libc.h>
|
||||
|
||||
#include "hoc.h"
|
||||
|
||||
double errcheck(double, char*);
|
||||
|
||||
double
|
||||
Log(double x)
|
||||
{
|
||||
return errcheck(log(x), "log");
|
||||
}
|
||||
double
|
||||
Log10(double x)
|
||||
{
|
||||
return errcheck(log10(x), "log10");
|
||||
}
|
||||
|
||||
double
|
||||
Sqrt(double x)
|
||||
{
|
||||
return errcheck(sqrt(x), "sqrt");
|
||||
}
|
||||
|
||||
double
|
||||
Exp(double x)
|
||||
{
|
||||
return errcheck(exp(x), "exp");
|
||||
}
|
||||
|
||||
double
|
||||
Asin(double x)
|
||||
{
|
||||
return errcheck(asin(x), "asin");
|
||||
}
|
||||
|
||||
double
|
||||
Acos(double x)
|
||||
{
|
||||
return errcheck(acos(x), "acos");
|
||||
}
|
||||
|
||||
double
|
||||
Sinh(double x)
|
||||
{
|
||||
return errcheck(sinh(x), "sinh");
|
||||
}
|
||||
double
|
||||
Cosh(double x)
|
||||
{
|
||||
return errcheck(cosh(x), "cosh");
|
||||
}
|
||||
double
|
||||
Pow(double x, double y)
|
||||
{
|
||||
return errcheck(pow(x,y), "exponentiation");
|
||||
}
|
||||
|
||||
double
|
||||
integer(double x)
|
||||
{
|
||||
if(x<-2147483648.0 || x>2147483647.0)
|
||||
execerror("argument out of domain", 0);
|
||||
return (double)(long)x;
|
||||
}
|
||||
|
||||
double
|
||||
errcheck(double d, char* s) /* check result of library call */
|
||||
{
|
||||
if(isNaN(d))
|
||||
execerror(s, "argument out of domain");
|
||||
if(isInf(d, 0))
|
||||
execerror(s, "result out of range");
|
||||
return d;
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue