Some updates to TimeToDie.

main
ck 11 months ago
parent fb3f8decb6
commit 904d20f09c
  1. 44
      src/TimeToDie/TimeToDie.lua
  2. 14
      src/Unit/Unit.lua

@ -20,9 +20,12 @@ local TimeToDie = {
-- Max history count : min=20, max=500, default = 100 -- Max history count : min=20, max=500, default = 100
HistoryCount = 100 HistoryCount = 100
}, },
---@type table<number, { time: number, percentage: number }>
Cache = {}, -- A cache of unused { time, value } tables to reduce garbage due to table creation Cache = {}, -- A cache of unused { time, value } tables to reduce garbage due to table creation
---@type table<string, {[1]: {[1]: {[1]: number, [2]: number}, [2]: number}, [2]: number }> --@type table<string, {[1]: {[1]: {[1]: number, [2]: number}, [2]: number}, [2]: number }>
Units = {}, -- Used to track units, --Units = {}, -- Used to track units,
---@type table<string, { history: table<number, { time: number, percentage: number }>, time: number }>
Units = {},
---@type table<string, boolean> ---@type table<string, boolean>
ExistingUnits = {}, -- Used to track GUIDs of currently existing units (to be compared with tracked units) ExistingUnits = {}, -- Used to track GUIDs of currently existing units (to be compared with tracked units)
Throttle = 0, Throttle = 0,
@ -69,33 +72,40 @@ function TimeToDie:Refresh()
local healthPercentage = unit:GetHealthPercent() local healthPercentage = unit:GetHealthPercent()
-- Check if it's a valid unit -- Check if it's a valid unit
if healthPercentage < 100 then if healthPercentage < 100 then
--local unitTable = units[unitGUID]
local unitTable = units[unitGUID] local unitTable = units[unitGUID]
-- Check if we have seen one time this unit, if we don't then initialize it. -- Check if we have seen one time this unit, if we don't then initialize it.
if not unitTable or healthPercentage > unitTable[1][1][2] then if not unitTable or healthPercentage > unitTable.history[1].percentage then
unitTable = { {}, currentTime } unitTable = {
history = {
{ time = currentTime, percentage = healthPercentage }
},
time =
currentTime
}
units[unitGUID] = unitTable units[unitGUID] = unitTable
end end
local values = unitTable[1] local history = unitTable.history
local time = currentTime - unitTable[2] local time = currentTime - unitTable.time
-- Check if the % HP changed since the last check (or if there were none) -- Check if the % HP changed since the last check (or if there were none)
if not values or healthPercentage ~= values[2] then if not history or healthPercentage ~= history[1].percentage then
local value local val
local lastIndex = #ttdCache local lastIndex = #ttdCache
-- Check if we can re-use a table from the cache -- Check if we can re-use a table from the cache
if lastIndex == 0 then if lastIndex == 0 then
value = { time, healthPercentage } val = { time = currentTime, percentage = healthPercentage }
else else
value = ttdCache[lastIndex] val = ttdCache[lastIndex]
ttdCache[lastIndex] = nil ttdCache[lastIndex] = nil
value[1] = time val.time = currentTime
value[2] = healthPercentage val.percentage = healthPercentage
end end
table.insert(values, 1, value) table.insert(history, 1, val)
local n = #values local n = #history
-- Delete values that are no longer valid -- Delete values that are no longer valid
while (n > historyCount) or (time - values[n][1] > historyTime) do while (n > historyCount) or (time - history[n].time > historyTime) do
ttdCache[#Cache + 1] = values[n] ttdCache[#ttdCache + 1] = history[n]
values[n] = nil history[n] = nil
n = n - 1 n = n - 1
end end
end end

@ -128,7 +128,7 @@ function Unit:GetMaxHealth()
return UnitHealthMax(self:GetOMToken()) return UnitHealthMax(self:GetOMToken())
end end
-- Get the units health percentage -- Return Health Percent as an integer (0-100)
---@return number ---@return number
function Unit:GetHP() function Unit:GetHP()
return self:GetHealth() / self:GetMaxHealth() * 100 return self:GetHealth() / self:GetMaxHealth() * 100
@ -152,7 +152,7 @@ function Unit:GetHealAbsorbedHealth()
return UnitGetTotalHealAbsorbs(self:GetOMToken()) return UnitGetTotalHealAbsorbs(self:GetOMToken())
end end
-- Get the units health deficit -- Return Health Percent as an integer (0-100)
---@return number ---@return number
function Unit:GetHealthPercent() function Unit:GetHealthPercent()
return self:GetHP() return self:GetHP()
@ -1493,15 +1493,15 @@ function Unit:TimeToX(percentage, minSamples)
-- Matrix arithmetic has been expanded and solved to make the following operation as fast as possible -- Matrix arithmetic has been expanded and solved to make the following operation as fast as possible
if unitTable then if unitTable then
minSamples = minSamples or 3 minSamples = minSamples or 3
local values = unitTable[1] local history = unitTable.history
local n = #values local n = #history
if n > minSamples then if n > minSamples then
local a, b = 0, 0 local a, b = 0, 0
local ex2, ex, exy, ey = 0, 0, 0, 0 local ex2, ex, exy, ey = 0, 0, 0, 0
for i = 1, n do for i = 1, n do
local value = values[i] local value = history[i]
local x, y = value[1], value[2] local x, y = value.time, value.percentage
ex2 = ex2 + x * x ex2 = ex2 + x * x
ex = ex + x ex = ex + x
@ -1517,7 +1517,7 @@ function Unit:TimeToX(percentage, minSamples)
-- Use best fit line to calculate estimated time to reach target health -- Use best fit line to calculate estimated time to reach target health
seconds = (percentage - a) / b seconds = (percentage - a) / b
-- Subtract current time to obtain "time remaining" -- Subtract current time to obtain "time remaining"
seconds = seconds - (GetTime() - unitTable[2]) seconds = seconds - (GetTime() - unitTable.time)
if seconds < 0 then seconds = Bastion.TimeToDie.Enums.NEGATIVE_TTD end if seconds < 0 then seconds = Bastion.TimeToDie.Enums.NEGATIVE_TTD end
end end
end end

Loading…
Cancel
Save