{ This file is part of the Mufasa Macro Library (MML) Copyright (c) 2009 by Raymond van Venetiƫ and Merlijn Wajer MML 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 3 of the License, or (at your option) any later version. MML 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 MML. If not, see . See the file COPYING, included in this distribution, for details about the copyright. Math.inc for the Mufasa Macro Library } function ps_iAbs(a : integer) : integer;ps_decl; begin result := abs(a); end; function ps_ceil(e : extended) : integer;ps_decl; begin result := ceil(e); end; function ps_pow(base,exponent : extended) : extended; ps_decl; begin result := power(base,exponent); end; function ps_Max(a,b : integer) : integer; ps_decl; begin result := max(a,b); end; function ps_Min(a, b: Integer): Integer; ps_decl; begin result := min(a,b); end; function ps_MinE(a, b : extended) : extended; ps_decl; begin result := min(a,b); end; function ps_MaxE(a,b : extended) : extended; ps_decl; begin result := max(a,b); end; function ps_Sqr(e : extended) : extended;ps_decl; begin result := sqr(e); end; function ps_Point(x,y : integer) : TPoint;ps_decl; begin result := classes.point(x,y); end; function ps_Distance(x1,y1,x2,y2 : integer) : integer;ps_decl; begin Result := Round(Sqrt(Sqr(x2-x1) + Sqr(y2-y1))); end; function ps_Hypot(X, Y: Extended): Extended;ps_decl; begin result := hypot(x,y); end; function ps_RandomRange(const aFrom, aTo: Integer): Integer; ps_decl; begin Result:=Random(Abs(aFrom-aTo))+Min(aTo,AFrom); end; function ps_ArcTan2(x,y : extended) : extended; begin result := ArcTan2(x,y); end; function Factorial(number: longword): Int64; ps_decl; var Loop : longword; begin result := 1; for loop := number downto 2 do result := result * loop; end; function BinCoe(a, b: LongInt): Extended; ps_decl; begin result := Factorial(a) / (factorial(b) * factorial(a-b)); end; function FixD(Degrees : extended) : Extended; ps_decl; begin; Result := Degrees; while Result < 0 do Result := Result + 360; while Result > 360 do Result := Result - 360; end; function IntToBox(x1,y1,x2,y2 : integer) : TBox; ps_decl; begin; result.x1 := x1; result.y1 := y1; result.x2 := x2; result.y2 := y2; end; function IntInBox(x, y: Integer; Box: TBox): Boolean; ps_decl; begin; result := (((x >= Box.x1) and(x <= Box.x2)) and ((y >= box.y1) and (y <= box.y2))); end; function PointToBox(PT1,PT2 : TPoint) : TBox; ps_decl; begin; result.x1 := PT1.x; result.y1 := PT1.y; result.x2 := PT2.x; result.y2 := PT2.y; end; function PointInBox(PT : TPoint; Box: TBox): Boolean; ps_decl; begin; result := (((PT.x >= Box.x1) and(PT.x <= Box.x2)) and ((PT.y>= box.y1) and (PT.y <= box.y2))); end;