| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 | /*	MIT License http://www.opensource.org/licenses/mit-license.php	Author Tobias Koppers @sokra*/"use strict";const binarySearchBounds = require("../util/binarySearchBounds");/** @typedef {function(number): void} Callback */class ParallelismFactorCalculator {	constructor() {		/** @type {number[]} */		this._rangePoints = [];		/** @type {Callback[]} */		this._rangeCallbacks = [];	}	/**	 * @param {number} start range start	 * @param {number} end range end	 * @param {Callback} callback callback	 * @returns {void}	 */	range(start, end, callback) {		if (start === end) return callback(1);		this._rangePoints.push(start);		this._rangePoints.push(end);		this._rangeCallbacks.push(callback);	}	calculate() {		const segments = Array.from(new Set(this._rangePoints)).sort((a, b) =>			a < b ? -1 : 1		);		const parallelism = segments.map(() => 0);		const rangeStartIndices = [];		for (let i = 0; i < this._rangePoints.length; i += 2) {			const start = this._rangePoints[i];			const end = this._rangePoints[i + 1];			let idx = binarySearchBounds.eq(segments, start);			rangeStartIndices.push(idx);			do {				parallelism[idx]++;				idx++;			} while (segments[idx] < end);		}		for (let i = 0; i < this._rangeCallbacks.length; i++) {			const start = this._rangePoints[i * 2];			const end = this._rangePoints[i * 2 + 1];			let idx = rangeStartIndices[i];			let sum = 0;			let totalDuration = 0;			let current = start;			do {				const p = parallelism[idx];				idx++;				const duration = segments[idx] - current;				totalDuration += duration;				current = segments[idx];				sum += p * duration;			} while (current < end);			this._rangeCallbacks[i](sum / totalDuration);		}	}}module.exports = ParallelismFactorCalculator;
 |