1
0
mirror of https://github.com/veden/Rampant.git synced 2024-12-30 21:19:46 +02:00
Rampant/libs/MathUtils.lua

178 lines
3.9 KiB
Lua
Raw Normal View History

2019-02-16 06:17:30 +02:00
if mathUtilsG then
return mathUtilsG
end
2016-10-15 02:00:18 +02:00
local mathUtils = {}
-- imports
local constants = require("Constants")
-- constants
local TICKS_A_MINUTE = constants.TICKS_A_MINUTE
2019-02-16 06:17:30 +02:00
local INTERVAL_LOGIC = constants.INTERVAL_LOGIC
2016-10-15 02:00:18 +02:00
-- imported functions
local mMax = math.max
2016-11-04 01:51:35 +02:00
local mSqrt = math.sqrt
local mLog10 = math.log10
2016-10-15 02:00:18 +02:00
local mRandom = math.random
2018-01-14 02:12:09 +02:00
local mFloor = math.floor
local mAbs = math.abs
-- module code
function mathUtils.roundToFloor(number, multiple)
return mFloor(number / multiple) * multiple
end
2016-10-15 02:00:18 +02:00
function mathUtils.roundToNearest(number, multiple)
local num = number + (multiple * 0.5)
return num - (num % multiple)
end
function mathUtils.randomTickEvent(tick, low, high)
local minutesToTick = mMax(high * mRandom(), low)
2016-10-15 02:00:18 +02:00
local nextTick = mathUtils.roundToNearest(TICKS_A_MINUTE * minutesToTick, INTERVAL_LOGIC)
return tick + nextTick
end
function mathUtils.linearInterpolation(percent, min, max)
return ((max - min) * percent) + min
end
2018-01-14 02:12:09 +02:00
function mathUtils.xorRandom(state)
local xor = bit32.bxor
local lshift = bit32.lshift
local rshift = bit32.rshift
2019-02-16 06:17:30 +02:00
2018-01-14 02:12:09 +02:00
state = state + 21594771
return function()
state = xor(state, lshift(state, 13))
state = xor(state, rshift(state, 17))
state = xor(state, lshift(state, 5))
state = state % 2147483647
return state * 4.65661287525e-10
end
end
2018-02-19 02:21:18 +02:00
function mathUtils.linearInterpolation(percent, min, max)
return ((max - min) * percent) + min
end
2016-11-04 01:51:35 +02:00
--[[
Used for gaussian random numbers
--]]
2018-01-14 02:12:09 +02:00
function mathUtils.gaussianRandom(mean, std_dev)
-- marsagliaPolarMethod
2019-02-16 06:17:30 +02:00
local iid1
local iid2
local q
2016-11-04 01:51:35 +02:00
repeat
2018-01-14 02:12:09 +02:00
iid1 = 2 * mRandom() + -1
iid2 = 2 * mRandom() + -1
2016-11-04 01:51:35 +02:00
q = (iid1 * iid1) + (iid2 * iid2)
until (q ~= 0) and (q < 1)
local s = mSqrt((-2 * mLog10(q)) / q)
2018-01-14 02:12:09 +02:00
local v = iid1 * s
2019-02-16 06:17:30 +02:00
2018-01-14 02:12:09 +02:00
return mean + (v * std_dev)
2016-11-04 01:51:35 +02:00
end
2018-01-14 02:12:09 +02:00
function mathUtils.gaussianRandomRange(mean, std_dev, min, max)
if (min == max) then
return min
end
local r
repeat
2019-02-16 06:17:30 +02:00
local iid1
local iid2
local q
2018-01-14 02:12:09 +02:00
repeat
iid1 = 2 * mRandom() + -1
iid2 = 2 * mRandom() + -1
q = (iid1 * iid1) + (iid2 * iid2)
until (q ~= 0) and (q < 1)
local s = mSqrt((-2 * mLog10(q)) / q)
local v = iid1 * s
2019-02-16 06:17:30 +02:00
2018-01-14 02:12:09 +02:00
r = mean + (v * std_dev)
until (r >= min) and (r <= max)
return r
2016-11-04 01:51:35 +02:00
end
2019-02-16 06:17:30 +02:00
function mathUtils.gaussianRandomRG(mean, std_dev, rg)
2018-01-14 02:12:09 +02:00
-- marsagliaPolarMethod
2019-02-16 06:17:30 +02:00
local iid1
local iid2
local q
2016-11-04 01:51:35 +02:00
repeat
2018-01-14 02:12:09 +02:00
iid1 = 2 * rg() + -1
iid2 = 2 * rg() + -1
q = (iid1 * iid1) + (iid2 * iid2)
until (q ~= 0) and (q < 1)
local s = mSqrt((-2 * mLog10(q)) / q)
local v = iid1 * s
2019-02-16 06:17:30 +02:00
2018-01-14 02:12:09 +02:00
return mean + (v * std_dev)
end
function mathUtils.gaussianRandomRangeRG(mean, std_dev, min, max, rg)
local r
if (min == max) then
return min
end
repeat
2019-02-16 06:17:30 +02:00
local iid1
local iid2
local q
2018-01-14 02:12:09 +02:00
repeat
iid1 = 2 * rg() + -1
iid2 = 2 * rg() + -1
2019-02-16 06:17:30 +02:00
q = (iid1 * iid1) + (iid2 * iid2)
2018-01-14 02:12:09 +02:00
until (q ~= 0) and (q < 1)
local s = mSqrt((-2 * mLog10(q)) / q)
local v = iid1 * s
r = mean + (v * std_dev)
until (r >= min) and (r <= max)
return r
2016-11-04 01:51:35 +02:00
end
function mathUtils.euclideanDistanceNamed(p1, p2)
local xs = p1.x - p2.x
local ys = p1.y - p2.y
return ((xs * xs) + (ys * ys)) ^ 0.5
end
function mathUtils.euclideanDistancePoints(x1, y1, x2, y2)
local xs = x1 - x2
local ys = y1 - y2
return ((xs * xs) + (ys * ys)) ^ 0.5
end
function mathUtils.mahattenDistancePoints(x1, y1, x2, y2)
local xs = x1 - x2
local ys = y1 - y2
return mAbs(xs + ys)
end
function mathUtils.euclideanDistanceArray(p1, p2)
local xs = p1[1] - p2[1]
local ys = p1[2] - p2[2]
return ((xs * xs) + (ys * ys)) ^ 0.5
end
function mathUtils.distortPosition(position)
local xDistort = mathUtils.gaussianRandomRange(1, 0.5, 0, 2) - 1
local yDistort = mathUtils.gaussianRandomRange(1, 0.5, 0, 2) - 1
position.x = position.x + (xDistort * 48)
position.y = position.y + (yDistort * 48)
end
2019-02-16 06:17:30 +02:00
mathUtilsG = mathUtils
2016-10-15 02:00:18 +02:00
return mathUtils