UNPKG

@types/d3-array

Version:
1,088 lines (977 loc) 47.8 kB
// Last module patch version validated against: 3.2.4 // -------------------------------------------------------------------------- // Shared Types and Interfaces // -------------------------------------------------------------------------- /** * Administrivia: JavaScript primitive types and Date */ export type Primitive = number | string | boolean | Date; /** * Administrivia: anything with a valueOf(): number method is comparable, so we allow it in numeric operations */ export interface Numeric { valueOf(): number; } /** * Administrivia: a matrix of numeric values. * If height is not specified, it is inferred from the given width and data.length. */ export interface Matrix { data: ArrayLike<number>; width: number; height?: number; } /** * Represents a nested/recursive InternMap type * * The first generic "TObject" refers to the type of the data object that is available in the accessor functions. * The second generic "TReduce" refers to the type of the data available at the deepest level (the result data). * The third generic "TKeys" refers to the type of the keys at each level of the nestes InternMap. */ export type NestedInternMap<TObject, TReduce, TKeys extends unknown[]> = TKeys extends [infer TFirst, ...infer TRest] ? InternMap<TFirst, NestedInternMap<TObject, TReduce, TRest>> : TReduce; /** * Represents a nested/recursive Array type * * The first generic "TObject" refers to the type of the data object that is available in the accessor functions. * The second generic "TReduce" refers to the type of the data available at the deepest level (the result data). * The third generic "TKeys" refers to the type of the keys at each level of the nestes Array. */ export type NestedArray<TObject, TReduce, TKeys extends unknown[]> = TKeys extends [infer TFirst, ...infer TRest] ? Array<[TFirst, NestedArray<TObject, TReduce, TRest>]> : TReduce; // -------------------------------------------------------------------------------------- // Statistics // -------------------------------------------------------------------------------------- /** * Return the minimum value in the array using natural order. */ export function min(iterable: Iterable<string>): string | undefined; /** * Return the minimum value in the array using natural order. */ export function min<T extends Numeric>(iterable: Iterable<T>): T | undefined; /** * Return the minimum value in the array using natural order. */ export function min<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => string | undefined | null, ): string | undefined; /** * Return the minimum value in the array using natural order. */ export function min<T, U extends Numeric>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => U | undefined | null, ): U | undefined; /** * Return the index of the minimum value in the array using natural order. */ export function minIndex(iterable: Iterable<unknown>): number; /** * Return the index of the minimum value in the array using natural order and a projection function to map values. */ export function minIndex<TDatum>( iterable: Iterable<TDatum>, accessor: (datum: TDatum, index: number, array: Iterable<TDatum>) => unknown, ): number; /** * Return the index of the minimum value in the array using natural order. */ export function minIndex(iterable: Iterable<unknown>): number; /** * Return the maximum value in the array of strings using natural order. */ export function max(iterable: Iterable<string>): string | undefined; /** * Return the maximum value in the array of numbers using natural order. */ export function max<T extends Numeric>(iterable: Iterable<T>): T | undefined; /** * Return the maximum value in the array using natural order and a projection function to map values to strings. */ export function max<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => string | undefined | null, ): string | undefined; /** * Return the maximum value in the array using natural order and a projection function to map values to easily-sorted values. */ export function max<T, U extends Numeric>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => U | undefined | null, ): U | undefined; /** * Return the index of the maximum value in the array using natural order. */ export function maxIndex(iterable: Iterable<unknown>): number; /** * Return the index of the maximum value in the array using natural order and a projection function to map values. */ export function maxIndex<TDatum>( iterable: Iterable<TDatum>, accessor: (datum: TDatum, index: number, array: Iterable<TDatum>) => unknown, ): number; /** * Return the min and max simultaneously. */ export function extent(iterable: Iterable<string>): [string, string] | [undefined, undefined]; /** * Return the min and max simultaneously. */ export function extent<T extends Numeric>(iterable: Iterable<T>): [T, T] | [undefined, undefined]; /** * Return the min and max simultaneously. */ export function extent<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => string | undefined | null, ): [string, string] | [undefined, undefined]; /** * Return the min and max simultaneously. */ export function extent<T, U extends Numeric>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => U | undefined | null, ): [U, U] | [undefined, undefined]; /** * Returns the mode of the given iterable, i.e. the value which appears the most often. * In case of equality, returns the first of the relevant values. * If the iterable contains no comparable values, returns undefined. * An optional accessor function may be specified, which is equivalent to calling Array.from before computing the mode. * This method ignores undefined, null and NaN values; this is useful for ignoring missing data. */ export function mode(iterable: Iterable<Numeric | undefined | null>): number; /** * Returns the mode of the given iterable, i.e. the value which appears the most often. * In case of equality, returns the first of the relevant values. * If the iterable contains no comparable values, returns undefined. * An optional accessor function may be specified, which is equivalent to calling Array.from before computing the mode. * This method ignores undefined, null and NaN values; this is useful for ignoring missing data. */ export function mode<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): number; /** * Compute the sum of an array of numbers. */ export function sum(iterable: Iterable<Numeric | undefined | null>): number; /** * Compute the sum of an array, using the given accessor to convert values to numbers. */ export function sum<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): number; /** * Return the mean of an array of numbers */ export function mean(iterable: Iterable<Numeric | undefined | null>): number | undefined; /** * Return the mean of an array of numbers */ export function mean<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): number | undefined; /** * Return the median of an array of numbers */ export function median(iterable: Iterable<Numeric | undefined | null>): number | undefined; /** * Return the median of an array of numbers */ export function median<T>( iterable: Iterable<T>, accessor: (element: T, i: number, array: Iterable<T>) => number | undefined | null, ): number | undefined; /** * Like median, but returns the index of the element to the left of the median. */ export function medianIndex(iterable: Iterable<Numeric | undefined | null>): number; /** * Like median, but returns the index of the element to the left of the median. */ export function medianIndex<T>( iterable: Iterable<T>, accessor: (element: T, i: number, array: Iterable<T>) => number | undefined | null, ): number; /** * Returns the cumulative sum of the given iterable of numbers, as a Float64Array of the same length. * If the iterable contains no numbers, returns zeros. * An optional accessor function may be specified, which is equivalent to calling Array.from before computing the cumulative sum. * This method ignores undefined and NaN values; this is useful for ignoring missing data. */ export function cumsum(iterable: Iterable<Numeric | undefined | null>): Float64Array; /** * Returns the cumulative sum of the given iterable of numbers, as a Float64Array of the same length. * If the iterable contains no numbers, returns zeros. * An optional accessor function may be specified, which is equivalent to calling Array.from before computing the cumulative sum. * This method ignores undefined and NaN values; this is useful for ignoring missing data. */ export function cumsum<T>( iterable: Iterable<T>, accessor: (element: T, i: number, array: Iterable<T>) => number | undefined | null, ): Float64Array; /** * Returns the p-quantile of the given iterable of numbers, where p is a number in the range [0, 1]. * * An optional accessor function may be specified, which is equivalent to calling array.map(accessor) before computing the quantile. */ export function quantile(iterable: Iterable<Numeric | undefined | null>, p: number): number | undefined; /** * Returns the p-quantile of the given iterable of numbers, where p is a number in the range [0, 1]. * * An optional accessor function may be specified, which is equivalent to calling array.map(accessor) before computing the quantile. */ export function quantile<T>( iterable: Iterable<T>, p: number, accessor: (element: T, i: number, array: Iterable<T>) => number | undefined | null, ): number | undefined; /** * Similar to quantile, but returns the index to the left of p. */ export function quantileIndex(iterable: Iterable<Numeric | undefined | null>, p: number): number; /** * Similar to quantile, but returns the index to the left of p. */ export function quantileIndex<T>( iterable: Iterable<T>, p: number, accessor: (element: T, i: number, array: Iterable<T>) => number | undefined | null, ): number; /** * Similar to quantile, but expects the input to be a sorted array of values. * In contrast with quantile, the accessor is only called on the elements needed to compute the quantile. */ export function quantileSorted( array: Array<Numeric | undefined | null>, p: number, ): number | undefined; /** * Similar to quantile, but expects the input to be a sorted array of values. * In contrast with quantile, the accessor is only called on the elements needed to compute the quantile. */ export function quantileSorted<T>( array: T[], p: number, accessor: (element: T, i: number, array: T[]) => number | undefined | null, ): number | undefined; /** * Returns an array with the rank of each value in the iterable, i.e. the zero-based index of the value when the iterable is sorted. * Nullish values are sorted to the end and ranked NaN. * An optional comparator or accessor function may be specified; the latter is equivalent to calling array.map(accessor) before computing the ranks. * If comparator is not specified, it defaults to ascending. * Ties (equivalent values) all get the same rank, defined as the first time the value is found. */ export function rank(iterable: Iterable<Numeric | undefined | null>): Float64Array; /** * Returns an array with the rank of each value in the iterable, i.e. the zero-based index of the value when the iterable is sorted. * Nullish values are sorted to the end and ranked NaN. * An optional comparator or accessor function may be specified; the latter is equivalent to calling array.map(accessor) before computing the ranks. * If comparator is not specified, it defaults to ascending. * Ties (equivalent values) all get the same rank, defined as the first time the value is found. */ export function rank<T>( iterable: Iterable<T>, accessorOrComparator: | ((datum: T, index: number, array: Iterable<T>) => number | undefined | null) | ((a: T, b: T) => number | undefined | null), ): Float64Array; /** * Returns an unbiased estimator of the population variance of the given iterable of numbers using Welford’s algorithm. * If the iterable has fewer than two numbers, returns undefined. * An optional accessor function may be specified, which is equivalent to calling Array.from before computing the variance. * This method ignores undefined and NaN values; this is useful for ignoring missing data. */ export function variance(iterable: Iterable<Numeric | undefined | null>): number | undefined; /** * Returns an unbiased estimator of the population variance of the given iterable of numbers using Welford’s algorithm. * If the iterable has fewer than two numbers, returns undefined. * An optional accessor function may be specified, which is equivalent to calling Array.from before computing the variance. * This method ignores undefined and NaN values; this is useful for ignoring missing data. */ export function variance<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): number | undefined; /** * Compute the standard deviation, defined as the square root of the bias-corrected variance, of the given array of numbers. */ export function deviation(iterable: Iterable<Numeric | undefined | null>): number | undefined; /** * Compute the standard deviation, defined as the square root of the bias-corrected variance, of the given array, * using the given accessor to convert values to numbers. */ export function deviation<T>( iterable: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): number | undefined; /** * Returns a full precision summation of the given values. * Although slower, d3.fsum can replace d3.sum wherever greater precision is needed. Uses d3.Adder. */ export function fsum(values: Iterable<Numeric | undefined | null>): number; /** * Returns a full precision summation of the given values. * Although slower, d3.fsum can replace d3.sum wherever greater precision is needed. Uses d3.Adder. */ export function fsum<T>( values: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): number; /** * Returns a full precision cumulative sum of the given values. * Although slower, d3.fcumsum can replace d3.cumsum when greater precision is needed. Uses d3.Adder. */ export function fcumsum(values: Iterable<Numeric | undefined | null>): Float64Array; /** * Returns a full precision cumulative sum of the given values. * Although slower, d3.fcumsum can replace d3.cumsum when greater precision is needed. Uses d3.Adder. */ export function fcumsum<T>( values: Iterable<T>, accessor: (datum: T, index: number, array: Iterable<T>) => number | undefined | null, ): Float64Array; export class Adder { /** * Creates a full precision adder for IEEE 754 floating point numbers, setting its initial value to 0. */ constructor(); /** * Adds the specified number to the adder’s current value and returns the adder. */ add(number: number): Adder; /** * Returns the IEEE 754 double precision representation of the adder’s current value. * Most useful as the short-hand notation +adder. */ valueOf(): number; } // -------------------------------------------------------------------------------------- // Search // -------------------------------------------------------------------------------------- /** * Returns the least element of the specified iterable according to the specified comparator. * If comparator is not specified, it defaults to ascending. */ export function least<T>(iterable: Iterable<T>, comparator?: (a: T, b: T) => number): T | undefined; /** * Returns the least element of the specified iterable according to the specified accessor. */ export function least<T>(iterable: Iterable<T>, accessor: (a: T) => unknown): T | undefined; /** * Returns the index of the least element of the specified iterable according to the specified comparator. */ export function leastIndex(iterable: Iterable<unknown>): number | undefined; /** * Returns the index of the least element of the specified iterable according to the specified comparator. */ export function leastIndex<T>(iterable: Iterable<T>, comparator: (a: T, b: T) => number): number | undefined; /** * Returns the index of the least element of the specified iterable according to the specified accessor. */ // tslint:disable-next-line:unified-signatures export function leastIndex<T>(iterable: Iterable<T>, accessor: (a: T) => unknown): number | undefined; /** * Returns the greatest element of the specified iterable according to the specified comparator or accessor. * If the given iterable contains no comparable elements (i.e., the comparator returns NaN when comparing each element to itself), returns undefined. * If comparator is not specified, it defaults to ascending. */ export function greatest<T>(iterable: Iterable<T>, comparator?: (a: T, b: T) => number): T | undefined; /** * Returns the greatest element of the specified iterable according to the specified comparator or accessor. * If the given iterable contains no comparable elements (i.e., the comparator returns NaN when comparing each element to itself), returns undefined. * If comparator is not specified, it defaults to ascending. */ export function greatest<T>(iterable: Iterable<T>, accessor: (a: T) => unknown): T | undefined; /** * Returns the index of the greatest element of the specified iterable according to the specified comparator or accessor. * If the given iterable contains no comparable elements (i.e., the comparator returns NaN when comparing each element to itself), returns -1. * If comparator is not specified, it defaults to ascending. */ export function greatestIndex(iterable: Iterable<unknown>): number | undefined; /** * Returns the index of the greatest element of the specified iterable according to the specified comparator or accessor. * If the given iterable contains no comparable elements (i.e., the comparator returns NaN when comparing each element to itself), returns -1. * If comparator is not specified, it defaults to ascending. */ export function greatestIndex<T>(iterable: Iterable<T>, comparator: (a: T, b: T) => number): number | undefined; /** * Returns the index of the greatest element of the specified iterable according to the specified comparator or accessor. * If the given iterable contains no comparable elements (i.e., the comparator returns NaN when comparing each element to itself), returns -1. * If comparator is not specified, it defaults to ascending. */ // tslint:disable-next-line:unified-signatures export function greatestIndex<T>(iterable: Iterable<T>, accessor: (a: T) => unknown): number | undefined; export function bisectLeft(array: ArrayLike<number>, x: number, lo?: number, hi?: number): number; export function bisectLeft(array: ArrayLike<string>, x: string, lo?: number, hi?: number): number; export function bisectLeft(array: ArrayLike<Date>, x: Date, lo?: number, hi?: number): number; export function bisectRight(array: ArrayLike<number>, x: number, lo?: number, hi?: number): number; export function bisectRight(array: ArrayLike<string>, x: string, lo?: number, hi?: number): number; export function bisectRight(array: ArrayLike<Date>, x: Date, lo?: number, hi?: number): number; export function bisectCenter(array: ArrayLike<number>, x: number, lo?: number, hi?: number): number; export function bisectCenter(array: ArrayLike<string>, x: string, lo?: number, hi?: number): number; export function bisectCenter(array: ArrayLike<Date>, x: Date, lo?: number, hi?: number): number; export const bisect: typeof bisectRight; export interface Bisector<T, U> { left(array: ArrayLike<T>, x: U, lo?: number, hi?: number): number; right(array: ArrayLike<T>, x: U, lo?: number, hi?: number): number; center(array: ArrayLike<T>, x: U, lo?: number, hi?: number): number; } export function bisector<T, U>(comparator: (a: T, b: U) => number): Bisector<T, U>; // tslint:disable-next-line:unified-signatures export function bisector<T, U>(accessor: (x: T) => U): Bisector<T, U>; /** * Rearranges items so that all items in the [left, k] are the smallest. The k-th element will have the (k - left + 1)-th smallest value in [left, right]. * * @param array The array to partially sort (in place). * @param k The middle index for partial sorting. * @param left The left index of the range to sort. * @param right The right index. * @param compare The compare function. */ export function quickselect<T>( array: ArrayLike<T>, k: number, left?: number, right?: number, compare?: (a: Primitive | undefined, b: Primitive | undefined) => number, ): T[]; // NB. this is limited to primitive values due to D3's use of the <, >, and >= operators. Results get weird for object instances. /** * Compares two primitive values for sorting (in ascending order). */ export function ascending(a: Primitive | undefined, b: Primitive | undefined): number; // NB. this is limited to primitive values due to D3's use of the <, >, and >= operators. Results get weird for object instances. /** * Compares two primitive values for sorting (in descending order). */ export function descending(a: Primitive | undefined, b: Primitive | undefined): number; // -------------------------------------------------------------------------------------- // Transformations // -------------------------------------------------------------------------------------- /** * Groups the specified iterable of values into an InternMap from key to array of value. * * @param iterable The iterable to group. * @param keys The key functions. */ export function group<TObject, TKeys extends unknown[]>( iterable: Iterable<TObject>, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): NestedInternMap<TObject, TObject[], TKeys>; /** * Equivalent to group, but returns nested arrays instead of nested maps. * * @param iterable The iterable to group. * @param keys The key functions. */ export function groups<TObject, TKeys extends unknown[]>( iterable: Iterable<TObject>, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): NestedArray<TObject, TObject[], TKeys>; /** * Equivalent to group, but returns a flat array of [key0, key1, …, values] instead of nested maps. * * @param iterable The iterable to group. * @param keys The key functions. */ export function flatGroup<TObject, TKeys extends unknown[]>( iterable: Iterable<TObject>, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): Array<[...TKeys, TObject[]]>; /** * Equivalent to group but returns a unique value per compound key instead of an array, throwing if the key is not unique. * * @param iterable The iterable to group. * @param key The key functions. */ export function index<TObject, TKeys extends unknown[]>( iterable: Iterable<TObject>, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): NestedInternMap<TObject, TObject, TKeys>; /** * Equivalent to index, but returns nested arrays instead of nested maps. * * @param iterable The iterable to group. * @param keys The key functions. */ export function indexes<TObject, TKeys extends unknown[]>( iterable: Iterable<TObject>, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): NestedArray<TObject, TObject, TKeys>; /** * Groups and reduces the specified array of values into an InternMap from key to value. * * @param iterable The iterable to group. * @param reduce The reduce function. * @param keys The key functions. */ export function rollup<TObject, TReduce, TKeys extends unknown[]>( iterable: Iterable<TObject>, reduce: (values: TObject[]) => TReduce, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): NestedInternMap<TObject, TReduce, TKeys>; /** * Equivalent to rollup, but returns nested arrays instead of nested maps. * * @param iterable The iterable to group. * @param reduce The reduce function. * @param keys The key functions. */ export function rollups<TObject, TReduce, TKeys extends unknown[]>( iterable: Iterable<TObject>, reduce: (values: TObject[]) => TReduce, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): NestedArray<TObject, TReduce, TKeys>; /** * Equivalent to rollup, but returns a flat array of [key0, key1, …, value] instead of nested maps. * * @param iterable The iterable to group. * @param reduce The reduce function. * @param keys The key functions. */ export function flatRollup<TObject, TReduce, TKeys extends unknown[]>( iterable: Iterable<TObject>, reduce: (values: TObject[]) => TReduce, ...keys: { [Index in keyof TKeys]: (value: TObject, index: number, values: TObject[]) => TKeys[Index]; } ): Array<[...TKeys, TReduce]>; /** * Groups the specified iterable of elements according to the specified key function, sorts the groups according to the specified comparator, and then returns an array of keys in sorted order. * The comparator will be asked to compare two groups a and b and should return a negative value if a should be before b, a positive value if a should be after b, or zero for a partial ordering. */ export function groupSort<TObject, TKey>( iterable: Iterable<TObject>, comparator: (a: TObject[], b: TObject[]) => number, key: (value: TObject) => TKey, ): TKey[]; /** * Groups the specified iterable of elements according to the specified key function, sorts the groups according to the specified accessor, and then returns an array of keys in sorted order. */ export function groupSort<TObject, TKey>( iterable: Iterable<TObject>, // tslint:disable-next-line:unified-signatures accessor: (value: TObject[]) => unknown, key: (value: TObject) => TKey, ): TKey[]; /** * Returns the number of valid number values (i.e., not null, NaN, or undefined) in the specified iterable; accepts an accessor. * * @param iterable Input array. */ export function count(iterable: Iterable<unknown>): number; /** * Returns the number of valid number values (i.e., not null, NaN, or undefined) in the specified iterable; accepts an accessor. * * @param iterable Input array. * @param accessor Accessor method. */ export function count<TObject>( iterable: Iterable<TObject>, accessor: (a: TObject, b: TObject) => number | null | undefined, ): number; /** * Returns the Cartesian product of the two arrays a and b. * For each element i in the specified array a and each element j in the specified array b, in order, * it creates a two-element array for each pair. * * @param a First input array. * @param b Second input array. */ export function cross<S, T>(a: Iterable<S>, b: Iterable<T>): Array<[S, T]>; /** * Returns the Cartesian product of the two arrays a and b. * For each element i in the specified array a and each element j in the specified array b, in order, * invokes the specified reducer function passing the element i and element j. * * @param a First input array. * @param b Second input array. * @param reducer A reducer function taking as input an element from "a" and "b" and returning a reduced value. */ export function cross<S, T, U>(a: Iterable<S>, b: Iterable<T>, reducer: (a: S, b: T) => U): U[]; /** * Merges the specified arrays into a single array. */ export function merge<T>(iterables: Iterable<Iterable<T>>): T[]; /** * For each adjacent pair of elements in the specified array, returns a new array of tuples of elements i and i - 1. * Returns the empty array if the input array has fewer than two elements. * * @param iterable Array of input elements */ export function pairs<T>(iterable: Iterable<T>): Array<[T, T]>; /** * For each adjacent pair of elements in the specified array, in order, invokes the specified reducer function passing the element i and element i - 1. * Returns the resulting array of pair-wise reduced elements. * Returns the empty array if the input array has fewer than two elements. * * @param iterable Array of input elements * @param reducer A reducer function taking as input to adjacent elements of the input array and returning a reduced value. */ export function pairs<T, U>(iterable: Iterable<T>, reducer: (a: T, b: T) => U): U[]; /** * Returns a permutation of the specified source object (or array) using the specified iterable of keys. * The returned array contains the corresponding property of the source object for each key in keys, in order. * For example, `permute(["a", "b", "c"], [1, 2, 0]) // ["b", "c", "a"]` * * It is acceptable to have more keys than source elements, and for keys to be duplicated or omitted. */ export function permute<T>(source: { [key: number]: T }, keys: Iterable<number>): T[]; /** * Extract the values from an object into an array with a stable order. For example: * `var object = {yield: 27, year: 1931, site: "University Farm"};` * `d3.permute(object, ["site", "yield"]); // ["University Farm", 27]` */ export function permute<T, K extends keyof T>(source: T, keys: Iterable<K>): Array<T[K]>; /** * Randomizes the order of the specified array using the Fisher–Yates shuffle. */ export function shuffle<T>(array: T[], lo?: number, hi?: number): T[]; export function shuffle(array: Int8Array, lo?: number, hi?: number): Int8Array; export function shuffle(array: Uint8Array, lo?: number, hi?: number): Uint8Array; export function shuffle(array: Uint8ClampedArray, lo?: number, hi?: number): Uint8ClampedArray; export function shuffle(array: Int16Array, lo?: number, hi?: number): Int16Array; export function shuffle(array: Uint16Array, lo?: number, hi?: number): Uint16Array; export function shuffle(array: Int32Array, lo?: number, hi?: number): Int32Array; export function shuffle(array: Uint32Array, lo?: number, hi?: number): Uint32Array; export function shuffle(array: Float32Array, lo?: number, hi?: number): Float32Array; export function shuffle(array: Float64Array, lo?: number, hi?: number): Float64Array; /** * Returns a shuffle function given the specified random source. */ export function shuffler(random: () => number): typeof shuffle; /** * Generate an array of approximately count + 1 uniformly-spaced, nicely-rounded values between start and stop (inclusive). * Each value is a power of ten multiplied by 1, 2 or 5. See also d3.tickIncrement, d3.tickStep and linear.ticks. * * Ticks are inclusive in the sense that they may include the specified start and stop values if (and only if) they are exact, * nicely-rounded values consistent with the inferred step. More formally, each returned tick t satisfies start ≤ t and t ≤ stop. * * @param start Start value for ticks * @param stop Stop value for ticks * @param count count + 1 is the approximate number of ticks to be returned by d3.ticks. */ export function ticks(start: number, stop: number, count: number): number[]; /** * Returns the difference between adjacent tick values if the same arguments were passed to d3.ticks: * a nicely-rounded value that is a power of ten multiplied by 1, 2 or 5. * * Like d3.tickStep, except requires that start is always less than or equal to stop, and if the tick step for the given start, * stop and count would be less than one, returns the negative inverse tick step instead. * * This method is always guaranteed to return an integer, and is used by d3.ticks to avoid guarantee that the returned tick values * are represented as precisely as possible in IEEE 754 floating point. * * @param start Start value for ticks * @param stop Stop value for ticks * @param count count + 1 is the approximate number of ticks to be returned by d3.ticks. */ export function tickIncrement(start: number, stop: number, count: number): number; /** * Returns the difference between adjacent tick values if the same arguments were passed to d3.ticks: * a nicely-rounded value that is a power of ten multiplied by 1, 2 or 5. * * Note that due to the limited precision of IEEE 754 floating point, the returned value may not be exact decimals; * use d3-format to format numbers for human consumption. * * @param start Start value for ticks * @param stop Stop value for ticks * @param count count + 1 is the approximate number of ticks to be returned by d3.ticks. */ export function tickStep(start: number, stop: number, count: number): number; /** * Returns a new interval [niceStart, niceStop] covering the given interval [start, stop] and where niceStart and niceStop are guaranteed to align with the corresponding tick step. * Like d3.tickIncrement, this requires that start is less than or equal to stop. * * @param start Start value for ticks * @param stop Stop value for ticks * @param count count + 1 is the approximate number of ticks to be returned by d3.ticks. */ export function nice(start: number, stop: number, count: number): [number, number]; /** * Generates a 0-based numeric sequence. The output range does not include 'stop'. */ export function range(stop: number): number[]; /** * Generates a numeric sequence starting from the given start and stop values. 'step' defaults to 1. The output range does not include 'stop'. */ // tslint:disable-next-line:unified-signatures export function range(start: number, stop: number, step?: number): number[]; /** * Transpose a matrix provided in Array of Arrays format. */ export function transpose<T>(matrix: ArrayLike<ArrayLike<T>>): T[][]; /** * Returns an array of arrays, where the ith array contains the ith element from each of the argument arrays. * The returned array is truncated in length to the shortest array in arrays. If arrays contains only a single array, the returned array * contains one-element arrays. With no arguments, the returned array is empty. */ export function zip<T>(...arrays: Array<ArrayLike<T>>): T[][]; // -------------------------------------------------------------------------------------- // Blur // -------------------------------------------------------------------------------------- /** * Blurs an array of data in-place by applying three iterations of a moving average transform (box filter) * for a fast approximation of a Gaussian kernel of the given radius, a non-negative number. * Returns the given data. */ export function blur(data: ArrayLike<number>, radius: number): ArrayLike<number>; /** * Blurs a matrix of the given width and height in-place by applying a horizontal blur of radius rx * and a vertical blur of radius ry (which defaults to rx). * The matrix values data are stored in a flat (one-dimensional) array. * If height is not specified, it is inferred from the given width and data.length. * Returns the blurred matrix {data, width, height}. */ export function blur2(data: Matrix, rx: number, ry?: number): Matrix; /** * Blurs the given ImageData in-place, blurring each of the RGBA layers independently by applying an horizontal blur of radius rx * and a vertical blur of radius ry (which defaults to rx). * Returns the blurred ImageData. */ export function blurImage(imageData: ImageData, rx: number, ry?: number): ImageData; // -------------------------------------------------------------------------------------- // Iterables // -------------------------------------------------------------------------------------- /** * Returns true if the given test function returns true for every value in the given iterable. * This method returns as soon as test returns a non-truthy value or all values are iterated over. * Equivalent to array.every. */ export function every<T>( iterable: Iterable<T>, test: (value: T, index: number, iterable: Iterable<T>) => unknown, ): boolean; /** * Returns true if the given test function returns true for any value in the given iterable. * This method returns as soon as test returns a truthy value or all values are iterated over. * Equivalent to array.some. */ export function some<T>( iterable: Iterable<T>, test: (value: T, index: number, iterable: Iterable<T>) => unknown, ): boolean; /** * Returns a new array containing the values from iterable, in order, for which the given test function returns true. * Equivalent to array.filter. */ export function filter<T>( iterable: Iterable<T>, test: (value: T, index: number, iterable: Iterable<T>) => unknown, ): T[]; /** * Returns a new array containing the mapped values from iterable, in order, as defined by given mapper function. * Equivalent to array.map and Array.from. */ export function map<T, U>(iterable: Iterable<T>, mapper: (value: T, index: number, iterable: Iterable<T>) => U): U[]; /** * Returns the reduced value defined by given reducer function, which is repeatedly invoked for each value in iterable, being passed the current reduced value and the next value. * Equivalent to array.reduce. */ export function reduce<T>( iterable: Iterable<T>, reducer: (previousValue: T, currentValue: T, currentIndex: number, iterable: Iterable<T>) => T, initialValue?: T, ): T; /** * Returns the reduced value defined by given reducer function, which is repeatedly invoked for each value in iterable, being passed the current reduced value and the next value. * Equivalent to array.reduce. */ export function reduce<T, U>( iterable: Iterable<T>, reducer: (previousValue: U, currentValue: T, currentIndex: number, iterable: Iterable<T>) => U, initialValue: U, ): U; /** * Returns an array containing the values in the given iterable in reverse order. * Equivalent to array.reverse, except that it does not mutate the given iterable. */ export function reverse<T>(iterable: Iterable<T>): T[]; /** * Returns an array containing the values in the given iterable in the sorted order defined by the given comparator function. * If comparator is not specified, it defaults to d3.ascending. * Equivalent to array.sort, except that it does not mutate the given iterable, and the comparator defaults to natural order instead of lexicographic order. */ export function sort<T>(iterable: Iterable<T>, comparator?: (a: T, b: T) => number): T[]; /** * Returns an array containing the values in the given iterable in the sorted order defined by the given accessor function. * This is equivalent to a comparator using natural order. * The accessor is only invoked once per element, and thus may be nondeterministic. * Multiple accessors may be specified to break ties. */ export function sort<T>(iterable: Iterable<T>, ...accessors: Array<(a: T) => unknown>): T[]; // -------------------------------------------------------------------------------------- // Sets // -------------------------------------------------------------------------------------- /** * Returns a new InternSet containing every value in iterable that is not in any of the others iterables. */ export function difference<T>(iterable: Iterable<T>, ...others: Array<Iterable<T>>): InternSet<T>; /** * Returns a new InternSet containing every (distinct) value that appears in any of the given iterables. * The order of values in the returned set is based on their first occurrence in the given iterables. */ export function union<T>(...iterables: Array<Iterable<T>>): InternSet<T>; /** * Returns a new InternSet containing every (distinct) value that appears in all of the given iterables. * The order of values in the returned set is based on their first occurrence in the given iterables. */ export function intersection<T>(...iterables: Array<Iterable<T>>): InternSet<T>; /** * Returns true if a is a superset of b: if every value in the given iterable b is also in the given iterable a. */ export function superset<T>(a: Iterable<T>, b: Iterable<T>): boolean; /** * Returns true if a is a subset of b: if every value in the given iterable a is also in the given iterable b. */ export function subset<T>(a: Iterable<T>, b: Iterable<T>): boolean; /** * Returns true if a and b are disjoint: if a and b contain no shared value. */ export function disjoint<T>(a: Iterable<T>, b: Iterable<T>): boolean; // -------------------------------------------------------------------------------------- // Bins // -------------------------------------------------------------------------------------- export interface Bin<Datum, Value extends number | Date | undefined> extends Array<Datum> { x0: Value | undefined; x1: Value | undefined; } /** * Type definition for threshold generator which returns the count of recommended thresholds */ export type ThresholdCountGenerator<Value extends number | undefined = number | undefined> = ( values: ArrayLike<Value>, min: number, max: number, ) => number; /** * Type definition for threshold generator which returns an array of recommended numbers thresholds */ export type ThresholdNumberArrayGenerator<Value extends number | undefined> = ( values: ArrayLike<Value>, min: number, max: number, ) => Value[]; /** * Type definition for threshold generator which returns an array of recommended dates thresholds */ export type ThresholdDateArrayGenerator<Value extends Date | undefined> = ( values: ArrayLike<Value>, min: Date, max: Date, ) => Value[]; export interface HistogramCommon<Datum, Value extends number | Date | undefined> { (data: ArrayLike<Datum>): Array<Bin<Datum, Value>>; value(): (d: Datum, i: number, data: ArrayLike<Datum>) => Value; value(valueAccessor: (d: Datum, i: number, data: ArrayLike<Datum>) => Value): this; } export interface HistogramGeneratorDate<Datum, Value extends Date | undefined> extends HistogramCommon<Datum, Date> { domain(): (values: ArrayLike<Value>) => [Date, Date]; domain(domain: [Date, Date] | ((values: ArrayLike<Value>) => [Date, Date])): this; thresholds(): ThresholdDateArrayGenerator<Value>; /** * Set the array of values to be used as thresholds in determining the bins. * * Any threshold values outside the domain are ignored. The first bin.x0 is always equal to the minimum domain value, * and the last bin.x1 is always equal to the maximum domain value. * * @param thresholds Either an array of threshold values used for binning. The elements must * be of the same type as the materialized values of the histogram. * Or a function which accepts as arguments the array of materialized values, and * optionally the domain minimum and maximum. The function calculates and returns the array of values to be used as * thresholds in determining the bins. */ thresholds(thresholds: ArrayLike<Value> | ThresholdDateArrayGenerator<Value>): this; } export interface HistogramGeneratorNumber<Datum, Value extends number | undefined> extends HistogramCommon<Datum, Value> { domain(): (values: Iterable<Value>) => [number, number] | [undefined, undefined]; domain(domain: [number, number] | ((values: Iterable<Value>) => [number, number] | [undefined, undefined])): this; thresholds(): ThresholdCountGenerator<Value> | ThresholdNumberArrayGenerator<Value>; /** * Divide the domain uniformly into approximately count bins. IMPORTANT: This threshold * setting approach only works, when the materialized values are numbers! * * Any threshold values outside the domain are ignored. The first bin.x0 is always equal to the minimum domain value, * and the last bin.x1 is always equal to the maximum domain value. * * @param count Either the desired number of uniform bins or a function which accepts as arguments the array of * materialized values, and optionally the domain minimum and maximum. The function calculates and returns the * suggested number of bins. */ thresholds(count: number | ThresholdCountGenerator<Value>): this; /** * Set the array of values to be used as thresholds in determining the bins. * * Any threshold values outside the domain are ignored. The first bin.x0 is always equal to the minimum domain value, * and the last bin.x1 is always equal to the maximum domain value. * * @param thresholds Either an array of threshold values used for binning. The elements must * be of the same type as the materialized values of the histogram. * Or a function which accepts as arguments the array of materialized values, and * optionally the domain minimum and maximum. The function calculates and returns the array of values to be used as * thresholds in determining the bins. */ // tslint:disable-next-line:unified-signatures thresholds(thresholds: ArrayLike<Value> | ThresholdNumberArrayGenerator<Value>): this; } /** * @deprecated Use bin instead. */ export function histogram(): HistogramGeneratorNumber<number, number>; /** * @deprecated Use bin instead. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function histogram<Datum, Value extends number | undefined>(): HistogramGeneratorNumber<Datum, Value>; /** * @deprecated Use bin instead. */ // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function histogram<Datum, Value extends Date | undefined>(): HistogramGeneratorDate<Datum, Value>; export function bin(): HistogramGeneratorNumber<number, number>; // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function bin<Datum, Value extends number | undefined>(): HistogramGeneratorNumber<Datum, Value>; // eslint-disable-next-line @definitelytyped/no-unnecessary-generics export function bin<Datum, Value extends Date | undefined>(): HistogramGeneratorDate<Datum, Value>; // -------------------------------------------------------------------------------------- // Histogram Thresholds // -------------------------------------------------------------------------------------- export function thresholdFreedmanDiaconis(values: ArrayLike<number | undefined>, min: number, max: number): number; // of type ThresholdCountGenerator export function thresholdScott(values: ArrayLike<number | undefined>, min: number, max: number): number; // of type ThresholdCountGenerator export function thresholdSturges(values: ArrayLike<number | undefined>): number; // of type ThresholdCountGenerator // -------------------------------------------------------------------------------------- // Interning // -------------------------------------------------------------------------------------- /** * The InternMap class extends the native JavaScript Map class, allowing Dates and other non-primitive keys by bypassing the SameValueZero algorithm when determining key equality. */ export class InternMap<K = any, V = any> extends Map<K, V> { } /** * The InternSet class extends the native JavaScript Set class, allowing Dates and other non-primitive keys by bypassing the SameValueZero algorithm when determining key equality. */ export class InternSet<T = any> extends Set<T> { }