faastjs
Version:
Serverless batch computing made simple.
291 lines • 32.4 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.SmallestN = exports.MaxHeap = exports.defined = exports.keysOf = exports.f2 = exports.f1 = exports.KB = exports.MB = exports.GB = exports.uuidv4Pattern = exports.roundTo100ms = exports.hasExpired = exports.computeHttpResponseBytes = exports.objectSize = exports.sum = exports.chomp = exports.streamToBuffer = exports.sleep = exports.ExponentiallyDecayingAverageValue = exports.Statistics = void 0;
/**
* Incrementally updated statistics on a set of values.
* @public
*/
class Statistics {
/**
* Incrementally track mean, stdev, min, max, of a sequence of values.
* @param printFixedPrecision - The number of decimal places to print in
* {@link Statistics.toString}.
*/
constructor(
/** The number of decimal places to print in {@link Statistics.toString} */
printFixedPrecision = 1) {
this.printFixedPrecision = printFixedPrecision;
/** Number of values observed. */
this.samples = 0;
/** The maximum value observed. Initialized to `Number.NEGATIVE_INFINITY`. */
this.max = Number.NEGATIVE_INFINITY;
/** The minimum value observed. Initialized to `Number.POSITIVE_INFINITY`. */
this.min = Number.POSITIVE_INFINITY;
/** The variance of the values observed. */
this.variance = 0;
/** The standard deviation of the values observed. */
this.stdev = 0;
/** The mean (average) of the values observed. */
this.mean = NaN;
}
/** @internal */
clone() {
const rv = new Statistics(this.printFixedPrecision);
return Object.assign(rv, this);
}
/**
* Update statistics with a new value in the sequence.
*/
update(value) {
if (value === undefined) {
return;
}
let previousMean = this.mean;
// https://math.stackexchange.com/questions/374881/recursive-formula-for-variance
let previousVariance = this.variance;
if (this.samples === 0) {
previousMean = 0;
previousVariance = 0;
}
this.samples++;
this.mean = previousMean + (value - previousMean) / this.samples;
this.variance =
((previousVariance + (previousMean - value) ** 2 / this.samples) *
(this.samples - 1)) /
this.samples;
this.stdev = Math.sqrt(this.variance);
if (value > this.max) {
this.max = value;
}
if (value < this.min) {
this.min = value;
}
}
/**
* Print the mean of the observations seen, with the precision specified in
* the constructor.
*/
toString() {
return `${this.mean.toFixed(this.printFixedPrecision)}`;
}
}
exports.Statistics = Statistics;
class ExponentiallyDecayingAverageValue {
constructor(smoothingFactor) {
this.smoothingFactor = smoothingFactor;
this.samples = 0;
this.value = 0;
}
update(n) {
// tslint:disable-next-line:prefer-conditional-expression
if (this.samples++ === 0) {
this.value = n;
}
else {
this.value =
this.smoothingFactor * n + (1 - this.smoothingFactor) * this.value;
}
}
toString() {
return this.value;
}
}
exports.ExponentiallyDecayingAverageValue = ExponentiallyDecayingAverageValue;
function sleep(ms, cancel = new Promise(() => { })) {
let id;
cancel.then(_ => clearTimeout(id)).catch(_ => clearTimeout(id));
return Promise.race([new Promise(resolve => (id = setTimeout(resolve, ms))), cancel]);
}
exports.sleep = sleep;
function streamToBuffer(s) {
return new Promise((resolve, reject) => {
const buffers = [];
s.on("error", reject);
s.on("data", (data) => buffers.push(data));
s.on("end", () => resolve(Buffer.concat(buffers)));
});
}
exports.streamToBuffer = streamToBuffer;
function chomp(s) {
if (s.length > 0 && s[s.length - 1] === "\n") {
s = s.slice(0, s.length - 1);
}
return s;
}
exports.chomp = chomp;
const sum = (a) => a.reduce((total, n) => total + n, 0);
exports.sum = sum;
function objectSize(obj) {
if (!obj) {
return 0;
}
return (0, exports.sum)(Object.keys(obj).map(key => key.length + obj[key].length));
}
exports.objectSize = objectSize;
function computeHttpResponseBytes(headers, opts = { httpHeaders: true, min: 0 }) {
const headerKeys = Object.keys(headers);
let contentLength = 0;
for (const key of headerKeys) {
if (key.match(/^content-length$/i)) {
contentLength = Number(headers[key]);
break;
}
}
if (!opts.httpHeaders) {
return Math.max(contentLength, opts.min);
}
const headerLength = objectSize(headers) + headerKeys.length * ": ".length;
const otherLength = 13;
return Math.max(contentLength + headerLength + otherLength, opts.min);
}
exports.computeHttpResponseBytes = computeHttpResponseBytes;
function hasExpired(date, retentionInDays) {
if (retentionInDays <= 0) {
return true;
}
const timestamp = typeof date === "string" ? Date.parse(date) : date || 0;
return timestamp < Date.now() - retentionInDays * 24 * 60 * 60 * 1000;
}
exports.hasExpired = hasExpired;
function roundTo100ms(n) {
return Math.round(n / 100) * 100;
}
exports.roundTo100ms = roundTo100ms;
exports.uuidv4Pattern = "[a-f0-9]{8}-[a-f0-9]{4}-4[a-f0-9]{3}-[89aAbB][a-f0-9]{3}-[a-f0-9]{12}";
exports.GB = 2 ** 30;
exports.MB = 2 ** 20;
exports.KB = 2 ** 10;
function f1(n) {
return n.toFixed(1);
}
exports.f1 = f1;
function f2(n) {
return n.toFixed(2);
}
exports.f2 = f2;
function keysOf(obj) {
return Object.keys(obj);
}
exports.keysOf = keysOf;
function defined(arg) {
return !!arg;
}
exports.defined = defined;
class MaxHeap {
constructor() {
this._heap = [];
}
get size() {
return this._heap.length;
}
clear() {
this._heap = [];
}
peekMax() {
return this._heap[0];
}
insert(value) {
const h = this._heap;
h.push(value);
let i = h.length - 1;
const parentOf = (n) => Math.floor((n - 1) / 2);
let parent = parentOf(i);
while (parent >= 0 && h[i] > h[parent]) {
const tmp = h[parent];
h[parent] = h[i];
h[i] = tmp;
i = parent;
parent = parentOf(i);
}
}
extractMax() {
const h = this._heap;
if (h.length === 0) {
throw new Error("extractMax called on empty heap");
}
let i = 0;
const rv = h[0];
h[0] = h[h.length - 1];
h.pop();
while (i < h.length) {
const [left, right] = [i * 2 + 1, i * 2 + 2];
let maybe;
if (h[i] < h[left] && !(h[right] > h[left])) {
maybe = left;
}
else if (h[i] < h[right]) {
maybe = right;
}
if (maybe === undefined) {
break;
}
const [iValue, mValue] = [h[i], h[maybe]];
h[i] = mValue;
h[maybe] = iValue;
i = maybe;
}
return rv;
}
[Symbol.iterator]() {
return this._heap[Symbol.iterator]();
}
}
exports.MaxHeap = MaxHeap;
class SmallestN {
constructor(_size) {
this._size = _size;
this._heap = new MaxHeap();
this._map = [];
}
update(key, value) {
if (this._heap.size < this._size) {
this._heap.insert(key);
this._map.push([key, value]);
return;
}
if (key >= this._heap.peekMax()) {
return;
}
this._heap.insert(key);
this._map.push([key, value]);
this.shrink();
}
shrink() {
const max = this._heap.extractMax();
let idx = this._map.length;
while (--idx >= 0) {
if (this._map[idx][0] === max) {
break;
}
}
if (idx === -1) {
throw new Error(`SmallestN: could not find entry for key ${max}`);
}
this._map.splice(idx, 1);
}
[Symbol.iterator]() {
return this._map[Symbol.iterator]();
}
entries() {
return this._map[Symbol.iterator];
}
keys() {
return [...this._heap];
}
get size() {
return this._size;
}
clear() {
this._heap.clear();
this._map = [];
}
setSize(newSize) {
while (this._size > newSize) {
this.shrink();
this._size--;
}
this._size = newSize;
}
}
exports.SmallestN = SmallestN;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared.js","sourceRoot":"","sources":["../../src/shared.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Incrementally updated statistics on a set of values.\n * @public\n */\nexport class Statistics {\n    /** Number of values observed. */\n    samples = 0;\n    /** The maximum value observed. Initialized to `Number.NEGATIVE_INFINITY`. */\n    max = Number.NEGATIVE_INFINITY;\n    /** The minimum value observed. Initialized to `Number.POSITIVE_INFINITY`. */\n    min = Number.POSITIVE_INFINITY;\n    /** The variance of the values observed. */\n    variance = 0;\n    /** The standard deviation of the values observed. */\n    stdev = 0;\n    /** The mean (average) of the values observed. */\n    mean = NaN;\n\n    /**\n     * Incrementally track mean, stdev, min, max, of a sequence of values.\n     * @param printFixedPrecision - The number of decimal places to print in\n     * {@link Statistics.toString}.\n     */\n    constructor(\n        /** The number of decimal places to print in {@link Statistics.toString} */\n        protected printFixedPrecision: number = 1\n    ) {}\n\n    /** @internal */\n    clone() {\n        const rv = new Statistics(this.printFixedPrecision);\n        return Object.assign(rv, this);\n    }\n\n    /**\n     * Update statistics with a new value in the sequence.\n     */\n    update(value: number | undefined) {\n        if (value === undefined) {\n            return;\n        }\n        let previousMean = this.mean;\n        // https://math.stackexchange.com/questions/374881/recursive-formula-for-variance\n        let previousVariance = this.variance;\n        if (this.samples === 0) {\n            previousMean = 0;\n            previousVariance = 0;\n        }\n        this.samples++;\n        this.mean = previousMean + (value - previousMean) / this.samples;\n        this.variance =\n            ((previousVariance + (previousMean - value) ** 2 / this.samples) *\n                (this.samples - 1)) /\n            this.samples;\n        this.stdev = Math.sqrt(this.variance);\n        if (value > this.max) {\n            this.max = value;\n        }\n        if (value < this.min) {\n            this.min = value;\n        }\n    }\n\n    /**\n     * Print the mean of the observations seen, with the precision specified in\n     * the constructor.\n     */\n    toString() {\n        return `${this.mean.toFixed(this.printFixedPrecision)}`;\n    }\n}\n\nexport class ExponentiallyDecayingAverageValue {\n    samples = 0;\n    value = 0;\n    constructor(public smoothingFactor: number) {}\n    update(n: number) {\n        // tslint:disable-next-line:prefer-conditional-expression\n        if (this.samples++ === 0) {\n            this.value = n;\n        } else {\n            this.value =\n                this.smoothingFactor * n + (1 - this.smoothingFactor) * this.value;\n        }\n    }\n    toString() {\n        return this.value;\n    }\n}\n\nexport function sleep(ms: number, cancel = new Promise<void>(() => {})) {\n    let id: NodeJS.Timer;\n    cancel.then(_ => clearTimeout(id)).catch(_ => clearTimeout(id));\n    return Promise.race([new Promise(resolve => (id = setTimeout(resolve, ms))), cancel]);\n}\n\nexport function streamToBuffer(s: NodeJS.ReadableStream) {\n    return new Promise<Buffer>((resolve, reject) => {\n        const buffers: Buffer[] = [];\n        s.on(\"error\", reject);\n        s.on(\"data\", (data: Buffer) => buffers.push(data));\n        s.on(\"end\", () => resolve(Buffer.concat(buffers)));\n    });\n}\n\nexport function chomp(s: string) {\n    if (s.length > 0 && s[s.length - 1] === \"\\n\") {\n        s = s.slice(0, s.length - 1);\n    }\n    return s;\n}\n\nexport const sum = (a: number[]) => a.reduce((total, n) => total + n, 0);\n\nexport function objectSize(obj?: { [key: string]: string }) {\n    if (!obj) {\n        return 0;\n    }\n    return sum(Object.keys(obj).map(key => key.length + obj[key].length));\n}\n\nexport function computeHttpResponseBytes(\n    headers: { [key: string]: string },\n    opts = { httpHeaders: true, min: 0 }\n) {\n    const headerKeys = Object.keys(headers);\n    let contentLength = 0;\n    for (const key of headerKeys) {\n        if (key.match(/^content-length$/i)) {\n            contentLength = Number(headers[key]);\n            break;\n        }\n    }\n    if (!opts.httpHeaders) {\n        return Math.max(contentLength, opts.min);\n    }\n    const headerLength = objectSize(headers) + headerKeys.length * \": \".length;\n    const otherLength = 13;\n    return Math.max(contentLength + headerLength + otherLength, opts.min);\n}\n\nexport function hasExpired(\n    date: string | number | undefined | null,\n    retentionInDays: number\n) {\n    if (retentionInDays <= 0) {\n        return true;\n    }\n    const timestamp = typeof date === \"string\" ? Date.parse(date) : date || 0;\n    return timestamp < Date.now() - retentionInDays * 24 * 60 * 60 * 1000;\n}\n\nexport function roundTo100ms(n: number) {\n    return Math.round(n / 100) * 100;\n}\n\nexport const uuidv4Pattern =\n    \"[a-f0-9]{8}-[a-f0-9]{4}-4[a-f0-9]{3}-[89aAbB][a-f0-9]{3}-[a-f0-9]{12}\";\n\nexport const GB = 2 ** 30;\nexport const MB = 2 ** 20;\nexport const KB = 2 ** 10;\n\nexport function f1(n: number) {\n    return n.toFixed(1);\n}\n\nexport function f2(n: number) {\n    return n.toFixed(2);\n}\n\nexport function keysOf<K extends string, O extends { [key in K]: any }>(\n    obj: O\n): Array<keyof O>;\nexport function keysOf<O extends object>(obj: O): Array<keyof O> {\n    return Object.keys(obj) as Array<keyof O>;\n}\n\nexport function defined<T>(arg: T | undefined | null | void): arg is T {\n    return !!arg;\n}\n\nexport class MaxHeap {\n    protected _heap: number[] = [];\n\n    get size() {\n        return this._heap.length;\n    }\n\n    clear() {\n        this._heap = [];\n    }\n\n    peekMax() {\n        return this._heap[0];\n    }\n\n    insert(value: number) {\n        const h = this._heap;\n        h.push(value);\n        let i = h.length - 1;\n        const parentOf = (n: number) => Math.floor((n - 1) / 2);\n        let parent = parentOf(i);\n        while (parent >= 0 && h[i] > h[parent]) {\n            const tmp = h[parent];\n            h[parent] = h[i];\n            h[i] = tmp;\n            i = parent;\n            parent = parentOf(i);\n        }\n    }\n\n    extractMax() {\n        const h = this._heap;\n        if (h.length === 0) {\n            throw new Error(\"extractMax called on empty heap\");\n        }\n        let i = 0;\n        const rv = h[0];\n        h[0] = h[h.length - 1];\n        h.pop();\n\n        while (i < h.length) {\n            const [left, right] = [i * 2 + 1, i * 2 + 2];\n            let maybe: number | undefined;\n            if (h[i] < h[left] && !(h[right] > h[left])) {\n                maybe = left;\n            } else if (h[i] < h[right]) {\n                maybe = right;\n            }\n            if (maybe === undefined) {\n                break;\n            }\n            const [iValue, mValue] = [h[i], h[maybe]];\n            h[i] = mValue;\n            h[maybe] = iValue;\n            i = maybe;\n        }\n\n        return rv;\n    }\n\n    [Symbol.iterator]() {\n        return this._heap[Symbol.iterator]();\n    }\n}\n\nexport class SmallestN<T = void> {\n    protected _heap = new MaxHeap();\n    protected _map: [number, T][] = [];\n\n    constructor(protected _size: number) {}\n\n    update(key: number, value: T) {\n        if (this._heap.size < this._size) {\n            this._heap.insert(key);\n            this._map.push([key, value]);\n            return;\n        }\n        if (key >= this._heap.peekMax()) {\n            return;\n        }\n        this._heap.insert(key);\n        this._map.push([key, value]);\n        this.shrink();\n    }\n\n    protected shrink() {\n        const max = this._heap.extractMax();\n        let idx = this._map.length;\n        while (--idx >= 0) {\n            if (this._map[idx][0] === max) {\n                break;\n            }\n        }\n        if (idx === -1) {\n            throw new Error(`SmallestN: could not find entry for key ${max}`);\n        }\n        this._map.splice(idx, 1);\n    }\n\n    [Symbol.iterator]() {\n        return this._map[Symbol.iterator]();\n    }\n\n    entries() {\n        return this._map[Symbol.iterator];\n    }\n\n    keys() {\n        return [...this._heap];\n    }\n\n    get size() {\n        return this._size;\n    }\n\n    clear() {\n        this._heap.clear();\n        this._map = [];\n    }\n\n    setSize(newSize: number) {\n        while (this._size > newSize) {\n            this.shrink();\n            this._size--;\n        }\n        this._size = newSize;\n    }\n}\n"]}