1 | "use strict";
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.createBellNumbers = void 0;
|
7 |
|
8 | var _factory = require("../../utils/factory");
|
9 |
|
10 | var name = 'bellNumbers';
|
11 | var dependencies = ['typed', 'addScalar', 'isNegative', 'isInteger', 'stirlingS2'];
|
12 | var createBellNumbers = (0, _factory.factory)(name, dependencies, function (_ref) {
|
13 | var typed = _ref.typed,
|
14 | addScalar = _ref.addScalar,
|
15 | isNegative = _ref.isNegative,
|
16 | isInteger = _ref.isInteger,
|
17 | stirlingS2 = _ref.stirlingS2;
|
18 |
|
19 | |
20 |
|
21 |
|
22 |
|
23 |
|
24 |
|
25 |
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 |
|
33 |
|
34 |
|
35 |
|
36 |
|
37 |
|
38 |
|
39 |
|
40 | return typed(name, {
|
41 | 'number | BigNumber': function numberBigNumber(n) {
|
42 | if (!isInteger(n) || isNegative(n)) {
|
43 | throw new TypeError('Non-negative integer value expected in function bellNumbers');
|
44 | }
|
45 |
|
46 |
|
47 | var result = 0;
|
48 |
|
49 | for (var i = 0; i <= n; i++) {
|
50 | result = addScalar(result, stirlingS2(n, i));
|
51 | }
|
52 |
|
53 | return result;
|
54 | }
|
55 | });
|
56 | });
|
57 | exports.createBellNumbers = createBellNumbers; |
\ | No newline at end of file |