From e0ff8437271dd3ff778e7a53e0db682c8ba43a2a Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Tue, 12 Dec 2023 22:30:26 +0100 Subject: [PATCH] x/incentives: Lower Epoch allocation overhead (#7100) (#7104) * Lower allocation overhead * Add changelog (cherry picked from commit 63d2551ba02d53be6681d49e8a96b75c1287745d) Co-authored-by: Dev Ojha --- CHANGELOG.md | 1 + x/incentives/keeper/distribute.go | 5 +++-- x/incentives/keeper/iterator.go | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index cc43ce91609..fe7d2fa1318 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -74,6 +74,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 * [#6890](https://github.com/osmosis-labs/osmosis/pull/6890) Enable arb filter for affiliate swap contract * [#6884](https://github.com/osmosis-labs/osmosis/pull/6914) Update ListPoolsByDenom function by using pool.GetPoolDenoms to filter denom directly * [#6959](https://github.com/osmosis-labs/osmosis/pull/6959) Increase high gas threshold to 2m from 1m +* [#7093](https://github.com/osmosis-labs/osmosis/pull/7093),[#7100](https://github.com/osmosis-labs/osmosis/pull/7100) Lower CPU overheads of the Osmosis epoch. ### API Breaks diff --git a/x/incentives/keeper/distribute.go b/x/incentives/keeper/distribute.go index e4fb1163b27..8e3df929c49 100644 --- a/x/incentives/keeper/distribute.go +++ b/x/incentives/keeper/distribute.go @@ -652,13 +652,14 @@ func (k Keeper) distributeInternal( if lockSum.IsZero() { return nil, nil } - remainingEpochsAsInt := osmomath.NewInt(int64(remainEpochs)) // total_denom_lock_amount * remain_epochs - lockSumTimesRemainingEpochs := lockSum.Mul(remainingEpochsAsInt) + lockSumTimesRemainingEpochs := lockSum.MulRaw(int64(remainEpochs)) for _, lock := range locks { distrCoins := sdk.Coins{} + // too expensive + verbose even in debug mode. // ctx.Logger().Debug("distributeInternal, distribute to lock", "module", types.ModuleName, "gaugeId", gauge.Id, "lockId", lock.ID, "remainCons", remainCoins, "height", ctx.BlockHeight()) + for _, coin := range remainCoins { // distribution amount = gauge_size * denom_lock_amount / (total_denom_lock_amount * remain_epochs) denomLockAmt := lock.Coins.AmountOfNoDenomValidation(denom) diff --git a/x/incentives/keeper/iterator.go b/x/incentives/keeper/iterator.go index d455136d832..4192b4f7749 100644 --- a/x/incentives/keeper/iterator.go +++ b/x/incentives/keeper/iterator.go @@ -64,7 +64,7 @@ func (k Keeper) FinishedGaugesIterator(ctx sdk.Context) sdk.Iterator { // FilterLocksByMinDuration returns locks whose lock duration is greater than the provided minimum duration. func FilterLocksByMinDuration(locks []lockuptypes.PeriodLock, minDuration time.Duration) []lockuptypes.PeriodLock { - filteredLocks := make([]lockuptypes.PeriodLock, 0, len(locks)/2) + filteredLocks := make([]lockuptypes.PeriodLock, 0, len(locks)) for _, lock := range locks { if lock.Duration >= minDuration { filteredLocks = append(filteredLocks, lock)