@datagrok-libraries/statistics 1.2.12 → 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.
- package/.eslintrc.json +1 -0
- package/CHANGELOG.md +21 -0
- package/README.md +0 -1
- package/package.json +1 -1
- package/src/correlation-coefficient.d.ts.map +1 -1
- package/src/correlation-coefficient.js +1 -1
- package/src/fit/fit-curve.d.ts +36 -67
- package/src/fit/fit-curve.d.ts.map +1 -1
- package/src/fit/fit-curve.js +160 -184
- package/src/fit/fit-data.d.ts +0 -4
- package/src/fit/fit-data.d.ts.map +1 -1
- package/src/fit/fit-data.js +22 -22
- package/src/fit/fitting-algorithm/optimizer-misc.d.ts +19 -0
- package/src/fit/fitting-algorithm/optimizer-misc.d.ts.map +1 -0
- package/src/fit/fitting-algorithm/optimizer-misc.js +7 -0
- package/src/fit/fitting-algorithm/optimizer-nelder-mead.d.ts +25 -0
- package/src/fit/fitting-algorithm/optimizer-nelder-mead.d.ts.map +1 -0
- package/src/fit/fitting-algorithm/optimizer-nelder-mead.js +156 -0
- package/src/fit/fitting-algorithm/optimizer-sampler.d.ts +2 -0
- package/src/fit/fitting-algorithm/optimizer-sampler.d.ts.map +1 -0
- package/src/fit/fitting-algorithm/optimizer-sampler.js +28 -0
- package/src/fit/fitting-algorithm/optimizer.d.ts +4 -0
- package/src/fit/fitting-algorithm/optimizer.d.ts.map +1 -0
- package/src/fit/fitting-algorithm/optimizer.js +48 -0
- package/lbfgs/lbfgs.d.ts +0 -1
- package/lbfgs/lbfgs.js +0 -316
package/src/fit/fit-data.d.ts
CHANGED
|
@@ -6,10 +6,6 @@ export declare type LogOptions = {
|
|
|
6
6
|
};
|
|
7
7
|
/** Creates default {@link IFitChartData} object */
|
|
8
8
|
export declare function createDefaultChartData(): IFitChartData;
|
|
9
|
-
/** Returns existing, or creates new dataframe default chart options. */
|
|
10
|
-
export declare function getDataFrameChartOptions(df: DG.DataFrame): IFitChartData;
|
|
11
|
-
/** Returns existing, or creates new column default chart options. */
|
|
12
|
-
export declare function getColumnChartOptions(column: DG.Column): IFitChartData;
|
|
13
9
|
/** Returns points arrays from {@link IFitPoint} array */
|
|
14
10
|
export declare function getPointsArrays(points: IFitPoint[]): {
|
|
15
11
|
xs: number[];
|
|
@@ -1 +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,
|
|
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,EAMX,MAAM,aAAa,CAAC;AAErB,oBAAY,UAAU,GAAG;IACvB,IAAI,EAAE,OAAO,GAAG,SAAS,CAAC;IAC1B,IAAI,EAAE,OAAO,GAAG,SAAS,CAAA;CAC1B,CAAC;AAcF,mDAAmD;AACnD,wBAAgB,sBAAsB,IAAI,aAAa,CAKtD;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;AAwED,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,CAIxF;AAED,oEAAoE;AACpE,wBAAgB,SAAS,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,QAAQ,CAOrG;AAED,mDAAmD;AACnD,wBAAgB,2BAA2B,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,EAClF,cAAc,EAAE,OAAO,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,sBAAsB,CAa1E;AAED,gCAAgC;AAChC,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,WAAW,EAAE,UAAU,CAAC,EAAE,UAAU,GAAG,aAAa,CAUpH"}
|
package/src/fit/fit-data.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* eslint-disable valid-jsdoc */
|
|
2
2
|
import * as DG from 'datagrok-api/dg';
|
|
3
|
-
import { FitErrorModel, fitData, getCurveConfidenceIntervals, getStatistics, getFittedCurve, getOrCreateFitFunction, fitSeriesProperties, fitChartDataProperties,
|
|
3
|
+
import { FitErrorModel, fitData, getCurveConfidenceIntervals, getStatistics, getFittedCurve, getOrCreateFitFunction, fitSeriesProperties, fitChartDataProperties, } from './fit-curve';
|
|
4
4
|
/** Creates new object with the default values specified in {@link properties} */
|
|
5
5
|
function createFromProperties(properties) {
|
|
6
6
|
const o = {};
|
|
@@ -18,18 +18,6 @@ export function createDefaultChartData() {
|
|
|
18
18
|
seriesOptions: createFromProperties(fitSeriesProperties),
|
|
19
19
|
};
|
|
20
20
|
}
|
|
21
|
-
/** Returns existing, or creates new dataframe default chart options. */
|
|
22
|
-
export function getDataFrameChartOptions(df) {
|
|
23
|
-
var _a;
|
|
24
|
-
var _b;
|
|
25
|
-
return JSON.parse((_a = (_b = df.tags)[TAG_FIT]) !== null && _a !== void 0 ? _a : (_b[TAG_FIT] = JSON.stringify(createDefaultChartData())));
|
|
26
|
-
}
|
|
27
|
-
/** Returns existing, or creates new column default chart options. */
|
|
28
|
-
export function getColumnChartOptions(column) {
|
|
29
|
-
var _a;
|
|
30
|
-
var _b;
|
|
31
|
-
return JSON.parse((_a = (_b = column.tags)[TAG_FIT]) !== null && _a !== void 0 ? _a : (_b[TAG_FIT] = JSON.stringify(createDefaultChartData())));
|
|
32
|
-
}
|
|
33
21
|
/** Returns points arrays from {@link IFitPoint} array */
|
|
34
22
|
export function getPointsArrays(points) {
|
|
35
23
|
const xs = [];
|
|
@@ -127,7 +115,10 @@ export function getSeriesFitFunction(series) {
|
|
|
127
115
|
}
|
|
128
116
|
/** Returns a curve function, either using the pre-computed parameters or by fitting on-the-fly */
|
|
129
117
|
export function getCurve(series, fitFunc) {
|
|
130
|
-
|
|
118
|
+
var _a;
|
|
119
|
+
const params = new Float32Array((_a = series.parameters) === null || _a === void 0 ? void 0 : _a.length);
|
|
120
|
+
params.set(series.parameters);
|
|
121
|
+
return getFittedCurve(fitFunc.y, params);
|
|
131
122
|
}
|
|
132
123
|
/** Fits the series data according to the series fitting settings */
|
|
133
124
|
export function fitSeries(series, fitFunc, logOptions) {
|
|
@@ -140,21 +131,30 @@ export function fitSeries(series, fitFunc, logOptions) {
|
|
|
140
131
|
}
|
|
141
132
|
/** Returns series confidence interval functions */
|
|
142
133
|
export function getSeriesConfidenceInterval(series, fitFunc, userParamsFlag, logOptions) {
|
|
143
|
-
var _a;
|
|
134
|
+
var _a, _b;
|
|
144
135
|
const data = userParamsFlag ? { x: series.points.map((p) => (logOptions === null || logOptions === void 0 ? void 0 : logOptions.logX) ? Math.log10(p.x) : p.x),
|
|
145
136
|
y: series.points.map((p) => (logOptions === null || logOptions === void 0 ? void 0 : logOptions.logY) ? Math.log10(p.y) : p.y) } :
|
|
146
137
|
{ x: series.points.filter((p) => !p.outlier).map((p) => (logOptions === null || logOptions === void 0 ? void 0 : logOptions.logX) ? Math.log10(p.x) : p.x),
|
|
147
138
|
y: series.points.filter((p) => !p.outlier).map((p) => (logOptions === null || logOptions === void 0 ? void 0 : logOptions.logY) ? Math.log10(p.y) : p.y) };
|
|
148
|
-
if (!series.parameters)
|
|
149
|
-
|
|
150
|
-
|
|
139
|
+
if (!series.parameters) {
|
|
140
|
+
const params = fitSeries(series, fitFunc).parameters;
|
|
141
|
+
series.parameters = [...params];
|
|
142
|
+
}
|
|
143
|
+
const params = new Float32Array((_a = series.parameters) === null || _a === void 0 ? void 0 : _a.length);
|
|
144
|
+
params.set(series.parameters);
|
|
145
|
+
return getCurveConfidenceIntervals(data, params, fitFunc.y, 0.05, (_b = series.errorModel) !== null && _b !== void 0 ? _b : FitErrorModel.CONSTANT);
|
|
151
146
|
}
|
|
152
147
|
/** Returns series statistics */
|
|
153
148
|
export function getSeriesStatistics(series, fitFunc, logOptions) {
|
|
149
|
+
var _a;
|
|
154
150
|
const data = { x: series.points.filter((p) => !p.outlier).map((p) => (logOptions === null || logOptions === void 0 ? void 0 : logOptions.logX) ? Math.log10(p.x) : p.x),
|
|
155
151
|
y: series.points.filter((p) => !p.outlier).map((p) => (logOptions === null || logOptions === void 0 ? void 0 : logOptions.logY) ? Math.log10(p.y) : p.y) };
|
|
156
|
-
if (!series.parameters)
|
|
157
|
-
|
|
158
|
-
|
|
152
|
+
if (!series.parameters) {
|
|
153
|
+
const params = fitSeries(series, fitFunc).parameters;
|
|
154
|
+
series.parameters = [...params];
|
|
155
|
+
}
|
|
156
|
+
const params = new Float32Array((_a = series.parameters) === null || _a === void 0 ? void 0 : _a.length);
|
|
157
|
+
params.set(series.parameters);
|
|
158
|
+
return getStatistics(data, params, fitFunc.y, true);
|
|
159
159
|
}
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fit-data.js","sourceRoot":"","sources":["fit-data.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable valid-jsdoc */\nimport * as DG from 'datagrok-api/dg';\n\nimport {\n  FitErrorModel,\n  fitData,\n  getCurveConfidenceIntervals,\n  getStatistics,\n  FitFunction,\n  getFittedCurve,\n  FitStatistics,\n  FitConfidenceIntervals,\n  FitCurve,\n  getOrCreateFitFunction,\n  IFitPoint,\n  IFitChartData,\n  IFitSeries,\n  fitSeriesProperties,\n  fitChartDataProperties,\n  TAG_FIT,\n  FitParamBounds,\n  IFitChartOptions,\n  FitErrorModelType,\n} from './fit-curve';\n\nexport type LogOptions = {\n  logX: boolean | undefined,\n  logY: boolean | undefined\n};\n\n\n/** Creates new object with the default values specified in {@link properties} */\nfunction createFromProperties(properties: DG.Property[]): any {\n  const o: any = {};\n  for (const p of properties) {\n    if (p.defaultValue !== null)\n      o[p.name] = p.defaultValue;\n  }\n  return o;\n}\n\n// TODO: set column with fit readonly value (in detectors) - try to only show chart - remove editable or prevent it??\n/** Creates default {@link IFitChartData} object */\nexport function createDefaultChartData(): IFitChartData {\n  return {\n    chartOptions: createFromProperties(fitChartDataProperties),\n    seriesOptions: createFromProperties(fitSeriesProperties),\n  };\n}\n\n/** Returns existing, or creates new dataframe default chart options. */\nexport function getDataFrameChartOptions(df: DG.DataFrame): IFitChartData {\n  return JSON.parse(df.tags[TAG_FIT] ??= JSON.stringify(createDefaultChartData()));\n}\n\n/** Returns existing, or creates new column default chart options. */\nexport function getColumnChartOptions(column: DG.Column): IFitChartData {\n  return JSON.parse(column.tags[TAG_FIT] ??= JSON.stringify(createDefaultChartData()));\n}\n\n/** Returns points arrays from {@link IFitPoint} array */\nexport function getPointsArrays(points: IFitPoint[]): {xs: number[], ys: number[]} {\n  const xs: number[] = [];\n  const ys: number[] = [];\n  for (let i = 0; i < points.length; i++) {\n    xs[i] = points[i].x;\n    ys[i] = points[i].y;\n  }\n  return {xs: xs, ys: ys};\n}\n\n/** Returns median from within multiple points */\nfunction getMedian(points: {x: number[], y: number[]}): number {\n  const mid = Math.floor(points.y.length / 2);\n  const sortedPoints = points.y.sort((a, b) => a - b);\n  const median = sortedPoints.length % 2 === 0 ? (sortedPoints[mid - 1] + sortedPoints[mid]) / 2 : sortedPoints[mid];\n  return median;\n}\n\n/** Returns median points from within multiple points with the same x. */\nfunction getMedianPoints(data: {x: number[], y: number[]}): {x: number[], y: number[]} {\n  const medianPoints: {x: number[], y: number[]} = {x: [], y: []};\n  const currentPoints: {x: number[], y: number[]} = {x: [data.x[0]], y: [data.y[0]]};\n  for (let i = 1; i < data.x.length; i++) {\n    if (data.x[i] === currentPoints.x[0]) {\n      currentPoints.x[currentPoints.x.length] = data.x[i];\n      currentPoints.y[currentPoints.y.length] = data.y[i];\n      continue;\n    }\n    const median = getMedian(currentPoints);\n    medianPoints.x[medianPoints.x.length] = currentPoints.x[0];\n    medianPoints.y[medianPoints.y.length] = median;\n    currentPoints.x = [data.x[i]];\n    currentPoints.y = [data.y[i]];\n  }\n  const median = getMedian(currentPoints);\n  medianPoints.x[medianPoints.x.length] = currentPoints.x[0];\n  medianPoints.y[medianPoints.y.length] = median;\n\n  return medianPoints;\n}\n\n/** Returns logarithmic IC50 parameter bounds. */\nfunction logIC50ParameterBounds(ic50Bounds: FitParamBounds): FitParamBounds {\n  if (ic50Bounds) {\n    if (ic50Bounds.max !== undefined)\n      ic50Bounds.max = Math.log10(ic50Bounds.max);\n    if (ic50Bounds.min !== undefined) {\n      ic50Bounds.min = ic50Bounds.min === 0 ?\n        -Number.MAX_VALUE : Math.log10(ic50Bounds.min);\n    }\n  }\n  return ic50Bounds;\n}\n\nfunction changeBounds(bounds: DG.Rect, chartOptions: IFitChartOptions): DG.Rect {\n  let x = bounds.x;\n  let y = bounds.y;\n  let width = bounds.width;\n  let height = bounds.height;\n\n  if (chartOptions.minX !== undefined && chartOptions.minX !== null &&\n    ((!chartOptions.logX) || (chartOptions.logX && chartOptions.minX > 0))) {\n    width += x - chartOptions.minX;\n    x = chartOptions.minX;\n  }\n  if (chartOptions.maxX !== undefined && chartOptions.maxX !== null &&\n    ((!chartOptions.logX) || (chartOptions.logX && chartOptions.maxX > 0)))\n    width += chartOptions.maxX - (x + width);\n  if (chartOptions.minY !== undefined && chartOptions.minY !== null &&\n    ((!chartOptions.logY) || (chartOptions.logY && chartOptions.minY > 0))) {\n    height += y - chartOptions.minY;\n    y = chartOptions.minY;\n  }\n  if (chartOptions.maxY !== undefined && chartOptions.maxY !== null &&\n    ((!chartOptions.logY) || (chartOptions.logY && chartOptions.maxY > 0)))\n    height += chartOptions.maxY - (y + height);\n\n  return new DG.Rect(x, y, width, height);\n}\n\n/** Returns the bounds of an {@link IFitChartData} object */\nexport function getChartBounds(chartData: IFitChartData): DG.Rect {\n  const o = chartData.chartOptions;\n  if (!chartData.series?.length || chartData.series.length === 0)\n    return new DG.Rect(0, 0, 1, 1);\n  else {\n    const {xs, ys} = getPointsArrays(chartData.series[0].points);\n    let bounds = DG.Rect.fromXYArrays(xs, ys);\n    for (let i = 1; i < chartData.series!.length; i++) {\n      const {xs, ys} = getPointsArrays(chartData.series[i].points);\n      if (xs.some((x) => x === undefined) || ys.some((y) => y === undefined))\n        continue;\n      bounds = bounds.union(DG.Rect.fromXYArrays(xs, ys));\n    }\n    return o ? changeBounds(bounds, o!): bounds;\n  }\n}\n\n/** Returns series fit function */\nexport function getSeriesFitFunction(series: IFitSeries): FitFunction {\n  return getOrCreateFitFunction(series.fitFunction!);\n}\n\n/** Returns a curve function, either using the pre-computed parameters or by fitting on-the-fly */\nexport function getCurve(series: IFitSeries, fitFunc: FitFunction): (x: number) => number {\n  return getFittedCurve(fitFunc.y, series.parameters!);\n}\n\n/** Fits the series data according to the series fitting settings */\nexport function fitSeries(series: IFitSeries, fitFunc: FitFunction, logOptions?: LogOptions): FitCurve {\n  const data = {x: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n    y: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)};\n  if (series.parameterBounds && logOptions?.logX)\n    series.parameterBounds[2] = logIC50ParameterBounds(series.parameterBounds[2]);\n  return fitData(getMedianPoints(data), fitFunc, series.errorModel ?? FitErrorModel.CONSTANT as FitErrorModelType,\n    series.parameterBounds);\n}\n\n/** Returns series confidence interval functions */\nexport function getSeriesConfidenceInterval(series: IFitSeries, fitFunc: FitFunction,\n  userParamsFlag: boolean, logOptions?: LogOptions): FitConfidenceIntervals {\n  const data = userParamsFlag ? {x: series.points.map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n    y: series.points.map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)} :\n    {x: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n      y: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)};\n  if (!series.parameters)\n    series.parameters = fitSeries(series, fitFunc).parameters;\n  return getCurveConfidenceIntervals(data, series.parameters, fitFunc.y, 0.05,\n    series.errorModel ?? FitErrorModel.CONSTANT as FitErrorModelType);\n}\n\n/** Returns series statistics */\nexport function getSeriesStatistics(series: IFitSeries, fitFunc: FitFunction, logOptions?: LogOptions): FitStatistics {\n  const data = {x: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n    y: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)};\n  if (!series.parameters)\n    series.parameters = fitSeries(series, fitFunc).parameters;\n  return getStatistics(data, series.parameters, fitFunc.y, true);\n}\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fit-data.js","sourceRoot":"","sources":["fit-data.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable valid-jsdoc */\nimport * as DG from 'datagrok-api/dg';\n\nimport {\n  FitErrorModel,\n  fitData,\n  getCurveConfidenceIntervals,\n  getStatistics,\n  FitFunction,\n  getFittedCurve,\n  FitStatistics,\n  FitConfidenceIntervals,\n  FitCurve,\n  getOrCreateFitFunction,\n  IFitPoint,\n  IFitChartData,\n  IFitSeries,\n  fitSeriesProperties,\n  fitChartDataProperties,\n  FitParamBounds,\n  IFitChartOptions,\n  FitErrorModelType,\n} from './fit-curve';\n\nexport type LogOptions = {\n  logX: boolean | undefined,\n  logY: boolean | undefined\n};\n\n\n/** Creates new object with the default values specified in {@link properties} */\nfunction createFromProperties(properties: DG.Property[]): any {\n  const o: any = {};\n  for (const p of properties) {\n    if (p.defaultValue !== null)\n      o[p.name] = p.defaultValue;\n  }\n  return o;\n}\n\n// TODO: set column with fit readonly value (in detectors) - try to only show chart - remove editable or prevent it??\n/** Creates default {@link IFitChartData} object */\nexport function createDefaultChartData(): IFitChartData {\n  return {\n    chartOptions: createFromProperties(fitChartDataProperties),\n    seriesOptions: createFromProperties(fitSeriesProperties),\n  };\n}\n\n/** Returns points arrays from {@link IFitPoint} array */\nexport function getPointsArrays(points: IFitPoint[]): {xs: number[], ys: number[]} {\n  const xs: number[] = [];\n  const ys: number[] = [];\n  for (let i = 0; i < points.length; i++) {\n    xs[i] = points[i].x;\n    ys[i] = points[i].y;\n  }\n  return {xs: xs, ys: ys};\n}\n\n/** Returns median from within multiple points */\nfunction getMedian(points: {x: number[], y: number[]}): number {\n  const mid = Math.floor(points.y.length / 2);\n  const sortedPoints = points.y.sort((a, b) => a - b);\n  const median = sortedPoints.length % 2 === 0 ? (sortedPoints[mid - 1] + sortedPoints[mid]) / 2 : sortedPoints[mid];\n  return median;\n}\n\n/** Returns median points from within multiple points with the same x. */\nfunction getMedianPoints(data: {x: number[], y: number[]}): {x: number[], y: number[]} {\n  const medianPoints: {x: number[], y: number[]} = {x: [], y: []};\n  const currentPoints: {x: number[], y: number[]} = {x: [data.x[0]], y: [data.y[0]]};\n  for (let i = 1; i < data.x.length; i++) {\n    if (data.x[i] === currentPoints.x[0]) {\n      currentPoints.x[currentPoints.x.length] = data.x[i];\n      currentPoints.y[currentPoints.y.length] = data.y[i];\n      continue;\n    }\n    const median = getMedian(currentPoints);\n    medianPoints.x[medianPoints.x.length] = currentPoints.x[0];\n    medianPoints.y[medianPoints.y.length] = median;\n    currentPoints.x = [data.x[i]];\n    currentPoints.y = [data.y[i]];\n  }\n  const median = getMedian(currentPoints);\n  medianPoints.x[medianPoints.x.length] = currentPoints.x[0];\n  medianPoints.y[medianPoints.y.length] = median;\n\n  return medianPoints;\n}\n\n/** Returns logarithmic IC50 parameter bounds. */\nfunction logIC50ParameterBounds(ic50Bounds: FitParamBounds): FitParamBounds {\n  if (ic50Bounds) {\n    if (ic50Bounds.max !== undefined)\n      ic50Bounds.max = Math.log10(ic50Bounds.max);\n    if (ic50Bounds.min !== undefined) {\n      ic50Bounds.min = ic50Bounds.min === 0 ?\n        -Number.MAX_VALUE : Math.log10(ic50Bounds.min);\n    }\n  }\n  return ic50Bounds;\n}\n\nfunction changeBounds(bounds: DG.Rect, chartOptions: IFitChartOptions): DG.Rect {\n  let x = bounds.x;\n  let y = bounds.y;\n  let width = bounds.width;\n  let height = bounds.height;\n\n  if (chartOptions.minX !== undefined && chartOptions.minX !== null &&\n    ((!chartOptions.logX) || (chartOptions.logX && chartOptions.minX > 0))) {\n    width += x - chartOptions.minX;\n    x = chartOptions.minX;\n  }\n  if (chartOptions.maxX !== undefined && chartOptions.maxX !== null &&\n    ((!chartOptions.logX) || (chartOptions.logX && chartOptions.maxX > 0)))\n    width += chartOptions.maxX - (x + width);\n  if (chartOptions.minY !== undefined && chartOptions.minY !== null &&\n    ((!chartOptions.logY) || (chartOptions.logY && chartOptions.minY > 0))) {\n    height += y - chartOptions.minY;\n    y = chartOptions.minY;\n  }\n  if (chartOptions.maxY !== undefined && chartOptions.maxY !== null &&\n    ((!chartOptions.logY) || (chartOptions.logY && chartOptions.maxY > 0)))\n    height += chartOptions.maxY - (y + height);\n\n  return new DG.Rect(x, y, width, height);\n}\n\n/** Returns the bounds of an {@link IFitChartData} object */\nexport function getChartBounds(chartData: IFitChartData): DG.Rect {\n  const o = chartData.chartOptions;\n  if (!chartData.series?.length || chartData.series.length === 0)\n    return new DG.Rect(0, 0, 1, 1);\n  else {\n    const {xs, ys} = getPointsArrays(chartData.series[0].points);\n    let bounds = DG.Rect.fromXYArrays(xs, ys);\n    for (let i = 1; i < chartData.series!.length; i++) {\n      const {xs, ys} = getPointsArrays(chartData.series[i].points);\n      if (xs.some((x) => x === undefined) || ys.some((y) => y === undefined))\n        continue;\n      bounds = bounds.union(DG.Rect.fromXYArrays(xs, ys));\n    }\n    return o ? changeBounds(bounds, o!): bounds;\n  }\n}\n\n/** Returns series fit function */\nexport function getSeriesFitFunction(series: IFitSeries): FitFunction {\n  return getOrCreateFitFunction(series.fitFunction!);\n}\n\n/** Returns a curve function, either using the pre-computed parameters or by fitting on-the-fly */\nexport function getCurve(series: IFitSeries, fitFunc: FitFunction): (x: number) => number {\n  const params = new Float32Array(series.parameters?.length!);\n  params.set(series.parameters!);\n  return getFittedCurve(fitFunc.y, params);\n}\n\n/** Fits the series data according to the series fitting settings */\nexport function fitSeries(series: IFitSeries, fitFunc: FitFunction, logOptions?: LogOptions): FitCurve {\n  const data = {x: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n    y: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)};\n  if (series.parameterBounds && logOptions?.logX)\n    series.parameterBounds[2] = logIC50ParameterBounds(series.parameterBounds[2]);\n  return fitData(getMedianPoints(data), fitFunc, series.errorModel ?? FitErrorModel.CONSTANT as FitErrorModelType,\n    series.parameterBounds);\n}\n\n/** Returns series confidence interval functions */\nexport function getSeriesConfidenceInterval(series: IFitSeries, fitFunc: FitFunction,\n  userParamsFlag: boolean, logOptions?: LogOptions): FitConfidenceIntervals {\n  const data = userParamsFlag ? {x: series.points.map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n    y: series.points.map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)} :\n    {x: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n      y: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)};\n  if (!series.parameters) {\n    const params = fitSeries(series, fitFunc).parameters;\n    series.parameters = [...params];\n  }\n  const params = new Float32Array(series.parameters?.length!);\n  params.set(series.parameters!);\n  return getCurveConfidenceIntervals(data, params, fitFunc.y, 0.05,\n    series.errorModel ?? FitErrorModel.CONSTANT as FitErrorModelType);\n}\n\n/** Returns series statistics */\nexport function getSeriesStatistics(series: IFitSeries, fitFunc: FitFunction, logOptions?: LogOptions): FitStatistics {\n  const data = {x: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logX ? Math.log10(p.x) : p.x),\n    y: series.points.filter((p) => !p.outlier).map((p) => logOptions?.logY ? Math.log10(p.y) : p.y)};\n  if (!series.parameters) {\n    const params = fitSeries(series, fitFunc).parameters;\n    series.parameters = [...params];\n  }\n  const params = new Float32Array(series.parameters?.length!);\n  params.set(series.parameters!);\n  return getStatistics(data, params, fitFunc.y, true);\n}\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import * as DG from 'datagrok-api/dg';
|
|
2
|
+
export declare type Extremum = {
|
|
3
|
+
point: Float32Array;
|
|
4
|
+
cost: number;
|
|
5
|
+
iterCosts: number[];
|
|
6
|
+
iterCount: number;
|
|
7
|
+
};
|
|
8
|
+
export declare type OptimizationResult = {
|
|
9
|
+
extremums: Extremum[];
|
|
10
|
+
fails: DG.DataFrame | null;
|
|
11
|
+
};
|
|
12
|
+
export interface IOptimizer {
|
|
13
|
+
(objectiveFunc: (x: Float32Array) => number, paramsInitial: Float32Array, settings: any, restrictionsBottom: Float32Array, restrictionsTop: Float32Array): Extremum;
|
|
14
|
+
}
|
|
15
|
+
/** Inconsistent tables error */
|
|
16
|
+
export declare class InconsistentTables extends Error {
|
|
17
|
+
constructor(msg: string);
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=optimizer-misc.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"optimizer-misc.d.ts","sourceRoot":"","sources":["optimizer-misc.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,iBAAiB,CAAC;AAGtC,oBAAY,QAAQ,GAAG;IACrB,KAAK,EAAE,YAAY,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAA;AAED,oBAAY,kBAAkB,GAAG;IAC/B,SAAS,EAAE,QAAQ,EAAE,CAAC;IACtB,KAAK,EAAE,EAAE,CAAC,SAAS,GAAG,IAAI,CAAC;CAC5B,CAAC;AAEF,MAAM,WAAW,UAAU;IACzB,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,YAAY,KAAK,MAAM,EAC3C,aAAa,EAAE,YAAY,EAC3B,QAAQ,EAAE,GAAG,EACb,kBAAkB,EAAE,YAAY,EAChC,eAAe,EAAE,YAAY,GAAG,QAAQ,CAAC;CAC1C;AAED,gCAAgC;AAChC,qBAAa,kBAAmB,SAAQ,KAAK;gBAC/B,GAAG,EAAE,MAAM;CAGxB"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/** Inconsistent tables error */
|
|
2
|
+
export class InconsistentTables extends Error {
|
|
3
|
+
constructor(msg) {
|
|
4
|
+
super(msg);
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW1pemVyLW1pc2MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJvcHRpbWl6ZXItbWlzYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QkEsZ0NBQWdDO0FBQ2hDLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxLQUFLO0lBQzNDLFlBQVksR0FBVztRQUNyQixLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDYixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBPcHRpbWl6ZXIgcm91dGluZVxuaW1wb3J0ICogYXMgREcgZnJvbSAnZGF0YWdyb2stYXBpL2RnJztcblxuXG5leHBvcnQgdHlwZSBFeHRyZW11bSA9IHtcbiAgcG9pbnQ6IEZsb2F0MzJBcnJheSxcbiAgY29zdDogbnVtYmVyLFxuICBpdGVyQ29zdHM6IG51bWJlcltdLFxuICBpdGVyQ291bnQ6IG51bWJlcixcbn1cblxuZXhwb3J0IHR5cGUgT3B0aW1pemF0aW9uUmVzdWx0ID0ge1xuICBleHRyZW11bXM6IEV4dHJlbXVtW10sXG4gIGZhaWxzOiBERy5EYXRhRnJhbWUgfCBudWxsLFxufTtcblxuZXhwb3J0IGludGVyZmFjZSBJT3B0aW1pemVyIHtcbiAgKG9iamVjdGl2ZUZ1bmM6ICh4OiBGbG9hdDMyQXJyYXkpID0+IG51bWJlcixcbiAgcGFyYW1zSW5pdGlhbDogRmxvYXQzMkFycmF5LFxuICBzZXR0aW5nczogYW55LFxuICByZXN0cmljdGlvbnNCb3R0b206IEZsb2F0MzJBcnJheSxcbiAgcmVzdHJpY3Rpb25zVG9wOiBGbG9hdDMyQXJyYXkpOiBFeHRyZW11bTtcbn1cblxuLyoqIEluY29uc2lzdGVudCB0YWJsZXMgZXJyb3IgKi9cbmV4cG9ydCBjbGFzcyBJbmNvbnNpc3RlbnRUYWJsZXMgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1zZzogc3RyaW5nKSB7XG4gICAgc3VwZXIobXNnKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { IOptimizer } from './optimizer-misc';
|
|
2
|
+
/** The Nelder-Mead method settings */
|
|
3
|
+
export declare type NelderMeadSettings = {
|
|
4
|
+
tolerance: number;
|
|
5
|
+
maxIter: number;
|
|
6
|
+
nonZeroParam: number;
|
|
7
|
+
initialScale: number;
|
|
8
|
+
scaleReflection: number;
|
|
9
|
+
scaleExpansion: number;
|
|
10
|
+
scaleContraction: number;
|
|
11
|
+
};
|
|
12
|
+
/** Default values for the Nelder-Mead method */
|
|
13
|
+
export declare enum NELDER_MEAD_DEFAULTS {
|
|
14
|
+
TOLERANCE = 0.01,
|
|
15
|
+
MAX_ITER = 20,
|
|
16
|
+
NON_ZERO_PARAM = 0.0001,
|
|
17
|
+
INITIAL_SCALE = 0.02,
|
|
18
|
+
SCALE_REFLECTION = 1,
|
|
19
|
+
SCALE_EXPANSION = 2,
|
|
20
|
+
SCALE_CONTRACTION = -0.5
|
|
21
|
+
}
|
|
22
|
+
/** Captions for the Nelder-Mead method settings */
|
|
23
|
+
export declare const nelderMeadCaptions: Map<string, string>;
|
|
24
|
+
export declare const optimizeNM: IOptimizer;
|
|
25
|
+
//# sourceMappingURL=optimizer-nelder-mead.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"optimizer-nelder-mead.d.ts","sourceRoot":"","sources":["optimizer-nelder-mead.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAGtD,sCAAsC;AACtC,oBAAY,kBAAkB,GAAG;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF,gDAAgD;AAChD,oBAAY,oBAAoB;IAC9B,SAAS,OAAO;IAChB,QAAQ,KAAK;IACb,cAAc,SAAS;IACvB,aAAa,OAAO;IACpB,gBAAgB,IAAI;IACpB,eAAe,IAAI;IACnB,iBAAiB,OAAO;CACzB;AAED,mDAAmD;AACnD,eAAO,MAAM,kBAAkB,qBAQ7B,CAAC;AAkEH,eAAO,MAAM,UAAU,EAAE,UA2HxB,CAAC"}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
/** Default values for the Nelder-Mead method */
|
|
2
|
+
export var NELDER_MEAD_DEFAULTS;
|
|
3
|
+
(function (NELDER_MEAD_DEFAULTS) {
|
|
4
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["TOLERANCE"] = 0.01] = "TOLERANCE";
|
|
5
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["MAX_ITER"] = 20] = "MAX_ITER";
|
|
6
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["NON_ZERO_PARAM"] = 0.0001] = "NON_ZERO_PARAM";
|
|
7
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["INITIAL_SCALE"] = 0.02] = "INITIAL_SCALE";
|
|
8
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["SCALE_REFLECTION"] = 1] = "SCALE_REFLECTION";
|
|
9
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["SCALE_EXPANSION"] = 2] = "SCALE_EXPANSION";
|
|
10
|
+
NELDER_MEAD_DEFAULTS[NELDER_MEAD_DEFAULTS["SCALE_CONTRACTION"] = -0.5] = "SCALE_CONTRACTION";
|
|
11
|
+
})(NELDER_MEAD_DEFAULTS || (NELDER_MEAD_DEFAULTS = {}));
|
|
12
|
+
/** Captions for the Nelder-Mead method settings */
|
|
13
|
+
export const nelderMeadCaptions = new Map([
|
|
14
|
+
['tolerance', 'Tolerance'],
|
|
15
|
+
['maxIter', 'Max iterations'],
|
|
16
|
+
['nonZeroParam', 'Non-zero param'],
|
|
17
|
+
['initialScale', 'Initial scale'],
|
|
18
|
+
['scaleReflection', 'Scale reflection'],
|
|
19
|
+
['scaleExpansion', 'Scale expansion'],
|
|
20
|
+
['scaleContraction', 'Scale contraction'],
|
|
21
|
+
]);
|
|
22
|
+
function getInitialParams(objectiveFunc, settings, paramsInitial, restrictionsBottom, restrictionsTop) {
|
|
23
|
+
const dim = paramsInitial.length + 1;
|
|
24
|
+
const dimParams = paramsInitial.length;
|
|
25
|
+
const nonZeroParam = settings.nonZeroParam;
|
|
26
|
+
const initScale = settings.initialScale;
|
|
27
|
+
const optParams = new Array(dim);
|
|
28
|
+
const pointObjectives = new Array(dim);
|
|
29
|
+
for (let i = 0; i < dim; i++) {
|
|
30
|
+
optParams[i] = new Float32Array(dimParams);
|
|
31
|
+
for (let j = 0; j < dimParams; j++) {
|
|
32
|
+
optParams[i][j] = paramsInitial[j];
|
|
33
|
+
if (i !== 0 && i - 1 === j) {
|
|
34
|
+
if (paramsInitial[j] === 0)
|
|
35
|
+
optParams[i][j] = nonZeroParam;
|
|
36
|
+
else
|
|
37
|
+
optParams[i][j] += initScale * paramsInitial[i - 1];
|
|
38
|
+
if (optParams[i][j] < restrictionsBottom[j])
|
|
39
|
+
optParams[i][j] = restrictionsBottom[j];
|
|
40
|
+
else if (optParams[i][j] > restrictionsTop[j])
|
|
41
|
+
optParams[i][j] = restrictionsTop[j];
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
pointObjectives[i] = objectiveFunc(optParams[i]);
|
|
45
|
+
}
|
|
46
|
+
return [optParams, pointObjectives];
|
|
47
|
+
}
|
|
48
|
+
function fillCentroid(centroid, dimParams, lastIndex, optParams) {
|
|
49
|
+
for (let i = 0; i < dimParams; i++) {
|
|
50
|
+
let val = 0;
|
|
51
|
+
for (let j = 0; j < dimParams + 1; j++) {
|
|
52
|
+
if (j !== lastIndex)
|
|
53
|
+
val += optParams[j][i];
|
|
54
|
+
}
|
|
55
|
+
centroid[i] = val / dimParams;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
function fillPoint(centroid, point, lastIndex, optParams, scale, dimParams, restrictionsBottom, restrictionsTop) {
|
|
59
|
+
for (let i = 0; i < dimParams; i++) {
|
|
60
|
+
point[i] = centroid[i];
|
|
61
|
+
point[i] += scale * (centroid[i] - optParams[lastIndex][i]);
|
|
62
|
+
if (point[i] < restrictionsBottom[i])
|
|
63
|
+
point[i] = restrictionsBottom[i];
|
|
64
|
+
else if (point[i] > restrictionsTop[i])
|
|
65
|
+
point[i] = restrictionsTop[i];
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
export const optimizeNM = function (objectiveFunc, paramsInitial, settings, restrictionsBottom, restrictionsTop) {
|
|
69
|
+
// Settings initialization
|
|
70
|
+
const tolerance = settings.tolerance;
|
|
71
|
+
const maxIter = settings.maxIter;
|
|
72
|
+
const scaleReflection = settings.scaleReflection;
|
|
73
|
+
const scaleExpansion = settings.scaleExpansion;
|
|
74
|
+
const scaleContraction = settings.scaleContraction;
|
|
75
|
+
const dim = paramsInitial.length + 1;
|
|
76
|
+
const dimParams = paramsInitial.length;
|
|
77
|
+
const [optParams, pointObjectives] = getInitialParams(objectiveFunc, settings, paramsInitial, restrictionsBottom, restrictionsTop);
|
|
78
|
+
const indexes = new Array(dim);
|
|
79
|
+
for (let i = 0; i < dim; i++)
|
|
80
|
+
indexes[i] = i;
|
|
81
|
+
const lastIndex = indexes.length - 1;
|
|
82
|
+
let iteration = 0;
|
|
83
|
+
let best = 0;
|
|
84
|
+
let previousBest = 0;
|
|
85
|
+
let noImprovement = 0;
|
|
86
|
+
const centroid = new Float32Array(dimParams);
|
|
87
|
+
const reflectionPoint = new Float32Array(dimParams);
|
|
88
|
+
const expansionPoint = new Float32Array(dimParams);
|
|
89
|
+
const contractionPoint = new Float32Array(dimParams);
|
|
90
|
+
const costs = new Array(maxIter);
|
|
91
|
+
if (dim > 1) {
|
|
92
|
+
while (true) {
|
|
93
|
+
indexes.sort((a, b) => {
|
|
94
|
+
return pointObjectives[a] - pointObjectives[b];
|
|
95
|
+
});
|
|
96
|
+
if (iteration > maxIter)
|
|
97
|
+
break;
|
|
98
|
+
if (iteration === 0) {
|
|
99
|
+
best = pointObjectives[0];
|
|
100
|
+
previousBest = 2 * pointObjectives[indexes[0]];
|
|
101
|
+
}
|
|
102
|
+
costs[iteration] = best;
|
|
103
|
+
++iteration;
|
|
104
|
+
best = pointObjectives[indexes[0]];
|
|
105
|
+
if (previousBest - best > tolerance)
|
|
106
|
+
noImprovement = 0;
|
|
107
|
+
else {
|
|
108
|
+
++noImprovement;
|
|
109
|
+
if (noImprovement > 2 * dim)
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
previousBest = best;
|
|
113
|
+
// centroid
|
|
114
|
+
fillCentroid(centroid, dimParams, indexes[lastIndex], optParams);
|
|
115
|
+
// reflection
|
|
116
|
+
fillPoint(centroid, reflectionPoint, indexes[lastIndex], optParams, scaleReflection, dimParams, restrictionsBottom, restrictionsTop);
|
|
117
|
+
const reflectionScore = objectiveFunc(reflectionPoint);
|
|
118
|
+
// expansion
|
|
119
|
+
if (reflectionScore < pointObjectives[indexes[lastIndex]]) {
|
|
120
|
+
fillPoint(centroid, expansionPoint, indexes[lastIndex], optParams, scaleExpansion, dimParams, restrictionsBottom, restrictionsTop);
|
|
121
|
+
const expansionScore = objectiveFunc(expansionPoint);
|
|
122
|
+
if (expansionScore < reflectionScore) {
|
|
123
|
+
pointObjectives[indexes[lastIndex]] = expansionScore;
|
|
124
|
+
for (let i = 0; i < dimParams; i++)
|
|
125
|
+
optParams[indexes[lastIndex]][i] = expansionPoint[i];
|
|
126
|
+
continue;
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
pointObjectives[indexes[lastIndex]] = reflectionScore;
|
|
130
|
+
for (let i = 0; i < dimParams; i++)
|
|
131
|
+
optParams[indexes[lastIndex]][i] = reflectionPoint[i];
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
// Contraction
|
|
136
|
+
fillPoint(centroid, contractionPoint, indexes[lastIndex], optParams, scaleContraction, dimParams, restrictionsBottom, restrictionsTop);
|
|
137
|
+
const contractionScore = objectiveFunc(contractionPoint);
|
|
138
|
+
if (contractionScore < pointObjectives[indexes[lastIndex]]) {
|
|
139
|
+
pointObjectives[indexes[lastIndex]] = contractionScore;
|
|
140
|
+
for (let i = 0; i < dimParams; i++)
|
|
141
|
+
optParams[indexes[lastIndex]][i] = contractionPoint[i];
|
|
142
|
+
continue;
|
|
143
|
+
}
|
|
144
|
+
break;
|
|
145
|
+
}
|
|
146
|
+
for (let i = iteration; i < maxIter; i++)
|
|
147
|
+
costs[i] = pointObjectives[indexes[0]];
|
|
148
|
+
}
|
|
149
|
+
return {
|
|
150
|
+
point: optParams[indexes[0]],
|
|
151
|
+
cost: pointObjectives[indexes[0]],
|
|
152
|
+
iterCosts: costs,
|
|
153
|
+
iterCount: iteration - 1,
|
|
154
|
+
};
|
|
155
|
+
};
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"optimizer-nelder-mead.js","sourceRoot":"","sources":["optimizer-nelder-mead.ts"],"names":[],"mappings":"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","sourcesContent":["import {Extremum, IOptimizer} from './optimizer-misc';\n\n\n/** The Nelder-Mead method settings */\nexport type NelderMeadSettings = {\n  tolerance: number,\n  maxIter: number,\n  nonZeroParam: number,\n  initialScale: number,\n  scaleReflection: number,\n  scaleExpansion: number,\n  scaleContraction: number,\n};\n\n/** Default values for the Nelder-Mead method */\nexport enum NELDER_MEAD_DEFAULTS {\n  TOLERANCE = 0.01,\n  MAX_ITER = 20,\n  NON_ZERO_PARAM = 0.0001,\n  INITIAL_SCALE = 0.02,\n  SCALE_REFLECTION = 1,\n  SCALE_EXPANSION = 2,\n  SCALE_CONTRACTION = -0.5,\n}\n\n/** Captions for the Nelder-Mead method settings */\nexport const nelderMeadCaptions = new Map([\n  ['tolerance', 'Tolerance'],\n  ['maxIter', 'Max iterations'],\n  ['nonZeroParam', 'Non-zero param'],\n  ['initialScale', 'Initial scale'],\n  ['scaleReflection', 'Scale reflection'],\n  ['scaleExpansion', 'Scale expansion'],\n  ['scaleContraction', 'Scale contraction'],\n]);\n\nfunction getInitialParams(\n  objectiveFunc: (x: Float32Array) => number,\n  settings: NelderMeadSettings,\n  paramsInitial: Float32Array,\n  restrictionsBottom: Float32Array,\n  restrictionsTop: Float32Array): [Float32Array[], number[]] {\n  const dim = paramsInitial.length + 1;\n  const dimParams = paramsInitial.length;\n  const nonZeroParam = settings.nonZeroParam;\n  const initScale = settings.initialScale;\n\n  const optParams = new Array<Float32Array>(dim);\n  const pointObjectives = new Array<number>(dim);\n\n  for (let i = 0; i < dim; i++) {\n    optParams[i] = new Float32Array(dimParams);\n    for (let j = 0; j < dimParams; j++) {\n      optParams[i][j] = paramsInitial[j];\n      if (i !== 0 && i - 1 === j) {\n        if (paramsInitial[j] === 0)\n          optParams[i][j] = nonZeroParam;\n        else\n          optParams[i][j] += initScale * paramsInitial[i - 1];\n\n        if (optParams[i][j] < restrictionsBottom[j])\n          optParams[i][j] = restrictionsBottom[j];\n        else if (optParams[i][j] > restrictionsTop[j])\n          optParams[i][j] = restrictionsTop[j];\n      }\n    }\n    pointObjectives[i] = objectiveFunc(optParams[i]);\n  }\n\n  return [optParams, pointObjectives];\n}\n\nfunction fillCentroid(centroid: Float32Array, dimParams: number, lastIndex: number, optParams: Float32Array[]) {\n  for (let i = 0; i < dimParams; i++) {\n    let val = 0;\n    for (let j = 0; j < dimParams + 1; j++) {\n      if (j !== lastIndex)\n        val += optParams[j][i];\n    }\n    centroid[i] = val / dimParams;\n  }\n}\n\nfunction fillPoint(\n  centroid: Float32Array, point: Float32Array,\n  lastIndex: number, optParams: Float32Array[],\n  scale: number, dimParams: number,\n  restrictionsBottom: Float32Array,\n  restrictionsTop: Float32Array) {\n  for (let i = 0; i < dimParams; i++) {\n    point[i] = centroid[i];\n    point[i] += scale * (centroid[i] - optParams[lastIndex][i]);\n\n    if (point[i] < restrictionsBottom[i])\n      point[i] = restrictionsBottom[i];\n    else if (point[i] > restrictionsTop[i])\n      point[i] = restrictionsTop[i];\n  }\n}\n\nexport const optimizeNM: IOptimizer = function(\n  objectiveFunc: (x: Float32Array) => number,\n  paramsInitial: Float32Array,\n  settings: NelderMeadSettings,\n  restrictionsBottom: Float32Array,\n  restrictionsTop: Float32Array): Extremum {\n  // Settings initialization\n  const tolerance = settings.tolerance;\n  const maxIter = settings.maxIter;\n\n  const scaleReflection = settings.scaleReflection;\n  const scaleExpansion = settings.scaleExpansion;\n  const scaleContraction = settings.scaleContraction;\n  const dim = paramsInitial.length + 1;\n  const dimParams = paramsInitial.length;\n\n  const [optParams, pointObjectives] =\n    getInitialParams(objectiveFunc, settings, paramsInitial, restrictionsBottom, restrictionsTop);\n\n  const indexes = new Array<number>(dim);\n  for (let i = 0; i < dim; i++)\n    indexes[i] = i;\n\n  const lastIndex = indexes.length - 1;\n  let iteration = 0;\n  let best = 0;\n  let previousBest = 0;\n  let noImprovement = 0;\n\n  const centroid = new Float32Array(dimParams);\n  const reflectionPoint = new Float32Array(dimParams);\n  const expansionPoint = new Float32Array(dimParams);\n  const contractionPoint = new Float32Array(dimParams);\n  const costs = new Array<number>(maxIter);\n\n  if (dim > 1) {\n    while (true) {\n      indexes.sort((a: number, b: number) => {\n        return pointObjectives[a] - pointObjectives[b];\n      });\n      if (iteration > maxIter)\n        break;\n\n      if (iteration === 0) {\n        best = pointObjectives[0];\n        previousBest = 2 * pointObjectives[indexes[0]];\n      }\n      costs[iteration] = best;\n\n      ++iteration;\n\n      best = pointObjectives[indexes[0]];\n      if (previousBest - best > tolerance)\n        noImprovement = 0;\n      else {\n        ++noImprovement;\n        if (noImprovement > 2 * dim)\n          break;\n      }\n\n      previousBest = best;\n\n      // centroid\n      fillCentroid(centroid, dimParams, indexes[lastIndex], optParams);\n\n      // reflection\n      fillPoint(centroid, reflectionPoint, indexes[lastIndex],\n        optParams, scaleReflection, dimParams, restrictionsBottom, restrictionsTop);\n      const reflectionScore = objectiveFunc(reflectionPoint);\n\n      // expansion\n      if (reflectionScore < pointObjectives[indexes[lastIndex]]) {\n        fillPoint(centroid, expansionPoint, indexes[lastIndex],\n          optParams, scaleExpansion, dimParams, restrictionsBottom, restrictionsTop);\n\n        const expansionScore = objectiveFunc(expansionPoint);\n\n        if (expansionScore < reflectionScore) {\n          pointObjectives[indexes[lastIndex]] = expansionScore;\n\n          for (let i = 0; i < dimParams; i++)\n            optParams[indexes[lastIndex]][i] = expansionPoint[i];\n\n          continue;\n        }\n        else {\n          pointObjectives[indexes[lastIndex]] = reflectionScore;\n\n          for (let i = 0; i < dimParams; i++)\n            optParams[indexes[lastIndex]][i] = reflectionPoint[i];\n\n          continue;\n        }\n      }\n\n      // Contraction\n      fillPoint(centroid, contractionPoint, indexes[lastIndex],\n        optParams, scaleContraction, dimParams, restrictionsBottom, restrictionsTop);\n\n      const contractionScore = objectiveFunc(contractionPoint);\n\n      if (contractionScore < pointObjectives[indexes[lastIndex]]) {\n        pointObjectives[indexes[lastIndex]] = contractionScore;\n\n        for (let i = 0; i < dimParams; i++)\n          optParams[indexes[lastIndex]][i] = contractionPoint[i];\n\n        continue;\n      }\n\n      break;\n    }\n\n    for (let i = iteration; i < maxIter; i++)\n      costs[i] = pointObjectives[indexes[0]];\n  }\n\n  return {\n    point: optParams[indexes[0]],\n    cost: pointObjectives[indexes[0]],\n    iterCosts: costs,\n    iterCount: iteration - 1,\n  };\n};\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"optimizer-sampler.d.ts","sourceRoot":"","sources":["optimizer-sampler.ts"],"names":[],"mappings":"AAYA,wBAAgB,YAAY,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,GAAG,YAAY,EAAE,CAmB1G"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
function sampleUniform(samplesCount, top, bottom) {
|
|
2
|
+
const scale = top - bottom;
|
|
3
|
+
const sample = new Array(samplesCount);
|
|
4
|
+
for (let i = 0; i < samplesCount; i++) {
|
|
5
|
+
const r = Math.random();
|
|
6
|
+
sample[i] = bottom + r * scale;
|
|
7
|
+
}
|
|
8
|
+
return sample;
|
|
9
|
+
}
|
|
10
|
+
export function sampleParams(samplesCount, top, bottom) {
|
|
11
|
+
const dim = top.length;
|
|
12
|
+
const params = new Array(samplesCount);
|
|
13
|
+
for (let i = 0; i < samplesCount; i++)
|
|
14
|
+
params[i] = new Float32Array(dim);
|
|
15
|
+
for (let i = 0; i < dim; i++) {
|
|
16
|
+
if (top[i] === bottom[i]) {
|
|
17
|
+
for (let j = 0; j < samplesCount; j++)
|
|
18
|
+
params[j][i] = top[i];
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
const paramVariations = sampleUniform(samplesCount, top[i], bottom[i]);
|
|
22
|
+
for (let j = 0; j < samplesCount; j++)
|
|
23
|
+
params[j][i] = paramVariations[j];
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return params;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW1pemVyLXNhbXBsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJvcHRpbWl6ZXItc2FtcGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxTQUFTLGFBQWEsQ0FBQyxZQUFvQixFQUFFLEdBQVcsRUFBRSxNQUFjO0lBQ3RFLE1BQU0sS0FBSyxHQUFHLEdBQUcsR0FBRyxNQUFNLENBQUM7SUFDM0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxLQUFLLENBQVMsWUFBWSxDQUFDLENBQUM7SUFFL0MsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFlBQVksRUFBRSxDQUFDLEVBQUcsRUFBRTtRQUN0QyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDeEIsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLE1BQU0sR0FBRyxDQUFDLEdBQUcsS0FBSyxDQUFDO0tBQ2hDO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSxZQUFZLENBQUMsWUFBb0IsRUFBRSxHQUFpQixFQUFFLE1BQW9CO0lBQ3hGLE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUM7SUFDdkIsTUFBTSxNQUFNLEdBQUcsSUFBSSxLQUFLLENBQWUsWUFBWSxDQUFDLENBQUM7SUFDckQsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFlBQVksRUFBRSxDQUFDLEVBQUc7UUFDcEMsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXBDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxFQUFHLEVBQUU7UUFDN0IsSUFBSSxHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3hCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxZQUFZLEVBQUUsQ0FBQyxFQUFHO2dCQUNwQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ3pCO2FBQ0k7WUFDSCxNQUFNLGVBQWUsR0FBRyxhQUFhLENBQUMsWUFBWSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN2RSxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsWUFBWSxFQUFFLENBQUMsRUFBRztnQkFDcEMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUNyQztLQUNGO0lBRUQsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImZ1bmN0aW9uIHNhbXBsZVVuaWZvcm0oc2FtcGxlc0NvdW50OiBudW1iZXIsIHRvcDogbnVtYmVyLCBib3R0b206IG51bWJlcik6IG51bWJlcltdIHtcbiAgY29uc3Qgc2NhbGUgPSB0b3AgLSBib3R0b207XG4gIGNvbnN0IHNhbXBsZSA9IG5ldyBBcnJheTxudW1iZXI+KHNhbXBsZXNDb3VudCk7XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBzYW1wbGVzQ291bnQ7IGkgKyspIHtcbiAgICBjb25zdCByID0gTWF0aC5yYW5kb20oKTtcbiAgICBzYW1wbGVbaV0gPSBib3R0b20gKyByICogc2NhbGU7XG4gIH1cblxuICByZXR1cm4gc2FtcGxlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2FtcGxlUGFyYW1zKHNhbXBsZXNDb3VudDogbnVtYmVyLCB0b3A6IEZsb2F0MzJBcnJheSwgYm90dG9tOiBGbG9hdDMyQXJyYXkpOiBGbG9hdDMyQXJyYXlbXSB7XG4gIGNvbnN0IGRpbSA9IHRvcC5sZW5ndGg7XG4gIGNvbnN0IHBhcmFtcyA9IG5ldyBBcnJheTxGbG9hdDMyQXJyYXk+KHNhbXBsZXNDb3VudCk7XG4gIGZvciAobGV0IGkgPSAwOyBpIDwgc2FtcGxlc0NvdW50OyBpICsrKVxuICAgIHBhcmFtc1tpXSA9IG5ldyBGbG9hdDMyQXJyYXkoZGltKTtcblxuICBmb3IgKGxldCBpID0gMDsgaSA8IGRpbTsgaSArKykge1xuICAgIGlmICh0b3BbaV0gPT09IGJvdHRvbVtpXSkge1xuICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBzYW1wbGVzQ291bnQ7IGogKyspXG4gICAgICAgIHBhcmFtc1tqXVtpXSA9IHRvcFtpXTtcbiAgICB9XG4gICAgZWxzZSB7XG4gICAgICBjb25zdCBwYXJhbVZhcmlhdGlvbnMgPSBzYW1wbGVVbmlmb3JtKHNhbXBsZXNDb3VudCwgdG9wW2ldLCBib3R0b21baV0pO1xuICAgICAgZm9yIChsZXQgaiA9IDA7IGogPCBzYW1wbGVzQ291bnQ7IGogKyspXG4gICAgICAgIHBhcmFtc1tqXVtpXSA9IHBhcmFtVmFyaWF0aW9uc1tqXTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gcGFyYW1zO1xufVxuIl19
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { OptimizationResult } from './optimizer-misc';
|
|
2
|
+
import { NelderMeadSettings } from './optimizer-nelder-mead';
|
|
3
|
+
export declare function performNelderMeadOptimization(objectiveFunc: (x: Float32Array) => number, paramsBottom: Float32Array, paramsTop: Float32Array, settings: NelderMeadSettings, samplesCount?: number, initialValues?: Float32Array | null, infiniteFirst?: boolean): OptimizationResult;
|
|
4
|
+
//# sourceMappingURL=optimizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"optimizer.d.ts","sourceRoot":"","sources":["optimizer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAW,kBAAkB,EAAqB,MAAM,kBAAkB,CAAC;AAClF,OAAO,EAAa,kBAAkB,EAAC,MAAM,yBAAyB,CAAC;AAIvE,wBAAgB,6BAA6B,CAC3C,aAAa,EAAE,CAAC,CAAC,EAAE,YAAY,KAAK,MAAM,EAC1C,YAAY,EAAE,YAAY,EAC1B,SAAS,EAAE,YAAY,EACvB,QAAQ,EAAE,kBAAkB,EAC5B,YAAY,GAAE,MAAU,EACxB,aAAa,GAAE,YAAY,GAAG,IAAW,EACzC,aAAa,GAAE,OAAc,GAC5B,kBAAkB,CA8CpB"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/** the Nelder-Mead optimizer */
|
|
2
|
+
import * as DG from 'datagrok-api/dg';
|
|
3
|
+
import { InconsistentTables } from './optimizer-misc';
|
|
4
|
+
import { optimizeNM } from './optimizer-nelder-mead';
|
|
5
|
+
import { sampleParams } from './optimizer-sampler';
|
|
6
|
+
export function performNelderMeadOptimization(objectiveFunc, paramsBottom, paramsTop, settings, samplesCount = 1, initialValues = null, infiniteFirst = true) {
|
|
7
|
+
const params = sampleParams(samplesCount, paramsTop, paramsBottom);
|
|
8
|
+
if (initialValues !== null)
|
|
9
|
+
params[0] = initialValues;
|
|
10
|
+
const extremums = [];
|
|
11
|
+
const warnings = [];
|
|
12
|
+
const failedInitPoint = [];
|
|
13
|
+
let failsCount = 0;
|
|
14
|
+
let failsDF = null;
|
|
15
|
+
let i;
|
|
16
|
+
for (i = 0; i < samplesCount; ++i) {
|
|
17
|
+
try {
|
|
18
|
+
if (i === 0 && infiniteFirst) {
|
|
19
|
+
const paramsB = new Float32Array(initialValues.length).map((_) => -Infinity);
|
|
20
|
+
const paramsT = new Float32Array(initialValues.length).map((_) => +Infinity);
|
|
21
|
+
extremums.push(optimizeNM(objectiveFunc, params[i], settings, paramsB, paramsT));
|
|
22
|
+
}
|
|
23
|
+
else
|
|
24
|
+
extremums.push(optimizeNM(objectiveFunc, params[i], settings, paramsBottom, paramsTop));
|
|
25
|
+
}
|
|
26
|
+
catch (e) {
|
|
27
|
+
if (e instanceof InconsistentTables)
|
|
28
|
+
throw new Error(`Inconsistent dataframes: ${e.message}`);
|
|
29
|
+
++failsCount;
|
|
30
|
+
warnings.push((e instanceof Error) ? e.message : 'Platform issue');
|
|
31
|
+
failedInitPoint.push(params[i]);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
if (failsCount > 0) {
|
|
35
|
+
const dim = paramsTop.length;
|
|
36
|
+
const raw = new Array(dim);
|
|
37
|
+
for (let i = 0; i < dim; ++i)
|
|
38
|
+
raw[i] = new Float32Array(failsCount);
|
|
39
|
+
failedInitPoint.forEach((point, idx) => point.forEach((val, jdx) => raw[jdx][idx] = val));
|
|
40
|
+
failsDF = DG.DataFrame.fromColumns(raw.map((arr, idx) => DG.Column.fromFloat32Array(`arg${idx}`, arr)));
|
|
41
|
+
failsDF.columns.add(DG.Column.fromStrings('Issue', warnings));
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
extremums: extremums,
|
|
45
|
+
fails: failsDF,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW1pemVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsib3B0aW1pemVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGdDQUFnQztBQUNoQyxPQUFPLEtBQUssRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3RDLE9BQU8sRUFBK0Isa0JBQWtCLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUNsRixPQUFPLEVBQUMsVUFBVSxFQUFxQixNQUFNLHlCQUF5QixDQUFDO0FBQ3ZFLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUdqRCxNQUFNLFVBQVUsNkJBQTZCLENBQzNDLGFBQTBDLEVBQzFDLFlBQTBCLEVBQzFCLFNBQXVCLEVBQ3ZCLFFBQTRCLEVBQzVCLGVBQXVCLENBQUMsRUFDeEIsZ0JBQXFDLElBQUksRUFDekMsZ0JBQXlCLElBQUk7SUFFN0IsTUFBTSxNQUFNLEdBQUcsWUFBWSxDQUFDLFlBQVksRUFBRSxTQUFTLEVBQUUsWUFBWSxDQUFDLENBQUM7SUFDbkUsSUFBSSxhQUFhLEtBQUssSUFBSTtRQUN4QixNQUFNLENBQUMsQ0FBQyxDQUFDLEdBQUcsYUFBYSxDQUFDO0lBRTVCLE1BQU0sU0FBUyxHQUFlLEVBQUUsQ0FBQztJQUNqQyxNQUFNLFFBQVEsR0FBYSxFQUFFLENBQUM7SUFDOUIsTUFBTSxlQUFlLEdBQW1CLEVBQUUsQ0FBQztJQUMzQyxJQUFJLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFDbkIsSUFBSSxPQUFPLEdBQXdCLElBQUksQ0FBQztJQUN4QyxJQUFJLENBQVMsQ0FBQztJQUVkLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsWUFBWSxFQUFFLEVBQUUsQ0FBQyxFQUFFO1FBQ2pDLElBQUk7WUFDRixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksYUFBYSxFQUFFO2dCQUM1QixNQUFNLE9BQU8sR0FBRyxJQUFJLFlBQVksQ0FBQyxhQUFjLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUM5RSxNQUFNLE9BQU8sR0FBRyxJQUFJLFlBQVksQ0FBQyxhQUFjLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUM5RSxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQzthQUNsRjs7Z0JBQ0MsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUM7U0FDM0Y7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLElBQUksQ0FBQyxZQUFZLGtCQUFrQjtnQkFDakMsTUFBTSxJQUFJLEtBQUssQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7WUFFM0QsRUFBRSxVQUFVLENBQUM7WUFDYixRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxZQUFZLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQ25FLGVBQWUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7U0FDakM7S0FDRjtJQUVELElBQUksVUFBVSxHQUFHLENBQUMsRUFBRTtRQUNsQixNQUFNLEdBQUcsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDO1FBQzdCLE1BQU0sR0FBRyxHQUFHLElBQUksS0FBSyxDQUFlLEdBQUcsQ0FBQyxDQUFDO1FBRXpDLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsRUFBRSxDQUFDO1lBQzFCLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUV4QyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQzFGLE9BQU8sR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxFQUFFLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEdBQUcsRUFBRSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN4RyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUMsQ0FBQztLQUMvRDtJQUVELE9BQU87UUFDTCxTQUFTLEVBQUUsU0FBUztRQUNwQixLQUFLLEVBQUUsT0FBTztLQUNmLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqIHRoZSBOZWxkZXItTWVhZCBvcHRpbWl6ZXIgKi9cbmltcG9ydCAqIGFzIERHIGZyb20gJ2RhdGFncm9rLWFwaS9kZyc7XG5pbXBvcnQge0V4dHJlbXVtLCBPcHRpbWl6YXRpb25SZXN1bHQsIEluY29uc2lzdGVudFRhYmxlc30gZnJvbSAnLi9vcHRpbWl6ZXItbWlzYyc7XG5pbXBvcnQge29wdGltaXplTk0sIE5lbGRlck1lYWRTZXR0aW5nc30gZnJvbSAnLi9vcHRpbWl6ZXItbmVsZGVyLW1lYWQnO1xuaW1wb3J0IHtzYW1wbGVQYXJhbXN9IGZyb20gJy4vb3B0aW1pemVyLXNhbXBsZXInO1xuXG5cbmV4cG9ydCBmdW5jdGlvbiBwZXJmb3JtTmVsZGVyTWVhZE9wdGltaXphdGlvbihcbiAgb2JqZWN0aXZlRnVuYzogKHg6IEZsb2F0MzJBcnJheSkgPT4gbnVtYmVyLFxuICBwYXJhbXNCb3R0b206IEZsb2F0MzJBcnJheSxcbiAgcGFyYW1zVG9wOiBGbG9hdDMyQXJyYXksXG4gIHNldHRpbmdzOiBOZWxkZXJNZWFkU2V0dGluZ3MsXG4gIHNhbXBsZXNDb3VudDogbnVtYmVyID0gMSxcbiAgaW5pdGlhbFZhbHVlczogRmxvYXQzMkFycmF5IHwgbnVsbCA9IG51bGwsXG4gIGluZmluaXRlRmlyc3Q6IGJvb2xlYW4gPSB0cnVlLFxuKTogT3B0aW1pemF0aW9uUmVzdWx0IHtcbiAgY29uc3QgcGFyYW1zID0gc2FtcGxlUGFyYW1zKHNhbXBsZXNDb3VudCwgcGFyYW1zVG9wLCBwYXJhbXNCb3R0b20pO1xuICBpZiAoaW5pdGlhbFZhbHVlcyAhPT0gbnVsbClcbiAgICBwYXJhbXNbMF0gPSBpbml0aWFsVmFsdWVzO1xuXG4gIGNvbnN0IGV4dHJlbXVtczogRXh0cmVtdW1bXSA9IFtdO1xuICBjb25zdCB3YXJuaW5nczogc3RyaW5nW10gPSBbXTtcbiAgY29uc3QgZmFpbGVkSW5pdFBvaW50OiBGbG9hdDMyQXJyYXlbXSA9IFtdO1xuICBsZXQgZmFpbHNDb3VudCA9IDA7XG4gIGxldCBmYWlsc0RGOiBERy5EYXRhRnJhbWUgfCBudWxsID0gbnVsbDtcbiAgbGV0IGk6IG51bWJlcjtcblxuICBmb3IgKGkgPSAwOyBpIDwgc2FtcGxlc0NvdW50OyArK2kpIHtcbiAgICB0cnkge1xuICAgICAgaWYgKGkgPT09IDAgJiYgaW5maW5pdGVGaXJzdCkge1xuICAgICAgICBjb25zdCBwYXJhbXNCID0gbmV3IEZsb2F0MzJBcnJheShpbml0aWFsVmFsdWVzIS5sZW5ndGgpLm1hcCgoXykgPT4gLUluZmluaXR5KTtcbiAgICAgICAgY29uc3QgcGFyYW1zVCA9IG5ldyBGbG9hdDMyQXJyYXkoaW5pdGlhbFZhbHVlcyEubGVuZ3RoKS5tYXAoKF8pID0+ICtJbmZpbml0eSk7XG4gICAgICAgIGV4dHJlbXVtcy5wdXNoKG9wdGltaXplTk0ob2JqZWN0aXZlRnVuYywgcGFyYW1zW2ldLCBzZXR0aW5ncywgcGFyYW1zQiwgcGFyYW1zVCkpO1xuICAgICAgfSBlbHNlXG4gICAgICAgIGV4dHJlbXVtcy5wdXNoKG9wdGltaXplTk0ob2JqZWN0aXZlRnVuYywgcGFyYW1zW2ldLCBzZXR0aW5ncywgcGFyYW1zQm90dG9tLCBwYXJhbXNUb3ApKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBpZiAoZSBpbnN0YW5jZW9mIEluY29uc2lzdGVudFRhYmxlcylcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbmNvbnNpc3RlbnQgZGF0YWZyYW1lczogJHtlLm1lc3NhZ2V9YCk7XG5cbiAgICAgICsrZmFpbHNDb3VudDtcbiAgICAgIHdhcm5pbmdzLnB1c2goKGUgaW5zdGFuY2VvZiBFcnJvcikgPyBlLm1lc3NhZ2UgOiAnUGxhdGZvcm0gaXNzdWUnKTtcbiAgICAgIGZhaWxlZEluaXRQb2ludC5wdXNoKHBhcmFtc1tpXSk7XG4gICAgfVxuICB9XG5cbiAgaWYgKGZhaWxzQ291bnQgPiAwKSB7XG4gICAgY29uc3QgZGltID0gcGFyYW1zVG9wLmxlbmd0aDtcbiAgICBjb25zdCByYXcgPSBuZXcgQXJyYXk8RmxvYXQzMkFycmF5PihkaW0pO1xuXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBkaW07ICsraSlcbiAgICAgIHJhd1tpXSA9IG5ldyBGbG9hdDMyQXJyYXkoZmFpbHNDb3VudCk7XG5cbiAgICBmYWlsZWRJbml0UG9pbnQuZm9yRWFjaCgocG9pbnQsIGlkeCkgPT4gcG9pbnQuZm9yRWFjaCgodmFsLCBqZHgpID0+IHJhd1tqZHhdW2lkeF0gPSB2YWwpKTtcbiAgICBmYWlsc0RGID0gREcuRGF0YUZyYW1lLmZyb21Db2x1bW5zKHJhdy5tYXAoKGFyciwgaWR4KSA9PiBERy5Db2x1bW4uZnJvbUZsb2F0MzJBcnJheShgYXJnJHtpZHh9YCwgYXJyKSkpO1xuICAgIGZhaWxzREYuY29sdW1ucy5hZGQoREcuQ29sdW1uLmZyb21TdHJpbmdzKCdJc3N1ZScsIHdhcm5pbmdzKSk7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGV4dHJlbXVtczogZXh0cmVtdW1zLFxuICAgIGZhaWxzOiBmYWlsc0RGLFxuICB9O1xufVxuIl19
|
package/lbfgs/lbfgs.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function limitedMemoryBFGS(optimizable: any, parameters: any): any;
|