@datagrok-libraries/statistics 1.2.13 → 1.3.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.
Files changed (32) hide show
  1. package/.eslintrc.json +1 -0
  2. package/CHANGELOG.md +6 -0
  3. package/README.md +0 -1
  4. package/package.json +1 -1
  5. package/src/correlation-coefficient.d.ts.map +1 -1
  6. package/src/correlation-coefficient.js +1 -1
  7. package/src/fit/fit-curve.d.ts +32 -67
  8. package/src/fit/fit-curve.d.ts.map +1 -1
  9. package/src/fit/fit-curve.js +160 -190
  10. package/src/fit/fit-data.d.ts +0 -4
  11. package/src/fit/fit-data.d.ts.map +1 -1
  12. package/src/fit/fit-data.js +22 -22
  13. package/src/fit/fitting-algorithm/optimizer-misc.d.ts +19 -0
  14. package/src/fit/fitting-algorithm/optimizer-misc.d.ts.map +1 -0
  15. package/src/fit/fitting-algorithm/optimizer-misc.js +7 -0
  16. package/src/fit/fitting-algorithm/optimizer-nelder-mead.d.ts +25 -0
  17. package/src/fit/fitting-algorithm/optimizer-nelder-mead.d.ts.map +1 -0
  18. package/src/fit/fitting-algorithm/optimizer-nelder-mead.js +156 -0
  19. package/src/fit/fitting-algorithm/optimizer-sampler.d.ts +2 -0
  20. package/src/fit/fitting-algorithm/optimizer-sampler.d.ts.map +1 -0
  21. package/src/fit/fitting-algorithm/optimizer-sampler.js +28 -0
  22. package/src/fit/fitting-algorithm/optimizer.d.ts +4 -0
  23. package/src/fit/fitting-algorithm/optimizer.d.ts.map +1 -0
  24. package/src/fit/fitting-algorithm/optimizer.js +48 -0
  25. package/lbfgs/lbfgs.d.ts +0 -1
  26. package/lbfgs/lbfgs.js +0 -316
  27. package/src/optimization/opt-nelder-mead.d.ts +0 -5
  28. package/src/optimization/opt-nelder-mead.d.ts.map +0 -1
  29. package/src/optimization/opt-nelder-mead.js +0 -116
  30. package/src/optimization/optimizer.d.ts +0 -28
  31. package/src/optimization/optimizer.d.ts.map +0 -1
  32. package/src/optimization/optimizer.js +0 -63
@@ -1,28 +0,0 @@
1
- export declare const FitErrorModel: {
2
- CONSTANT: string;
3
- PROPORTIONAL: string;
4
- };
5
- export declare type Likelihood = {
6
- likelihood: number;
7
- likelihoodYs: number[];
8
- residualSquaresSums: number[];
9
- };
10
- export declare abstract class FitFunction {
11
- abstract solve(params: Float32Array, xs: Float32Array[]): NumericalSolution;
12
- }
13
- export declare abstract class Optimizer {
14
- abstract optimize(params: Float32Array, objectiveFunc: (params: Float32Array) => Likelihood): Likelihood;
15
- }
16
- export declare type NumericalSolution = {
17
- ys: Float32Array[];
18
- devereges: boolean;
19
- };
20
- export declare function getLikelihood(func: FitFunction, params: Float32Array, sigmaTypes: string[], sigmaValues: number[], data: {
21
- ys: Float32Array[];
22
- xs: Float32Array[];
23
- }): Likelihood;
24
- export declare function fit(func: FitFunction, params: Float32Array, sigmaTypes: string[], data: {
25
- ys: Float32Array[];
26
- xs: Float32Array[];
27
- }, optimizer: Optimizer): void;
28
- //# sourceMappingURL=optimizer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"optimizer.d.ts","sourceRoot":"","sources":["optimizer.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,aAAa;;;CAGzB,CAAC;AAEF,oBAAY,UAAU,GAAG;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,mBAAmB,EAAE,MAAM,EAAE,CAAA;CAC9B,CAAC;AAEF,8BAAsB,WAAW;IAG/B,QAAQ,CAAC,KAAK,CAAC,MAAM,EAAE,YAAY,EAAE,EAAE,EAAE,YAAY,EAAE,GAAG,iBAAiB;CAE5E;AAED,8BAAsB,SAAS;IAC7B,QAAQ,CAAC,QAAQ,CACf,MAAM,EAAE,YAAY,EACpB,aAAa,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,UAAU,GAClD,UAAU;CACd;AAED,oBAAY,iBAAiB,GAAG;IAC9B,EAAE,EAAE,YAAY,EAAG,CAAC;IACpB,SAAS,EAAE,OAAO,CAAA;CACnB,CAAA;AAiBD,wBAAgB,aAAa,CAC3B,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,EAAE,EACpF,IAAI,EAAE;IAAC,EAAE,EAAE,YAAY,EAAE,CAAC;IAAC,EAAE,EAAE,YAAY,EAAE,CAAA;CAAC,GAAG,UAAU,CAyB5D;AAED,wBAAgB,GAAG,CAAC,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,EAC/E,IAAI,EAAE;IAAC,EAAE,EAAE,YAAY,EAAE,CAAC;IAAC,EAAE,EAAE,YAAY,EAAE,CAAA;CAAC,EAAE,SAAS,EAAE,SAAS,QAmBrE"}
@@ -1,63 +0,0 @@
1
- const INFINITY = Number.MAX_VALUE;
2
- const PI = Math.PI;
3
- export const FitErrorModel = {
4
- CONSTANT: 'constant',
5
- PROPORTIONAL: 'proportional',
6
- };
7
- export class FitFunction {
8
- }
9
- export class Optimizer {
10
- }
11
- function getResiduals(observed, predicted) {
12
- const dimYtypes = predicted.length;
13
- const residuals = new Array(dimYtypes);
14
- for (let i = 0; i < dimYtypes; i++) {
15
- const dimY = predicted[i].length;
16
- residuals[i] = new Float32Array(dimY);
17
- for (let j = 0; j < dimY; j++)
18
- residuals[i][j] = observed[i][j] - predicted[i][j];
19
- }
20
- return residuals;
21
- }
22
- //sigma types number equal to data.ys.length, data.xs.length
23
- export function getLikelihood(func, params, sigmaTypes, sigmaValues, data) {
24
- const solution = func.solve(params, data.xs);
25
- if (solution.devereges)
26
- return { likelihood: INFINITY, likelihoodYs: [], residualSquaresSums: [] };
27
- const residuals = getResiduals(data.ys, solution.ys);
28
- const dimYtypes = data.ys.length;
29
- const residualSquaresSums = new Array(dimYtypes);
30
- const likelihoodYs = new Array(dimYtypes);
31
- let likelihood = 0;
32
- for (let i = 0; i < dimYtypes; i++) {
33
- const dimY = solution.ys[i].length;
34
- const sigmaSqare = sigmaValues[i] * sigmaValues[i];
35
- for (let j = 0; j < dimY; j++) {
36
- const square = residuals[i][j] * residuals[i][j];
37
- likelihoodYs[i] += square / sigmaSqare + Math.log(2 * PI * sigmaSqare);
38
- if (sigmaTypes[i] == FitErrorModel.PROPORTIONAL)
39
- residualSquaresSums[i] += square / (solution.ys[i][j] * solution.ys[i][j]);
40
- else
41
- residualSquaresSums[i] += square;
42
- }
43
- likelihood += likelihoodYs[i];
44
- }
45
- return { likelihood, likelihoodYs, residualSquaresSums };
46
- }
47
- export function fit(func, params, sigmaTypes, data, optimizer) {
48
- let convergenceIndicator = INFINITY / 2;
49
- let convergenceIndicatorOld = INFINITY;
50
- const dimYtypes = data.ys.length;
51
- const sigmaValues = new Array(dimYtypes).fill(1);
52
- const objectiveFunc = (params) => {
53
- return getLikelihood(func, params, sigmaTypes, sigmaValues, data);
54
- };
55
- while (Math.abs(convergenceIndicator - convergenceIndicatorOld) > 0.001) {
56
- const optimizedLikelihood = optimizer.optimize(params, objectiveFunc);
57
- for (let i = 0; i < dimYtypes; i++)
58
- sigmaValues[i] = Math.sqrt(optimizedLikelihood.residualSquaresSums[i] / data.ys[i].length);
59
- convergenceIndicatorOld = convergenceIndicator;
60
- convergenceIndicator = optimizedLikelihood.likelihood;
61
- }
62
- }
63
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"optimizer.js","sourceRoot":"","sources":["optimizer.ts"],"names":[],"mappings":"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","sourcesContent":["\nconst INFINITY = Number.MAX_VALUE;\nconst PI = Math.PI;\n\nexport const FitErrorModel = {\n  CONSTANT: 'constant',\n  PROPORTIONAL: 'proportional',\n};\n\nexport type Likelihood = {\n  likelihood: number,\n  likelihoodYs: number[],\n  residualSquaresSums: number[]\n};\n\nexport abstract class FitFunction {\n  // abstract get name(): string;\n  // abstract get parameterNames(): string[];\n  abstract solve(params: Float32Array, xs: Float32Array[]): NumericalSolution;\n  //abstract getInitialParameters(x: number[], y: number[]): number[];\n}\n\nexport abstract class Optimizer {\n  abstract optimize(\n    params: Float32Array,\n    objectiveFunc: (params: Float32Array) => Likelihood\n  ): Likelihood\n}\n\nexport type NumericalSolution = {\n  ys: Float32Array [],\n  devereges: boolean\n}\n\nfunction getResiduals(observed: Float32Array[], predicted: Float32Array[]): Float32Array[] {\n  const dimYtypes = predicted.length;\n  const residuals = new Array<Float32Array>(dimYtypes);\n\n  for (let i = 0; i < dimYtypes; i++) {\n    const dimY = predicted[i].length;\n    residuals[i] = new Float32Array(dimY);\n    for (let j = 0; j < dimY; j++)\n      residuals[i][j] = observed[i][j] - predicted[i][j];\n  }\n\n  return residuals;\n}\n\n//sigma types number equal to data.ys.length, data.xs.length\nexport function getLikelihood(\n  func: FitFunction, params: Float32Array, sigmaTypes: string[], sigmaValues: number[],\n  data: {ys: Float32Array[], xs: Float32Array[]}): Likelihood {\n  const solution = func.solve(params, data.xs);\n  if (solution.devereges)\n    return {likelihood: INFINITY, likelihoodYs: [], residualSquaresSums: []};\n\n  const residuals = getResiduals(data.ys, solution.ys);\n  const dimYtypes = data.ys.length;\n  const residualSquaresSums = new Array<number>(dimYtypes);\n  const likelihoodYs = new Array<number>(dimYtypes);\n  let likelihood = 0;\n  for (let i = 0; i < dimYtypes; i++) {\n    const dimY = solution.ys[i].length;\n    const sigmaSqare = sigmaValues[i]*sigmaValues[i];\n    for (let j = 0; j < dimY; j++) {\n      const square = residuals[i][j]*residuals[i][j];\n      likelihoodYs[i] += square/sigmaSqare + Math.log(2*PI*sigmaSqare);\n      if (sigmaTypes[i] == FitErrorModel.PROPORTIONAL)\n        residualSquaresSums[i] += square/(solution.ys[i][j]*solution.ys[i][j]);\n      else\n        residualSquaresSums[i] += square;\n    }\n    likelihood += likelihoodYs[i];\n  }\n\n  return {likelihood, likelihoodYs, residualSquaresSums};\n}\n\nexport function fit(func: FitFunction, params: Float32Array, sigmaTypes: string[],\n  data: {ys: Float32Array[], xs: Float32Array[]}, optimizer: Optimizer) {\n  let convergenceIndicator = INFINITY / 2;\n  let convergenceIndicatorOld = INFINITY;\n  const dimYtypes = data.ys.length;\n  const sigmaValues = new Array<number>(dimYtypes).fill(1);\n\n  const objectiveFunc = (params: Float32Array) => {\n    return getLikelihood(func, params, sigmaTypes, sigmaValues, data);\n  };\n\n  while (Math.abs(convergenceIndicator - convergenceIndicatorOld) > 0.001) {\n    const optimizedLikelihood = optimizer.optimize(params, objectiveFunc);\n\n    for (let i = 0; i < dimYtypes; i++)\n      sigmaValues[i] = Math.sqrt(optimizedLikelihood.residualSquaresSums[i]/data.ys[i].length);\n\n    convergenceIndicatorOld = convergenceIndicator;\n    convergenceIndicator = optimizedLikelihood.likelihood;\n  }\n}\n"]}