You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
476 lines
11 KiB
476 lines
11 KiB
15 years ago
|
//=============================================================================
|
||
|
//
|
||
|
// File : libkvimath.cpp
|
||
|
// Creation date : Sat Jan 13 14:00:12 2006 GMT by Szymon Stefanek
|
||
|
//
|
||
|
// This math is part of the KVirc irc client distribution
|
||
|
// Copyright (C) 2006 Szymon Stefanek (pragma at kvirc dot net)
|
||
|
//
|
||
|
// This program is FREE software. You can redistribute it and/or
|
||
|
// modify it under the terms of the GNU General Public License
|
||
|
// as published by the Free Software Foundation; either version 2
|
||
|
// of the License, or (at your opinion) any later version.
|
||
|
//
|
||
|
// This program is distributed in the HOPE that it will be USEFUL,
|
||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||
|
// See the GNU General Public License for more details.
|
||
|
//
|
||
|
// You should have received a copy of the GNU General Public License
|
||
|
// along with this program. If not, write to the Free Software Foundation,
|
||
|
// Inc. ,51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
|
//
|
||
|
//=============================================================================
|
||
|
|
||
|
#include "kvi_settings.h"
|
||
|
#include "kvi_module.h"
|
||
|
#include "kvi_string.h"
|
||
|
|
||
|
#include <math.h>
|
||
|
|
||
|
// Workaround for lost isnan and isinf definitions after
|
||
|
// inclusion of iostream.h on some MacOS X systems
|
||
|
#ifdef Q_OS_MACX
|
||
|
#ifndef isnan
|
||
|
extern "C" int isnan (double);
|
||
|
#endif
|
||
|
#ifndef isinf
|
||
|
extern "C" int isinf (double);
|
||
|
#endif
|
||
|
#endif
|
||
|
|
||
|
#define MATH_KVS_1PARAM_FUNCTION(__fncname,__paramname,__mathcallname) \
|
||
|
static bool __fncname(KviKvsModuleFunctionCall * c) \
|
||
|
{ \
|
||
|
kvs_real_t dReal; \
|
||
|
KVSM_PARAMETERS_BEGIN(c) \
|
||
|
KVSM_PARAMETER(__paramname,KVS_PT_REAL,0,dReal) \
|
||
|
KVSM_PARAMETERS_END(c) \
|
||
|
c->returnValue()->setReal(__mathcallname(dReal)); \
|
||
|
return true; \
|
||
|
}
|
||
|
|
||
|
#ifdef COMPILE_ON_WINDOWS
|
||
|
// dobbiamo testare meglio, i risultati.
|
||
|
static double cbrt(double x)
|
||
|
{
|
||
|
if (x > 0.0) return pow(x, 1.0/3.0);
|
||
|
else return -pow(-x, 1.0/3.0);
|
||
|
}
|
||
|
|
||
|
static int isinf (double d) {
|
||
|
int expon = 0;
|
||
|
double val = frexp (d, &expon);
|
||
|
if (expon == 1025) {
|
||
|
if (val == 0.5) return 1;
|
||
|
else if (val == -0.5) return -1;
|
||
|
else return 0;
|
||
|
} else {
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
static int isnan (double d) {
|
||
|
int expon = 0;
|
||
|
double val = frexp (d, &expon);
|
||
|
if (expon == 1025) {
|
||
|
if (val == 0.5) return 0;
|
||
|
else if (val == -0.5) return 0;
|
||
|
else return 1;
|
||
|
} else {
|
||
|
return 0;
|
||
|
}
|
||
|
}
|
||
|
#endif
|
||
|
/*
|
||
|
@doc: math.sin
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.sin
|
||
|
@short:
|
||
|
Returns the sinus of the specified angle in radiants
|
||
|
@syntax:
|
||
|
<real> $math.sin(<angle:real>)
|
||
|
@description:
|
||
|
Returns the sinus of the specified angle in radiants
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_sin,"angle",sin)
|
||
|
|
||
|
/*
|
||
|
@doc: math.cos
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.cos
|
||
|
@short:
|
||
|
Returns the cosinus of the specified angle in radiants
|
||
|
@syntax:
|
||
|
<real> $math.cos(<angle:real>)
|
||
|
@description:
|
||
|
Returns the cosinus of the specified angle in radiants
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_cos,"angle",cos)
|
||
|
|
||
|
/*
|
||
|
@doc: math.tan
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.tan
|
||
|
@short:
|
||
|
Returns the tangent of the specified angle in radiants
|
||
|
@syntax:
|
||
|
<real> $math.tan(<angle:real>)
|
||
|
@description:
|
||
|
Returns the tangent of the specified angle in radiants
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_tan,"angle",tan)
|
||
|
|
||
|
/*
|
||
|
@doc: math.asin
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.asin
|
||
|
@short:
|
||
|
Returns the angle in radiants that has the specified sinus value.
|
||
|
@syntax:
|
||
|
<real> $math.asin(<sinus:real>)
|
||
|
@description:
|
||
|
Returns the angle in radiants that has the specified sinus value.
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_asin,"sinus",asin)
|
||
|
|
||
|
/*
|
||
|
@doc: math.acos
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.acos
|
||
|
@short:
|
||
|
Returns the angle in radiants that has the specified cosinus value.
|
||
|
@syntax:
|
||
|
<real> $math.acos(<cosinus:real>)
|
||
|
@description:
|
||
|
Returns the angle in radiants that has the specified cosinus value.
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_acos,"cosinus",acos)
|
||
|
|
||
|
|
||
|
/*
|
||
|
@doc: math.atan
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.atan
|
||
|
@short:
|
||
|
Returns the angle in radiants that has the specified tangent value.
|
||
|
@syntax:
|
||
|
<real> $math.atan(<tangent:real>)
|
||
|
@description:
|
||
|
Returns the angle in radiants that has the specified tangent value.
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_atan,"tangent",atan)
|
||
|
|
||
|
/*
|
||
|
@doc: math.sqrt
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.sqrt
|
||
|
@short:
|
||
|
Returns the square root of a number
|
||
|
@syntax:
|
||
|
<real> $math.sqrt(<number:real>)
|
||
|
@description:
|
||
|
Returns the square root of the specified number
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_sqrt,"number",sqrt)
|
||
|
|
||
|
/*
|
||
|
@doc: math.cbrt
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.cbrt
|
||
|
@short:
|
||
|
Returns the cube root of a number
|
||
|
@syntax:
|
||
|
<real> $math.cbrt(<number:real>)
|
||
|
@description:
|
||
|
Returns the cube root of the specified number
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_cbrt,"number",cbrt)
|
||
|
|
||
|
/*
|
||
|
@doc: math.abs
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.abs
|
||
|
@short:
|
||
|
Returns the absolute value of a number
|
||
|
@syntax:
|
||
|
<real> $math.abs(<number:real>)
|
||
|
@description:
|
||
|
Returns the absolute value of the specified number
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_abs,"number",fabs)
|
||
|
|
||
|
/*
|
||
|
@doc: math.floor
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.floor
|
||
|
@short:
|
||
|
Rounds down to the nearest integer
|
||
|
@syntax:
|
||
|
<real> $math.floor(<number:real>)
|
||
|
@description:
|
||
|
Rounds down number to the nearest integer
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_floor,"number",floor)
|
||
|
|
||
|
/*
|
||
|
@doc: math.ceil
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.ceil
|
||
|
@short:
|
||
|
Rounds up to the nearest integer
|
||
|
@syntax:
|
||
|
<real> $math.ceil(<number:real>)
|
||
|
@description:
|
||
|
Rounds up number to the nearest integer
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_ceil,"number",ceil)
|
||
|
|
||
|
/*
|
||
|
@doc: math.exp
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.exp
|
||
|
@short:
|
||
|
Returns the exponential of the specified number
|
||
|
@syntax:
|
||
|
<real> $math.exp(<number:real>)
|
||
|
@description:
|
||
|
Returns the exponential of the specified number
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_exp,"number",exp)
|
||
|
|
||
|
/*
|
||
|
@doc: math.log
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.log
|
||
|
@short:
|
||
|
Returns the natural logarithm of the specified number
|
||
|
@syntax:
|
||
|
<real> $math.log(<number:real>)
|
||
|
@description:
|
||
|
Returns the natural (base e) logarithm of the specified number
|
||
|
*/
|
||
|
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_log,"number",log)
|
||
|
|
||
|
|
||
|
/*
|
||
|
@doc: math.log10
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.log10
|
||
|
@short:
|
||
|
Returns the base 10 logarithm of the specified number
|
||
|
@syntax:
|
||
|
<real> $math.log10(<number:real>)
|
||
|
@description:
|
||
|
Returns the base 10 logarithm of the specified number
|
||
|
*/
|
||
|
MATH_KVS_1PARAM_FUNCTION(math_kvs_fnc_log10,"number",log10)
|
||
|
|
||
|
/*
|
||
|
@doc: math.isnan
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.isnan
|
||
|
@short:
|
||
|
Checks if the value is not a number
|
||
|
@syntax:
|
||
|
<boolean> $math.isnan(<value:real>)
|
||
|
@description:
|
||
|
Checks if the specified value is a valid number
|
||
|
or NaN (Not a Number). NaN is returned by several
|
||
|
math functions when the result would be undefined.
|
||
|
*/
|
||
|
static bool math_kvs_fnc_isnan(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
kvs_real_t dReal;
|
||
|
KVSM_PARAMETERS_BEGIN(c)
|
||
|
KVSM_PARAMETER("value",KVS_PT_REAL,0,dReal)
|
||
|
KVSM_PARAMETERS_END(c)
|
||
|
c->returnValue()->setBoolean(isnan(dReal));
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
@doc: math.isinf
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.isinf
|
||
|
@short:
|
||
|
Checks if the value is the infinity
|
||
|
@syntax:
|
||
|
<boolean> $math.isinf(<value:real>)
|
||
|
@description:
|
||
|
Checks if the specified value is the infinity.
|
||
|
*/
|
||
|
#ifdef COMPILE_ON_WINDOWS
|
||
|
static bool math_kvs_fnc_isinf(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
kvs_real_t dReal;
|
||
|
KVSM_PARAMETERS_BEGIN(c)
|
||
|
KVSM_PARAMETER("value",KVS_PT_REAL,0,dReal)
|
||
|
KVSM_PARAMETERS_END(c)
|
||
|
c->returnValue()->setBoolean(sinf(dReal));
|
||
|
return true;
|
||
|
}
|
||
|
#else
|
||
|
static bool math_kvs_fnc_isinf(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
kvs_real_t dReal;
|
||
|
KVSM_PARAMETERS_BEGIN(c)
|
||
|
KVSM_PARAMETER("value",KVS_PT_REAL,0,dReal)
|
||
|
KVSM_PARAMETERS_END(c)
|
||
|
c->returnValue()->setBoolean(isinf(dReal));
|
||
|
return true;
|
||
|
}
|
||
|
#endif //COMPILE_ON_WINDOWS
|
||
|
/*
|
||
|
@doc: math.pow
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.pow
|
||
|
@short:
|
||
|
Returns a to the power of b
|
||
|
@syntax:
|
||
|
<real> $math.pow(<a:real>,<b:real>)
|
||
|
@description:
|
||
|
Returns a to the power of b
|
||
|
*/
|
||
|
static bool math_kvs_fnc_pow(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
kvs_real_t dA,dB;
|
||
|
KVSM_PARAMETERS_BEGIN(c)
|
||
|
KVSM_PARAMETER("a",KVS_PT_REAL,0,dA)
|
||
|
KVSM_PARAMETER("b",KVS_PT_REAL,0,dB)
|
||
|
KVSM_PARAMETERS_END(c)
|
||
|
c->returnValue()->setReal(pow(dA,dB));
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
@doc: math.pi
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.pi
|
||
|
@short:
|
||
|
Returns the value of pi
|
||
|
@syntax:
|
||
|
<real> $math.pi()
|
||
|
@description:
|
||
|
Returns the value of pi
|
||
|
*/
|
||
|
#ifdef COMPILE_ON_WINDOWS
|
||
|
static bool math_kvs_fnc_pi(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
c->returnValue()->setReal(3.141592653589793238462643383279502884197169399375);
|
||
|
return true;
|
||
|
}
|
||
|
#else
|
||
|
static bool math_kvs_fnc_pi(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
c->returnValue()->setReal(M_PI);
|
||
|
return true;
|
||
|
}
|
||
|
#endif
|
||
|
/*
|
||
|
@doc: math.e
|
||
|
@type:
|
||
|
function
|
||
|
@title:
|
||
|
$math.e
|
||
|
@short:
|
||
|
Returns the value of e
|
||
|
@syntax:
|
||
|
<real> $math.e()
|
||
|
@description:
|
||
|
Returns the value of the euler constant e
|
||
|
*/
|
||
|
|
||
|
|
||
|
#ifdef COMPILE_ON_WINDOWS
|
||
|
static bool math_kvs_fnc_e(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
c->returnValue()->setReal(1.56903485);
|
||
|
return true;
|
||
|
}
|
||
|
#else
|
||
|
static bool math_kvs_fnc_e(KviKvsModuleFunctionCall * c)
|
||
|
{
|
||
|
c->returnValue()->setReal(M_E);
|
||
|
return true;
|
||
|
}
|
||
|
#endif
|
||
|
static bool math_module_init(KviModule * m)
|
||
|
{
|
||
|
KVSM_REGISTER_FUNCTION(m,"sin",math_kvs_fnc_sin);
|
||
|
KVSM_REGISTER_FUNCTION(m,"cos",math_kvs_fnc_cos);
|
||
|
KVSM_REGISTER_FUNCTION(m,"tan",math_kvs_fnc_tan);
|
||
|
KVSM_REGISTER_FUNCTION(m,"asin",math_kvs_fnc_asin);
|
||
|
KVSM_REGISTER_FUNCTION(m,"acos",math_kvs_fnc_acos);
|
||
|
KVSM_REGISTER_FUNCTION(m,"atan",math_kvs_fnc_atan);
|
||
|
KVSM_REGISTER_FUNCTION(m,"sqrt",math_kvs_fnc_sqrt);
|
||
|
KVSM_REGISTER_FUNCTION(m,"cbrt",math_kvs_fnc_cbrt);
|
||
|
KVSM_REGISTER_FUNCTION(m,"abs",math_kvs_fnc_abs);
|
||
|
KVSM_REGISTER_FUNCTION(m,"floor",math_kvs_fnc_floor);
|
||
|
KVSM_REGISTER_FUNCTION(m,"ceil",math_kvs_fnc_ceil);
|
||
|
KVSM_REGISTER_FUNCTION(m,"pow",math_kvs_fnc_pow);
|
||
|
KVSM_REGISTER_FUNCTION(m,"exp",math_kvs_fnc_exp);
|
||
|
KVSM_REGISTER_FUNCTION(m,"log",math_kvs_fnc_log);
|
||
|
KVSM_REGISTER_FUNCTION(m,"log10",math_kvs_fnc_log10);
|
||
|
KVSM_REGISTER_FUNCTION(m,"pi",math_kvs_fnc_pi);
|
||
|
KVSM_REGISTER_FUNCTION(m,"e",math_kvs_fnc_e);
|
||
|
KVSM_REGISTER_FUNCTION(m,"isnan",math_kvs_fnc_isnan);
|
||
|
KVSM_REGISTER_FUNCTION(m,"isinf",math_kvs_fnc_isinf);
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
|
||
|
static bool math_module_cleanup(KviModule *m)
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
KVIRC_MODULE(
|
||
|
"Math", // module name
|
||
|
"1.0.0", // module version
|
||
|
"Copyright (C) 2006 Szymon Stefanek (pragma at kvirc dot net),"\
|
||
|
"Tonino Imbesi (grifisx at barmes dot org)," \
|
||
|
"Alessandro Carbone (noldor at barmes dot org)",
|
||
|
"Mathematical function module",
|
||
|
math_module_init,
|
||
|
0,
|
||
|
0,
|
||
|
math_module_cleanup
|
||
|
)
|