Tweaks to stats page

This commit is contained in:
James Grugett 2022-06-14 10:27:50 -05:00
parent e49f614acb
commit be094ef8e5
2 changed files with 14 additions and 12 deletions

View File

@ -1,4 +1,4 @@
import { sortBy } from 'lodash' import { sortBy, sum } from 'lodash'
export const logInterpolation = (min: number, max: number, value: number) => { export const logInterpolation = (min: number, max: number, value: number) => {
if (value <= min) return 0 if (value <= min) return 0
@ -20,13 +20,17 @@ export function normpdf(x: number, mean = 0, variance = 1) {
export const TAU = Math.PI * 2 export const TAU = Math.PI * 2
export function median(values: number[]) { export function median(xs: number[]) {
if (values.length === 0) return NaN if (xs.length === 0) return NaN
const sorted = sortBy(values, (x) => x) const sorted = sortBy(xs, (x) => x)
const mid = Math.floor(sorted.length / 2) const mid = Math.floor(sorted.length / 2)
if (sorted.length % 2 === 0) { if (sorted.length % 2 === 0) {
return (sorted[mid - 1] + sorted[mid]) / 2 return (sorted[mid - 1] + sorted[mid]) / 2
} }
return sorted[mid] return sorted[mid]
} }
export function average(xs: number[]) {
return sum(xs) / xs.length
}

View File

@ -16,6 +16,7 @@ import { getDailyContracts } from 'web/lib/firebase/contracts'
import { getDailyNewUsers } from 'web/lib/firebase/users' import { getDailyNewUsers } from 'web/lib/firebase/users'
import { SiteLink } from 'web/components/site-link' import { SiteLink } from 'web/components/site-link'
import { Linkify } from 'web/components/linkify' import { Linkify } from 'web/components/linkify'
import { average } from 'common/util/math'
export const getStaticProps = fromPropz(getStaticPropz) export const getStaticProps = fromPropz(getStaticPropz)
export async function getStaticPropz() { export async function getStaticPropz() {
@ -61,7 +62,7 @@ export async function getStaticPropz() {
}) })
const monthlyActiveUsers = dailyUserIds.map((_, i) => { const monthlyActiveUsers = dailyUserIds.map((_, i) => {
const start = Math.max(0, i - 30) const start = Math.max(0, i - 29)
const end = i const end = i
const uniques = new Set<string>() const uniques = new Set<string>()
for (let j = start; j <= end; j++) for (let j = start; j <= end; j++)
@ -166,16 +167,12 @@ export async function getStaticPropz() {
const weeklyTopTenthActions = dailyTopTenthActions.map((_, i) => { const weeklyTopTenthActions = dailyTopTenthActions.map((_, i) => {
const start = Math.max(0, i - 6) const start = Math.max(0, i - 6)
const end = i const end = i
const total = sum(dailyTopTenthActions.slice(start, end)) return average(dailyTopTenthActions.slice(start, end))
if (end - start < 7) return (total * 7) / (end - start)
return total
}) })
const monthlyTopTenthActions = dailyTopTenthActions.map((_, i) => { const monthlyTopTenthActions = dailyTopTenthActions.map((_, i) => {
const start = Math.max(0, i - 29) const start = Math.max(0, i - 29)
const end = i const end = i
const total = sum(dailyTopTenthActions.slice(start, end)) return average(dailyTopTenthActions.slice(start, end))
if (end - start < 30) return (total * 30) / (end - start)
return total
}) })
// Total mana divided by 100. // Total mana divided by 100.
@ -193,7 +190,8 @@ export async function getStaticPropz() {
const start = Math.max(0, i - 29) const start = Math.max(0, i - 29)
const end = i const end = i
const total = sum(dailyManaBet.slice(start, end)) const total = sum(dailyManaBet.slice(start, end))
if (end - start < 30) return (total * 30) / (end - start) const range = end - start + 1
if (range < 30) return (total * 30) / range
return total return total
}) })