UNPKG

ts-combinatorics

Version:

Simple combinatorics like power set, combination, and permutation in JavaScript

294 lines 24.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.CartesianProduct = exports.PowerSet = exports.BaseN = exports.Combination = exports.Permutation = exports.randomInteger = exports.combinadic = exports.factoradic = exports.factorial = exports.combination = exports.permutation = exports.version = void 0; exports.version = "1.4.5"; const _BI = typeof BigInt == "function" ? BigInt : Number; const _crop = (n) => (n <= Number.MAX_SAFE_INTEGER ? Number(n) : _BI(n)); function permutation(n, k) { if (n < 0) throw new RangeError(`negative n is not acceptable`); if (k < 0) throw new RangeError(`negative k is not acceptable`); if (0 == k) return 1; if (n < k) return 0; [n, k] = [_BI(n), _BI(k)]; let p = _BI(1); while (k--) p *= n--; return _crop(p); } exports.permutation = permutation; function combination(n, k) { if (0 == k) return 1; if (n == k) return 1; if (n < k) return 0; const P = permutation; const c = _BI(P(n, k)) / _BI(P(k, k)); return _crop(c); } exports.combination = combination; function factorial(n) { return permutation(n, n); } exports.factorial = factorial; function factoradic(n, l = 0) { if (n < 0) return undefined; let [bn, bf] = [_BI(n), _BI(1)]; if (!l) { for (l = 1; bf < bn; bf *= _BI(++l)) ; if (bn < bf) bf /= _BI(l--); } else { bf = _BI(factorial(l)); } let digits = [0]; for (; l; bf /= _BI(l--)) { digits[l] = Math.floor(Number(bn / bf)); bn %= bf; } return digits; } exports.factoradic = factoradic; function combinadic(n, k) { const count = combination(n, k); return (m) => { if (m < 0 || count <= m) return undefined; let digits = []; let [a, b] = [n, k]; let x = _BI(count) - _BI(1) - _BI(m); for (let i = 0; i < k; i++) { a--; while (x < combination(a, b)) a--; digits.push(n - 1 - a); x -= _BI(combination(a, b)); b--; } return digits; }; } exports.combinadic = combinadic; const _crypto = typeof crypto !== "undefined" ? crypto : {}; const _randomBytes = typeof _crypto["randomBytes"] === "function" ? (len) => Uint8Array.from(_crypto["randomBytes"](len)) : typeof _crypto["getRandomValues"] === "function" ? (len) => _crypto["getRandomValues"](new Uint8Array(len)) : (len) => Uint8Array.from(Array(len), () => Math.random() * 256); function randomInteger(min = 0, max = Math.pow(2, 53)) { let ctor = min.constructor; if (arguments.length === 0) { return Math.floor(Math.random() * ctor(max)); } if (arguments.length == 1) { ; [min, max] = [ctor(0), min]; } if (typeof min == "number") { ; [min, max] = [Math.ceil(Number(min)), Math.ceil(Number(max))]; return Math.floor(Math.random() * (max - min)) + min; } const mag = ctor(max) - ctor(min); const len = mag.toString(16).length; const u8s = _randomBytes(len); const rnd = u8s.reduce((a, v) => (a << ctor(8)) + ctor(v), ctor(0)); return ((ctor(rnd) * mag) >> ctor(len * 8)) + ctor(min); } exports.randomInteger = randomInteger; class _CBase { static of(...args) { return new (Function.prototype.bind.apply(this, [null].concat(args)))(); } static from(arg) { return new (Function.prototype.bind.apply(this, [null].concat(arg)))(); } [Symbol.iterator]() { return (function* (it, len) { for (let i = 0; i < len; i++) yield it.nth(i); })(this, this.length); } toArray() { return [...this]; } get isBig() { return Number.MAX_SAFE_INTEGER < this.length; } get isSafe() { return typeof BigInt !== "undefined" || !this.isBig; } _check(n) { if (n < 0) { if (this.length < -n) return undefined; return _crop(_BI(this.length) + _BI(n)); } if (this.length <= n) return undefined; return n; } nth(n) { return []; } sample() { return this.nth(randomInteger(this.length)); } samples() { return (function* (it) { while (true) yield it.sample(); })(this); } } class Permutation extends _CBase { constructor(seed, size = 0) { super(); this.seed = [...seed]; this.size = 0 < size ? size : this.seed.length; this.length = permutation(this.seed.length, this.size); Object.freeze(this); } nth(n) { n = this._check(n); if (n === undefined) return undefined; const offset = this.seed.length - this.size; const skip = factorial(offset); let digits = factoradic(_BI(n) * _BI(skip), this.seed.length); let source = this.seed.slice(); let result = []; for (let i = this.seed.length - 1; offset <= i; i--) { result.push(source.splice(digits[i], 1)[0]); } return result; } } exports.Permutation = Permutation; class Combination extends _CBase { constructor(seed, size = 0) { super(); this.seed = [...seed]; this.size = 0 < size ? size : this.seed.length; this.size = size; this.length = combination(this.seed.length, this.size); this.comb = combinadic(this.seed.length, this.size); Object.freeze(this); } bitwiseIterator() { const ctor = this.length.constructor; const [zero, one, two] = [ctor(0), ctor(1), ctor(2)]; const inc = (x) => { const u = x & -x; const v = u + x; return v + (((v ^ x) / u) >> two); }; let x = (one << ctor(this.size)) - one; return (function* (it, len) { for (let i = 0; i < len; i++, x = inc(x)) { var result = []; for (let y = x, j = 0; zero < y; y >>= one, j++) { if (y & one) result.push(it.seed[j]); } yield result; } })(this, this.length); } nth(n) { n = this._check(n); if (n === undefined) return undefined; return this.comb(n).reduce((a, v) => a.concat(this.seed[v]), []); } } exports.Combination = Combination; class BaseN extends _CBase { constructor(seed, size = 1) { super(); this.seed = [...seed]; this.size = size; let base = this.seed.length; this.base = base; let length = size < 1 ? 0 : Array(size) .fill(_BI(base)) .reduce((a, v) => a * v); this.length = _crop(length); Object.freeze(this); } nth(n) { n = this._check(n); if (n === undefined) return undefined; let bn = _BI(n); const bb = _BI(this.base); let result = []; for (let i = 0; i < this.size; i++) { var bd = bn % bb; result.push(this.seed[Number(bd)]); bn -= bd; bn /= bb; } return result; } } exports.BaseN = BaseN; class PowerSet extends _CBase { constructor(seed) { super(); this.seed = [...seed]; const length = _BI(1) << _BI(this.seed.length); this.length = _crop(length); Object.freeze(this); } nth(n) { n = this._check(n); if (n === undefined) return undefined; let bn = _BI(n); let result = []; for (let bi = _BI(0); bn; bn >>= _BI(1), bi++) if (bn & _BI(1)) result.push(this.seed[Number(bi)]); return result; } } exports.PowerSet = PowerSet; class CartesianProduct extends _CBase { constructor(...args) { super(); this.seed = args.map((v) => [...v]); this.size = this.seed.length; const length = this.seed.reduce((a, v) => a * _BI(v.length), _BI(1)); this.length = _crop(length); Object.freeze(this); } nth(n) { n = this._check(n); if (n === undefined) return undefined; let bn = _BI(n); let result = []; for (let i = 0; i < this.size; i++) { const base = this.seed[i].length; const bb = _BI(base); const bd = bn % bb; result.push(this.seed[i][Number(bd)]); bn -= bd; bn /= bb; } return result; } } exports.CartesianProduct = CartesianProduct; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"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"}