Skip to content

Commit

Permalink
version 1.2.0
Browse files Browse the repository at this point in the history
  • Loading branch information
dankogai committed Jul 27, 2020
2 parents 5036a9e + ba13563 commit 0e7f2ec
Show file tree
Hide file tree
Showing 11 changed files with 525 additions and 130 deletions.
15 changes: 15 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
TS=combinatorics.ts
JS=combinatorics.js
MJS=combinatorics.mjs
DTS=combinatorics.d.ts

all: $(JS)

$(JS): $(TS)
tsc -d --target es6 $(TS)

test: $(JS)
mocha --require esm

clean:
-rm $(DTS) $(MJS) $(JS)
6 changes: 4 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ Simple combinatorics in JavaScript
* module. `import` instead of `require`.
* `BigInt` where possible

And from version 1.2 it is written in TypeScript. `combinatorics.js` and `combinatorics.d.ts` are compiled from `combinatorics.ts`.

APIs will change accordingly. Old versions are available in the `version0` branch.

### For Swift programmers
Expand Down Expand Up @@ -48,7 +50,7 @@ import {Combination, Permutation} from 'combinatorics.js';
You don't even have to install if you `import` from CDNs.

```javascript
import * as $C from 'https://cdn.jsdelivr.net/npm/js-combinatorics@1.1.1/combinatorics.min.js';
import * as $C from 'https://cdn.jsdelivr.net/npm/js-combinatorics@1.2.0/combinatorics.min.js';
```

Since this is an ES6 module, `type="module"` is required the `<script>` tags. of your HTML files. But you can make it globally available as follows.
Expand Down Expand Up @@ -97,7 +99,7 @@ undefined
factoradic: [Function: factoradic],
factorial: [Function: factorial],
permutation: [Function: permutation],
version: '1.1.1'
version: '1.2.0'
}
> [...new $C.Permutation('abcd')]
[
Expand Down
127 changes: 127 additions & 0 deletions combinatorics.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,127 @@
/**
* combinatorics.js
*
* Licensed under the MIT license.
* http://www.opensource.org/licenses/mit-license.php
*
* @typedef {(number|bigint)} aint
*
* @author: Dan Kogai <[email protected]>
* References:
* @link: http://www.ruby-doc.org/core-2.0/Array.html#method-i-combination
* @link: http://www.ruby-doc.org/core-2.0/Array.html#method-i-permutation
* @link: http://en.wikipedia.org/wiki/Factorial_number_system
*/
export declare const version = "1.2.0";
/**
* BigInt Workaround
*
* https://github.com/streamich/memfs/issues/275
*/
declare type anyint = number | bigint;
/**
* calculates `P(n, k)`.
*
* @link https://en.wikipedia.org/wiki/Permutation
*/
export declare function permutation(n: anyint, k: anyint): number | bigint;
/**
* calculates `C(n, k)`.
*
* @link https://en.wikipedia.org/wiki/Combination
*/
export declare function combination(n: anyint, k: anyint): number | bigint;
/**
* calculates `n!` === `P(n, n)`.
*
* @link https://en.wikipedia.org/wiki/Factorial
*/
export declare function factorial(n: anyint): number | bigint;
/**
* returns the factoradic representation of `n`, least significant order.
*
* @link https://en.wikipedia.org/wiki/Factorial_number_system
* @param {number} l the number of digits
*/
export declare function factoradic(n: anyint, l?: number): number[];
/**
* Base Class of `js-combinatorics`
*/
declare class _CBase {
/**
* does `new`
* @param args
*/
static make(...args: any[]): any;
/**
* Same as `make` but takes a single array `arg`
*
* cf. https://stackoverflow.com/questions/1606797/use-of-apply-with-new-operator-is-this-possible
*/
static vmake(arg: any): any;
/**
* Common iterator
*/
[Symbol.iterator](): Generator<any[], void, unknown>;
/**
* returns `[...this]`.
*/
toArray(): any[][];
/**
* tells wether you need `BigInt` to access all elements.
*/
get isBig(): boolean;
/**
* tells wether it is safe to work on this instance.
*
* * always `true` unless your platform does not support `BigInt`.
* * if not, `true` iff `.isBig` is `false`.
*/
get isSafe(): boolean;
/**
* check n for nth
*/
_check(n: any): any;
nth(n: anyint): any[];
seed: any[];
size: number;
length: anyint;
}
/**
* Permutation
*/
export declare class Permutation extends _CBase {
constructor(seed: any, size?: number);
nth(n: anyint, nocheck?: boolean): any[];
}
/**
* Combination
*/
export declare class Combination extends _CBase {
perm: Permutation;
constructor(seed: Iterable<any>, size?: number);
nth(n: anyint): any[];
}
/**
* Base N
*/
export declare class BaseN extends _CBase {
base: number;
constructor(seed: Iterable<any>, size?: number);
nth(n: anyint): any[];
}
/**
* Power Set
*/
export declare class PowerSet extends _CBase {
constructor(seed: Iterable<any>);
nth(n: anyint): any[];
}
/**
* Cartesian Product
*/
export declare class CartesianProduct extends _CBase {
constructor(...args: Iterable<any>[]);
nth(n: anyint): any[];
}
export {};
Loading

0 comments on commit 0e7f2ec

Please sign in to comment.