fix: handle empty data set in median computation
[poolifier.git] / src / utils.ts
CommitLineData
bbeadd16
JB
1import type { WorkerChoiceStrategyOptions } from './pools/selection-strategies/selection-strategies-types'
2
6e9d10db
JB
3/**
4 * An intentional empty function.
5 */
4f3c3d89 6export const EMPTY_FUNCTION: () => void = Object.freeze(() => {
6e9d10db 7 /* Intentionally empty */
4f3c3d89 8})
78099a15
JB
9
10/**
bbeadd16
JB
11 * Default worker choice strategy options.
12 */
13export const DEFAULT_WORKER_CHOICE_STRATEGY_OPTIONS: WorkerChoiceStrategyOptions =
14 {
15 medRunTime: false
16 }
17
18/**
19 * Compute the median of the given data set.
78099a15
JB
20 *
21 * @param dataSet - Data set.
22 * @returns The median of the given data set.
23 */
24export const median = (dataSet: number[]): number => {
4a45e8d2
JB
25 if (Array.isArray(dataSet) && dataSet.length === 0) {
26 return 0
27 }
78099a15
JB
28 if (Array.isArray(dataSet) && dataSet.length === 1) {
29 return dataSet[0]
30 }
d27d0733 31 dataSet = dataSet.slice().sort((a, b) => a - b)
cdef2f76 32 return (dataSet[(dataSet.length - 1) >> 1] + dataSet[dataSet.length >> 1]) / 2
78099a15 33}
0d80593b
JB
34
35export const isPlainObject = (obj: unknown): boolean =>
36 typeof obj === 'object' &&
37 obj !== null &&
38 obj?.constructor === Object &&
39 Object.prototype.toString.call(obj) === '[object Object]'