UNPKG

pip-services3-commons-node

Version:
67 lines (58 loc) 2.46 kB
/** @module random */ /** * Random generator for integer values. * * ### Example ### * * let value1 = RandomInteger.nextInteger(5, 10); // Possible result: 7 * let value2 = RandomInteger.nextInteger(10); // Possible result: 3 * let value3 = RandomInteger.updateInteger(10, 3); // Possible result: 9 */ export class RandomInteger { /** * Generates a integer in the range ['min', 'max']. If 'max' is omitted, then the range will be set to [0, 'min']. * * @param min minimum value of the integer that will be generated. * If 'max' is omitted, then 'max' is set to 'min' and 'min' is set to 0. * @param max (optional) maximum value of the float that will be generated. Defaults to 'min' if omitted. * @returns generated random integer value. */ public static nextInteger(min: number, max: number = null): number { if (max == null) { max = min; min = 0; } if (max - min <= 0) return min; return Math.floor(min + Math.random() * (max - min)); } /** * Updates (drifts) a integer value within specified range defined * * @param value a integer value to drift. * @param range (optional) a range. Default: 10% of the value */ public static updateInteger(value: number, range: number = null): number { if (range == null) range = 0; range = range == 0 ? Math.floor(0.1 * value) : range; let minValue = value - range; let maxValue = value + range; return RandomInteger.nextInteger(minValue, maxValue); } /** * Generates a random sequence of integers starting from 0 like: [0,1,2,3...??] * * @param min minimum value of the integer that will be generated. * If 'max' is omitted, then 'max' is set to 'min' and 'min' is set to 0. * @param max (optional) maximum value of the float that will be generated. Defaults to 'min' if omitted. * @returns generated array of integers. */ public static sequence(min: number, max: number = null): number[] { max = max != null ? max : min; let count = RandomInteger.nextInteger(min, max); let result: number[] = []; for (let i = 0; i < count; i++) result.push(i); return result; } }