Skip to content

Commit

Permalink
backend/refactor : #65 Driver Pool Optimisation
Browse files Browse the repository at this point in the history
  • Loading branch information
janhavi.soni authored and pius-1 committed Apr 29, 2023
1 parent cf3f71a commit df1963c
Showing 1 changed file with 58 additions and 5 deletions.
63 changes: 58 additions & 5 deletions lib/mobility-core/src/Kernel/Utils/SlidingWindowCounters.hs
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ decrementByValueImpl mbTimeStamp val keyModifier key SlidingWindowOptions {..} =
void $ Redis.decrby finalKey val
Redis.expire finalKey $ fromIntegral expirationTime

-- ================= Getter functions for fetching window results ======================
-- ================= Getter functions for fetching window results during first calculation ======================

-- Logic :
-- get last n (n=period) postivie and total counts from redis, add them up and simply divide them
Expand All @@ -245,26 +245,79 @@ decrementByValueImpl mbTimeStamp val keyModifier key SlidingWindowOptions {..} =
-- ** counts = {<TIMEBASED_KEY_FOR_POSITIVE_CASE>: positiveCases , <TIMEBASED_KEY_FOR_THE_TOTAL_CASES>: totalCases}

-- | getLatestRatio :: (id to getResult for, and generate TIMEBASED_KEY_FOR_THE_TOTAL_CASES) -> (id modifier to create TIMEBASED_KEY_FOR_POSITIVE_CASE) -> Resultsant Ratio of the sliding window
getLatestRatio ::
-- Minutes | Hours | Days | Months | Years
calculateRatioForFirstTime ::
( L.MonadFlow m,
Redis.HedisFlow m r
) =>
Text ->
(Text -> Text) ->
(Text -> Text) ->
(Text -> Text -> Text) ->
Text ->
SlidingWindowOptions ->
m Double
getLatestRatio driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn s@SlidingWindowOptions {..} = do
calculateRatioForFirstTime driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn mkOldRatioKeyfn ratioType s@SlidingWindowOptions {..} = do
utcTime <- L.runIO getCurrentTime
let positiveCaseKeysList = getkeysForLastPeriods s utcTime $ makeSlidingWindowKey periodType (mkPostiveCaseKeyfn driverId)
let totalCountKeysList = getkeysForLastPeriods s utcTime $ makeSlidingWindowKey periodType (mkTotalCaseKeyfn driverId)
totalCountKeysList = getkeysForLastPeriods s utcTime $ makeSlidingWindowKey periodType (mkTotalCaseKeyfn driverId)
positiveCases <- sum <$> mapMaybeM Redis.get positiveCaseKeysList
totalCases <- nonZero . sum <$> mapMaybeM Redis.get totalCountKeysList
pure $ positiveCases / totalCases
let ratio = positiveCases / totalCases
expTime = fromInteger . floor $ diffUTCTime (incrementPeriod periodType utcTime) utcTime
Redis.setExp (mkOldRatioKeyfn driverId ratioType) ratio expTime
pure ratio
where
nonZero :: Double -> Double
nonZero a = if a == 0.0 then 1.0 else a

recalculateRatio ::
( L.MonadFlow m,
Redis.HedisFlow m r
) =>
Text ->
(Text -> Text) ->
(Text -> Text) ->
(Text -> Text -> Text) ->
Text ->
SlidingWindowOptions ->
m Double
recalculateRatio driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn mkOldRatioKeyfn ratioType s@SlidingWindowOptions {..} = do
let positiveCaseKey = mkPostiveCaseKeyfn driverId
totalCaseKey = mkTotalCaseKeyfn driverId
oldRatioKey = mkOldRatioKeyfn driverId ratioType
positiveCase <-
Redis.get positiveCaseKey >>= \case
Nothing -> return 0
Just num -> return num
totalCase <-
Redis.get totalCaseKey >>= \case
Nothing -> return 1
Just total -> return total
ratio <-
Redis.get oldRatioKey >>= \case
Nothing -> calculateRatioForFirstTime driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn mkOldRatioKeyfn ratioType s
Just prevRatio -> return prevRatio
let newRatio = (positiveCase / totalCase + ratio) / 2
return newRatio

getLatestRatio ::
( L.MonadFlow m,
Redis.HedisFlow m r
) =>
Text ->
(Text -> Text) ->
(Text -> Text) ->
(Text -> Text -> Text) ->
Text ->
SlidingWindowOptions ->
m Double
getLatestRatio driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn mkOldRatioKeyfn ratioType SlidingWindowOptions {..} = do
ratio :: (Maybe Double) <- Redis.get (mkOldRatioKeyfn driverId ratioType)
case ratio of
Nothing -> calculateRatioForFirstTime driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn mkOldRatioKeyfn ratioType SlidingWindowOptions {..}
_ -> recalculateRatio driverId mkPostiveCaseKeyfn mkTotalCaseKeyfn mkOldRatioKeyfn ratioType SlidingWindowOptions {..}

getCurrentWindowValues ::
( L.MonadFlow m,
Redis.HedisFlow m r,
Expand Down

0 comments on commit df1963c

Please sign in to comment.