@safeticsinc/dra 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,165 @@
1
+ export interface CalculationResult<T = number> {
2
+ value: T;
3
+ chain<R>(fn: (value: T) => R): R;
4
+ log(label?: string): CalculationResult<T>;
5
+ }
6
+ export declare namespace ISO13855 {
7
+ function A1(K: number, T: number, C: number): number;
8
+ function A2(t_1: number, t_2: number): number;
9
+ function A3(T: number, d: number): number;
10
+ function A4(T: number, d: number): number;
11
+ function A5(T: number): number;
12
+ function A6(T: number): number;
13
+ function A7(T: number, H: number): number;
14
+ function A8(d: number): number;
15
+ function A9(H: number): number;
16
+ function A10(K: number, T: number, C_RO: number): number;
17
+ function A11(T: number, C_RO: number): number;
18
+ function A12(T: number, C_RO: number): number;
19
+ function A13(pathLengths: number[]): number;
20
+ function A14(T: number): number;
21
+ function A15(T: number, h: number): number;
22
+ function A16(T: number): number;
23
+ function A17(e: number, v: number): number;
24
+ function B1(measurements: number[]): number;
25
+ function B2(l_1: number, l_2: number, l_3: number): number;
26
+ function B3(S_1: number, S_2: number, S_3: number): number;
27
+ function B4(T: number): number;
28
+ function B5(t_11: number, t_12: number): number;
29
+ function B6(S_RT: number, S_RO: number): number;
30
+ function B7(t_1: number, t_2: number, t_3: number): number;
31
+ function B8(projectionLengths: number[]): number;
32
+ /**
33
+ * === C 공식: 표준에서 태그되지 않은 조건 수식 ===
34
+ */
35
+ function C1(S: number): number;
36
+ function C2(S: number): number;
37
+ function C3(S: number, detectionCapacity?: number): boolean;
38
+ function C4(S: number, detectionCapacity?: number): boolean;
39
+ function C5(S_actual: number, S_required: number): boolean;
40
+ function C6(H_min: number): boolean;
41
+ function C7(H_max: number): boolean;
42
+ function C8(H_min: number): boolean;
43
+ function C9(angleA_s: number, angleA_h: number): boolean;
44
+ function C10(S_2000: number): '2000mm/s' | '1600mm/s';
45
+ /**
46
+ * === T 공식: 표 기반 공식 ===
47
+ */
48
+ interface Table_T1_Entry {
49
+ hazardHeight: number;
50
+ sensorTopHeight: number;
51
+ invasionDistance: number;
52
+ }
53
+ interface Table_TE1_Entry {
54
+ beamCount: number;
55
+ beamHeights: number[];
56
+ }
57
+ /**
58
+ * === 계산 체인 구조 ===
59
+ */
60
+ interface Params {
61
+ t_1?: number;
62
+ t_11?: number;
63
+ t_12?: number;
64
+ t_2?: number;
65
+ t_3?: number;
66
+ [key: string]: any;
67
+ }
68
+ interface CalculationChain {
69
+ /**
70
+ * 공식 A 계열 계산
71
+ */
72
+ A1(K: number, T: number, C: number): CalculationResult<number>;
73
+ A2(t_1: number, t_2: number): CalculationResult<number>;
74
+ A3(T: number, d: number): CalculationResult<number>;
75
+ A4(T: number, d: number): CalculationResult<number>;
76
+ A5(T: number): CalculationResult<number>;
77
+ A6(T: number): CalculationResult<number>;
78
+ A7(T: number, H: number): CalculationResult<number>;
79
+ A8(d: number): CalculationResult<number>;
80
+ A9(H: number): CalculationResult<number>;
81
+ A10(K: number, T: number, C_RO: number): CalculationResult<number>;
82
+ A11(T: number, C_RO: number): CalculationResult<number>;
83
+ A12(T: number, C_RO: number): CalculationResult<number>;
84
+ A13(pathLengths: number[]): CalculationResult<number>;
85
+ A14(T: number): CalculationResult<number>;
86
+ A15(T: number, h: number): CalculationResult<number>;
87
+ A16(T: number): CalculationResult<number>;
88
+ A17(e: number, v: number): CalculationResult<number>;
89
+ /**
90
+ * 공식 B 계열 계산
91
+ */
92
+ B1(measurements: number[]): CalculationResult<number>;
93
+ B2(l_1: number, l_2: number, l_3: number): CalculationResult<number>;
94
+ B3(S_1: number, S_2: number, S_3: number): CalculationResult<number>;
95
+ B4(T: number): CalculationResult<number>;
96
+ B5(t_11: number, t_12: number): CalculationResult<number>;
97
+ B6(S_RT: number, S_RO: number): CalculationResult<number>;
98
+ B7(t_1: number, t_2: number, t_3: number): CalculationResult<number>;
99
+ B8(projectionLengths: number[]): CalculationResult<number>;
100
+ /**
101
+ * 조건 공식 C 계열
102
+ */
103
+ C1(S: number): CalculationResult<number>;
104
+ C2(S: number): CalculationResult<number>;
105
+ C3(S: number, detectionCapacity?: number): boolean;
106
+ C4(S: number, detectionCapacity?: number): boolean;
107
+ C5(S_actual: number, S_required: number): boolean;
108
+ C6(H_min: number): boolean;
109
+ C7(H_max: number): boolean;
110
+ C8(H_min: number): boolean;
111
+ C9(angleA_s: number, angleA_h: number): boolean;
112
+ C10(S_2000: number): '2000mm/s' | '1600mm/s';
113
+ /**
114
+ * 파라미터 저장 및 업데이트
115
+ */
116
+ params(params: Params): CalculationChain;
117
+ update(params: Partial<Params>): CalculationChain;
118
+ }
119
+ const builder: CalculationChain;
120
+ }
121
+ export declare namespace ISO13857 {
122
+ function B1(S_h: number, S_r: number): number;
123
+ interface Table_T1_Entry {
124
+ description: string;
125
+ minSafeDistance: number;
126
+ }
127
+ interface Table_T2_Entry {
128
+ description: string;
129
+ minSafeDistance: number;
130
+ }
131
+ interface Table_T3_Entry {
132
+ movementType: string;
133
+ safetyReach: number;
134
+ }
135
+ /**
136
+ * T4: 규칙적인 개구부를 통한 도달 — 14세 이상인 사람
137
+ */
138
+ interface Table_T4_Entry {
139
+ apertureType: 'circular' | 'rectangular' | 'slot';
140
+ minOpeningWidth: number;
141
+ maxReachDistance: number;
142
+ }
143
+ /**
144
+ * T6: 추가 보호용 구조물을 가진 주변에 도달
145
+ */
146
+ interface Table_T6_Entry {
147
+ protectionType: string;
148
+ reducedSafeDistance: number;
149
+ }
150
+ interface Params {
151
+ [key: string]: any;
152
+ }
153
+ interface CalculationChain {
154
+ B1(S_h: number, S_r: number): CalculationResult<number>;
155
+ params(params: Params): CalculationChain;
156
+ update(params: Partial<Params>): CalculationChain;
157
+ }
158
+ const builder: CalculationChain;
159
+ }
160
+ export declare const DRA: {
161
+ ISO13855: ISO13855.CalculationChain;
162
+ ISO13857: ISO13857.CalculationChain;
163
+ wrap<T>(value: T): CalculationResult<T>;
164
+ };
165
+ //# sourceMappingURL=formulas.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formulas.d.ts","sourceRoot":"","sources":["../../src/algorithm/formulas.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,385 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DRA = exports.ISO13857 = exports.ISO13855 = void 0;
4
+ const error_1 = require("../core/error");
5
+ class ChainableResult {
6
+ constructor(value) {
7
+ this.value = value;
8
+ }
9
+ chain(fn) {
10
+ return fn(this.value);
11
+ }
12
+ log(label = 'Result') {
13
+ console.log(`[${label}]: ${this.value}`);
14
+ return this;
15
+ }
16
+ }
17
+ // ==================== ISO 13855 - 광전자식 방호장치 ====================
18
+ var ISO13855;
19
+ (function (ISO13855) {
20
+ function A1(K, T, C) {
21
+ error_1.ErrorHandler.validateType('K', K, 'number');
22
+ error_1.ErrorHandler.validateType('T', T, 'number');
23
+ error_1.ErrorHandler.validateType('C', C, 'number');
24
+ return K * T + C;
25
+ }
26
+ ISO13855.A1 = A1;
27
+ function A2(t_1, t_2) {
28
+ error_1.ErrorHandler.validateType('t_1', t_1, 'number');
29
+ error_1.ErrorHandler.validateType('t_2', t_2, 'number');
30
+ return t_1 + t_2;
31
+ }
32
+ ISO13855.A2 = A2;
33
+ function A3(T, d) {
34
+ error_1.ErrorHandler.validateType('T', T, 'number');
35
+ error_1.ErrorHandler.validateType('d', d, 'number');
36
+ return 2000 * T + 8 * (d - 14);
37
+ }
38
+ ISO13855.A3 = A3;
39
+ function A4(T, d) {
40
+ error_1.ErrorHandler.validateType('T', T, 'number');
41
+ error_1.ErrorHandler.validateType('d', d, 'number');
42
+ return 1600 * T + 8 * (d - 14);
43
+ }
44
+ ISO13855.A4 = A4;
45
+ function A5(T) {
46
+ error_1.ErrorHandler.validateType('T', T, 'number');
47
+ return 1600 * T + 850;
48
+ }
49
+ ISO13855.A5 = A5;
50
+ function A6(T) {
51
+ error_1.ErrorHandler.validateType('T', T, 'number');
52
+ return 1600 * T + 1200;
53
+ }
54
+ ISO13855.A6 = A6;
55
+ function A7(T, H) {
56
+ error_1.ErrorHandler.validateType('T', T, 'number');
57
+ error_1.ErrorHandler.validateType('H', H, 'number');
58
+ const invasionDistance = Math.max(1200 - 0.4 * H, 850);
59
+ return 1600 * T + invasionDistance;
60
+ }
61
+ ISO13855.A7 = A7;
62
+ function A8(d) {
63
+ error_1.ErrorHandler.validateType('d', d, 'number');
64
+ return 15 * (d - 50);
65
+ }
66
+ ISO13855.A8 = A8;
67
+ function A9(H) {
68
+ error_1.ErrorHandler.validateType('H', H, 'number');
69
+ return H / 15 + 50;
70
+ }
71
+ ISO13855.A9 = A9;
72
+ function A10(K, T, C_RO) {
73
+ error_1.ErrorHandler.validateType('K', K, 'number');
74
+ error_1.ErrorHandler.validateType('T', T, 'number');
75
+ error_1.ErrorHandler.validateType('C_RO', C_RO, 'number');
76
+ return K * T + C_RO;
77
+ }
78
+ ISO13855.A10 = A10;
79
+ function A11(T, C_RO) {
80
+ error_1.ErrorHandler.validateType('K', T, 'number');
81
+ error_1.ErrorHandler.validateType('K', C_RO, 'number');
82
+ return 2000 * T + C_RO;
83
+ }
84
+ ISO13855.A11 = A11;
85
+ function A12(T, C_RO) {
86
+ error_1.ErrorHandler.validateType('T', T, 'number');
87
+ error_1.ErrorHandler.validateType('C_RO', C_RO, 'number');
88
+ return 1600 * T + C_RO;
89
+ }
90
+ ISO13855.A12 = A12;
91
+ function A13(pathLengths) {
92
+ error_1.ErrorHandler.validateArrayLength('pathLengths', pathLengths, 0);
93
+ return pathLengths.reduce((sum, length) => sum + length, 0);
94
+ }
95
+ ISO13855.A13 = A13;
96
+ function A14(T) {
97
+ error_1.ErrorHandler.validateType('T', T, 'number');
98
+ return 1600 * T + 1200;
99
+ }
100
+ ISO13855.A14 = A14;
101
+ function A15(T, h) {
102
+ error_1.ErrorHandler.validateType('T', T, 'number');
103
+ error_1.ErrorHandler.validateType('h', h, 'number');
104
+ return 1600 * T + (1200 - 0.4 * h);
105
+ }
106
+ ISO13855.A15 = A15;
107
+ function A16(T) {
108
+ error_1.ErrorHandler.validateType('T', T, 'number');
109
+ return 1600 * T + 250;
110
+ }
111
+ ISO13855.A16 = A16;
112
+ function A17(e, v) {
113
+ error_1.ErrorHandler.validateType('e', e, 'number');
114
+ error_1.ErrorHandler.validateType('v', v, 'number');
115
+ error_1.ErrorHandler.validateRange('v', v, Number.EPSILON);
116
+ return e / v;
117
+ }
118
+ ISO13855.A17 = A17;
119
+ function B1(measurements) {
120
+ error_1.ErrorHandler.validateArrayLength('measurements', measurements, 10);
121
+ const mean = measurements.reduce((a, b) => a + b) / measurements.length;
122
+ const variance = measurements.reduce((sum, x) => sum + Math.pow(x - mean, 2), 0) /
123
+ measurements.length;
124
+ const sigma = Math.sqrt(variance);
125
+ const calculated = mean + 3 * sigma;
126
+ const maximum = Math.max(...measurements);
127
+ return Math.max(calculated, maximum);
128
+ }
129
+ ISO13855.B1 = B1;
130
+ function B2(l_1, l_2, l_3) {
131
+ error_1.ErrorHandler.validateType('l_1', l_1, 'number');
132
+ error_1.ErrorHandler.validateType('l_2', l_2, 'number');
133
+ error_1.ErrorHandler.validateType('l_3', l_3, 'number');
134
+ return l_1 + l_2 + l_3;
135
+ }
136
+ ISO13855.B2 = B2;
137
+ function B3(S_1, S_2, S_3) {
138
+ error_1.ErrorHandler.validateType('S_1', S_1, 'number');
139
+ error_1.ErrorHandler.validateType('S_2', S_2, 'number');
140
+ error_1.ErrorHandler.validateType('S_3', S_3, 'number');
141
+ return S_1 + S_2 + S_3;
142
+ }
143
+ ISO13855.B3 = B3;
144
+ function B4(T) {
145
+ error_1.ErrorHandler.validateType('T', T, 'number');
146
+ return 1600 * T;
147
+ }
148
+ ISO13855.B4 = B4;
149
+ function B5(t_11, t_12) {
150
+ error_1.ErrorHandler.validateType('t_11', t_11, 'number');
151
+ error_1.ErrorHandler.validateType('t_12', t_12, 'number');
152
+ return t_11 + t_12;
153
+ }
154
+ ISO13855.B5 = B5;
155
+ function B6(S_RT, S_RO) {
156
+ error_1.ErrorHandler.validateType('S_RT', S_RT, 'number');
157
+ error_1.ErrorHandler.validateType('S_RO', S_RO, 'number');
158
+ return Math.max(S_RT, S_RO);
159
+ }
160
+ ISO13855.B6 = B6;
161
+ function B7(t_1, t_2, t_3) {
162
+ error_1.ErrorHandler.validateType('t_1', t_1, 'number');
163
+ error_1.ErrorHandler.validateType('t_2', t_2, 'number');
164
+ error_1.ErrorHandler.validateType('t_3', t_3, 'number');
165
+ return t_1 + t_2 - t_3;
166
+ }
167
+ ISO13855.B7 = B7;
168
+ function B8(projectionLengths) {
169
+ error_1.ErrorHandler.validateArrayLength('projectionLenths', projectionLengths, 0);
170
+ return projectionLengths.reduce((sum, length) => sum + length, 0);
171
+ }
172
+ ISO13855.B8 = B8;
173
+ /**
174
+ * === C 공식: 표준에서 태그되지 않은 조건 수식 ===
175
+ */
176
+ function C1(S) {
177
+ error_1.ErrorHandler.validateType('S', S, 'number');
178
+ return Math.max(S, 100);
179
+ }
180
+ ISO13855.C1 = C1;
181
+ function C2(S) {
182
+ error_1.ErrorHandler.validateType('S', S, 'number');
183
+ return Math.max(S, 500);
184
+ }
185
+ ISO13855.C2 = C2;
186
+ function C3(S, detectionCapacity = 30) {
187
+ error_1.ErrorHandler.validateType('S', S, 'number');
188
+ error_1.ErrorHandler.validateType('detectionCapacity', detectionCapacity, 'number');
189
+ return S > 150 && detectionCapacity <= 30;
190
+ }
191
+ ISO13855.C3 = C3;
192
+ function C4(S, detectionCapacity = 14) {
193
+ error_1.ErrorHandler.validateType('S', S, 'number');
194
+ error_1.ErrorHandler.validateType('detectionCapacity', detectionCapacity, 'number');
195
+ return S > 100 && detectionCapacity <= 14;
196
+ }
197
+ ISO13855.C4 = C4;
198
+ function C5(S_actual, S_required) {
199
+ error_1.ErrorHandler.validateType('S_actual', S_actual, 'number');
200
+ error_1.ErrorHandler.validateType('S_required', S_required, 'number');
201
+ return S_actual >= S_required;
202
+ }
203
+ ISO13855.C5 = C5;
204
+ function C6(H_min) {
205
+ error_1.ErrorHandler.validateType('H_min', H_min, 'number');
206
+ return H_min <= 300;
207
+ }
208
+ ISO13855.C6 = C6;
209
+ function C7(H_max) {
210
+ error_1.ErrorHandler.validateType('H_max', H_max, 'number');
211
+ return H_max <= 1000;
212
+ }
213
+ ISO13855.C7 = C7;
214
+ function C8(H_min) {
215
+ error_1.ErrorHandler.validateType('H_min', H_min, 'number');
216
+ return H_min <= 750;
217
+ }
218
+ ISO13855.C8 = C8;
219
+ function C9(angleA_s, angleA_h) {
220
+ error_1.ErrorHandler.validateType('angleA_s', angleA_s, 'number');
221
+ return angleA_s - angleA_h > 30;
222
+ }
223
+ ISO13855.C9 = C9;
224
+ function C10(S_2000) {
225
+ error_1.ErrorHandler.validateType('S_2000', S_2000, 'number');
226
+ return S_2000 > 500 ? '1600mm/s' : '2000mm/s';
227
+ }
228
+ ISO13855.C10 = C10;
229
+ class CalculationChainImpl {
230
+ constructor() {
231
+ this.storedParams = {};
232
+ }
233
+ params(params) {
234
+ this.storedParams = params;
235
+ return this;
236
+ }
237
+ update(params) {
238
+ this.storedParams = { ...this.storedParams, ...params };
239
+ return this;
240
+ }
241
+ // A 계열
242
+ A1(K, T, C) {
243
+ return new ChainableResult(A1(K, T, C));
244
+ }
245
+ A2(t_1, t_2) {
246
+ return new ChainableResult(A2(t_1, t_2));
247
+ }
248
+ A3(T, d) {
249
+ return new ChainableResult(A3(T, d));
250
+ }
251
+ A4(T, d) {
252
+ return new ChainableResult(A4(T, d));
253
+ }
254
+ A5(T) {
255
+ return new ChainableResult(A5(T));
256
+ }
257
+ A6(T) {
258
+ return new ChainableResult(A6(T));
259
+ }
260
+ A7(T, H) {
261
+ return new ChainableResult(A7(T, H));
262
+ }
263
+ A8(d) {
264
+ return new ChainableResult(A8(d));
265
+ }
266
+ A9(H) {
267
+ return new ChainableResult(A9(H));
268
+ }
269
+ A10(K, T, C_RO) {
270
+ return new ChainableResult(A10(K, T, C_RO));
271
+ }
272
+ A11(T, C_RO) {
273
+ return new ChainableResult(A11(T, C_RO));
274
+ }
275
+ A12(T, C_RO) {
276
+ return new ChainableResult(A12(T, C_RO));
277
+ }
278
+ A13(pathLengths) {
279
+ return new ChainableResult(A13(pathLengths));
280
+ }
281
+ A14(T) {
282
+ return new ChainableResult(A14(T));
283
+ }
284
+ A15(T, h) {
285
+ return new ChainableResult(A15(T, h));
286
+ }
287
+ A16(T) {
288
+ return new ChainableResult(A16(T));
289
+ }
290
+ A17(e, v) {
291
+ return new ChainableResult(A17(e, v));
292
+ }
293
+ // B 계열
294
+ B1(measurements) {
295
+ return new ChainableResult(B1(measurements));
296
+ }
297
+ B2(l_1, l_2, l_3) {
298
+ return new ChainableResult(B2(l_1, l_2, l_3));
299
+ }
300
+ B3(S_1, S_2, S_3) {
301
+ return new ChainableResult(B3(S_1, S_2, S_3));
302
+ }
303
+ B4(T) {
304
+ return new ChainableResult(B4(T));
305
+ }
306
+ B5(t_11, t_12) {
307
+ return new ChainableResult(B5(t_11, t_12));
308
+ }
309
+ B6(S_RT, S_RO) {
310
+ return new ChainableResult(B6(S_RT, S_RO));
311
+ }
312
+ B7(t_1, t_2, t_3) {
313
+ return new ChainableResult(B7(t_1, t_2, t_3));
314
+ }
315
+ B8(projectionLengths) {
316
+ return new ChainableResult(B8(projectionLengths));
317
+ }
318
+ // C 조건식
319
+ C1(S) {
320
+ return new ChainableResult(C1(S));
321
+ }
322
+ C2(S) {
323
+ return new ChainableResult(C2(S));
324
+ }
325
+ C3(S, detectionCapacity) {
326
+ return C3(S, detectionCapacity);
327
+ }
328
+ C4(S, detectionCapacity) {
329
+ return C4(S, detectionCapacity);
330
+ }
331
+ C5(S_actual, S_required) {
332
+ return C5(S_actual, S_required);
333
+ }
334
+ C6(H_min) {
335
+ return C6(H_min);
336
+ }
337
+ C7(H_max) {
338
+ return C7(H_max);
339
+ }
340
+ C8(H_min) {
341
+ return C8(H_min);
342
+ }
343
+ C9(angleA_s, angleA_h) {
344
+ return C9(angleA_s, angleA_h);
345
+ }
346
+ C10(S_2000) {
347
+ return C10(S_2000);
348
+ }
349
+ }
350
+ ISO13855.builder = new CalculationChainImpl();
351
+ })(ISO13855 || (exports.ISO13855 = ISO13855 = {}));
352
+ // ==================== ISO 13857 - 보호 구조물 ====================
353
+ var ISO13857;
354
+ (function (ISO13857) {
355
+ function B1(S_h, S_r) {
356
+ error_1.ErrorHandler.validateType('S_h', S_h, 'number');
357
+ return Math.max(S_h, S_r);
358
+ }
359
+ ISO13857.B1 = B1;
360
+ class CalculationChainImpl {
361
+ constructor() {
362
+ this.storedParams = {};
363
+ }
364
+ params(params) {
365
+ this.storedParams = params;
366
+ return this;
367
+ }
368
+ update(params) {
369
+ this.storedParams = { ...this.storedParams, ...params };
370
+ return this;
371
+ }
372
+ B1(S_h, S_r) {
373
+ return new ChainableResult(B1(S_h, S_r));
374
+ }
375
+ }
376
+ ISO13857.builder = new CalculationChainImpl();
377
+ })(ISO13857 || (exports.ISO13857 = ISO13857 = {}));
378
+ exports.DRA = {
379
+ ISO13855: ISO13855.builder,
380
+ ISO13857: ISO13857.builder,
381
+ wrap(value) {
382
+ return new ChainableResult(value);
383
+ },
384
+ };
385
+ //# sourceMappingURL=formulas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formulas.js","sourceRoot":"","sources":["../../src/algorithm/formulas.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './formulas';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/algorithm/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./formulas"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/algorithm/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B"}