@datagrok-libraries/statistics 1.8.0 → 1.9.0

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.
@@ -3,8 +3,6 @@
3
3
  import * as DG from 'datagrok-api/dg';
4
4
  //@ts-ignore: no types
5
5
  import * as jStat from 'jstat';
6
- import { performNelderMeadOptimization } from './fitting-algorithm/optimizer';
7
- import { NELDER_MEAD_DEFAULTS } from './fitting-algorithm/optimizer-nelder-mead';
8
6
  export const FitErrorModel = {
9
7
  CONSTANT: 'constant',
10
8
  PROPORTIONAL: 'proportional',
@@ -31,7 +29,7 @@ export const FitErrorModel = {
31
29
  * - Ability to overlay curves from multiple grid cells (special viewer)
32
30
  * - Work with series stored in multiple formats (binary for performance, json for flexibility, etc)
33
31
  */
34
- const DROPLINES = ['IC50'];
32
+ export const DROPLINES = ['IC50'];
35
33
  /** Class that implements {@link IFitChartData} interface */
36
34
  export class FitChartData {
37
35
  constructor() {
@@ -41,165 +39,6 @@ export class FitChartData {
41
39
  }
42
40
  }
43
41
  // TODO: show labels in property panel if present, color by default from series
44
- // TODO?: add method to return parameters - get parameters from fit function
45
- /** Class for the fit functions */
46
- export class FitFunction {
47
- }
48
- /** Class that implements the linear function */
49
- export class LinearFunction extends FitFunction {
50
- get name() {
51
- return FIT_FUNCTION_LINEAR;
52
- }
53
- get parameterNames() {
54
- return ['Slope', 'Intercept'];
55
- }
56
- y(params, x) {
57
- return linear(params, x);
58
- }
59
- getInitialParameters(x, y) {
60
- let minIndex = 0;
61
- let maxIndex = 0;
62
- for (let i = 1; i < x.length; i++) {
63
- if (x[i] < x[minIndex])
64
- minIndex = i;
65
- if (x[i] > x[maxIndex])
66
- maxIndex = i;
67
- }
68
- const deltaX = x[maxIndex] - x[minIndex];
69
- const deltaY = y[maxIndex] - y[minIndex];
70
- const A = deltaY / deltaX;
71
- const B = y[maxIndex] - A * x[maxIndex];
72
- const params = new Float32Array(2);
73
- params.set([A, B]);
74
- return params;
75
- }
76
- }
77
- /** Class that implements the sigmoid function */
78
- export class SigmoidFunction extends FitFunction {
79
- get name() {
80
- return FIT_FUNCTION_SIGMOID;
81
- }
82
- get parameterNames() {
83
- return ['Top', 'Slope', 'IC50', 'Bottom'];
84
- }
85
- y(params, x) {
86
- return sigmoid(params, x);
87
- }
88
- getInitialParameters(x, y) {
89
- const dataBounds = DG.Rect.fromXYArrays(x, y);
90
- const medY = (dataBounds.maxY - dataBounds.minY) / 2 + dataBounds.minY;
91
- let maxYInterval = dataBounds.maxY - dataBounds.minY;
92
- let nearestXIndex = 0;
93
- for (let i = 0; i < x.length; i++) {
94
- const currentInterval = Math.abs(y[i] - medY);
95
- if (currentInterval < maxYInterval) {
96
- maxYInterval = currentInterval;
97
- nearestXIndex = i;
98
- }
99
- }
100
- const xAtMedY = x[nearestXIndex];
101
- const slope = y[0] > y[y.length - 1] ? 1 : -1;
102
- // params are: [max, tan, IC50, min]
103
- const params = new Float32Array(4);
104
- params.set([dataBounds.maxY, slope, xAtMedY, dataBounds.minY]);
105
- return params;
106
- }
107
- }
108
- /** Class that implements the linear logarithmic function */
109
- export class LogLinearFunction extends FitFunction {
110
- get name() {
111
- return FIT_FUNCTION_LOG_LINEAR;
112
- }
113
- get parameterNames() {
114
- return ['Slope', 'Intercept'];
115
- }
116
- y(params, x) {
117
- return logLinear(params, x);
118
- }
119
- getInitialParameters(x, y) {
120
- const params = new Float32Array(2);
121
- params.set([-5, 100]);
122
- return params;
123
- }
124
- }
125
- /** Class that implements the exponential function */
126
- export class ExponentialFunction extends FitFunction {
127
- get name() {
128
- return FIT_FUNCTION_EXPONENTIAL;
129
- }
130
- get parameterNames() {
131
- return ['Mantissa', 'Power'];
132
- }
133
- y(params, x) {
134
- return exponential(params, x);
135
- }
136
- getInitialParameters(x, y) {
137
- const params = new Float32Array(2);
138
- params.set([100, -2]);
139
- return params;
140
- }
141
- }
142
- /** Class that implements the Four Parameter Logistic Regression function */
143
- export class FourPLRegressionFunction extends FitFunction {
144
- get name() {
145
- return FIT_FUNCTION_4PL_REGRESSION;
146
- }
147
- get parameterNames() {
148
- return ['Top', 'Slope', 'EC50', 'Bottom'];
149
- }
150
- y(params, x) {
151
- return fourPLRegression(params, x);
152
- }
153
- getInitialParameters(x, y) {
154
- const params = new Float32Array(4);
155
- const bottom = Math.min(...y);
156
- const top = Math.max(...y);
157
- const medY = (top - bottom) / 2 + bottom;
158
- let maxYInterval = top - bottom;
159
- let nearestXIndex = 0;
160
- for (let i = 0; i < x.length; i++) {
161
- const currentInterval = Math.abs(y[i] - medY);
162
- if (currentInterval < maxYInterval) {
163
- maxYInterval = currentInterval;
164
- nearestXIndex = i;
165
- }
166
- }
167
- const ec50 = x[nearestXIndex];
168
- const slope = y[0] > y[y.length - 1] ? -10 : 10;
169
- params.set([top, slope, ec50, bottom]);
170
- return params;
171
- }
172
- }
173
- /** Class that implements user JS functions */
174
- export class JsFunction extends FitFunction {
175
- constructor(name, yFunc, getInitParamsFunc, parameterNames) {
176
- super();
177
- this._name = name;
178
- this._parameterNames = parameterNames;
179
- this.y = yFunc;
180
- this.getInitialParameters = getInitParamsFunc;
181
- }
182
- get name() {
183
- return this._name;
184
- }
185
- get parameterNames() {
186
- return this._parameterNames;
187
- }
188
- y(params, x) {
189
- throw new Error('Not implemented');
190
- }
191
- getInitialParameters(x, y) {
192
- throw new Error('Not implemented');
193
- }
194
- }
195
- // Object with fit functions
196
- export const fitFunctions = {
197
- 'linear': new LinearFunction(),
198
- 'sigmoid': new SigmoidFunction(),
199
- 'log-linear': new LogLinearFunction(),
200
- 'exponential': new ExponentialFunction(),
201
- '4pl-regression': new FourPLRegressionFunction(),
202
- };
203
42
  /** Properties that describe {@link FitStatistics}. Useful for editing, initialization, transformations, etc. */
204
43
  export const statisticsProperties = [
205
44
  DG.Property.js('rSquared', DG.TYPE.FLOAT, { userEditable: false }),
@@ -231,164 +70,20 @@ export const fitChartDataProperties = [
231
70
  //@ts-ignore
232
71
  friendlyName: 'Statistics' }),
233
72
  ];
234
- /** Properties that describe {@link IFitSeriesOptions}. Useful for editing, initialization, transformations, etc. */
235
- export const fitSeriesProperties = [
236
- DG.Property.js('fitFunction', DG.TYPE.STRING, { category: 'Fitting', choices: Object.keys(fitFunctions), defaultValue: 'sigmoid' }),
237
- DG.Property.js('pointColor', DG.TYPE.STRING, { category: 'Rendering', nullable: true, inputType: 'Color' }),
238
- DG.Property.js('fitLineColor', DG.TYPE.STRING, { category: 'Rendering', nullable: true, inputType: 'Color' }),
239
- DG.Property.js('outlierColor', DG.TYPE.STRING, { category: 'Rendering', nullable: true, inputType: 'Color' }),
240
- DG.Property.js('errorModel', DG.TYPE.STRING, { category: 'Fitting', defaultValue: 'constant',
241
- choices: ['constant', 'proportional', 'combined'], nullable: false }),
242
- DG.Property.js('connectDots', DG.TYPE.BOOL, { category: 'Fitting', defaultValue: false }),
243
- DG.Property.js('clickToToggle', DG.TYPE.BOOL, { category: 'Fitting', description: 'Click on a point to mark it as outlier and refit', nullable: true, defaultValue: false }),
244
- DG.Property.js('showFitLine', DG.TYPE.BOOL, { category: 'Fitting', defaultValue: true }),
245
- DG.Property.js('showPoints', DG.TYPE.STRING, // rewrite description
246
- { category: 'Fitting', description: 'Whether points/candlesticks/none should be rendered',
247
- defaultValue: 'points', choices: ['points', 'candlesticks', 'both'] }),
248
- DG.Property.js('showCurveConfidenceInterval', DG.TYPE.BOOL, { category: 'Fitting', description: 'Whether confidence intervals should be rendered', defaultValue: false,
249
- //@ts-ignore
250
- friendlyName: 'Confidence Interval' }),
251
- DG.Property.js('markerType', DG.TYPE.STRING, { category: 'Rendering', defaultValue: 'circle',
252
- choices: ['asterisk', 'circle', 'cross border', 'diamond', 'square', 'star',
253
- 'triangle bottom', 'triangle left', 'triangle right', 'triangle top'], nullable: false,
254
- //@ts-ignore
255
- friendlyName: 'Marker' }),
256
- DG.Property.js('outlierMarkerType', DG.TYPE.STRING, { category: 'Rendering', defaultValue: 'outlier',
257
- choices: ['asterisk', 'circle', 'cross border', 'diamond', 'outlier', 'square', 'star',
258
- 'triangle bottom', 'triangle left', 'triangle right', 'triangle top'], nullable: false,
259
- //@ts-ignore
260
- friendlyName: 'Outlier Marker' }),
261
- DG.Property.js('lineStyle', DG.TYPE.STRING, { category: 'Rendering', defaultValue: 'solid',
262
- choices: ['solid', 'dotted', 'dashed', 'dashdotted'], nullable: false }),
263
- DG.Property.js('droplines', DG.TYPE.STRING_LIST, { description: 'Whether specific droplines should be rendered',
264
- choices: DROPLINES, inputType: 'MultiChoice' }),
265
- DG.Property.js('columnName', DG.TYPE.STRING, { description: 'Column name where the series is stored', defaultValue: '' }),
266
- ];
267
73
  export const FIT_FUNCTION_SIGMOID = 'sigmoid';
268
74
  export const FIT_FUNCTION_LINEAR = 'linear';
269
75
  export const FIT_FUNCTION_LOG_LINEAR = 'log-linear';
270
76
  export const FIT_FUNCTION_EXPONENTIAL = 'exponential';
271
77
  export const FIT_FUNCTION_4PL_REGRESSION = '4pl-regression';
78
+ export const FIT_FUNCTION_4PL_DOSE_RESPONSE = '4pl-dose-response';
79
+ export const FIT_JS_FUNCTION = 'js-function';
272
80
  export const FIT_STATS_RSQUARED = 'rSquared';
273
81
  export const FIT_STATS_AUC = 'auc';
274
- export function getOrCreateFitFunction(seriesFitFunc) {
275
- if (typeof seriesFitFunc === 'string')
276
- return fitFunctions[seriesFitFunc];
277
- else if (!fitFunctions[seriesFitFunc.name]) {
278
- const name = seriesFitFunc.name;
279
- const paramNames = seriesFitFunc.parameterNames;
280
- const fitFunctionParts = seriesFitFunc.function.split('=>').map((elem) => elem.trim());
281
- const getInitParamsParts = seriesFitFunc.getInitialParameters.split('=>').map((elem) => elem.trim());
282
- const fitFunction = new Function(fitFunctionParts[0].slice(1, fitFunctionParts[0].length - 1), `${fitFunctionParts[1].includes(';') ? '' : 'return '}${fitFunctionParts[1]}`);
283
- const getInitParamsFunc = new Function(getInitParamsParts[0].slice(1, getInitParamsParts[0].length - 1), `return ${getInitParamsParts[1]}`);
284
- const fitFunc = new JsFunction(name, fitFunction, getInitParamsFunc, paramNames);
285
- fitFunctions[name] = fitFunc;
286
- }
287
- return fitFunctions[seriesFitFunc.name];
288
- }
289
- export function fitData(data, fitFunction, errorModel, parameterBounds) {
290
- errorModel !== null && errorModel !== void 0 ? errorModel : (errorModel = FitErrorModel.CONSTANT);
291
- const curveFunction = fitFunction.y;
292
- let paramValues = fitFunction.getInitialParameters(data.x, data.y);
293
- const of = objectiveFactory(curveFunction, data, errorModel);
294
- const bottomParamBounds = new Float32Array(fitFunction.parameterNames.length);
295
- const topParamBounds = new Float32Array(fitFunction.parameterNames.length);
296
- for (let i = 0; i < fitFunction.parameterNames.length; i++) {
297
- bottomParamBounds[i] = paramValues[i] === 0 ? -1 : paramValues[i] - Math.abs(paramValues[i] * 0.5);
298
- topParamBounds[i] = paramValues[i] === 0 ? 1 : paramValues[i] + Math.abs(paramValues[i] * 0.5);
299
- }
300
- const parameterBoundsBitset = DG.BitSet.create(fitFunction.parameterNames.length * 2);
301
- if (parameterBounds && parameterBounds.length !== 0) {
302
- for (let i = 0; i < parameterBounds.length; i++) {
303
- if (parameterBounds[i].min !== undefined && parameterBounds[i].min !== null) {
304
- bottomParamBounds[i] = parameterBounds[i].min;
305
- parameterBoundsBitset.set(i * 2, true);
306
- }
307
- if (parameterBounds[i].max !== undefined && parameterBounds[i].max !== null) {
308
- topParamBounds[i] = parameterBounds[i].max;
309
- parameterBoundsBitset.set(i * 2 + 1, true);
310
- }
311
- }
312
- }
313
- const getConsistency = (extremum) => {
314
- const residuals = of(extremum.point).residuals;
315
- let q1q4 = 0;
316
- let q2q3 = 0;
317
- // TODO: rewrite quartiles to a better condition
318
- for (let i = 0; i < residuals.length; i++) {
319
- if (residuals.length / 4 > i)
320
- q1q4 += Math.pow(residuals[i], 2);
321
- else if (3 * residuals.length / 4 > i)
322
- q2q3 += Math.pow(residuals[i], 2);
323
- else
324
- q1q4 += Math.pow(residuals[i], 2);
325
- }
326
- return q1q4 / q2q3;
327
- };
328
- let iter = -1;
329
- let continueOptimization = 0;
330
- let statistics = null;
331
- let optimization;
332
- let minIdx = 0;
333
- do {
334
- optimization = performNelderMeadOptimization(of, bottomParamBounds, topParamBounds, {
335
- tolerance: NELDER_MEAD_DEFAULTS.TOLERANCE,
336
- maxIter: NELDER_MEAD_DEFAULTS.MAX_ITER,
337
- nonZeroParam: NELDER_MEAD_DEFAULTS.NON_ZERO_PARAM,
338
- initialScale: NELDER_MEAD_DEFAULTS.INITIAL_SCALE,
339
- scaleReflection: NELDER_MEAD_DEFAULTS.SCALE_REFLECTION,
340
- scaleExpansion: NELDER_MEAD_DEFAULTS.SCALE_EXPANSION,
341
- scaleContraction: NELDER_MEAD_DEFAULTS.SCALE_CONTRACTION,
342
- }, 10, paramValues);
343
- minIdx = 0;
344
- for (let i = 1; i < optimization.extremums.length; i++) {
345
- if (optimization.extremums[i].cost < optimization.extremums[minIdx].cost)
346
- minIdx = i;
347
- }
348
- const newStatistics = getConsistency(optimization.extremums[minIdx]);
349
- if (statistics === null)
350
- statistics = newStatistics;
351
- else if (newStatistics < statistics) {
352
- statistics = newStatistics;
353
- continueOptimization = 0;
354
- }
355
- else
356
- continueOptimization++;
357
- paramValues = optimization.extremums[minIdx].point;
358
- if (iter > 40 || continueOptimization === 3)
359
- break;
360
- for (let i = 0; i < fitFunction.parameterNames.length; i++) {
361
- if (!parameterBoundsBitset.get(i * 2))
362
- bottomParamBounds[i] = paramValues[i] - Math.abs(paramValues[i] * (continueOptimization + 0.5));
363
- if (!parameterBoundsBitset.get(i * 2 + 1))
364
- topParamBounds[i] = paramValues[i] + Math.abs(paramValues[i] * (continueOptimization + 0.5));
365
- }
366
- iter++;
367
- } while (true);
368
- const fittedCurve = getFittedCurve(curveFunction, paramValues);
369
- return {
370
- fittedCurve: fittedCurve,
371
- parameters: paramValues,
372
- };
373
- }
374
82
  export function getFittedCurve(curveFunction, paramValues) {
375
83
  return (x) => {
376
84
  return curveFunction(paramValues, x);
377
85
  };
378
86
  }
379
- export function getCurveConfidenceIntervals(data, paramValues, curveFunction, confidenceLevel = 0.05, errorModel) {
380
- const error = getSigma(curveFunction, data, errorModel, paramValues);
381
- const quantile = jStat.normal.inv(1 - confidenceLevel / 2, 0, 1);
382
- const top = (x) => {
383
- const value = curveFunction(paramValues, x);
384
- return value + quantile * (error.sigmaA + Math.abs(value) * error.sigmaB);
385
- };
386
- const bottom = (x) => {
387
- const value = curveFunction(paramValues, x);
388
- return value - quantile * (error.sigmaA + Math.abs(value) * error.sigmaB);
389
- };
390
- return { confidenceTop: top, confidenceBottom: bottom };
391
- }
392
87
  // TODO: for linear - slope - A, interceptY - B
393
88
  export function getStatistics(data, paramValues, curveFunction, statistics = true) {
394
89
  const fittedCurve = getFittedCurve(curveFunction, paramValues);
@@ -458,12 +153,20 @@ export function exponential(params, x) {
458
153
  return A * Math.exp(x * B);
459
154
  }
460
155
  export function fourPLRegression(params, x) {
461
- const A = params[0];
462
- const B = params[1];
463
- const C = params[2];
464
- const D = params[3];
156
+ const A = params[0]; // max
157
+ const B = params[1]; // hill
158
+ const C = params[2]; // IC50 / inflection point
159
+ const D = params[3]; // min
465
160
  return D + (A - D) / (1 + Math.pow(x / C, B));
466
161
  }
162
+ export function fourPLDoseResponse(params, x) {
163
+ const min = params[3];
164
+ const max = params[0];
165
+ const hill = params[1];
166
+ const ic50 = params[2];
167
+ // be ware, IC50 that comes here is already log10 transformed
168
+ return min + (max - min) / (1 + Math.pow(10, hill * (ic50 - x)));
169
+ }
467
170
  export function getAuc(fittedCurve, data) {
468
171
  let auc = 0;
469
172
  const min = Math.min(...data.x);
@@ -498,72 +201,4 @@ function getInvError(targetFunc, data) {
498
201
  sigma = Math.sqrt(sigmaSq);
499
202
  return sigma;
500
203
  }
501
- function objectiveFactory(targetFunc, data, errorModel) {
502
- return (params) => {
503
- let likelihood = 0;
504
- let sigmaA = 0;
505
- let sigmaB = 0;
506
- const obs = data.y;
507
- const pred = data.x.map((x) => targetFunc(params, x));
508
- const residuals = obs.map((obs, i) => obs - pred[i]);
509
- const residuesSquares = residuals.map((res) => Math.pow(res, 2));
510
- for (let i = 0; i < residuesSquares.length; i++) {
511
- if ([FitErrorModel.CONSTANT, FitErrorModel.COMBINED].includes(errorModel))
512
- sigmaA += residuesSquares[i];
513
- else if (errorModel === FitErrorModel.PROPORTIONAL)
514
- sigmaB += residuesSquares[i] / (pred[i] * pred[i]);
515
- }
516
- sigmaA = Math.sqrt(sigmaA / residuesSquares.length);
517
- sigmaB = Math.sqrt(sigmaB / residuesSquares.length);
518
- if (errorModel === FitErrorModel.COMBINED)
519
- ({ sigmaA, sigmaB } = getSigmasForCombinedErrorModel(sigmaA, sigmaB, residuesSquares, pred));
520
- const sigmaSqI = [];
521
- for (let i = 0; i < residuesSquares.length; i++) {
522
- sigmaSqI[i] = Math.pow(sigmaA + sigmaB * pred[i], 2);
523
- likelihood += residuesSquares[i] / sigmaSqI[i] + Math.log(2 * Math.PI * sigmaSqI[i]);
524
- }
525
- return { likelihood, residuals };
526
- };
527
- }
528
- function getSigma(targetFunc, data, errorModel, params) {
529
- let sigmaA = 0;
530
- let sigmaB = 0;
531
- const obs = data.y;
532
- const pred = data.x.map((x) => targetFunc(params, x));
533
- const residuals = obs.map((obs, i) => obs - pred[i]);
534
- const residuesSquares = residuals.map((res) => Math.pow(res, 2));
535
- for (let i = 0; i < residuesSquares.length; i++) {
536
- if ([FitErrorModel.CONSTANT, FitErrorModel.COMBINED].includes(errorModel))
537
- sigmaA += residuesSquares[i];
538
- else if (errorModel === FitErrorModel.PROPORTIONAL)
539
- sigmaB += Math.pow(residuals[i] / Math.abs(pred[i]), 2);
540
- }
541
- sigmaA = Math.sqrt(sigmaA / residuesSquares.length);
542
- sigmaB = Math.sqrt(sigmaB / residuesSquares.length);
543
- if (errorModel === FitErrorModel.COMBINED)
544
- ({ sigmaA, sigmaB } = getSigmasForCombinedErrorModel(sigmaA, sigmaB, residuesSquares, pred));
545
- return { sigmaA, sigmaB };
546
- }
547
- function getSigmasForCombinedErrorModel(sigmaA, sigmaB, residuesSquares, pred) {
548
- let likelihoodCombined = Number.MAX_VALUE;
549
- let finalProportion = 0;
550
- for (let i = 0; i <= 10; i++) {
551
- let likelihoodCombinedLocal = 0;
552
- const proportion = i / 10;
553
- const sigmaACombined = sigmaA * proportion;
554
- const sigmaBCombined = sigmaA * (1 - proportion);
555
- const sigmaSqICombined = [];
556
- for (let j = 0; j < residuesSquares.length; j++) {
557
- sigmaSqICombined[j] = Math.pow(sigmaACombined + sigmaBCombined * pred[j], 2);
558
- likelihoodCombinedLocal += residuesSquares[j] / sigmaSqICombined[j] + Math.log(2 * Math.PI * sigmaSqICombined[j]);
559
- }
560
- if (likelihoodCombinedLocal < likelihoodCombined) {
561
- likelihoodCombined = likelihoodCombinedLocal;
562
- finalProportion = proportion;
563
- }
564
- }
565
- sigmaB = sigmaA * (1 - finalProportion);
566
- sigmaA = sigmaA * finalProportion;
567
- return { sigmaA, sigmaB };
568
- }
569
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fit-curve.js","sourceRoot":"","sources":["fit-curve.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable max-len */\n/* eslint-disable no-multi-spaces */\nimport * as DG from 'datagrok-api/dg';\n//@ts-ignore: no types\nimport * as jStat from 'jstat';\nimport {performNelderMeadOptimization} from './fitting-algorithm/optimizer';\nimport {NELDER_MEAD_DEFAULTS} from './fitting-algorithm/optimizer-nelder-mead';\nimport {Extremum, OptimizationResult} from './fitting-algorithm/optimizer-misc';\n\n\nexport const FitErrorModel = {\n  CONSTANT: 'constant',\n  PROPORTIONAL: 'proportional',\n  COMBINED: 'combined',\n};\n\nexport type FitParamBounds = {\n  min?: number;\n  max?: number;\n};\n\n/** Fit function description. Applies to custom user fit functions.\n * Requires JS arrow functions for the fit functions and initial parameters. */\nexport interface IFitFunctionDescription {\n  name: string;\n  function: string;\n  getInitialParameters: string;\n  parameterNames: string[];\n}\n\nexport type FitCurve = {\n  fittedCurve: (x: number) => number;\n  parameters: Float32Array;\n};\n\nexport type FitConfidenceIntervals = {\n  confidenceTop: (x: number) => number;\n  confidenceBottom: (x: number) => number;\n};\n\nexport type FitStatistics = {\n  rSquared?: number,\n  auc?: number,\n  interceptX?: number, // parameters[2]\n  interceptY?: number, // fittedCurve[parameters[2]]\n  slope?: number, // parameters[1]\n  top?: number, // parameters[0]\n  bottom?: number, // parameters[3]\n};\n\nexport type FitInvertedFunctions = {\n  inverted: (y: number) => number,\n  invertedTop: (y: number) => number,\n  invertedBottom: (y: number) => number,\n};\n\n/**\n *  Datagrok curve fitting\n *\n * - Fitting: computing parameters of the specified function to best fit the data\n *   - Uses BFGS optimization algorithm (multi-threading for performance).\n *     For dose-response curves, we are typically fitting the sigmoid function\n *   - Ability to dynamically register custom fitting functions\n *     - Automatic fit function determination\n *     - Caching of custom fitting functions\n *   - Ability to get fitting performance characteristics (r-squared, classification, etc)\n * - Deep integration with the Datagrok grid\n *   - Either fitting on the fly, or using the supplied function + parameters\n *   - Multiple series in one cell\n *   - Candlesticks, confidence intervals, and droplines drawing\n *   - Ability to define chart, marker, or fitting options (such as fit function or marker color)\n *     on the column level, with the ability to override it on a grid cell or point level\n *   - Clicking a point in a chart within a grid makes it an outlier -> curve is re-fitted on the fly\n *   - Ability to specify a chart as \"reference\" so that it is shown on every other chart for comparison\n * - Ability to overlay curves from multiple grid cells (special viewer)\n * - Work with series stored in multiple formats (binary for performance, json for flexibility, etc)\n*/\n\nconst DROPLINES = ['IC50'];\n\nexport type FitMarkerType = 'asterisk' | 'circle' | 'cross border' | 'diamond' | 'square' | 'star' | 'triangle bottom' |\n  'triangle left' | 'triangle right' | 'triangle top';\n\nexport type FitOutlierMarkerType = 'asterisk' | 'circle' | 'cross border' | 'diamond' | 'outlier' | 'square' | 'star' |\n  'triangle bottom' | 'triangle left' | 'triangle right' | 'triangle top';\n\nexport type FitLineStyle = 'solid' | 'dotted' | 'dashed' | 'dashdotted';\n\nexport type FitErrorModelType = 'constant' | 'proportional' | 'combined';\n\n/** A point in the fit series. Only x and y are required. Can override some fields defined in IFitSeriesOptions. */\nexport interface IFitPoint {\n  x: number;\n  y: number;\n  outlier?: boolean;       // if true, renders as 'x' and gets ignored for curve fitting\n  color?: string;          // overrides the marker color defined in IFitSeriesOptions\n  outlierColor?: string;   // overrides the outlier color defined in IFitSeriesOptions\n  marker?: FitMarkerType;  // overrides the marker type defined in IFitSeriesOptions\n  outlierMarker?: FitOutlierMarkerType; // overrides the outlier marker type defined in IFitSeriesOptions\n  size?: number;           // overrides the default marker size\n  stdev?: number;          // when defined, renders an error bar candlestick\n  // minY?: number;           // when defined, the marker renders as a candlestick with whiskers [minY, maxY]\n  // maxY?: number;           // when defined, the marker renders as a candlestick with whiskers [minY, maxY]\n  meta?: any;           // any additional data\n}\n\n/** A series consists of points, has a name, and options.\n * If defined, seriesOptions are merged with {@link IFitChartData.seriesOptions} */\nexport interface IFitSeries extends IFitSeriesOptions {\n  points: IFitPoint[];\n}\n\n/** Chart labels options. Controls the chart labels. */\nexport interface IFitChartLabelOptions {\n  visible: boolean;         // if true, renders the label on the plot\n  color: string;            // defines the label color\n  name: string;             // defines the label name\n}\n\n/** Chart options. For fitted curves, this object is stored in the grid column tags and is used by the renderer. */\nexport interface IFitChartOptions {\n  minX?: number;\n  minY?: number;\n  maxX?: number;\n  maxY?: number;\n\n  title?: string;            // defines the plot title. If the plot size is enough, will render it.\n  xAxisName?: string;        // defines the x axis name. If the plot size is enough, will render it.\n  yAxisName?: string;        // defines the Y axis name. If the plot size is enough, will render it.\n\n  logX?: boolean;            // defines whether the x data should be logarithmic or not\n  logY?: boolean;            // defines whether the y data should be logarithmic or not\n\n  allowXZeroes?: boolean;    // defines whether x zeroes allowed for logarithmic data or not\n  mergeSeries?: boolean;     // defines whether to merge series or not\n\n  showColumnLabel?: boolean; // defines whether to show the column label in the legend or not\n  showStatistics?: string[]; // defines the statistics that would be shown on the plot\n  labelOptions?: IFitChartLabelOptions[]; // controls the plot labels\n}\n\n/** Data for the fit chart. */\nexport interface IFitChartData {\n  chartOptions?: IFitChartOptions;\n  seriesOptions?: IFitSeriesOptions;  // Default series options. Individual series can override it.\n  series?: IFitSeries[];\n}\n\n/** Class that implements {@link IFitChartData} interface */\nexport class FitChartData implements IFitChartData {\n  chartOptions: IFitChartOptions = {};\n  seriesOptions: IFitSeriesOptions = {};  // Default series options. Individual series can override it.\n  series: IFitSeries[] = [];\n}\n\n/** Series options can be either applied globally on a column level, or partially overridden in particular series */\nexport interface IFitSeriesOptions {\n  [key: string]: any;                   // allows getting data by key\n  name?: string;                        // controls the series name\n  fitFunction?: string | IFitFunctionDescription; // controls the series fit function\n  parameters?: number[];                // controls the series parameters, auto-fitting when not defined\n  parameterBounds?: FitParamBounds[];   // defines the acceptable range of each parameter, which is taken into account during the fitting. See also `parameters`.\n  markerType?: FitMarkerType;           // defines the series marker type\n  outlierMarkerType?: FitOutlierMarkerType;  // defines the series outlier marker type\n  lineStyle?: FitLineStyle;             // defines the series line style\n  pointColor?: string;                  // overrides the standardized series point color\n  fitLineColor?: string;                // overrides the standardized series fit line color\n  confidenceIntervalColor?: string;     // overrides the standardized series confidence interval color\n  outlierColor?: string;                // overrides the standardized series outlier color\n  connectDots?: boolean;                // defines whether to connect the points with lines or not. If true and showFitLine is false - fitting is disabled - otherwise, it will be rendered accordingly to the parameter value.\n  showFitLine?: boolean;                // defines whether to show the fit line or not\n  showPoints?: string;                  // defines the data display mode\n  showCurveConfidenceInterval?: boolean;    // defines whether to show the confidence intervals or not\n  errorModel?: FitErrorModelType;       // defines the series error model\n  clickToToggle?: boolean;    // if true, clicking on the point toggles its outlier status and causes curve refitting\n  labels?: {[key: string]: string | number | boolean}; // controlled by IFitChartData labelOptions, shows labels\n  droplines?: string[];                 // defines the droplines that would be shown on the plot (IC50)\n  columnName?: string;                  // defines the column name where the series is stored\n}\n// TODO: show labels in property panel if present, color by default from series\n\n// TODO?: add method to return parameters - get parameters from fit function\n/** Class for the fit functions */\nexport abstract class FitFunction {\n  abstract get name(): string;\n  abstract get parameterNames(): string[];\n  abstract y(params: Float32Array, x: number): number;\n  abstract getInitialParameters(x: number[], y: number[]): Float32Array;\n}\n\n/** Class that implements the linear function */\nexport class LinearFunction extends FitFunction {\n  get name(): string {\n    return FIT_FUNCTION_LINEAR;\n  }\n\n  get parameterNames(): string[] {\n    return ['Slope', 'Intercept'];\n  }\n\n  y(params: Float32Array, x: number): number {\n    return linear(params, x);\n  }\n\n  getInitialParameters(x: number[], y: number[]): Float32Array {\n    let minIndex = 0;\n    let maxIndex = 0;\n    for (let i = 1; i < x.length; i++) {\n      if (x[i] < x[minIndex])\n        minIndex = i;\n      if (x[i] > x[maxIndex])\n        maxIndex = i;\n    }\n\n    const deltaX = x[maxIndex] - x[minIndex];\n    const deltaY = y[maxIndex] - y[minIndex];\n    const A = deltaY / deltaX;\n    const B = y[maxIndex] - A * x[maxIndex];\n    const params = new Float32Array(2);\n    params.set([A, B]);\n    return params;\n  }\n}\n\n/** Class that implements the sigmoid function */\nexport class SigmoidFunction extends FitFunction {\n  get name(): string {\n    return FIT_FUNCTION_SIGMOID;\n  }\n\n  get parameterNames(): string[] {\n    return ['Top', 'Slope', 'IC50', 'Bottom'];\n  }\n\n  y(params: Float32Array, x: number): number {\n    return sigmoid(params, x);\n  }\n\n  getInitialParameters(x: number[], y: number[]): Float32Array {\n    const dataBounds = DG.Rect.fromXYArrays(x, y);\n    const medY = (dataBounds.maxY - dataBounds.minY) / 2 + dataBounds.minY;\n    let maxYInterval = dataBounds.maxY - dataBounds.minY;\n    let nearestXIndex = 0;\n    for (let i = 0; i < x.length; i++) {\n      const currentInterval = Math.abs(y[i] - medY);\n      if (currentInterval < maxYInterval) {\n        maxYInterval = currentInterval;\n        nearestXIndex = i;\n      }\n    }\n    const xAtMedY = x[nearestXIndex];\n    const slope = y[0] > y[y.length - 1] ? 1 : -1;\n\n    // params are: [max, tan, IC50, min]\n    const params = new Float32Array(4);\n    params.set([dataBounds.maxY, slope, xAtMedY, dataBounds.minY]);\n    return params;\n  }\n}\n\n/** Class that implements the linear logarithmic function */\nexport class LogLinearFunction extends FitFunction {\n  get name(): string {\n    return FIT_FUNCTION_LOG_LINEAR;\n  }\n\n  get parameterNames(): string[] {\n    return ['Slope', 'Intercept'];\n  }\n\n  y(params: Float32Array, x: number): number {\n    return logLinear(params, x);\n  }\n\n  getInitialParameters(x: number[], y: number[]): Float32Array {\n    const params = new Float32Array(2);\n    params.set([-5, 100]);\n    return params;\n  }\n}\n\n/** Class that implements the exponential function */\nexport class ExponentialFunction extends FitFunction {\n  get name(): string {\n    return FIT_FUNCTION_EXPONENTIAL;\n  }\n\n  get parameterNames(): string[] {\n    return ['Mantissa', 'Power'];\n  }\n\n  y(params: Float32Array, x: number): number {\n    return exponential(params, x);\n  }\n\n  getInitialParameters(x: number[], y: number[]): Float32Array {\n    const params = new Float32Array(2);\n    params.set([100, -2]);\n    return params;\n  }\n}\n\n/** Class that implements the Four Parameter Logistic Regression function */\nexport class FourPLRegressionFunction extends FitFunction {\n  get name(): string {\n    return FIT_FUNCTION_4PL_REGRESSION;\n  }\n\n  get parameterNames(): string[] {\n    return ['Top', 'Slope', 'EC50', 'Bottom'];\n  }\n\n  y(params: Float32Array, x: number): number {\n    return fourPLRegression(params, x);\n  }\n\n  getInitialParameters(x: number[], y: number[]): Float32Array {\n    const params = new Float32Array(4);\n    const bottom = Math.min(...y);\n    const top = Math.max(...y);\n    const medY = (top - bottom) / 2 + bottom;\n    let maxYInterval = top -bottom;\n    let nearestXIndex = 0;\n    for (let i = 0; i < x.length; i++) {\n      const currentInterval = Math.abs(y[i] - medY);\n      if (currentInterval < maxYInterval) {\n        maxYInterval = currentInterval;\n        nearestXIndex = i;\n      }\n    }\n    const ec50 = x[nearestXIndex];\n    const slope = y[0] > y[y.length - 1]? -10 : 10;\n    params.set([top, slope, ec50, bottom]);\n    return params;\n  }\n}\n\n/** Class that implements user JS functions */\nexport class JsFunction extends FitFunction {\n  private _name: string;\n  private _parameterNames: string[];\n\n  constructor(name: string, yFunc: (params: Float32Array, x: number) => number,\n    getInitParamsFunc: (x: number[], y: number[]) => Float32Array, parameterNames: string[]) {\n    super();\n\n    this._name = name;\n    this._parameterNames = parameterNames;\n\n    this.y = yFunc;\n    this.getInitialParameters = getInitParamsFunc;\n  }\n\n  get name(): string {\n    return this._name;\n  }\n\n  get parameterNames(): string[] {\n    return this._parameterNames;\n  }\n\n  y(params: Float32Array, x: number): number {\n    throw new Error('Not implemented');\n  }\n\n  getInitialParameters(x: number[], y: number[]): Float32Array {\n    throw new Error('Not implemented');\n  }\n}\n\n// Object with fit functions\nexport const fitFunctions: {[index: string]: FitFunction} = {\n  'linear': new LinearFunction(),\n  'sigmoid': new SigmoidFunction(),\n  'log-linear': new LogLinearFunction(),\n  'exponential': new ExponentialFunction(),\n  '4pl-regression': new FourPLRegressionFunction(),\n};\n\n/** Properties that describe {@link FitStatistics}. Useful for editing, initialization, transformations, etc. */\nexport const statisticsProperties: DG.Property[] = [\n  DG.Property.js('rSquared', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('auc', DG.TYPE.FLOAT, {userEditable: false, friendlyName: 'AUC'}),\n  DG.Property.js('interceptY', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('interceptX', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('slope', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('top', DG.TYPE.FLOAT, {userEditable: false, friendlyName: 'Max Y'}),\n  DG.Property.js('bottom', DG.TYPE.FLOAT, {userEditable: false, friendlyName: 'Min Y'}),\n];\n\n/** Properties that describe {@link IFitChartOptions}. Useful for editing, initialization, transformations, etc. */\nexport const fitChartDataProperties: DG.Property[] = [\n  // Style and zoom\n  // remove unnecessary tooltips\n  DG.Property.js('minX', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('minY', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('maxX', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('maxY', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('title', DG.TYPE.STRING, {nullable: true}),\n  DG.Property.js('xAxisName', DG.TYPE.STRING, {description:\n    'Label to show on the X axis. If not specified, corresponding data column name is used', nullable: true}),\n  DG.Property.js('yAxisName', DG.TYPE.STRING, {description:\n    'Label to show on the Y axis. If not specified, corresponding data column name is used', nullable: true}),\n  DG.Property.js('logX', DG.TYPE.BOOL, {description: 'Whether the X axis should be logarithmic', defaultValue: false}),\n  DG.Property.js('logY', DG.TYPE.BOOL, {description: 'Whether the Y axis should be logarithmic', defaultValue: false}),\n  DG.Property.js('allowXZeroes', DG.TYPE.BOOL, {description: 'Whether x zeroes allowed for logarithmic data or not', defaultValue: true}),\n  DG.Property.js('mergeSeries', DG.TYPE.BOOL, {description: 'Merges all series within one cell into one series', defaultValue: false}),\n  DG.Property.js('showColumnLabel', DG.TYPE.BOOL, {description: 'Whether to show the column label in the legend or not', defaultValue: false}),\n  DG.Property.js('showStatistics', DG.TYPE.STRING_LIST, {description: 'Whether specific statistics should be rendered',\n    choices: statisticsProperties.map((frp) => frp.name), inputType: 'MultiChoice',\n    //@ts-ignore\n    friendlyName: 'Statistics'}),\n];\n\n/** Properties that describe {@link IFitSeriesOptions}. Useful for editing, initialization, transformations, etc. */\nexport const fitSeriesProperties: DG.Property[] = [\n  DG.Property.js('fitFunction', DG.TYPE.STRING,\n    {category: 'Fitting', choices: Object.keys(fitFunctions), defaultValue: 'sigmoid'}),\n  DG.Property.js('pointColor', DG.TYPE.STRING,\n    {category: 'Rendering', nullable: true, inputType: 'Color'}),\n  DG.Property.js('fitLineColor', DG.TYPE.STRING,\n    {category: 'Rendering', nullable: true, inputType: 'Color'}),\n  DG.Property.js('outlierColor', DG.TYPE.STRING,\n    {category: 'Rendering', nullable: true, inputType: 'Color'}),\n  DG.Property.js('errorModel', DG.TYPE.STRING, {category: 'Fitting', defaultValue: 'constant',\n    choices: ['constant', 'proportional', 'combined'], nullable: false}),\n  DG.Property.js('connectDots', DG.TYPE.BOOL, {category: 'Fitting', defaultValue: false}),\n  DG.Property.js('clickToToggle', DG.TYPE.BOOL, {category: 'Fitting', description:\n    'Click on a point to mark it as outlier and refit', nullable: true, defaultValue: false}),\n  DG.Property.js('showFitLine', DG.TYPE.BOOL, {category: 'Fitting', defaultValue: true}),\n  DG.Property.js('showPoints', DG.TYPE.STRING, // rewrite description\n    {category: 'Fitting', description: 'Whether points/candlesticks/none should be rendered',\n      defaultValue: 'points', choices: ['points', 'candlesticks', 'both']}),\n  DG.Property.js('showCurveConfidenceInterval', DG.TYPE.BOOL,\n    {category: 'Fitting', description: 'Whether confidence intervals should be rendered', defaultValue: false,\n      //@ts-ignore\n      friendlyName: 'Confidence Interval'}),\n  DG.Property.js('markerType', DG.TYPE.STRING, {category: 'Rendering', defaultValue: 'circle',\n    choices: ['asterisk', 'circle', 'cross border', 'diamond', 'square', 'star',\n      'triangle bottom', 'triangle left', 'triangle right', 'triangle top'], nullable: false,\n    //@ts-ignore\n    friendlyName: 'Marker'}),\n  DG.Property.js('outlierMarkerType', DG.TYPE.STRING, {category: 'Rendering', defaultValue: 'outlier',\n    choices: ['asterisk', 'circle', 'cross border', 'diamond', 'outlier', 'square', 'star',\n      'triangle bottom', 'triangle left', 'triangle right', 'triangle top'], nullable: false,\n    //@ts-ignore\n    friendlyName: 'Outlier Marker'}),\n  DG.Property.js('lineStyle', DG.TYPE.STRING, {category: 'Rendering', defaultValue: 'solid',\n    choices: ['solid', 'dotted', 'dashed', 'dashdotted'], nullable: false}),\n  DG.Property.js('droplines', DG.TYPE.STRING_LIST, {description: 'Whether specific droplines should be rendered',\n    choices: DROPLINES, inputType: 'MultiChoice'}),\n  DG.Property.js('columnName', DG.TYPE.STRING, {description: 'Column name where the series is stored', defaultValue: ''}),\n];\n\nexport const FIT_FUNCTION_SIGMOID = 'sigmoid';\nexport const FIT_FUNCTION_LINEAR = 'linear';\nexport const FIT_FUNCTION_LOG_LINEAR = 'log-linear';\nexport const FIT_FUNCTION_EXPONENTIAL = 'exponential';\nexport const FIT_FUNCTION_4PL_REGRESSION = '4pl-regression';\n\nexport const FIT_STATS_RSQUARED = 'rSquared';\nexport const FIT_STATS_AUC = 'auc';\n\nexport function getOrCreateFitFunction(seriesFitFunc: string | IFitFunctionDescription): FitFunction {\n  if (typeof seriesFitFunc === 'string')\n    return fitFunctions[seriesFitFunc];\n  else if (!fitFunctions[seriesFitFunc.name]) {\n    const name = seriesFitFunc.name;\n    const paramNames = seriesFitFunc.parameterNames;\n    const fitFunctionParts = seriesFitFunc.function.split('=>').map((elem) => elem.trim());\n    const getInitParamsParts = seriesFitFunc.getInitialParameters.split('=>').map((elem) => elem.trim());\n    const fitFunction = new Function(fitFunctionParts[0].slice(1, fitFunctionParts[0].length - 1),\n      `${fitFunctionParts[1].includes(';') ? '' : 'return '}${fitFunctionParts[1]}`);\n    const getInitParamsFunc = new Function(getInitParamsParts[0].slice(1, getInitParamsParts[0].length - 1),\n      `return ${getInitParamsParts[1]}`);\n    const fitFunc = new JsFunction(name, (fitFunction as (params: Float32Array, x: number) => number),\n      (getInitParamsFunc as (x: number[], y: number[]) => Float32Array), paramNames);\n    fitFunctions[name] = fitFunc;\n  }\n\n  return fitFunctions[seriesFitFunc.name];\n}\n\nexport function fitData(data: {x: number[], y: number[]}, fitFunction: FitFunction, errorModel?: FitErrorModelType,\n  parameterBounds?: FitParamBounds[]): FitCurve {\n  errorModel ??= FitErrorModel.CONSTANT as FitErrorModelType;\n  const curveFunction = fitFunction.y;\n  let paramValues = fitFunction.getInitialParameters(data.x, data.y);\n\n  const of = objectiveFactory(curveFunction, data, errorModel);\n  const bottomParamBounds = new Float32Array(fitFunction.parameterNames.length);\n  const topParamBounds = new Float32Array(fitFunction.parameterNames.length);\n  for (let i = 0; i < fitFunction.parameterNames.length; i++) {\n    bottomParamBounds[i] = paramValues[i] === 0 ? -1 : paramValues[i] - Math.abs(paramValues[i] * 0.5);\n    topParamBounds[i] = paramValues[i] === 0 ? 1 : paramValues[i] + Math.abs(paramValues[i] * 0.5);\n  }\n  const parameterBoundsBitset: DG.BitSet = DG.BitSet.create(fitFunction.parameterNames.length * 2);\n  if (parameterBounds && parameterBounds.length !== 0) {\n    for (let i = 0; i < parameterBounds.length; i++) {\n      if (parameterBounds[i].min !== undefined && parameterBounds[i].min !== null) {\n        bottomParamBounds[i] = parameterBounds[i].min!;\n        parameterBoundsBitset.set(i * 2, true);\n      }\n      if (parameterBounds[i].max !== undefined && parameterBounds[i].max !== null) {\n        topParamBounds[i] = parameterBounds[i].max!;\n        parameterBoundsBitset.set(i * 2 + 1, true);\n      }\n    }\n  }\n  const getConsistency = (extremum: Extremum) => {\n    const residuals = of(extremum.point).residuals;\n    let q1q4 = 0;\n    let q2q3 = 0;\n    // TODO: rewrite quartiles to a better condition\n    for (let i = 0; i < residuals.length; i++) {\n      if (residuals.length / 4 > i)\n        q1q4 += Math.pow(residuals[i], 2);\n      else if (3 * residuals.length / 4 > i)\n        q2q3 += Math.pow(residuals[i], 2);\n      else\n        q1q4 += Math.pow(residuals[i], 2);\n    }\n    return q1q4 / q2q3;\n  };\n\n  let iter = -1;\n  let continueOptimization = 0;\n  let statistics: number | null = null;\n  let optimization: OptimizationResult;\n  let minIdx = 0;\n  do {\n    optimization = performNelderMeadOptimization(of, bottomParamBounds, topParamBounds, {\n      tolerance: NELDER_MEAD_DEFAULTS.TOLERANCE,\n      maxIter: NELDER_MEAD_DEFAULTS.MAX_ITER,\n      nonZeroParam: NELDER_MEAD_DEFAULTS.NON_ZERO_PARAM,\n      initialScale: NELDER_MEAD_DEFAULTS.INITIAL_SCALE,\n      scaleReflection: NELDER_MEAD_DEFAULTS.SCALE_REFLECTION,\n      scaleExpansion: NELDER_MEAD_DEFAULTS.SCALE_EXPANSION,\n      scaleContraction: NELDER_MEAD_DEFAULTS.SCALE_CONTRACTION,\n    }, 10, paramValues);\n\n    minIdx = 0;\n    for (let i = 1; i < optimization.extremums.length; i++) {\n      if (optimization.extremums[i].cost < optimization.extremums[minIdx].cost)\n        minIdx = i;\n    }\n\n    const newStatistics = getConsistency(optimization.extremums[minIdx]);\n    if (statistics === null)\n      statistics = newStatistics;\n    else if (newStatistics < statistics) {\n      statistics = newStatistics;\n      continueOptimization = 0;\n    }\n    else\n      continueOptimization++;\n\n    paramValues = optimization.extremums[minIdx].point;\n\n    if (iter > 40 || continueOptimization === 3)\n      break;\n\n    for (let i = 0; i < fitFunction.parameterNames.length; i++) {\n      if (!parameterBoundsBitset.get(i * 2))\n        bottomParamBounds[i] = paramValues[i] - Math.abs(paramValues[i] * (continueOptimization + 0.5));\n      if (!parameterBoundsBitset.get(i * 2 + 1))\n        topParamBounds[i] = paramValues[i] + Math.abs(paramValues[i] * (continueOptimization + 0.5));\n    }\n\n    iter++;\n  } while (true);\n\n  const fittedCurve = getFittedCurve(curveFunction, paramValues);\n\n  return {\n    fittedCurve: fittedCurve,\n    parameters: paramValues,\n  };\n}\n\nexport function getFittedCurve(curveFunction: (params: Float32Array, x: number) => number, paramValues: Float32Array):\n (x: number) => number {\n  return (x: number) => {\n    return curveFunction(paramValues, x);\n  };\n}\n\nexport function getCurveConfidenceIntervals(data: {x: number[], y: number[]}, paramValues: Float32Array,\n  curveFunction: (params: Float32Array, x: number) => number, confidenceLevel: number = 0.05, errorModel: FitErrorModelType):\n  FitConfidenceIntervals {\n  const error = getSigma(curveFunction, data, errorModel, paramValues);\n  const quantile = jStat.normal.inv(1 - confidenceLevel/2, 0, 1);\n\n  const top = (x: number) => {\n    const value = curveFunction(paramValues, x);\n    return value + quantile * (error.sigmaA + Math.abs(value) * error.sigmaB);\n  };\n\n  const bottom = (x: number) => {\n    const value = curveFunction(paramValues, x);\n    return value - quantile * (error.sigmaA + Math.abs(value) * error.sigmaB);\n  };\n\n  return {confidenceTop: top, confidenceBottom: bottom};\n}\n\n// TODO: for linear - slope - A, interceptY - B\nexport function getStatistics(data: {x: number[], y: number[]}, paramValues: Float32Array,\n  curveFunction: (params: Float32Array, x: number) => number, statistics: boolean = true): FitStatistics {\n  const fittedCurve = getFittedCurve(curveFunction, paramValues);\n\n  return {\n    rSquared: statistics ? getDetCoeff(fittedCurve, data) : undefined,\n    auc: statistics ? getAuc(fittedCurve, data) : undefined,\n    interceptX: paramValues[2],\n    interceptY: fittedCurve(paramValues[2]),\n    slope: paramValues[1],\n    top: paramValues[0],\n    bottom: paramValues[3],\n  };\n}\n\nexport function getInvertedFunctions(data: {x: number[], y: number[]}, paramValues: number[],\n  confidenceLevel: number = 0.05, statistics: boolean = true): FitInvertedFunctions | null {\n  const studentQ = jStat.studentt.inv(1 - confidenceLevel / 2, data.x.length - paramValues.length);\n\n  let inv: (y: number) => number = (y: number) => {\n    return 0;\n  };\n  let invTop: (y: number) => number = (y: number) => {\n    return 0;\n  };\n  let invBottom: (y: number) => number = (y: number) => {\n    return 0;\n  };\n\n  if (statistics) {\n    inv = (y: number) => {\n      //should check if more than bottom and less than top\n      return paramValues[2] / Math.pow((paramValues[0] - y) / (y - paramValues[3]), 1 / paramValues[1]);\n    };\n\n    const error = getInvError(inv, data);\n\n    invTop = (y: number) => {\n      const value = inv(y);\n      return value + studentQ * error / Math.sqrt(data.y.length);\n    };\n\n    invBottom = (y: number) => {\n      const value = inv(y);\n      return value - studentQ * error / Math.sqrt(data.y.length);\n    };\n\n    return {\n      inverted: inv,\n      invertedTop: invTop,\n      invertedBottom: invBottom,\n    };\n  }\n\n  return null;\n}\n\nexport function sigmoid(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  const C = params[2];\n  const D = params[3];\n  return (D + (A - D) / (1 + Math.pow(10, (x - C) * B)));\n}\n\nexport function linear(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  return A * x + B;\n}\n\nexport function logLinear(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  return A * Math.log(x + 1) + B;\n}\n\nexport function exponential(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  return A * Math.exp(x * B);\n}\n\nexport function fourPLRegression(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  const C = params[2];\n  const D = params[3];\n  return D + (A - D) / (1 + Math.pow(x / C, B));\n}\n\nexport function getAuc(fittedCurve: (x: number) => number, data: {x: number[], y: number[]}): number {\n  let auc = 0;\n  const min = Math.min(...data.x);\n  const max = Math.max(...data.x);\n  const integrationStep = (max - min) / 1000;\n  for (let x = min; x < max; x+= integrationStep)\n    auc += integrationStep * fittedCurve(x);\n\n  return auc;\n}\n\nexport function getDetCoeff(fittedCurve: (x: number) => number, data: {x: number[], y: number[]}): number {\n  let ssRes = 0;\n  let ssTot = 0;\n  const yMean = jStat.mean(data.y);\n  for (let i = 0; i < data.x.length; i++) {\n    ssRes += Math.pow(data.y[i] - fittedCurve(data.x[i]), 2);\n    ssTot += Math.pow(data.y[i] - yMean, 2);\n  }\n\n  return 1 - ssRes / ssTot;\n}\n\nfunction getInvError(targetFunc: (y: number) => number, data: {y: number[], x: number[]}): number {\n  let sigma = 0;\n  let sigmaSq = 0;\n  const residuesSquares = new Float32Array(data.y.length);\n  for (let i = 0; i < data.y.length; i++) {\n    const obs = data.x[i];\n    const pred = targetFunc(data.y[i]);\n    residuesSquares[i] = Math.pow(obs - pred, 2);\n  }\n\n  for (let i = 0; i < residuesSquares.length; i++)\n    sigmaSq += residuesSquares[i];\n\n  sigmaSq /= residuesSquares.length;\n  sigma = Math.sqrt(sigmaSq);\n\n  return sigma;\n}\n\nfunction objectiveFactory(targetFunc: (params: Float32Array, x: number) => number,\n  data: {y: number[], x: number[]}, errorModel: FitErrorModelType):\n    (params: Float32Array) => {likelihood: number, residuals: number[]} {\n  return (params: Float32Array) => {\n    let likelihood = 0;\n    let sigmaA = 0;\n    let sigmaB = 0;\n\n    const obs = data.y;\n    const pred = data.x.map((x) => targetFunc(params, x));\n    const residuals = obs.map((obs, i) => obs - pred[i]);\n    const residuesSquares = residuals.map((res) => Math.pow(res, 2));\n\n    for (let i = 0; i < residuesSquares.length; i++) {\n      if ([FitErrorModel.CONSTANT, FitErrorModel.COMBINED].includes(errorModel))\n        sigmaA += residuesSquares[i];\n      else if (errorModel === FitErrorModel.PROPORTIONAL)\n        sigmaB += residuesSquares[i] / (pred[i] * pred[i]);\n    }\n    sigmaA = Math.sqrt(sigmaA / residuesSquares.length);\n    sigmaB = Math.sqrt(sigmaB / residuesSquares.length);\n\n    if (errorModel === FitErrorModel.COMBINED)\n      ({sigmaA, sigmaB} = getSigmasForCombinedErrorModel(sigmaA, sigmaB, residuesSquares, pred));\n\n    const sigmaSqI: number[] = [];\n    for (let i = 0; i < residuesSquares.length; i++) {\n      sigmaSqI[i] = Math.pow(sigmaA + sigmaB * pred[i], 2);\n      likelihood += residuesSquares[i] / sigmaSqI[i] + Math.log(2 * Math.PI * sigmaSqI[i]);\n    }\n\n    return {likelihood, residuals};\n  };\n}\n\nfunction getSigma(targetFunc: (params: Float32Array, x: number) => number,\n  data: {y: number[], x: number[]}, errorModel: FitErrorModelType, params: Float32Array): {sigmaA: number, sigmaB: number} {\n  let sigmaA = 0;\n  let sigmaB = 0;\n\n  const obs = data.y;\n  const pred = data.x.map((x) => targetFunc(params, x));\n  const residuals = obs.map((obs, i) => obs - pred[i]);\n  const residuesSquares = residuals.map((res) => Math.pow(res, 2));\n\n  for (let i = 0; i < residuesSquares.length; i++) {\n    if ([FitErrorModel.CONSTANT, FitErrorModel.COMBINED].includes(errorModel))\n      sigmaA += residuesSquares[i];\n    else if (errorModel === FitErrorModel.PROPORTIONAL)\n      sigmaB += Math.pow(residuals[i] / Math.abs(pred[i]), 2);\n  }\n  sigmaA = Math.sqrt(sigmaA / residuesSquares.length);\n  sigmaB = Math.sqrt(sigmaB / residuesSquares.length);\n\n  if (errorModel === FitErrorModel.COMBINED)\n    ({sigmaA, sigmaB} = getSigmasForCombinedErrorModel(sigmaA, sigmaB, residuesSquares, pred));\n\n  return {sigmaA, sigmaB};\n}\n\nfunction getSigmasForCombinedErrorModel(sigmaA: number, sigmaB: number, residuesSquares: number[], pred: number[]):\n  {sigmaA: number, sigmaB: number} {\n  let likelihoodCombined = Number.MAX_VALUE;\n  let finalProportion = 0;\n  for (let i = 0; i <= 10; i++) {\n    let likelihoodCombinedLocal = 0;\n    const proportion = i / 10;\n    const sigmaACombined = sigmaA * proportion;\n    const sigmaBCombined = sigmaA * (1 - proportion);\n    const sigmaSqICombined: number[] = [];\n    for (let j = 0; j < residuesSquares.length; j++) {\n      sigmaSqICombined[j] = Math.pow(sigmaACombined + sigmaBCombined * pred[j], 2);\n      likelihoodCombinedLocal += residuesSquares[j] / sigmaSqICombined[j] + Math.log(2 * Math.PI * sigmaSqICombined[j]);\n    }\n    if (likelihoodCombinedLocal < likelihoodCombined) {\n      likelihoodCombined = likelihoodCombinedLocal;\n      finalProportion = proportion;\n    }\n  }\n  sigmaB = sigmaA * (1 - finalProportion);\n  sigmaA = sigmaA * finalProportion;\n\n  return {sigmaA, sigmaB};\n}\n"]}
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fit-curve.js","sourceRoot":"","sources":["fit-curve.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable max-len */\n/* eslint-disable no-multi-spaces */\nimport * as DG from 'datagrok-api/dg';\n//@ts-ignore: no types\nimport * as jStat from 'jstat';\n\nexport const FitErrorModel = {\n  CONSTANT: 'constant',\n  PROPORTIONAL: 'proportional',\n  COMBINED: 'combined',\n};\n\nexport type FitParamBounds = {\n  min?: number;\n  max?: number;\n};\n\n/** Fit function description. Applies to custom user fit functions.\n * Requires JS arrow functions for the fit functions and initial parameters. */\nexport interface IFitFunctionDescription {\n  name: string;\n  function: string;\n  getInitialParameters: string;\n  parameterNames: string[];\n}\n\nexport type FitCurve = {\n  fittedCurve: (x: number) => number;\n  parameters: Float32Array;\n};\n\nexport type FitConfidenceIntervals = {\n  confidenceTop: (x: number) => number;\n  confidenceBottom: (x: number) => number;\n};\n\nexport type FitStatistics = {\n  rSquared?: number,\n  auc?: number,\n  interceptX?: number, // parameters[2]\n  interceptY?: number, // fittedCurve[parameters[2]]\n  slope?: number, // parameters[1]\n  top?: number, // parameters[0]\n  bottom?: number, // parameters[3]\n};\n\nexport type FitInvertedFunctions = {\n  inverted: (y: number) => number,\n  invertedTop: (y: number) => number,\n  invertedBottom: (y: number) => number,\n};\n\n/**\n *  Datagrok curve fitting\n *\n * - Fitting: computing parameters of the specified function to best fit the data\n *   - Uses BFGS optimization algorithm (multi-threading for performance).\n *     For dose-response curves, we are typically fitting the sigmoid function\n *   - Ability to dynamically register custom fitting functions\n *     - Automatic fit function determination\n *     - Caching of custom fitting functions\n *   - Ability to get fitting performance characteristics (r-squared, classification, etc)\n * - Deep integration with the Datagrok grid\n *   - Either fitting on the fly, or using the supplied function + parameters\n *   - Multiple series in one cell\n *   - Candlesticks, confidence intervals, and droplines drawing\n *   - Ability to define chart, marker, or fitting options (such as fit function or marker color)\n *     on the column level, with the ability to override it on a grid cell or point level\n *   - Clicking a point in a chart within a grid makes it an outlier -> curve is re-fitted on the fly\n *   - Ability to specify a chart as \"reference\" so that it is shown on every other chart for comparison\n * - Ability to overlay curves from multiple grid cells (special viewer)\n * - Work with series stored in multiple formats (binary for performance, json for flexibility, etc)\n*/\n\nexport const DROPLINES = ['IC50'];\n\nexport type FitMarkerType = 'asterisk' | 'circle' | 'cross border' | 'diamond' | 'square' | 'star' | 'triangle bottom' |\n  'triangle left' | 'triangle right' | 'triangle top';\n\nexport type FitOutlierMarkerType = 'asterisk' | 'circle' | 'cross border' | 'diamond' | 'outlier' | 'square' | 'star' |\n  'triangle bottom' | 'triangle left' | 'triangle right' | 'triangle top';\n\nexport type FitLineStyle = 'solid' | 'dotted' | 'dashed' | 'dashdotted';\n\nexport type FitErrorModelType = 'constant' | 'proportional' | 'combined';\n\n/** A point in the fit series. Only x and y are required. Can override some fields defined in IFitSeriesOptions. */\nexport interface IFitPoint {\n  x: number;\n  y: number;\n  outlier?: boolean;       // if true, renders as 'x' and gets ignored for curve fitting\n  color?: string;          // overrides the marker color defined in IFitSeriesOptions\n  outlierColor?: string;   // overrides the outlier color defined in IFitSeriesOptions\n  marker?: FitMarkerType;  // overrides the marker type defined in IFitSeriesOptions\n  outlierMarker?: FitOutlierMarkerType; // overrides the outlier marker type defined in IFitSeriesOptions\n  size?: number;           // overrides the default marker size\n  stdev?: number;          // when defined, renders an error bar candlestick\n  // minY?: number;           // when defined, the marker renders as a candlestick with whiskers [minY, maxY]\n  // maxY?: number;           // when defined, the marker renders as a candlestick with whiskers [minY, maxY]\n  meta?: any;           // any additional data\n}\n\n/** A series consists of points, has a name, and options.\n * If defined, seriesOptions are merged with {@link IFitChartData.seriesOptions} */\nexport interface IFitSeries extends IFitSeriesOptions {\n  points: IFitPoint[];\n}\n\n/** Chart labels options. Controls the chart labels. */\nexport interface IFitChartLabelOptions {\n  visible: boolean;         // if true, renders the label on the plot\n  color: string;            // defines the label color\n  name: string;             // defines the label name\n}\n\n/** Chart options. For fitted curves, this object is stored in the grid column tags and is used by the renderer. */\nexport interface IFitChartOptions {\n  minX?: number;\n  minY?: number;\n  maxX?: number;\n  maxY?: number;\n\n  title?: string;            // defines the plot title. If the plot size is enough, will render it.\n  xAxisName?: string;        // defines the x axis name. If the plot size is enough, will render it.\n  yAxisName?: string;        // defines the Y axis name. If the plot size is enough, will render it.\n\n  logX?: boolean;            // defines whether the x data should be logarithmic or not\n  logY?: boolean;            // defines whether the y data should be logarithmic or not\n\n  allowXZeroes?: boolean;    // defines whether x zeroes allowed for logarithmic data or not\n  mergeSeries?: boolean;     // defines whether to merge series or not\n\n  showColumnLabel?: boolean; // defines whether to show the column label in the legend or not\n  showStatistics?: string[]; // defines the statistics that would be shown on the plot\n  labelOptions?: IFitChartLabelOptions[]; // controls the plot labels\n}\n\n/** Data for the fit chart. */\nexport interface IFitChartData {\n  chartOptions?: IFitChartOptions;\n  seriesOptions?: IFitSeriesOptions;  // Default series options. Individual series can override it.\n  series?: IFitSeries[];\n}\n\n/** Class that implements {@link IFitChartData} interface */\nexport class FitChartData implements IFitChartData {\n  chartOptions: IFitChartOptions = {};\n  seriesOptions: IFitSeriesOptions = {};  // Default series options. Individual series can override it.\n  series: IFitSeries[] = [];\n}\n\n/** Series options can be either applied globally on a column level, or partially overridden in particular series */\nexport interface IFitSeriesOptions {\n  [key: string]: any;                   // allows getting data by key\n  name?: string;                        // controls the series name\n  fitFunction?: string | IFitFunctionDescription; // controls the series fit function\n  parameters?: number[];                // controls the series parameters, auto-fitting when not defined\n  parameterBounds?: FitParamBounds[];   // defines the acceptable range of each parameter, which is taken into account during the fitting. See also `parameters`.\n  markerType?: FitMarkerType;           // defines the series marker type\n  outlierMarkerType?: FitOutlierMarkerType;  // defines the series outlier marker type\n  lineStyle?: FitLineStyle;             // defines the series line style\n  pointColor?: string;                  // overrides the standardized series point color\n  fitLineColor?: string;                // overrides the standardized series fit line color\n  confidenceIntervalColor?: string;     // overrides the standardized series confidence interval color\n  outlierColor?: string;                // overrides the standardized series outlier color\n  connectDots?: boolean;                // defines whether to connect the points with lines or not. If true and showFitLine is false - fitting is disabled - otherwise, it will be rendered accordingly to the parameter value.\n  showFitLine?: boolean;                // defines whether to show the fit line or not\n  showPoints?: string;                  // defines the data display mode\n  showCurveConfidenceInterval?: boolean;    // defines whether to show the confidence intervals or not\n  errorModel?: FitErrorModelType;       // defines the series error model\n  clickToToggle?: boolean;    // if true, clicking on the point toggles its outlier status and causes curve refitting\n  labels?: {[key: string]: string | number | boolean}; // controlled by IFitChartData labelOptions, shows labels\n  droplines?: string[];                 // defines the droplines that would be shown on the plot (IC50)\n  columnName?: string;                  // defines the column name where the series is stored\n}\n// TODO: show labels in property panel if present, color by default from series\n\n\n/** Properties that describe {@link FitStatistics}. Useful for editing, initialization, transformations, etc. */\nexport const statisticsProperties: DG.Property[] = [\n  DG.Property.js('rSquared', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('auc', DG.TYPE.FLOAT, {userEditable: false, friendlyName: 'AUC'}),\n  DG.Property.js('interceptY', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('interceptX', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('slope', DG.TYPE.FLOAT, {userEditable: false}),\n  DG.Property.js('top', DG.TYPE.FLOAT, {userEditable: false, friendlyName: 'Max Y'}),\n  DG.Property.js('bottom', DG.TYPE.FLOAT, {userEditable: false, friendlyName: 'Min Y'}),\n];\n\n/** Properties that describe {@link IFitChartOptions}. Useful for editing, initialization, transformations, etc. */\nexport const fitChartDataProperties: DG.Property[] = [\n  // Style and zoom\n  // remove unnecessary tooltips\n  DG.Property.js('minX', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('minY', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('maxX', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('maxY', DG.TYPE.FLOAT, {nullable: true}),\n  DG.Property.js('title', DG.TYPE.STRING, {nullable: true}),\n  DG.Property.js('xAxisName', DG.TYPE.STRING, {description:\n    'Label to show on the X axis. If not specified, corresponding data column name is used', nullable: true}),\n  DG.Property.js('yAxisName', DG.TYPE.STRING, {description:\n    'Label to show on the Y axis. If not specified, corresponding data column name is used', nullable: true}),\n  DG.Property.js('logX', DG.TYPE.BOOL, {description: 'Whether the X axis should be logarithmic', defaultValue: false}),\n  DG.Property.js('logY', DG.TYPE.BOOL, {description: 'Whether the Y axis should be logarithmic', defaultValue: false}),\n  DG.Property.js('allowXZeroes', DG.TYPE.BOOL, {description: 'Whether x zeroes allowed for logarithmic data or not', defaultValue: true}),\n  DG.Property.js('mergeSeries', DG.TYPE.BOOL, {description: 'Merges all series within one cell into one series', defaultValue: false}),\n  DG.Property.js('showColumnLabel', DG.TYPE.BOOL, {description: 'Whether to show the column label in the legend or not', defaultValue: false}),\n  DG.Property.js('showStatistics', DG.TYPE.STRING_LIST, {description: 'Whether specific statistics should be rendered',\n    choices: statisticsProperties.map((frp) => frp.name), inputType: 'MultiChoice',\n    //@ts-ignore\n    friendlyName: 'Statistics'}),\n];\n\nexport const FIT_FUNCTION_SIGMOID = 'sigmoid';\nexport const FIT_FUNCTION_LINEAR = 'linear';\nexport const FIT_FUNCTION_LOG_LINEAR = 'log-linear';\nexport const FIT_FUNCTION_EXPONENTIAL = 'exponential';\nexport const FIT_FUNCTION_4PL_REGRESSION = '4pl-regression';\nexport const FIT_FUNCTION_4PL_DOSE_RESPONSE = '4pl-dose-response';\nexport const FIT_JS_FUNCTION = 'js-function';\n\nexport const FIT_STATS_RSQUARED = 'rSquared';\nexport const FIT_STATS_AUC = 'auc';\n\nexport function getFittedCurve(curveFunction: (params: Float32Array, x: number) => number, paramValues: Float32Array):\n (x: number) => number {\n  return (x: number) => {\n    return curveFunction(paramValues, x);\n  };\n}\n\n// TODO: for linear - slope - A, interceptY - B\nexport function getStatistics(data: {x: number[], y: number[]}, paramValues: Float32Array,\n  curveFunction: (params: Float32Array, x: number) => number, statistics: boolean = true): FitStatistics {\n  const fittedCurve = getFittedCurve(curveFunction, paramValues);\n\n  return {\n    rSquared: statistics ? getDetCoeff(fittedCurve, data) : undefined,\n    auc: statistics ? getAuc(fittedCurve, data) : undefined,\n    interceptX: paramValues[2],\n    interceptY: fittedCurve(paramValues[2]),\n    slope: paramValues[1],\n    top: paramValues[0],\n    bottom: paramValues[3],\n  };\n}\n\nexport function getInvertedFunctions(data: {x: number[], y: number[]}, paramValues: number[],\n  confidenceLevel: number = 0.05, statistics: boolean = true): FitInvertedFunctions | null {\n  const studentQ = jStat.studentt.inv(1 - confidenceLevel / 2, data.x.length - paramValues.length);\n\n  let inv: (y: number) => number = (y: number) => {\n    return 0;\n  };\n  let invTop: (y: number) => number = (y: number) => {\n    return 0;\n  };\n  let invBottom: (y: number) => number = (y: number) => {\n    return 0;\n  };\n\n  if (statistics) {\n    inv = (y: number) => {\n      //should check if more than bottom and less than top\n      return paramValues[2] / Math.pow((paramValues[0] - y) / (y - paramValues[3]), 1 / paramValues[1]);\n    };\n\n    const error = getInvError(inv, data);\n\n    invTop = (y: number) => {\n      const value = inv(y);\n      return value + studentQ * error / Math.sqrt(data.y.length);\n    };\n\n    invBottom = (y: number) => {\n      const value = inv(y);\n      return value - studentQ * error / Math.sqrt(data.y.length);\n    };\n\n    return {\n      inverted: inv,\n      invertedTop: invTop,\n      invertedBottom: invBottom,\n    };\n  }\n\n  return null;\n}\n\nexport function sigmoid(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  const C = params[2];\n  const D = params[3];\n  return (D + (A - D) / (1 + Math.pow(10, (x - C) * B)));\n}\n\nexport function linear(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  return A * x + B;\n}\n\nexport function logLinear(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  return A * Math.log(x + 1) + B;\n}\n\nexport function exponential(params: Float32Array, x: number): number {\n  const A = params[0];\n  const B = params[1];\n  return A * Math.exp(x * B);\n}\n\nexport function fourPLRegression(params: Float32Array, x: number): number {\n  const A = params[0]; // max\n  const B = params[1]; // hill\n  const C = params[2]; // IC50 / inflection point\n  const D = params[3]; // min\n  return D + (A - D) / (1 + Math.pow(x / C, B));\n}\n\nexport function fourPLDoseResponse(params: Float32Array, x: number): number {\n  const min = params[3];\n  const max = params[0];\n  const hill = params[1];\n  const ic50 = params[2];\n  // be ware, IC50 that comes here is already log10 transformed\n  return min + (max - min) / (1 + Math.pow(10, hill * (ic50 - x)));\n}\n\nexport function getAuc(fittedCurve: (x: number) => number, data: {x: number[], y: number[]}): number {\n  let auc = 0;\n  const min = Math.min(...data.x);\n  const max = Math.max(...data.x);\n  const integrationStep = (max - min) / 1000;\n  for (let x = min; x < max; x+= integrationStep)\n    auc += integrationStep * fittedCurve(x);\n\n  return auc;\n}\n\nexport function getDetCoeff(fittedCurve: (x: number) => number, data: {x: number[], y: number[]}): number {\n  let ssRes = 0;\n  let ssTot = 0;\n  const yMean = jStat.mean(data.y);\n  for (let i = 0; i < data.x.length; i++) {\n    ssRes += Math.pow(data.y[i] - fittedCurve(data.x[i]), 2);\n    ssTot += Math.pow(data.y[i] - yMean, 2);\n  }\n\n  return 1 - ssRes / ssTot;\n}\n\nfunction getInvError(targetFunc: (y: number) => number, data: {y: number[], x: number[]}): number {\n  let sigma = 0;\n  let sigmaSq = 0;\n  const residuesSquares = new Float32Array(data.y.length);\n  for (let i = 0; i < data.y.length; i++) {\n    const obs = data.x[i];\n    const pred = targetFunc(data.y[i]);\n    residuesSquares[i] = Math.pow(obs - pred, 2);\n  }\n\n  for (let i = 0; i < residuesSquares.length; i++)\n    sigmaSq += residuesSquares[i];\n\n  sigmaSq /= residuesSquares.length;\n  sigma = Math.sqrt(sigmaSq);\n\n  return sigma;\n}\n"]}