From 32b4e36835de62046c42dffb342a2da9c541e3cb Mon Sep 17 00:00:00 2001 From: Uladzislau Hubar Date: Wed, 31 Jan 2024 14:53:35 +0100 Subject: [PATCH] Fixed LinearSum score calculation to avoid underflows --- src/service/proximity-scoring-service.js | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/service/proximity-scoring-service.js b/src/service/proximity-scoring-service.js index fb6c09a732..a0fcb37f99 100644 --- a/src/service/proximity-scoring-service.js +++ b/src/service/proximity-scoring-service.js @@ -164,10 +164,22 @@ class ProximityScoringService { '1000000000000000000', ); - const proximityScore = oneEther.sub(normalizedDistance).mul(w1); + const isProximityScorePositive = oneEther.gte(normalizedDistance); + + const proximityScore = isProximityScorePositive + ? oneEther.sub(normalizedDistance).mul(w1) + : normalizedDistance.sub(oneEther).mul(w1); const stakeScore = normalizedStake.mul(w2); - let finalScore = proximityScore.add(stakeScore); + let finalScore; + if (isProximityScorePositive) { + finalScore = proximityScore.add(stakeScore); + } else if (stakeScore.gte(proximityScore)) { + finalScore = stakeScore.sub(proximityScore); + } else { + finalScore = await this.blockchainModuleManager.toBigNumber(blockchain, 0); + } + if (finalScore.gt(UINT40_MAX_BN)) { finalScore = finalScore.mod(UINT40_MAX_BN.add(1)); }