* 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
 | |
|   }
 | |
| }
 |