From 26f83ac4f657d7d7b2785bc103d78233fb8ed8a1 Mon Sep 17 00:00:00 2001 From: FRC Date: Fri, 9 Sep 2022 23:42:51 +0100 Subject: [PATCH 1/2] Adds investmentValue to group leaderboard calculation (#855) * Adds investmentValue to group leaderboard calculation * Initial investment is no longer counted, only the profit * Simplify scoring calculation * Remove console.log * Group bets by user first Co-authored-by: James Grugett --- common/scoring.ts | 43 +++---------------------------------------- 1 file changed, 3 insertions(+), 40 deletions(-) diff --git a/common/scoring.ts b/common/scoring.ts index 39a342fd..e88ea5fc 100644 --- a/common/scoring.ts +++ b/common/scoring.ts @@ -1,6 +1,7 @@ import { groupBy, sumBy, mapValues, partition } from 'lodash' import { Bet } from './bet' +import { getContractBetMetrics } from './calculate' import { Contract } from './contract' import { getPayouts } from './payouts' @@ -30,46 +31,8 @@ export function scoreTraders(contracts: Contract[], bets: Bet[][]) { } export function scoreUsersByContract(contract: Contract, bets: Bet[]) { - const { resolution } = contract - const resolutionProb = - contract.outcomeType == 'BINARY' - ? contract.resolutionProbability - : undefined - - const [closedBets, openBets] = partition( - bets, - (bet) => bet.isSold || bet.sale - ) - const { payouts: resolvePayouts } = getPayouts( - resolution as string, - contract, - openBets, - [], - {}, - resolutionProb - ) - - const salePayouts = closedBets.map((bet) => { - const { userId, sale } = bet - return { userId, payout: sale ? sale.amount : 0 } - }) - - const investments = bets - .filter((bet) => !bet.sale) - .map((bet) => { - const { userId, amount, loanAmount } = bet - const payout = -amount - (loanAmount ?? 0) - return { userId, payout } - }) - - const netPayouts = [...resolvePayouts, ...salePayouts, ...investments] - - const userScore = mapValues( - groupBy(netPayouts, (payout) => payout.userId), - (payouts) => sumBy(payouts, ({ payout }) => payout) - ) - - return userScore + const betsByUser = groupBy(bets, bet => bet.userId) + return mapValues(betsByUser, bets => getContractBetMetrics(contract, bets).profit) } export function addUserScores( From 11ba65ec4a942837b20cf83af07716993b246498 Mon Sep 17 00:00:00 2001 From: jahooma Date: Fri, 9 Sep 2022 22:43:33 +0000 Subject: [PATCH 2/2] Auto-remove unused imports --- common/scoring.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/common/scoring.ts b/common/scoring.ts index e88ea5fc..4ef46534 100644 --- a/common/scoring.ts +++ b/common/scoring.ts @@ -1,9 +1,8 @@ -import { groupBy, sumBy, mapValues, partition } from 'lodash' +import { groupBy, sumBy, mapValues } from 'lodash' import { Bet } from './bet' import { getContractBetMetrics } from './calculate' import { Contract } from './contract' -import { getPayouts } from './payouts' export function scoreCreators(contracts: Contract[]) { const creatorScore = mapValues(