apophysis/2.02f/Source/ap_Math.pas
2005-01-09 18:00:21 +00:00

1049 lines
27 KiB
ObjectPascal

{***************************************************************************}
{ This source code was generated automatically by }
{ Pas file import tool for Scripter Studio }
{ }
{ Scripter Studio and Pas file import tool for Scripter Studio }
{ written by Automa / TMS Software }
{ copyright © 1997 - 2003 }
{ Email : info@tmssoftware.com }
{ Web : http://www.tmssoftware.com }
{***************************************************************************}
unit ap_Math;
interface
uses
SysUtils,
Types,
Math,
Variants,
atScript;
type
TatMathLibrary = class(TatScripterLibrary)
procedure __ArcCos(AMachine: TatVirtualMachine);
procedure __ArcSin(AMachine: TatVirtualMachine);
procedure __ArcTan2(AMachine: TatVirtualMachine);
procedure __SinCos(AMachine: TatVirtualMachine);
procedure __Tan(AMachine: TatVirtualMachine);
procedure __Cotan(AMachine: TatVirtualMachine);
procedure __Secant(AMachine: TatVirtualMachine);
procedure __Cosecant(AMachine: TatVirtualMachine);
procedure __Hypot(AMachine: TatVirtualMachine);
procedure __RadToDeg(AMachine: TatVirtualMachine);
procedure __RadToGrad(AMachine: TatVirtualMachine);
procedure __RadToCycle(AMachine: TatVirtualMachine);
procedure __DegToRad(AMachine: TatVirtualMachine);
procedure __DegToGrad(AMachine: TatVirtualMachine);
procedure __DegToCycle(AMachine: TatVirtualMachine);
procedure __GradToRad(AMachine: TatVirtualMachine);
procedure __GradToDeg(AMachine: TatVirtualMachine);
procedure __GradToCycle(AMachine: TatVirtualMachine);
procedure __CycleToRad(AMachine: TatVirtualMachine);
procedure __CycleToDeg(AMachine: TatVirtualMachine);
procedure __CycleToGrad(AMachine: TatVirtualMachine);
procedure __Cot(AMachine: TatVirtualMachine);
procedure __Sec(AMachine: TatVirtualMachine);
procedure __Csc(AMachine: TatVirtualMachine);
procedure __Cosh(AMachine: TatVirtualMachine);
procedure __Sinh(AMachine: TatVirtualMachine);
procedure __Tanh(AMachine: TatVirtualMachine);
procedure __CotH(AMachine: TatVirtualMachine);
procedure __SecH(AMachine: TatVirtualMachine);
procedure __CscH(AMachine: TatVirtualMachine);
procedure __ArcCot(AMachine: TatVirtualMachine);
procedure __ArcSec(AMachine: TatVirtualMachine);
procedure __ArcCsc(AMachine: TatVirtualMachine);
procedure __ArcCosh(AMachine: TatVirtualMachine);
procedure __ArcSinh(AMachine: TatVirtualMachine);
procedure __ArcTanh(AMachine: TatVirtualMachine);
procedure __ArcCotH(AMachine: TatVirtualMachine);
procedure __ArcSecH(AMachine: TatVirtualMachine);
procedure __ArcCscH(AMachine: TatVirtualMachine);
procedure __LnXP1(AMachine: TatVirtualMachine);
procedure __Log10(AMachine: TatVirtualMachine);
procedure __Log2(AMachine: TatVirtualMachine);
procedure __LogN(AMachine: TatVirtualMachine);
procedure __IntPower(AMachine: TatVirtualMachine);
procedure __Power(AMachine: TatVirtualMachine);
procedure __Frexp(AMachine: TatVirtualMachine);
procedure __Ldexp(AMachine: TatVirtualMachine);
procedure __Ceil(AMachine: TatVirtualMachine);
procedure __Floor(AMachine: TatVirtualMachine);
procedure __RandG(AMachine: TatVirtualMachine);
procedure __IsNan(AMachine: TatVirtualMachine);
procedure __IsInfinite(AMachine: TatVirtualMachine);
procedure __RandomRange(AMachine: TatVirtualMachine);
procedure __DivMod(AMachine: TatVirtualMachine);
procedure __RoundTo(AMachine: TatVirtualMachine);
procedure __SimpleRoundTo(AMachine: TatVirtualMachine);
procedure __DoubleDecliningBalance(AMachine: TatVirtualMachine);
procedure __FutureValue(AMachine: TatVirtualMachine);
procedure __InterestPayment(AMachine: TatVirtualMachine);
procedure __InterestRate(AMachine: TatVirtualMachine);
procedure __NumberOfPeriods(AMachine: TatVirtualMachine);
procedure __Payment(AMachine: TatVirtualMachine);
procedure __PeriodPayment(AMachine: TatVirtualMachine);
procedure __PresentValue(AMachine: TatVirtualMachine);
procedure __SLNDepreciation(AMachine: TatVirtualMachine);
procedure __SYDDepreciation(AMachine: TatVirtualMachine);
procedure __GetRoundMode(AMachine: TatVirtualMachine);
procedure __SetRoundMode(AMachine: TatVirtualMachine);
procedure __GetPrecisionMode(AMachine: TatVirtualMachine);
procedure __SetPrecisionMode(AMachine: TatVirtualMachine);
procedure __GetExceptionMask(AMachine: TatVirtualMachine);
procedure __SetExceptionMask(AMachine: TatVirtualMachine);
procedure __ClearExceptions(AMachine: TatVirtualMachine);
procedure Init; override;
class function LibraryName: string; override;
end;
EInvalidArgumentClass = class of EInvalidArgument;
implementation
{$WARNINGS OFF}
procedure TatMathLibrary.__ArcCos(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcCos(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcSin(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcSin(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcTan2(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcTan2(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SinCos(AMachine: TatVirtualMachine);
var
Param1: Extended;
Param2: Extended;
begin
with AMachine do
begin
Param1 := GetInputArg(1);
Param2 := GetInputArg(2);
Math.SinCos(GetInputArg(0),Param1,Param2);
SetInputArg(1,Param1);
SetInputArg(2,Param2);
end;
end;
procedure TatMathLibrary.__Tan(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Tan(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Cotan(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Cotan(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Secant(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Secant(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Cosecant(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Cosecant(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Hypot(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Hypot(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__RadToDeg(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.RadToDeg(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__RadToGrad(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.RadToGrad(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__RadToCycle(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.RadToCycle(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__DegToRad(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.DegToRad(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__DegToGrad(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.DegToGrad(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__DegToCycle(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.DegToCycle(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__GradToRad(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.GradToRad(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__GradToDeg(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.GradToDeg(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__GradToCycle(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.GradToCycle(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__CycleToRad(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.CycleToRad(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__CycleToDeg(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.CycleToDeg(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__CycleToGrad(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.CycleToGrad(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Cot(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Cot(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Sec(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Sec(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Csc(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Csc(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Cosh(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Cosh(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Sinh(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Sinh(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Tanh(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Tanh(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__CotH(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.CotH(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SecH(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.SecH(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__CscH(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.CscH(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcCot(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcCot(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcSec(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcSec(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcCsc(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcCsc(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcCosh(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcCosh(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcSinh(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcSinh(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcTanh(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcTanh(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcCotH(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcCotH(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcSecH(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcSecH(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ArcCscH(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.ArcCscH(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__LnXP1(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.LnXP1(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Log10(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Log10(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Log2(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Log2(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__LogN(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.LogN(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__IntPower(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.IntPower(GetInputArg(0),VarToInteger(GetInputArg(1)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Power(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Power(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Frexp(AMachine: TatVirtualMachine);
var
Param1: Extended;
Param2: Integer;
begin
with AMachine do
begin
Param1 := GetInputArg(1);
Param2 := VarToInteger(GetInputArg(2));
Math.Frexp(GetInputArg(0),Param1,Param2);
SetInputArg(1,Param1);
SetInputArg(2,Integer(Param2));
end;
end;
procedure TatMathLibrary.__Ldexp(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Ldexp(GetInputArg(0),VarToInteger(GetInputArg(1)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Ceil(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Integer(Math.Ceil(GetInputArg(0)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Floor(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Integer(Math.Floor(GetInputArg(0)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__RandG(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.RandG(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__IsNan(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.IsNan(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__IsInfinite(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.IsInfinite(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__RandomRange(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Integer(Math.RandomRange(VarToInteger(GetInputArg(0)),VarToInteger(GetInputArg(1))));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__DivMod(AMachine: TatVirtualMachine);
var
Param2: Word;
Param3: Word;
begin
with AMachine do
begin
Param2 := VarToInteger(GetInputArg(2));
Param3 := VarToInteger(GetInputArg(3));
Math.DivMod(VarToInteger(GetInputArg(0)),VarToInteger(GetInputArg(1)),Param2,Param3);
SetInputArg(2,Integer(Param2));
SetInputArg(3,Integer(Param3));
end;
end;
procedure TatMathLibrary.__RoundTo(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.RoundTo(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SimpleRoundTo(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.SimpleRoundTo(GetInputArg(0),GetInputArg(1));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__DoubleDecliningBalance(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.DoubleDecliningBalance(GetInputArg(0),GetInputArg(1),VarToInteger(GetInputArg(2)),VarToInteger(GetInputArg(3)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__FutureValue(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.FutureValue(GetInputArg(0),VarToInteger(GetInputArg(1)),GetInputArg(2),GetInputArg(3),GetInputArg(4));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__InterestPayment(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.InterestPayment(GetInputArg(0),VarToInteger(GetInputArg(1)),VarToInteger(GetInputArg(2)),GetInputArg(3),GetInputArg(4),GetInputArg(5));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__InterestRate(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.InterestRate(VarToInteger(GetInputArg(0)),GetInputArg(1),GetInputArg(2),GetInputArg(3),GetInputArg(4));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__NumberOfPeriods(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.NumberOfPeriods(GetInputArg(0),GetInputArg(1),GetInputArg(2),GetInputArg(3),GetInputArg(4));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__Payment(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.Payment(GetInputArg(0),VarToInteger(GetInputArg(1)),GetInputArg(2),GetInputArg(3),GetInputArg(4));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__PeriodPayment(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.PeriodPayment(GetInputArg(0),VarToInteger(GetInputArg(1)),VarToInteger(GetInputArg(2)),GetInputArg(3),GetInputArg(4),GetInputArg(5));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__PresentValue(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.PresentValue(GetInputArg(0),VarToInteger(GetInputArg(1)),GetInputArg(2),GetInputArg(3),GetInputArg(4));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SLNDepreciation(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.SLNDepreciation(GetInputArg(0),GetInputArg(1),VarToInteger(GetInputArg(2)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SYDDepreciation(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.SYDDepreciation(GetInputArg(0),GetInputArg(1),VarToInteger(GetInputArg(2)),VarToInteger(GetInputArg(3)));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__GetRoundMode(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.GetRoundMode;
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SetRoundMode(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.SetRoundMode(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__GetPrecisionMode(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.GetPrecisionMode;
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SetPrecisionMode(AMachine: TatVirtualMachine);
var
AResult: variant;
begin
with AMachine do
begin
AResult := Math.SetPrecisionMode(GetInputArg(0));
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__GetExceptionMask(AMachine: TatVirtualMachine);
var
AResultSet: TFPUExceptionMask;
AResult: variant;
begin
with AMachine do
begin
AResultSet := Math.GetExceptionMask;
AResult := IntFromSet(AResultSet);
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__SetExceptionMask(AMachine: TatVirtualMachine);
var
Param0: TFPUExceptionMask;
AResultSet: TFPUExceptionMask;
AResult: variant;
begin
with AMachine do
begin
IntToSet(Param0,VarToInteger(GetInputArg(0)));
AResultSet := Math.SetExceptionMask(Param0);
AResult := IntFromSet(AResultSet);
ReturnOutputArg(AResult);
end;
end;
procedure TatMathLibrary.__ClearExceptions(AMachine: TatVirtualMachine);
begin
with AMachine do
begin
Math.ClearExceptions;
end;
end;
procedure TatMathLibrary.Init;
begin
With Scripter.DefineClass(EInvalidArgument) do
begin
end;
With Scripter.DefineClass(ClassType) do
begin
DefineMethod('ArcCos',1,tkVariant,nil,__ArcCos,false);
DefineMethod('ArcSin',1,tkVariant,nil,__ArcSin,false);
DefineMethod('ArcTan2',2,tkVariant,nil,__ArcTan2,false);
DefineMethod('SinCos',3,tkNone,nil,__SinCos,false).SetVarArgs([1,2]);
DefineMethod('Tan',1,tkVariant,nil,__Tan,false);
DefineMethod('Cotan',1,tkVariant,nil,__Cotan,false);
DefineMethod('Secant',1,tkVariant,nil,__Secant,false);
DefineMethod('Cosecant',1,tkVariant,nil,__Cosecant,false);
DefineMethod('Hypot',2,tkVariant,nil,__Hypot,false);
DefineMethod('RadToDeg',1,tkVariant,nil,__RadToDeg,false);
DefineMethod('RadToGrad',1,tkVariant,nil,__RadToGrad,false);
DefineMethod('RadToCycle',1,tkVariant,nil,__RadToCycle,false);
DefineMethod('DegToRad',1,tkVariant,nil,__DegToRad,false);
DefineMethod('DegToGrad',1,tkVariant,nil,__DegToGrad,false);
DefineMethod('DegToCycle',1,tkVariant,nil,__DegToCycle,false);
DefineMethod('GradToRad',1,tkVariant,nil,__GradToRad,false);
DefineMethod('GradToDeg',1,tkVariant,nil,__GradToDeg,false);
DefineMethod('GradToCycle',1,tkVariant,nil,__GradToCycle,false);
DefineMethod('CycleToRad',1,tkVariant,nil,__CycleToRad,false);
DefineMethod('CycleToDeg',1,tkVariant,nil,__CycleToDeg,false);
DefineMethod('CycleToGrad',1,tkVariant,nil,__CycleToGrad,false);
DefineMethod('Cot',1,tkVariant,nil,__Cot,false);
DefineMethod('Sec',1,tkVariant,nil,__Sec,false);
DefineMethod('Csc',1,tkVariant,nil,__Csc,false);
DefineMethod('Cosh',1,tkVariant,nil,__Cosh,false);
DefineMethod('Sinh',1,tkVariant,nil,__Sinh,false);
DefineMethod('Tanh',1,tkVariant,nil,__Tanh,false);
DefineMethod('CotH',1,tkVariant,nil,__CotH,false);
DefineMethod('SecH',1,tkVariant,nil,__SecH,false);
DefineMethod('CscH',1,tkVariant,nil,__CscH,false);
DefineMethod('ArcCot',1,tkVariant,nil,__ArcCot,false);
DefineMethod('ArcSec',1,tkVariant,nil,__ArcSec,false);
DefineMethod('ArcCsc',1,tkVariant,nil,__ArcCsc,false);
DefineMethod('ArcCosh',1,tkVariant,nil,__ArcCosh,false);
DefineMethod('ArcSinh',1,tkVariant,nil,__ArcSinh,false);
DefineMethod('ArcTanh',1,tkVariant,nil,__ArcTanh,false);
DefineMethod('ArcCotH',1,tkVariant,nil,__ArcCotH,false);
DefineMethod('ArcSecH',1,tkVariant,nil,__ArcSecH,false);
DefineMethod('ArcCscH',1,tkVariant,nil,__ArcCscH,false);
DefineMethod('LnXP1',1,tkVariant,nil,__LnXP1,false);
DefineMethod('Log10',1,tkVariant,nil,__Log10,false);
DefineMethod('Log2',1,tkVariant,nil,__Log2,false);
DefineMethod('LogN',2,tkVariant,nil,__LogN,false);
DefineMethod('IntPower',2,tkVariant,nil,__IntPower,false);
DefineMethod('Power',2,tkVariant,nil,__Power,false);
DefineMethod('Frexp',3,tkNone,nil,__Frexp,false).SetVarArgs([1,2]);
DefineMethod('Ldexp',2,tkVariant,nil,__Ldexp,false);
DefineMethod('Ceil',1,tkInteger,nil,__Ceil,false);
DefineMethod('Floor',1,tkInteger,nil,__Floor,false);
DefineMethod('RandG',2,tkVariant,nil,__RandG,false);
DefineMethod('IsNan',1,tkVariant,nil,__IsNan,false);
DefineMethod('IsInfinite',1,tkVariant,nil,__IsInfinite,false);
DefineMethod('RandomRange',2,tkInteger,nil,__RandomRange,false);
DefineMethod('DivMod',4,tkNone,nil,__DivMod,false).SetVarArgs([2,3]);
DefineMethod('RoundTo',2,tkVariant,nil,__RoundTo,false);
DefineMethod('SimpleRoundTo',2,tkVariant,nil,__SimpleRoundTo,false);
DefineMethod('DoubleDecliningBalance',4,tkVariant,nil,__DoubleDecliningBalance,false);
DefineMethod('FutureValue',5,tkVariant,nil,__FutureValue,false);
DefineMethod('InterestPayment',6,tkVariant,nil,__InterestPayment,false);
DefineMethod('InterestRate',5,tkVariant,nil,__InterestRate,false);
DefineMethod('NumberOfPeriods',5,tkVariant,nil,__NumberOfPeriods,false);
DefineMethod('Payment',5,tkVariant,nil,__Payment,false);
DefineMethod('PeriodPayment',6,tkVariant,nil,__PeriodPayment,false);
DefineMethod('PresentValue',5,tkVariant,nil,__PresentValue,false);
DefineMethod('SLNDepreciation',3,tkVariant,nil,__SLNDepreciation,false);
DefineMethod('SYDDepreciation',4,tkVariant,nil,__SYDDepreciation,false);
DefineMethod('GetRoundMode',0,tkEnumeration,nil,__GetRoundMode,false);
DefineMethod('SetRoundMode',1,tkEnumeration,nil,__SetRoundMode,false);
DefineMethod('GetPrecisionMode',0,tkEnumeration,nil,__GetPrecisionMode,false);
DefineMethod('SetPrecisionMode',1,tkEnumeration,nil,__SetPrecisionMode,false);
DefineMethod('GetExceptionMask',0,tkInteger,nil,__GetExceptionMask,false);
DefineMethod('SetExceptionMask',1,tkInteger,nil,__SetExceptionMask,false);
DefineMethod('ClearExceptions',0,tkNone,nil,__ClearExceptions,false);
AddConstant('ptEndOfPeriod',ptEndOfPeriod);
AddConstant('ptStartOfPeriod',ptStartOfPeriod);
AddConstant('rmNearest',rmNearest);
AddConstant('rmDown',rmDown);
AddConstant('rmUp',rmUp);
AddConstant('rmTruncate',rmTruncate);
AddConstant('pmSingle',pmSingle);
AddConstant('pmReserved',pmReserved);
AddConstant('pmDouble',pmDouble);
AddConstant('pmExtended',pmExtended);
AddConstant('exInvalidOp',exInvalidOp);
AddConstant('exDenormalized',exDenormalized);
AddConstant('exZeroDivide',exZeroDivide);
AddConstant('exOverflow',exOverflow);
AddConstant('exUnderflow',exUnderflow);
AddConstant('exPrecision',exPrecision);
AddConstant('MinSingle',MinSingle);
AddConstant('MaxSingle',MaxSingle);
AddConstant('MinDouble',MinDouble);
AddConstant('MaxDouble',MaxDouble);
AddConstant('NaN',NaN);
AddConstant('Infinity',Infinity);
AddConstant('NegInfinity',NegInfinity);
AddConstant('NegativeValue',NegativeValue);
AddConstant('ZeroValue',ZeroValue);
AddConstant('PositiveValue',PositiveValue);
end;
end;
class function TatMathLibrary.LibraryName: string;
begin
result := 'Math';
end;
initialization
RegisterScripterLibrary(TatMathLibrary, True);
{$WARNINGS ON}
end.