c183e00d47
* cpmm initial commit: common logic, cloud functions * remove unnecessary property * contract type * rename 'calculate.ts' => 'calculate-dpm.ts' * rename dpm calculations * use focus hook * mechanism-agnostic calculations * bet panel: use new calculations * use new calculations * delete markets cloud function * use correct contract type in scripts / functions * calculate fixed payouts; bets list calculations * new bet: use calculateCpmmPurchase * getOutcomeProbabilityAfterBet * use deductFixedFees * fix auto-refactor * fix antes * separate logic to payouts-dpm, payouts-fixed * liquidity provision tracking * remove comment * liquidity label * create liquidity provision even if no ante bet * liquidity fee * use all bets for getFixedCancelPayouts * updateUserBalance: allow negative balances * store initialProbability in contracts * turn on liquidity fee; turn off creator fee * Include time param in tweet url, so image preview is re-fetched * share redemption * cpmm ContractBetsTable display * formatMoney: handle minus zero * filter out redemption bets * track fees on contract and bets; change fee schedule for cpmm markets; only pay out creator fees at resolution * small fixes * small fixes * Redeem shares pays back loans first * Fix initial point on graph * calculateCpmmPurchase: deduct creator fee * Filter out redemption bets from feed * set env to dev for user-testing purposes * creator fees messaging * new cfmm: k = y^(1-p) * n^p * addCpmmLiquidity * correct price function * enable fees * handle overflow * liquidity provision tracking * raise fees * Fix merge error * fix dpm free response payout for single outcome * Fix DPM payout calculation * Remove hardcoding as dev Co-authored-by: James Grugett <jahooma@gmail.com>
78 lines
2.0 KiB
TypeScript
78 lines
2.0 KiB
TypeScript
import * as _ from 'lodash'
|
|
|
|
import { Bet } from './bet'
|
|
import { Binary, Contract, FullContract } from './contract'
|
|
import { getPayouts } from './payouts'
|
|
|
|
export function scoreCreators(contracts: Contract[], bets: Bet[][]) {
|
|
const creatorScore = _.mapValues(
|
|
_.groupBy(contracts, ({ creatorId }) => creatorId),
|
|
(contracts) => _.sumBy(contracts, ({ pool }) => pool.YES + pool.NO)
|
|
)
|
|
|
|
return creatorScore
|
|
}
|
|
|
|
export function scoreTraders(contracts: Contract[], bets: Bet[][]) {
|
|
const userScoresByContract = contracts.map((contract, index) =>
|
|
scoreUsersByContract(contract, bets[index])
|
|
)
|
|
const userScores: { [userId: string]: number } = {}
|
|
for (const scores of userScoresByContract) {
|
|
addUserScores(scores, userScores)
|
|
}
|
|
return userScores
|
|
}
|
|
|
|
export function scoreUsersByContract(
|
|
contract: FullContract<any, Binary>,
|
|
bets: Bet[]
|
|
) {
|
|
const { resolution, resolutionProbability } = contract
|
|
|
|
const [closedBets, openBets] = _.partition(
|
|
bets,
|
|
(bet) => bet.isSold || bet.sale
|
|
)
|
|
const [resolvePayouts] = getPayouts(
|
|
resolution,
|
|
{},
|
|
contract,
|
|
openBets,
|
|
[],
|
|
resolutionProbability
|
|
)
|
|
|
|
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
|
|
}
|
|
|
|
export function addUserScores(
|
|
src: { [userId: string]: number },
|
|
dest: { [userId: string]: number }
|
|
) {
|
|
for (const [userId, score] of Object.entries(src)) {
|
|
if (dest[userId] === undefined) dest[userId] = 0
|
|
dest[userId] += score
|
|
}
|
|
}
|