@datagrok-libraries/statistics 1.1.8 → 1.2.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.
- package/.eslintrc.json +6 -1
- package/package.json +4 -4
- package/src/box-plot-statistics.d.ts +9 -0
- package/src/box-plot-statistics.d.ts.map +1 -0
- package/src/box-plot-statistics.js +57 -0
- package/src/correlation-coefficient.d.ts +1 -1
- package/src/correlation-coefficient.d.ts.map +1 -1
- package/src/correlation-coefficient.js +1 -2
- package/src/fit/fit-curve.d.ts +207 -0
- package/src/fit/fit-curve.d.ts.map +1 -0
- package/src/fit/fit-curve.js +417 -0
- package/src/fit/fit-data.d.ts +24 -0
- package/src/fit/fit-data.d.ts.map +1 -0
- package/src/fit/fit-data.js +86 -0
- package/src/parameter-estimation/fit-curve.d.ts +0 -56
- package/src/parameter-estimation/fit-curve.d.ts.map +0 -1
- package/src/parameter-estimation/fit-curve.js +0 -263
|
@@ -0,0 +1,417 @@
|
|
|
1
|
+
/* eslint-disable no-multi-spaces */
|
|
2
|
+
import * as DG from 'datagrok-api/dg';
|
|
3
|
+
import { Property } from 'datagrok-api/src/entities';
|
|
4
|
+
import { TYPE } from 'datagrok-api/src/const';
|
|
5
|
+
import { limitedMemoryBFGS } from '../../lbfgs/lbfgs';
|
|
6
|
+
//@ts-ignore: no types
|
|
7
|
+
import * as jStat from 'jstat';
|
|
8
|
+
export var FitErrorModel;
|
|
9
|
+
(function (FitErrorModel) {
|
|
10
|
+
FitErrorModel[FitErrorModel["Constant"] = 0] = "Constant";
|
|
11
|
+
FitErrorModel[FitErrorModel["Proportional"] = 1] = "Proportional";
|
|
12
|
+
})(FitErrorModel || (FitErrorModel = {}));
|
|
13
|
+
/**
|
|
14
|
+
* Datagrok curve fitting
|
|
15
|
+
*
|
|
16
|
+
* - Fitting: computing parameters of the specified function to best fit the data
|
|
17
|
+
* - Uses BFGS optimization algorithm (multi-threading for performance).
|
|
18
|
+
* For dose-response curves, we are typically fitting the sigmoid function
|
|
19
|
+
* - Ability to dynamically register custom fitting functions
|
|
20
|
+
* - Automatic fit function determination
|
|
21
|
+
* - Caching of custom fitting functions
|
|
22
|
+
* - Ability to get fitting performance characteristics (r-squared, classification, etc)
|
|
23
|
+
* - Deep integration with the Datagrok grid
|
|
24
|
+
* - Either fitting on the fly, or using the supplied function + parameters
|
|
25
|
+
* - Multiple series in one cell
|
|
26
|
+
* - Confidence intervals drawing
|
|
27
|
+
* - Ability to define chart, marker, or fitting options (such as fit function or marker color)
|
|
28
|
+
* on the column level, with the ability to override it on a grid cell or point level
|
|
29
|
+
* - Clicking a point in a chart within a grid makes it an outlier -> curve is re-fitted on the fly
|
|
30
|
+
* - Ability to specify a chart as "reference" so that it is shown on every other chart for comparison
|
|
31
|
+
* - Ability to overlay curves from multiple grid cells (special viewer)
|
|
32
|
+
* - Work with series stored in multiple formats (binary for performance, json for flexibility, etc)
|
|
33
|
+
*/
|
|
34
|
+
export const FIT_SEM_TYPE = 'fit';
|
|
35
|
+
export const FIT_CELL_TYPE = 'fit';
|
|
36
|
+
export const TAG_FIT = '.fit';
|
|
37
|
+
export const CONFIDENCE_INTERVAL_STROKE_COLOR = 'rgba(255,191,63,0.4)';
|
|
38
|
+
export const CONFIDENCE_INTERVAL_FILL_COLOR = 'rgba(255,238,204,0.3)';
|
|
39
|
+
export const CURVE_CONFIDENCE_INTERVAL_BOUNDS = {
|
|
40
|
+
TOP: 'top',
|
|
41
|
+
BOTTOM: 'bottom',
|
|
42
|
+
};
|
|
43
|
+
/** Class that implements {@link IFitChartData} interface */
|
|
44
|
+
export class FitChartData {
|
|
45
|
+
constructor() {
|
|
46
|
+
this.chartOptions = {};
|
|
47
|
+
this.seriesOptions = {}; // Default series options. Individual series can override it.
|
|
48
|
+
this.series = [];
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// TODO: show labels in property panel if present, color by default from series
|
|
52
|
+
/** Properties that describe {@link FitStatistics}. Useful for editing, initialization, transformations, etc. */
|
|
53
|
+
export const statisticsProperties = [
|
|
54
|
+
Property.js('rSquared', TYPE.FLOAT, { userEditable: false }),
|
|
55
|
+
Property.js('auc', TYPE.FLOAT, { userEditable: false }),
|
|
56
|
+
Property.js('interceptY', TYPE.FLOAT, { userEditable: false }),
|
|
57
|
+
Property.js('interceptX', TYPE.FLOAT, { userEditable: false }),
|
|
58
|
+
Property.js('slope', TYPE.FLOAT, { userEditable: false }),
|
|
59
|
+
Property.js('top', TYPE.FLOAT, { userEditable: false }),
|
|
60
|
+
Property.js('bottom', TYPE.FLOAT, { userEditable: false }),
|
|
61
|
+
];
|
|
62
|
+
/** Properties that describe {@link IFitChartOptions}. Useful for editing, initialization, transformations, etc. */
|
|
63
|
+
export const fitChartDataProperties = [
|
|
64
|
+
// Style and zoom
|
|
65
|
+
Property.js('minX', TYPE.FLOAT, { description: 'Minimum value of the X axis', nullable: true }),
|
|
66
|
+
Property.js('minY', TYPE.FLOAT, { description: 'Minimum value of the Y axis', nullable: true }),
|
|
67
|
+
Property.js('maxX', TYPE.FLOAT, { description: 'Maximum value of the X axis', nullable: true }),
|
|
68
|
+
Property.js('maxY', TYPE.FLOAT, { description: 'Maximum value of the Y axis', nullable: true }),
|
|
69
|
+
Property.js('xAxisName', TYPE.STRING, { description: 'Label to show on the X axis. If not specified, corresponding data column name is used', nullable: true }),
|
|
70
|
+
Property.js('yAxisName', TYPE.STRING, { description: 'Label to show on the Y axis. If not specified, corresponding data column name is used', nullable: true }),
|
|
71
|
+
Property.js('logX', TYPE.BOOL, { defaultValue: false }),
|
|
72
|
+
Property.js('logY', TYPE.BOOL, { defaultValue: false }),
|
|
73
|
+
Property.js('showStatistics', TYPE.STRING_LIST, { choices: statisticsProperties.map((frp) => frp.name),
|
|
74
|
+
inputType: 'MultiChoice' }),
|
|
75
|
+
];
|
|
76
|
+
/** Properties that describe {@link IFitSeriesOptions}. Useful for editing, initialization, transformations, etc. */
|
|
77
|
+
export const fitSeriesProperties = [
|
|
78
|
+
Property.js('name', TYPE.STRING),
|
|
79
|
+
Property.js('fitFunction', TYPE.STRING, { category: 'Fitting', choices: ['sigmoid', 'linear'], defaultValue: 'sigmoid' }),
|
|
80
|
+
Property.js('pointColor', TYPE.STRING, { category: 'Rendering', defaultValue: DG.Color.toHtml(DG.Color.scatterPlotMarker), nullable: true,
|
|
81
|
+
inputType: 'Color' }),
|
|
82
|
+
Property.js('fitLineColor', TYPE.STRING, { category: 'Rendering', defaultValue: DG.Color.toHtml(DG.Color.scatterPlotMarker), nullable: true,
|
|
83
|
+
inputType: 'Color' }),
|
|
84
|
+
Property.js('clickToToggle', TYPE.BOOL, { category: 'Fitting', description: 'If true, clicking on the point toggles its outlier status and causes curve refitting', nullable: true, defaultValue: false }),
|
|
85
|
+
Property.js('autoFit', TYPE.BOOL, { category: 'Fitting', description: 'Perform fitting on-the-fly', defaultValue: true }),
|
|
86
|
+
Property.js('showFitLine', TYPE.BOOL, { category: 'Fitting', description: 'Whether the fit line should be rendered', defaultValue: true }),
|
|
87
|
+
Property.js('showPoints', TYPE.STRING, { category: 'Fitting', description: 'Whether points/candlesticks/none should be rendered',
|
|
88
|
+
defaultValue: 'points', choices: ['points', 'candlesticks', 'both'] }),
|
|
89
|
+
Property.js('markerType', TYPE.STRING, { category: 'Rendering', description: 'Marker type used when rendering',
|
|
90
|
+
defaultValue: 'circle', choices: ['asterisk', 'circle', 'cross border', 'diamond', 'square', 'star',
|
|
91
|
+
'triangle bottom', 'triangle left', 'triangle right', 'triangle top'], nullable: false }),
|
|
92
|
+
// Property.js('showBoxPlot', TYPE.BOOL,
|
|
93
|
+
// {category: 'Fitting', description: 'Whether candlesticks should be rendered', defaultValue: true}),
|
|
94
|
+
];
|
|
95
|
+
export const FIT_FUNCTION_SIGMOID = 'sigmoid';
|
|
96
|
+
export const FIT_FUNCTION_LINEAR = 'linear';
|
|
97
|
+
export const FIT_STATS_RSQUARED = 'rSquared';
|
|
98
|
+
export const FIT_STATS_AUC = 'auc';
|
|
99
|
+
// TODO?: add method to return parameters - get parameters from fit function
|
|
100
|
+
export class FitFunction {
|
|
101
|
+
}
|
|
102
|
+
export class LinearFunction extends FitFunction {
|
|
103
|
+
get name() {
|
|
104
|
+
return FIT_FUNCTION_LINEAR;
|
|
105
|
+
}
|
|
106
|
+
get parameterNames() {
|
|
107
|
+
return ['Slope', 'Intercept'];
|
|
108
|
+
}
|
|
109
|
+
y(params, x) {
|
|
110
|
+
throw new Error('Not implemented');
|
|
111
|
+
}
|
|
112
|
+
getInitialParameters(x, y) {
|
|
113
|
+
throw new Error('Not implemented');
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
export class SigmoidFunction extends FitFunction {
|
|
117
|
+
get name() {
|
|
118
|
+
return FIT_FUNCTION_SIGMOID;
|
|
119
|
+
}
|
|
120
|
+
get parameterNames() {
|
|
121
|
+
return ['Top', 'Bottom', 'Slope', 'IC50'];
|
|
122
|
+
}
|
|
123
|
+
y(params, x) {
|
|
124
|
+
return sigmoid(params, x);
|
|
125
|
+
}
|
|
126
|
+
getInitialParameters(x, y) {
|
|
127
|
+
const dataBounds = DG.Rect.fromXYArrays(x, y);
|
|
128
|
+
const medY = (dataBounds.bottom - dataBounds.top) / 2 + dataBounds.top;
|
|
129
|
+
let maxYInterval = dataBounds.bottom - dataBounds.top;
|
|
130
|
+
let nearestXIndex = 0;
|
|
131
|
+
for (let i = 0; i < x.length; i++) {
|
|
132
|
+
const currentInterval = Math.abs(y[i] - medY);
|
|
133
|
+
if (currentInterval < maxYInterval) {
|
|
134
|
+
maxYInterval = currentInterval;
|
|
135
|
+
nearestXIndex = i;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
const xAtMedY = x[nearestXIndex];
|
|
139
|
+
const slope = y[0] > y[y.length - 1] ? 1.2 : -1.2;
|
|
140
|
+
// params are: [max, tan, IC50, min]
|
|
141
|
+
return [dataBounds.bottom, slope, xAtMedY, dataBounds.top];
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
export class JsFunction extends FitFunction {
|
|
145
|
+
constructor(name, yFunc, getInitParamsFunc, parameterNames) {
|
|
146
|
+
super();
|
|
147
|
+
this._name = name;
|
|
148
|
+
this._parameterNames = parameterNames;
|
|
149
|
+
this.y = yFunc;
|
|
150
|
+
this.getInitialParameters = getInitParamsFunc;
|
|
151
|
+
}
|
|
152
|
+
get name() {
|
|
153
|
+
return this._name;
|
|
154
|
+
}
|
|
155
|
+
get parameterNames() {
|
|
156
|
+
return this._parameterNames;
|
|
157
|
+
}
|
|
158
|
+
y(params, x) {
|
|
159
|
+
throw new Error('Not implemented');
|
|
160
|
+
}
|
|
161
|
+
getInitialParameters(x, y) {
|
|
162
|
+
throw new Error('Not implemented');
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
export const fitFunctions = {
|
|
166
|
+
'linear': new LinearFunction(),
|
|
167
|
+
'sigmoid': new SigmoidFunction(),
|
|
168
|
+
};
|
|
169
|
+
function createObjectiveFunction(errorModel) {
|
|
170
|
+
let of;
|
|
171
|
+
switch (errorModel) {
|
|
172
|
+
case FitErrorModel.Constant:
|
|
173
|
+
of = objectiveNormalConstant;
|
|
174
|
+
break;
|
|
175
|
+
case FitErrorModel.Proportional:
|
|
176
|
+
of = objectiveNormalProportional;
|
|
177
|
+
break;
|
|
178
|
+
default:
|
|
179
|
+
of = objectiveNormalConstant;
|
|
180
|
+
break;
|
|
181
|
+
}
|
|
182
|
+
return of;
|
|
183
|
+
}
|
|
184
|
+
function createOptimizable(data, curveFunction, of, fixed) {
|
|
185
|
+
return {
|
|
186
|
+
getValue: (parameters) => {
|
|
187
|
+
return of(curveFunction, data, parameters).value;
|
|
188
|
+
},
|
|
189
|
+
getGradient: (parameters, gradient) => {
|
|
190
|
+
for (let i = 0; i < parameters.length; i++)
|
|
191
|
+
gradient[i] = fixed.includes(i) ? 0 : getObjectiveDerivative(of, curveFunction, data, parameters, i);
|
|
192
|
+
return gradient;
|
|
193
|
+
},
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
export function getOrCreateFitFunction(seriesFitFunc) {
|
|
197
|
+
if (typeof seriesFitFunc === 'string')
|
|
198
|
+
return fitFunctions[seriesFitFunc];
|
|
199
|
+
else if (!fitFunctions[seriesFitFunc.name]) {
|
|
200
|
+
const name = seriesFitFunc.name;
|
|
201
|
+
const paramNames = seriesFitFunc.parameterNames;
|
|
202
|
+
const fitFunctionParts = seriesFitFunc.function.split('=>').map((elem) => elem.trim());
|
|
203
|
+
const getInitParamsParts = seriesFitFunc.getInitialParameters.split('=>').map((elem) => elem.trim());
|
|
204
|
+
const fitFunction = new Function(fitFunctionParts[0].slice(1, fitFunctionParts[0].length - 1), `${fitFunctionParts[1].includes(';') ? '' : 'return '}${fitFunctionParts[1]}`);
|
|
205
|
+
const getInitParamsFunc = new Function(getInitParamsParts[0].slice(1, getInitParamsParts[0].length - 1), `return ${getInitParamsParts[1]}`);
|
|
206
|
+
const fitFunc = new JsFunction(name, fitFunction, getInitParamsFunc, paramNames);
|
|
207
|
+
fitFunctions[name] = fitFunc;
|
|
208
|
+
}
|
|
209
|
+
return fitFunctions[seriesFitFunc.name];
|
|
210
|
+
}
|
|
211
|
+
export function fitData(data, fitFunction, errorModel, parameterBounds) {
|
|
212
|
+
var _a, _b;
|
|
213
|
+
const curveFunction = fitFunction.y;
|
|
214
|
+
const paramValues = fitFunction.getInitialParameters(data.x, data.y);
|
|
215
|
+
const of = createObjectiveFunction(errorModel);
|
|
216
|
+
const fixed = [];
|
|
217
|
+
let overLimits = true;
|
|
218
|
+
while (overLimits) {
|
|
219
|
+
const optimizable = createOptimizable(data, curveFunction, of, fixed);
|
|
220
|
+
limitedMemoryBFGS(optimizable, paramValues);
|
|
221
|
+
limitedMemoryBFGS(optimizable, paramValues);
|
|
222
|
+
overLimits = false;
|
|
223
|
+
if (!parameterBounds)
|
|
224
|
+
break;
|
|
225
|
+
for (let i = 0; i < parameterBounds.length; i++) {
|
|
226
|
+
if (((_a = parameterBounds[i]) === null || _a === void 0 ? void 0 : _a.maxBound) !== undefined && paramValues[i] > parameterBounds[i].maxBound) {
|
|
227
|
+
overLimits = true;
|
|
228
|
+
fixed.push(i);
|
|
229
|
+
paramValues[i] = parameterBounds[i].maxBound;
|
|
230
|
+
break;
|
|
231
|
+
}
|
|
232
|
+
if (((_b = parameterBounds[i]) === null || _b === void 0 ? void 0 : _b.minBound) !== undefined && paramValues[i] < parameterBounds[i].minBound) {
|
|
233
|
+
overLimits = true;
|
|
234
|
+
fixed.push(i);
|
|
235
|
+
paramValues[i] = parameterBounds[i].minBound;
|
|
236
|
+
break;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
const fittedCurve = getFittedCurve(curveFunction, paramValues);
|
|
241
|
+
return {
|
|
242
|
+
fittedCurve: fittedCurve,
|
|
243
|
+
parameters: paramValues,
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
export function getFittedCurve(curveFunction, paramValues) {
|
|
247
|
+
return (x) => {
|
|
248
|
+
return curveFunction(paramValues, x);
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
export function getCurveConfidenceIntervals(data, paramValues, curveFunction, confidenceLevel = 0.05, errorModel) {
|
|
252
|
+
const of = createObjectiveFunction(errorModel);
|
|
253
|
+
const error = errorModel === FitErrorModel.Proportional ?
|
|
254
|
+
of(curveFunction, data, paramValues).mult :
|
|
255
|
+
of(curveFunction, data, paramValues).const;
|
|
256
|
+
const quantile = jStat.normal.inv(1 - confidenceLevel / 2, 0, 1);
|
|
257
|
+
const top = (x) => {
|
|
258
|
+
const value = curveFunction(paramValues, x);
|
|
259
|
+
if (errorModel === FitErrorModel.Constant)
|
|
260
|
+
return value + quantile * error;
|
|
261
|
+
else
|
|
262
|
+
return value + quantile * Math.abs(value) * error;
|
|
263
|
+
};
|
|
264
|
+
const bottom = (x) => {
|
|
265
|
+
const value = curveFunction(paramValues, x);
|
|
266
|
+
if (errorModel === FitErrorModel.Constant)
|
|
267
|
+
return value - quantile * error;
|
|
268
|
+
else
|
|
269
|
+
return value - quantile * Math.abs(value) * error;
|
|
270
|
+
};
|
|
271
|
+
return { confidenceTop: top, confidenceBottom: bottom };
|
|
272
|
+
}
|
|
273
|
+
export function getStatistics(data, paramValues, curveFunction, statistics = true) {
|
|
274
|
+
const fittedCurve = getFittedCurve(curveFunction, paramValues);
|
|
275
|
+
return {
|
|
276
|
+
rSquared: statistics ? getDetCoeff(fittedCurve, data) : undefined,
|
|
277
|
+
auc: statistics ? getAuc(fittedCurve, data) : undefined,
|
|
278
|
+
interceptX: paramValues[2],
|
|
279
|
+
interceptY: fittedCurve(paramValues[2]),
|
|
280
|
+
slope: paramValues[1],
|
|
281
|
+
top: paramValues[0],
|
|
282
|
+
bottom: paramValues[3],
|
|
283
|
+
};
|
|
284
|
+
}
|
|
285
|
+
export function getInvertedFunctions(data, paramValues, confidenceLevel = 0.05, statistics = true) {
|
|
286
|
+
const studentQ = jStat.studentt.inv(1 - confidenceLevel / 2, data.x.length - paramValues.length);
|
|
287
|
+
let inv = (y) => {
|
|
288
|
+
return 0;
|
|
289
|
+
};
|
|
290
|
+
let invTop = (y) => {
|
|
291
|
+
return 0;
|
|
292
|
+
};
|
|
293
|
+
let invBottom = (y) => {
|
|
294
|
+
return 0;
|
|
295
|
+
};
|
|
296
|
+
if (statistics) {
|
|
297
|
+
inv = (y) => {
|
|
298
|
+
//should check if more than bottom and less than top
|
|
299
|
+
return paramValues[2] / Math.pow((paramValues[0] - y) / (y - paramValues[3]), 1 / paramValues[1]);
|
|
300
|
+
};
|
|
301
|
+
const error = getInvError(inv, data);
|
|
302
|
+
invTop = (y) => {
|
|
303
|
+
const value = inv(y);
|
|
304
|
+
return value + studentQ * error / Math.sqrt(data.y.length);
|
|
305
|
+
};
|
|
306
|
+
invBottom = (y) => {
|
|
307
|
+
const value = inv(y);
|
|
308
|
+
return value - studentQ * error / Math.sqrt(data.y.length);
|
|
309
|
+
};
|
|
310
|
+
return {
|
|
311
|
+
inverted: inv,
|
|
312
|
+
invertedTop: invTop,
|
|
313
|
+
invertedBottom: invBottom,
|
|
314
|
+
};
|
|
315
|
+
}
|
|
316
|
+
return null;
|
|
317
|
+
}
|
|
318
|
+
export function sigmoid(params, x) {
|
|
319
|
+
const A = params[0];
|
|
320
|
+
const B = params[1];
|
|
321
|
+
const C = params[2];
|
|
322
|
+
const D = params[3];
|
|
323
|
+
return (D + (A - D) / (1 + Math.pow(10, (x - C) * B)));
|
|
324
|
+
}
|
|
325
|
+
export function getAuc(fittedCurve, data) {
|
|
326
|
+
let auc = 0;
|
|
327
|
+
const min = Math.min(...data.x);
|
|
328
|
+
const max = Math.max(...data.x);
|
|
329
|
+
const integrationStep = (max - min) / 1000;
|
|
330
|
+
for (let x = min; x < max; x += integrationStep)
|
|
331
|
+
auc += integrationStep * fittedCurve(x);
|
|
332
|
+
return auc;
|
|
333
|
+
}
|
|
334
|
+
export function getDetCoeff(fittedCurve, data) {
|
|
335
|
+
let ssRes = 0;
|
|
336
|
+
let ssTot = 0;
|
|
337
|
+
const yMean = jStat.mean(data.y);
|
|
338
|
+
for (let i = 0; i < data.x.length; i++) {
|
|
339
|
+
ssRes += Math.pow(data.y[i] - fittedCurve(data.x[i]), 2);
|
|
340
|
+
ssTot += Math.pow(data.y[i] - yMean, 2);
|
|
341
|
+
}
|
|
342
|
+
return 1 - ssRes / ssTot;
|
|
343
|
+
}
|
|
344
|
+
function getInvError(targetFunc, data) {
|
|
345
|
+
let sigma = 0;
|
|
346
|
+
let sigmaSq = 0;
|
|
347
|
+
const residuesSquares = new Float32Array(data.y.length);
|
|
348
|
+
for (let i = 0; i < data.y.length; i++) {
|
|
349
|
+
const obs = data.x[i];
|
|
350
|
+
const pred = targetFunc(data.y[i]);
|
|
351
|
+
residuesSquares[i] = Math.pow(obs - pred, 2);
|
|
352
|
+
}
|
|
353
|
+
for (let i = 0; i < residuesSquares.length; i++)
|
|
354
|
+
sigmaSq += residuesSquares[i];
|
|
355
|
+
sigmaSq /= residuesSquares.length;
|
|
356
|
+
sigma = Math.sqrt(sigmaSq);
|
|
357
|
+
return sigma;
|
|
358
|
+
}
|
|
359
|
+
function getObjectiveDerivative(of, curveFunction, data, params, selectedParam) {
|
|
360
|
+
const step = (params[selectedParam] * 0.0001) === 0 ? 0.001 : (params[selectedParam] * 0.0001);
|
|
361
|
+
const paramsTop = [];
|
|
362
|
+
const paramsBottom = [];
|
|
363
|
+
for (let i = 0; i < params.length; i++) {
|
|
364
|
+
if (i === selectedParam) {
|
|
365
|
+
paramsTop.push(params[i] + step);
|
|
366
|
+
paramsBottom.push(params[i] - step);
|
|
367
|
+
}
|
|
368
|
+
else {
|
|
369
|
+
paramsTop.push(params[i]);
|
|
370
|
+
paramsBottom.push(params[i]);
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
const drvTop = of(curveFunction, data, paramsTop).value;
|
|
374
|
+
const drvBottom = of(curveFunction, data, paramsBottom).value;
|
|
375
|
+
return (drvTop - drvBottom) / (2 * step);
|
|
376
|
+
}
|
|
377
|
+
function objectiveNormalConstant(targetFunc, data, params) {
|
|
378
|
+
//assure observed and args same length
|
|
379
|
+
const pi = Math.PI;
|
|
380
|
+
let sigma = 0;
|
|
381
|
+
let sigmaSq = 0;
|
|
382
|
+
let likelihood = 0;
|
|
383
|
+
const residuesSquares = new Float32Array(data.x.length);
|
|
384
|
+
for (let i = 0; i < data.x.length; i++) {
|
|
385
|
+
const obs = data.y[i];
|
|
386
|
+
const pred = targetFunc(params, data.x[i]);
|
|
387
|
+
residuesSquares[i] = Math.pow(obs - pred, 2);
|
|
388
|
+
}
|
|
389
|
+
for (let i = 0; i < residuesSquares.length; i++)
|
|
390
|
+
sigmaSq += residuesSquares[i];
|
|
391
|
+
sigmaSq /= residuesSquares.length;
|
|
392
|
+
sigma = Math.sqrt(sigmaSq);
|
|
393
|
+
for (let i = 0; i < residuesSquares.length; i++)
|
|
394
|
+
likelihood += residuesSquares[i] / sigmaSq + Math.log(2 * pi * sigmaSq);
|
|
395
|
+
return { value: -likelihood, const: sigma, mult: 0 };
|
|
396
|
+
}
|
|
397
|
+
function objectiveNormalProportional(targetFunc, data, params) {
|
|
398
|
+
//assure observed and args same length
|
|
399
|
+
const pi = Math.PI;
|
|
400
|
+
let sigma = 0;
|
|
401
|
+
let sigmaSq = 0;
|
|
402
|
+
let likelihood = 0;
|
|
403
|
+
const residuesSquares = new Float32Array(data.x.length);
|
|
404
|
+
for (let i = 0; i < data.x.length; i++) {
|
|
405
|
+
const obs = data.y[i];
|
|
406
|
+
const pred = targetFunc(params, data.x[i]);
|
|
407
|
+
residuesSquares[i] = Math.pow(obs - pred, 2);
|
|
408
|
+
}
|
|
409
|
+
for (let i = 0; i < residuesSquares.length; i++)
|
|
410
|
+
sigmaSq += residuesSquares[i];
|
|
411
|
+
sigmaSq /= residuesSquares.length;
|
|
412
|
+
sigma = Math.sqrt(sigmaSq);
|
|
413
|
+
for (let i = 0; i < residuesSquares.length; i++)
|
|
414
|
+
likelihood += residuesSquares[i] / sigmaSq + Math.log(2 * pi * sigmaSq);
|
|
415
|
+
return { value: -likelihood, const: sigma, mult: 0 };
|
|
416
|
+
}
|
|
417
|
+
//# 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 no-multi-spaces */\nimport * as DG from 'datagrok-api/dg';\nimport {Property} from 'datagrok-api/src/entities';\nimport {TYPE} from 'datagrok-api/src/const';\n\nimport {limitedMemoryBFGS} from '../../lbfgs/lbfgs';\n//@ts-ignore: no types\nimport * as jStat from 'jstat';\n\n\ntype Optimizable = {\n  getValue: (parameters: number[]) => number,\n  getGradient: (parameters: number[], gradient: number[]) => number[],\n}\n\ntype Likelihood = {\n  value: number,\n  const: number,\n  mult: number\n};\n\ntype ObjectiveFunction = (targetFunc: (params: number[], x: number) => number,\n  data: {x: number[], y: number[]}, params: number[]) => Likelihood;\n\nexport enum FitErrorModel {\n  Constant,\n  Proportional\n}\n\nexport type FitParamBounds = {\n  minBound?: number;\n  maxBound?: number;\n};\n\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: number[];\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 *   - Confidence intervals 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 FIT_SEM_TYPE = 'fit';\nexport const FIT_CELL_TYPE = 'fit';\nexport const TAG_FIT = '.fit';\n\nexport const CONFIDENCE_INTERVAL_STROKE_COLOR = 'rgba(255,191,63,0.4)';\nexport const CONFIDENCE_INTERVAL_FILL_COLOR = 'rgba(255,238,204,0.3)';\n\nexport const CURVE_CONFIDENCE_INTERVAL_BOUNDS = {\n  TOP: 'top',\n  BOTTOM: 'bottom',\n};\n\nexport type FitMarkerType = 'asterisk' | 'circle' | 'cross border' | 'diamond' | 'square' | 'star' | 'triangle bottom' |\n  'triangle left' | 'triangle right' | 'triangle top';\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  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  marker?: FitMarkerType;  // overrides the marker type defined in IFitSeriesOptions\n  color?: string;          // overrides the marker color defined in IFitSeriesOptions\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\nexport interface IFitChartLabelOptions {\n  visible: boolean;\n  color: string;\n  name: string;\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  xAxisName?: string;\n  yAxisName?: string;\n\n  logX?: boolean;\n  logY?: boolean;\n\n  showStatistics?: string[];\n  labelOptions?: IFitChartLabelOptions[];\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  name?: string;\n  fitFunction?: string | IFitFunctionDescription;\n  parameters?: number[];         // auto-fitting when not defined\n  parameterBounds?: FitParamBounds[];\n  markerType?: FitMarkerType;\n  pointColor?: string;\n  fitLineColor?: string;\n  confidenceIntervalColor?: string;\n  showFitLine?: boolean;\n  showPoints?: string;\n  showCurveConfidenceInterval?: boolean;   // show ribbon\n  showIntercept?: boolean;\n  showBoxPlot?: boolean;      // if true, multiple values with the same X are rendered as a candlestick\n  showConfidenceForX?: number;\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\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: Property[] = [\n  Property.js('rSquared', TYPE.FLOAT, {userEditable: false}),\n  Property.js('auc', TYPE.FLOAT, {userEditable: false}),\n  Property.js('interceptY', TYPE.FLOAT, {userEditable: false}),\n  Property.js('interceptX', TYPE.FLOAT, {userEditable: false}),\n  Property.js('slope', TYPE.FLOAT, {userEditable: false}),\n  Property.js('top', TYPE.FLOAT, {userEditable: false}),\n  Property.js('bottom', TYPE.FLOAT, {userEditable: false}),\n];\n\n/** Properties that describe {@link IFitChartOptions}. Useful for editing, initialization, transformations, etc. */\nexport const fitChartDataProperties: Property[] = [\n  // Style and zoom\n  Property.js('minX', TYPE.FLOAT, {description: 'Minimum value of the X axis', nullable: true}),\n  Property.js('minY', TYPE.FLOAT, {description: 'Minimum value of the Y axis', nullable: true}),\n  Property.js('maxX', TYPE.FLOAT, {description: 'Maximum value of the X axis', nullable: true}),\n  Property.js('maxY', TYPE.FLOAT, {description: 'Maximum value of the Y axis', nullable: true}),\n  Property.js('xAxisName', TYPE.STRING, {description:\n    'Label to show on the X axis. If not specified, corresponding data column name is used', nullable: true}),\n  Property.js('yAxisName', TYPE.STRING, {description:\n    'Label to show on the Y axis. If not specified, corresponding data column name is used', nullable: true}),\n  Property.js('logX', TYPE.BOOL, {defaultValue: false}),\n  Property.js('logY', TYPE.BOOL, {defaultValue: false}),\n  Property.js('showStatistics', TYPE.STRING_LIST, {choices: statisticsProperties.map((frp) => frp.name),\n    inputType: 'MultiChoice'}),\n];\n\n/** Properties that describe {@link IFitSeriesOptions}. Useful for editing, initialization, transformations, etc. */\nexport const fitSeriesProperties: Property[] = [\n  Property.js('name', TYPE.STRING),\n  Property.js('fitFunction', TYPE.STRING,\n    {category: 'Fitting', choices: ['sigmoid', 'linear'], defaultValue: 'sigmoid'}),\n  Property.js('pointColor', TYPE.STRING,\n    {category: 'Rendering', defaultValue: DG.Color.toHtml(DG.Color.scatterPlotMarker), nullable: true,\n      inputType: 'Color'}),\n  Property.js('fitLineColor', TYPE.STRING,\n    {category: 'Rendering', defaultValue: DG.Color.toHtml(DG.Color.scatterPlotMarker), nullable: true,\n      inputType: 'Color'}),\n  Property.js('clickToToggle', TYPE.BOOL, {category: 'Fitting', description:\n    'If true, clicking on the point toggles its outlier status and causes curve refitting', nullable: true, defaultValue: false}),\n  Property.js('autoFit', TYPE.BOOL,\n    {category: 'Fitting', description: 'Perform fitting on-the-fly', defaultValue: true}),\n  Property.js('showFitLine', TYPE.BOOL,\n    {category: 'Fitting', description: 'Whether the fit line should be rendered', defaultValue: true}),\n  Property.js('showPoints', TYPE.STRING,\n    {category: 'Fitting', description: 'Whether points/candlesticks/none should be rendered',\n      defaultValue: 'points', choices: ['points', 'candlesticks', 'both']}),\n  Property.js('markerType', TYPE.STRING, {category: 'Rendering', description: 'Marker type used when rendering',\n    defaultValue: 'circle', choices: ['asterisk', 'circle', 'cross border', 'diamond', 'square', 'star',\n      'triangle bottom', 'triangle left', 'triangle right', 'triangle top'], nullable: false}),\n  // Property.js('showBoxPlot', TYPE.BOOL,\n  //   {category: 'Fitting', description: 'Whether candlesticks should be rendered', defaultValue: true}),\n];\n\nexport const FIT_FUNCTION_SIGMOID = 'sigmoid';\nexport const FIT_FUNCTION_LINEAR = 'linear';\n\nexport const FIT_STATS_RSQUARED = 'rSquared';\nexport const FIT_STATS_AUC = 'auc';\n\n\n// TODO?: add method to return parameters - get parameters from fit function\nexport abstract class FitFunction {\n  abstract get name(): string;\n  abstract get parameterNames(): string[];\n  abstract y(params: number[], x: number): number;\n  abstract getInitialParameters(x: number[], y: number[]): number[];\n}\n\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: number[], x: number): number {\n    throw new Error('Not implemented');\n  }\n\n  getInitialParameters(x: number[], y: number[]): number[] {\n    throw new Error('Not implemented');\n  }\n}\n\nexport class SigmoidFunction extends FitFunction {\n  get name(): string {\n    return FIT_FUNCTION_SIGMOID;\n  }\n\n  get parameterNames(): string[] {\n    return ['Top', 'Bottom', 'Slope', 'IC50'];\n  }\n\n  y(params: number[], x: number): number {\n    return sigmoid(params, x);\n  }\n\n  getInitialParameters(x: number[], y: number[]): number[] {\n    const dataBounds = DG.Rect.fromXYArrays(x, y);\n    const medY = (dataBounds.bottom - dataBounds.top) / 2 + dataBounds.top;\n    let maxYInterval = dataBounds.bottom - dataBounds.top;\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.2 : -1.2;\n\n    // params are: [max, tan, IC50, min]\n    return [dataBounds.bottom, slope, xAtMedY, dataBounds.top];\n  }\n}\n\nexport class JsFunction extends FitFunction {\n  private _name: string;\n  private _parameterNames: string[];\n\n  constructor(name: string, yFunc: (params: number[], x: number) => number,\n    getInitParamsFunc: (x: number[], y: number[]) => number[], 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: number[], x: number): number {\n    throw new Error('Not implemented');\n  }\n\n  getInitialParameters(x: number[], y: number[]): number[] {\n    throw new Error('Not implemented');\n  }\n}\n\nexport const fitFunctions: {[index: string]: FitFunction} = {\n  'linear': new LinearFunction(),\n  'sigmoid': new SigmoidFunction(),\n};\n\nexport interface IFitOptions {\n  errorModel: FitErrorModel;\n  confidenceLevel: number;\n  statistics: boolean;\n}\n\n\nfunction createObjectiveFunction(errorModel: FitErrorModel): ObjectiveFunction {\n  let of: ObjectiveFunction;\n\n  switch (errorModel) {\n  case FitErrorModel.Constant:\n    of = objectiveNormalConstant;\n    break;\n  case FitErrorModel.Proportional:\n    of = objectiveNormalProportional;\n    break;\n  default:\n    of = objectiveNormalConstant;\n    break;\n  }\n\n  return of;\n}\n\nfunction createOptimizable(data: {x: number[], y: number[]}, curveFunction: (params: number[], x: number) => number,\n  of: ObjectiveFunction, fixed: number[]): Optimizable {\n  return {\n    getValue: (parameters: number[]) => {\n      return of(curveFunction, data, parameters).value;\n    },\n    getGradient: (parameters: number[], gradient: number[]) => {\n      for (let i = 0; i < parameters.length; i++)\n        gradient[i] = fixed.includes(i) ? 0 : getObjectiveDerivative(of, curveFunction, data, parameters, i);\n\n      return gradient;\n    },\n  };\n}\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: number[], x: number) => number),\n      (getInitParamsFunc as (x: number[], y: number[]) => number[]), 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: FitErrorModel,\n  parameterBounds?: FitParamBounds[]): FitCurve {\n  const curveFunction = fitFunction.y;\n  const paramValues = fitFunction.getInitialParameters(data.x, data.y);\n\n  const of = createObjectiveFunction(errorModel);\n  const fixed: number[] = [];\n  let overLimits = true;\n\n  while (overLimits) {\n    const optimizable = createOptimizable(data, curveFunction, of, fixed);\n    limitedMemoryBFGS(optimizable, paramValues);\n    limitedMemoryBFGS(optimizable, paramValues);\n\n    overLimits = false;\n    if (!parameterBounds)\n      break;\n\n    for (let i = 0; i < parameterBounds.length; i++) {\n      if (parameterBounds[i]?.maxBound !== undefined && paramValues[i] > parameterBounds[i].maxBound!) {\n        overLimits = true;\n        fixed.push(i);\n        paramValues[i] = parameterBounds[i].maxBound!;\n        break;\n      }\n      if (parameterBounds[i]?.minBound !== undefined && paramValues[i] < parameterBounds[i].minBound!) {\n        overLimits = true;\n        fixed.push(i);\n        paramValues[i] = parameterBounds[i].minBound!;\n        break;\n      }\n    }\n  }\n\n  const fittedCurve = getFittedCurve(curveFunction, paramValues);\n\n  return {\n    fittedCurve: fittedCurve,\n    parameters: paramValues,\n  };\n}\n\nexport function getFittedCurve(curveFunction: (params: number[], x: number) => number, paramValues: number[]):\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: number[],\n  curveFunction: (params: number[], x: number) => number, confidenceLevel: number = 0.05, errorModel: FitErrorModel):\n  FitConfidenceIntervals {\n  const of = createObjectiveFunction(errorModel);\n\n  const error = errorModel === FitErrorModel.Proportional ?\n    of(curveFunction, data, paramValues).mult :\n    of(curveFunction, data, paramValues).const;\n\n  const quantile = jStat.normal.inv(1 - confidenceLevel/2, 0, 1);\n\n  const top = (x: number) =>{\n    const value = curveFunction(paramValues, x);\n    if (errorModel === FitErrorModel.Constant)\n      return value + quantile * error;\n    else\n      return value + quantile * Math.abs(value) * error;\n  };\n\n  const bottom = (x: number) => {\n    const value = curveFunction(paramValues, x);\n    if (errorModel === FitErrorModel.Constant)\n      return value - quantile * error;\n    else\n      return value - quantile * Math.abs(value) * error;\n  };\n\n  return {confidenceTop: top, confidenceBottom: bottom};\n}\n\nexport function getStatistics(data: {x: number[], y: number[]}, paramValues: number[],\n  curveFunction: (params: number[], 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: number[], 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 getAuc(fittedCurve: (x: number) => number, data: {x: number[], y: number[]}): number {\n  let auc = 0;\n\n  const min = Math.min(...data.x);\n  const max = Math.max(...data.x);\n  const integrationStep = (max - min) / 1000;\n\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\n  const yMean = jStat.mean(data.y);\n\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\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 getObjectiveDerivative(of: ObjectiveFunction, curveFunction: (params: number[], x: number) => number,\n  data: {x: number[], y: number[]}, params: number[], selectedParam: number): number {\n  const step = (params[selectedParam] * 0.0001) === 0 ? 0.001 : (params[selectedParam] * 0.0001);\n  const paramsTop: number[] = [];\n  const paramsBottom: number[] = [];\n  for (let i = 0; i < params.length; i++) {\n    if (i === selectedParam) {\n      paramsTop.push(params[i] + step);\n      paramsBottom.push(params[i] - step);\n    } else {\n      paramsTop.push(params[i]);\n      paramsBottom.push(params[i]);\n    }\n  }\n  const drvTop = of(curveFunction, data, paramsTop).value;\n  const drvBottom = of(curveFunction, data, paramsBottom).value;\n\n  return (drvTop - drvBottom) / (2 * step);\n}\n\nfunction objectiveNormalConstant(targetFunc: (params: number[], x: number) => number,\n  data: {y: number[], x: number[]}, params: number[]): Likelihood {\n  //assure observed and args same length\n  const pi = Math.PI;\n  let sigma = 0;\n  let sigmaSq = 0;\n  let likelihood = 0;\n\n  const residuesSquares = new Float32Array(data.x.length);\n  for (let i = 0; i < data.x.length; i++) {\n    const obs = data.y[i];\n    const pred = targetFunc(params, data.x[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  for (let i = 0; i < residuesSquares.length; i++)\n    likelihood += residuesSquares[i] / sigmaSq + Math.log(2 * pi * sigmaSq);\n\n  return {value: -likelihood, const: sigma, mult: 0};\n}\n\nfunction objectiveNormalProportional(targetFunc: (params: number[], x: number) => number,\n  data: {y: number[], x: number[]}, params: number[]): Likelihood {\n  //assure observed and args same length\n  const pi = Math.PI;\n  let sigma = 0;\n  let sigmaSq = 0;\n  let likelihood = 0;\n\n  const residuesSquares = new Float32Array(data.x.length);\n  for (let i = 0; i < data.x.length; i++) {\n    const obs = data.y[i];\n    const pred = targetFunc(params, data.x[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  for (let i = 0; i < residuesSquares.length; i++)\n    likelihood += residuesSquares[i] / sigmaSq + Math.log(2 * pi * sigmaSq);\n\n  return {value: -likelihood, const: sigma, mult: 0};\n}\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as DG from 'datagrok-api/dg';
|
|
2
|
+
import { FitFunction, FitStatistics, FitConfidenceIntervals, FitCurve, IFitPoint, IFitChartData, IFitSeries } from './fit-curve';
|
|
3
|
+
/** Creates default {@link IFitChartData} object */
|
|
4
|
+
export declare function createDefaultChartData(): IFitChartData;
|
|
5
|
+
/** Returns existing, or creates new column default chart options. */
|
|
6
|
+
export declare function getColumnChartOptions(gridColumn: DG.GridColumn): IFitChartData;
|
|
7
|
+
/** Returns points arrays from {@link IFitPoint} array */
|
|
8
|
+
export declare function getPointsArrays(points: IFitPoint[]): {
|
|
9
|
+
xs: number[];
|
|
10
|
+
ys: number[];
|
|
11
|
+
};
|
|
12
|
+
/** Returns the bounds of an {@link IFitChartData} object */
|
|
13
|
+
export declare function getChartBounds(chartData: IFitChartData): DG.Rect;
|
|
14
|
+
/** Returns series fit function */
|
|
15
|
+
export declare function getSeriesFitFunction(series: IFitSeries): FitFunction;
|
|
16
|
+
/** Returns a curve function, either using the pre-computed parameters or by fitting on-the-fly */
|
|
17
|
+
export declare function getCurve(series: IFitSeries, fitFunc: FitFunction): (x: number) => number;
|
|
18
|
+
/** Fits the series data according to the series fitting settings */
|
|
19
|
+
export declare function fitSeries(series: IFitSeries, fitFunc: FitFunction): FitCurve;
|
|
20
|
+
/** Returns series confidence interval functions */
|
|
21
|
+
export declare function getSeriesConfidenceInterval(series: IFitSeries, fitFunc: FitFunction, userParamsFlag: boolean): FitConfidenceIntervals;
|
|
22
|
+
/** Returns series statistics */
|
|
23
|
+
export declare function getSeriesStatistics(series: IFitSeries, fitFunc: FitFunction): FitStatistics;
|
|
24
|
+
//# sourceMappingURL=fit-data.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fit-data.d.ts","sourceRoot":"","sources":["fit-data.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAEtC,OAAO,EAKL,WAAW,EAEX,aAAa,EACb,sBAAsB,EACtB,QAAQ,EAER,SAAS,EACT,aAAa,EACb,UAAU,EAIX,MAAM,aAAa,CAAC;AAcrB,mDAAmD;AACnD,wBAAgB,sBAAsB,IAAI,aAAa,CAKtD;AAED,qEAAqE;AACrE,wBAAgB,qBAAqB,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,GAAG,aAAa,CAE9E;AAED,yDAAyD;AACzD,wBAAgB,eAAe,CAAC,MAAM,EAAE,SAAS,EAAE,GAAG;IAAC,EAAE,EAAE,MAAM,EAAE,CAAC;IAAC,EAAE,EAAE,MAAM,EAAE,CAAA;CAAC,CAQjF;AAED,4DAA4D;AAC5D,wBAAgB,cAAc,CAAC,SAAS,EAAE,aAAa,GAAG,EAAE,CAAC,IAAI,CAehE;AAED,kCAAkC;AAClC,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,UAAU,GAAG,WAAW,CAEpE;AAED,kGAAkG;AAClG,wBAAgB,QAAQ,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,GAAG,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,CAExF;AAED,oEAAoE;AACpE,wBAAgB,SAAS,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,GAAG,QAAQ,CAI5E;AAED,mDAAmD;AACnD,wBAAgB,2BAA2B,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,EAClF,cAAc,EAAE,OAAO,GAAG,sBAAsB,CAOjD;AAED,gCAAgC;AAChC,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,GAAG,aAAa,CAM3F"}
|