Anton Tarasenko
2 years ago
2 changed files with 77 additions and 0 deletions
@ -0,0 +1,75 @@
|
||||
/** |
||||
* API that provides a collection of non-built in math methods used in Acedia. |
||||
* Copyright 2022 Anton Tarasenko |
||||
*------------------------------------------------------------------------------ |
||||
* This file is part of Acedia. |
||||
* |
||||
* Acedia 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, version 3 of the License, or |
||||
* (at your option) any later version. |
||||
* |
||||
* Acedia 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 Acedia. If not, see <https://www.gnu.org/licenses/>. |
||||
*/ |
||||
class MathAPI extends AcediaObject; |
||||
|
||||
/** |
||||
* For storing result of integer division. |
||||
* |
||||
* If we divide `number` by `divisor`, then |
||||
* `number = divisor * quotient + remainder` |
||||
*/ |
||||
struct IntegerDivisionResult |
||||
{ |
||||
var int quotient; |
||||
var int remainder; |
||||
}; |
||||
|
||||
/** |
||||
* Computes remainder of the integer division of `number` by `divisor`. |
||||
* |
||||
* This method is necessary as a replacement for `%` module operator, since it |
||||
* is an operation on `float`s in UnrealScript and does not have appropriate |
||||
* value range to work with big integer values. |
||||
* |
||||
* @see `IntegerDivision()` method if you need both quotient and remainder. |
||||
* |
||||
* @param number Number that we are dividing. |
||||
* @param divisor Number we are dividing by. |
||||
* @return Remainder of the integer division. |
||||
*/ |
||||
public function int Remainder(int number, int divisor) |
||||
{ |
||||
local int quotient; |
||||
|
||||
quotient = number / divisor; |
||||
return (number - quotient * divisor); |
||||
} |
||||
|
||||
/** |
||||
* Computes quotient and remainder of the integer division of `number` by |
||||
* `divisor`. |
||||
* |
||||
* @see `IntegerDivision()` method if you only need remainder. |
||||
* @param number Number that we are dividing. |
||||
* @param divisor Number we are dividing by. |
||||
* @return `struct` with quotient and remainder of the integer division. |
||||
*/ |
||||
public function IntegerDivisionResult IntegerDivision(int number, int divisor) |
||||
{ |
||||
local IntegerDivisionResult result; |
||||
|
||||
result.quotient = number / divisor; |
||||
result.remainder = (number - result.quotient * divisor); |
||||
return result; |
||||
} |
||||
|
||||
defaultproperties |
||||
{ |
||||
} |
Loading…
Reference in new issue