@things-factory/spc 7.0.0-alpha.18
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/CHANGELOG.md +8 -0
- package/client/bootstrap.ts +1 -0
- package/client/index.ts +0 -0
- package/client/pages/spc-chart-page.ts +322 -0
- package/client/route.ts +7 -0
- package/client/tsconfig.json +13 -0
- package/dist-client/bootstrap.d.ts +1 -0
- package/dist-client/bootstrap.js +2 -0
- package/dist-client/bootstrap.js.map +1 -0
- package/dist-client/index.d.ts +0 -0
- package/dist-client/index.js +2 -0
- package/dist-client/index.js.map +1 -0
- package/dist-client/pages/spc-chart-page.d.ts +44 -0
- package/dist-client/pages/spc-chart-page.js +309 -0
- package/dist-client/pages/spc-chart-page.js.map +1 -0
- package/dist-client/route.d.ts +1 -0
- package/dist-client/route.js +8 -0
- package/dist-client/route.js.map +1 -0
- package/dist-client/tsconfig.tsbuildinfo +1 -0
- package/dist-server/controllers/data-use-case-spc.js +40 -0
- package/dist-server/controllers/data-use-case-spc.js.map +1 -0
- package/dist-server/controllers/index.js +5 -0
- package/dist-server/controllers/index.js.map +1 -0
- package/dist-server/controllers/rules/cp-cpk.js +21 -0
- package/dist-server/controllers/rules/cp-cpk.js.map +1 -0
- package/dist-server/controllers/spc-chart/c.js +26 -0
- package/dist-server/controllers/spc-chart/c.js.map +1 -0
- package/dist-server/controllers/spc-chart/histogram.js +26 -0
- package/dist-server/controllers/spc-chart/histogram.js.map +1 -0
- package/dist-server/controllers/spc-chart/i.js +26 -0
- package/dist-server/controllers/spc-chart/i.js.map +1 -0
- package/dist-server/controllers/spc-chart/index.js +172 -0
- package/dist-server/controllers/spc-chart/index.js.map +1 -0
- package/dist-server/controllers/spc-chart/mr.js +25 -0
- package/dist-server/controllers/spc-chart/mr.js.map +1 -0
- package/dist-server/controllers/spc-chart/np.js +26 -0
- package/dist-server/controllers/spc-chart/np.js.map +1 -0
- package/dist-server/controllers/spc-chart/p.js +25 -0
- package/dist-server/controllers/spc-chart/p.js.map +1 -0
- package/dist-server/controllers/spc-chart/pareto.js +24 -0
- package/dist-server/controllers/spc-chart/pareto.js.map +1 -0
- package/dist-server/controllers/spc-chart/r.js +31 -0
- package/dist-server/controllers/spc-chart/r.js.map +1 -0
- package/dist-server/controllers/spc-chart/u.js +27 -0
- package/dist-server/controllers/spc-chart/u.js.map +1 -0
- package/dist-server/controllers/spc-chart/x-bar-r.js +45 -0
- package/dist-server/controllers/spc-chart/x-bar-r.js.map +1 -0
- package/dist-server/controllers/spc-chart/x-bar.js +45 -0
- package/dist-server/controllers/spc-chart/x-bar.js.map +1 -0
- package/dist-server/index.js +11 -0
- package/dist-server/index.js.map +1 -0
- package/dist-server/service/index.js +21 -0
- package/dist-server/service/index.js.map +1 -0
- package/dist-server/service/spc-chart/index.js +8 -0
- package/dist-server/service/spc-chart/index.js.map +1 -0
- package/dist-server/service/spc-chart/spc-chart-query.js +99 -0
- package/dist-server/service/spc-chart/spc-chart-query.js.map +1 -0
- package/dist-server/service/spc-chart/spc-chart-type.js +134 -0
- package/dist-server/service/spc-chart/spc-chart-type.js.map +1 -0
- package/dist-server/tsconfig.tsbuildinfo +1 -0
- package/helps/spc/spc-chart-concept.md +59 -0
- package/helps/spc/spc-chart.md +68 -0
- package/package.json +37 -0
- package/server/controllers/data-use-case-spc.ts +44 -0
- package/server/controllers/index.ts +1 -0
- package/server/controllers/rules/cp-cpk.ts +29 -0
- package/server/controllers/spc-chart/c.ts +31 -0
- package/server/controllers/spc-chart/histogram.ts +38 -0
- package/server/controllers/spc-chart/i.ts +31 -0
- package/server/controllers/spc-chart/index.ts +171 -0
- package/server/controllers/spc-chart/mr.ts +30 -0
- package/server/controllers/spc-chart/np.ts +30 -0
- package/server/controllers/spc-chart/p.ts +29 -0
- package/server/controllers/spc-chart/pareto.ts +32 -0
- package/server/controllers/spc-chart/r.ts +34 -0
- package/server/controllers/spc-chart/u.ts +31 -0
- package/server/controllers/spc-chart/x-bar-r.ts +53 -0
- package/server/controllers/spc-chart/x-bar.ts +53 -0
- package/server/index.ts +10 -0
- package/server/service/index.ts +21 -0
- package/server/service/spc-chart/index.ts +5 -0
- package/server/service/spc-chart/spc-chart-query.ts +102 -0
- package/server/service/spc-chart/spc-chart-type.ts +105 -0
- package/server/tsconfig.json +10 -0
- package/things-factory.config.js +11 -0
- package/translations/en.json +3 -0
- package/translations/ja.json +3 -0
- package/translations/ko.json +3 -0
- package/translations/ms.json +3 -0
- package/translations/zh.json +3 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-use-case-spc.js","sourceRoot":"","sources":["../../server/controllers/data-use-case-spc.ts"],"names":[],"mappings":";;;AAEA,MAAa,cAAc;IACzB,gBAAgB;QACd,OAAO;YACL,IAAI,EAAE,KAAK;YACX,WAAW,EAAE,uCAAuC;YACpD,IAAI,EAAE,EAAE;YACR,KAAK,EAAE;gBACL;oBACE,IAAI,EAAE,YAAY,CAAC,kEAAkE;oBACrF,KAAK,EAAE,gBAAgB;oBACvB,IAAI,EAAE,eAAe;iBACtB;aACF;SACF,CAAA;IACH,CAAC;IAED,QAAQ,CAAC,IAAS,EAAE,MAAmB;QACrC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,CAAA;QAE/D,IAAI,CAAC,CAAC,MAAM,YAAY,KAAK,CAAC,EAAE;YAC9B,MAAM,GAAG,CAAC,MAAM,CAAC,CAAA;SAClB;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACtC,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA;YAEvB,IAAI,OAAO,IAAI,IAAI,IAAI,KAAK,GAAG,OAAO,EAAE;gBACtC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,CAAA;aAChC;YAED,IAAI,OAAO,IAAI,IAAI,IAAI,KAAK,GAAG,OAAO,EAAE;gBACtC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,CAAA;aAChC;YAED,IAAI,WAAW,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gBACvD,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,CAAA;aAChC;SACF;QAED,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,CAAA;IACnC,CAAC;CACF;AAzCD,wCAyCC","sourcesContent":["import { DataItemSpecSet, DataUseCase, EvaluationResult } from '@things-factory/dataset'\n\nexport class DataUseCaseSPC implements DataUseCase {\n getSpecification(): DataItemSpecSet {\n return {\n name: 'SPC',\n description: 'Statistical Process Control Data Spec',\n help: '',\n specs: [\n {\n type: 'spc-limits' /* 'A value which seperates acceptability from unacceptability' */,\n label: 'control limits',\n name: 'controlLimits'\n }\n ]\n }\n }\n\n evaluate(spec: any, values: any | any[]): EvaluationResult {\n const { minimum, maximum, acceptables } = spec['controlLimits']\n\n if (!(values instanceof Array)) {\n values = [values]\n }\n\n for (let i = 0; i < values.length; i++) {\n const value = values[i]\n\n if (minimum != null && value < minimum) {\n return { oos: true, ooc: true }\n }\n\n if (maximum != null && value > maximum) {\n return { oos: true, ooc: true }\n }\n\n if (acceptables != null && !acceptables.includes(value)) {\n return { oos: true, ooc: true }\n }\n }\n\n return { oos: false, ooc: false }\n }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/controllers/index.ts"],"names":[],"mappings":";;;AAAA,8DAAmC","sourcesContent":["export * from './data-use-case-spc'\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
function calculateProcessCapability(plots, USL, LSL) {
|
|
4
|
+
// 전체 평균 계산
|
|
5
|
+
const overallMean = plots.reduce((sum, plot) => sum + plot.xbar, 0) / plots.length;
|
|
6
|
+
// 전체 표준 편차 계산
|
|
7
|
+
let allValues = plots.flatMap(plot => plot.values);
|
|
8
|
+
const meanOfAllValues = allValues.reduce((sum, value) => sum + value, 0) / allValues.length;
|
|
9
|
+
const squaredDiffs = allValues.map(value => Math.pow(value - meanOfAllValues, 2));
|
|
10
|
+
const variance = squaredDiffs.reduce((sum, diff) => sum + diff, 0) / (allValues.length - 1);
|
|
11
|
+
const stdDeviation = Math.sqrt(variance);
|
|
12
|
+
// CP 계산
|
|
13
|
+
const cp = (USL - LSL) / (6 * stdDeviation);
|
|
14
|
+
// CPK 계산
|
|
15
|
+
const cpk = Math.min((USL - overallMean) / (3 * stdDeviation), (overallMean - LSL) / (3 * stdDeviation));
|
|
16
|
+
return {
|
|
17
|
+
cp,
|
|
18
|
+
cpk
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=cp-cpk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cp-cpk.js","sourceRoot":"","sources":["../../../server/controllers/rules/cp-cpk.ts"],"names":[],"mappings":";;AAOA,SAAS,0BAA0B,CAAC,KAAqB,EAAE,GAAW,EAAE,GAAW;IACjF,WAAW;IACX,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAA;IAElF,cAAc;IACd,IAAI,SAAS,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAClD,MAAM,eAAe,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,GAAG,KAAK,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC,MAAM,CAAA;IAC3F,MAAM,YAAY,GAAG,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,eAAe,EAAE,CAAC,CAAC,CAAC,CAAA;IACjF,MAAM,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IAC3F,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IAExC,QAAQ;IACR,MAAM,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC,CAAA;IAE3C,SAAS;IACT,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC,EAAE,CAAC,WAAW,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,CAAA;IAExG,OAAO;QACL,EAAE;QACF,GAAG;KACJ,CAAA;AACH,CAAC","sourcesContent":["import { SPCChartPlot } from '../../service/spc-chart/spc-chart-type'\n\ninterface ProcessCapabilityAnalysis {\n cp: number\n cpk: number\n}\n\nfunction calculateProcessCapability(plots: SPCChartPlot[], USL: number, LSL: number): ProcessCapabilityAnalysis {\n // 전체 평균 계산\n const overallMean = plots.reduce((sum, plot) => sum + plot.xbar, 0) / plots.length\n\n // 전체 표준 편차 계산\n let allValues = plots.flatMap(plot => plot.values)\n const meanOfAllValues = allValues.reduce((sum, value) => sum + value, 0) / allValues.length\n const squaredDiffs = allValues.map(value => Math.pow(value - meanOfAllValues, 2))\n const variance = squaredDiffs.reduce((sum, diff) => sum + diff, 0) / (allValues.length - 1)\n const stdDeviation = Math.sqrt(variance)\n\n // CP 계산\n const cp = (USL - LSL) / (6 * stdDeviation)\n\n // CPK 계산\n const cpk = Math.min((USL - overallMean) / (3 * stdDeviation), (overallMean - LSL) / (3 * stdDeviation))\n\n return {\n cp,\n cpk\n }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateCChartAnalysisResult = void 0;
|
|
4
|
+
function calculateCChartAnalysisResult(plots) {
|
|
5
|
+
// 각 샘플의 평균을 계산
|
|
6
|
+
plots = plots.map(plot => (Object.assign(Object.assign({}, plot), { defects: plot.values.map(Boolean).length, n: plot.values.length })));
|
|
7
|
+
// 총 결함 수를 계산합니다.
|
|
8
|
+
const totalDefects = plots.reduce((sum, { defects }) => sum + defects, 0);
|
|
9
|
+
// 평균 결함 수(C-bar)를 계산합니다.
|
|
10
|
+
const cl = totalDefects / plots.length;
|
|
11
|
+
// 상한 제어선(UCL)과 하한 제어선(LCL)을 계산합니다.
|
|
12
|
+
// 포아송 분포를 가정할 때, UCL = C-bar + 3*sqrt(C-bar), LCL = C-bar - 3*sqrt(C-bar) (단, LCL이 음수인 경우 0으로 설정)
|
|
13
|
+
const ucl = cl + 3 * Math.sqrt(cl);
|
|
14
|
+
const lcl = Math.max(cl - 3 * Math.sqrt(cl), 0);
|
|
15
|
+
return {
|
|
16
|
+
chartType: 'C',
|
|
17
|
+
controlLimits: {
|
|
18
|
+
ucl,
|
|
19
|
+
lcl,
|
|
20
|
+
cl
|
|
21
|
+
},
|
|
22
|
+
plots
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
exports.calculateCChartAnalysisResult = calculateCChartAnalysisResult;
|
|
26
|
+
//# sourceMappingURL=c.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"c.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/c.ts"],"names":[],"mappings":";;;AAEA,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,iCACrB,IAAI,KACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,MAAM,EACxC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,IACrB,CAAC,CAAA;IAEH,iBAAiB;IACjB,MAAM,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,GAAG,GAAG,OAAO,EAAE,CAAC,CAAC,CAAA;IAEzE,yBAAyB;IACzB,MAAM,EAAE,GAAG,YAAY,GAAG,KAAK,CAAC,MAAM,CAAA;IAEtC,mCAAmC;IACnC,kGAAkG;IAClG,MAAM,GAAG,GAAG,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IAClC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAA;IAE/C,OAAO;QACL,SAAS,EAAE,GAAG;QACd,aAAa,EAAE;YACb,GAAG;YACH,GAAG;YACH,EAAE;SACH;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA5BD,sEA4BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculateCChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map(plot => ({\n ...plot,\n defects: plot.values.map(Boolean).length,\n n: plot.values.length\n }))\n\n // 총 결함 수를 계산합니다.\n const totalDefects = plots.reduce((sum, { defects }) => sum + defects, 0)\n\n // 평균 결함 수(C-bar)를 계산합니다.\n const cl = totalDefects / plots.length\n\n // 상한 제어선(UCL)과 하한 제어선(LCL)을 계산합니다.\n // 포아송 분포를 가정할 때, UCL = C-bar + 3*sqrt(C-bar), LCL = C-bar - 3*sqrt(C-bar) (단, LCL이 음수인 경우 0으로 설정)\n const ucl = cl + 3 * Math.sqrt(cl)\n const lcl = Math.max(cl - 3 * Math.sqrt(cl), 0)\n\n return {\n chartType: 'C',\n controlLimits: {\n ucl,\n lcl,\n cl\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateHistogram = void 0;
|
|
4
|
+
function calculateHistogram(samples, numBins) {
|
|
5
|
+
const values = samples.map(sample => sample.value);
|
|
6
|
+
const minValue = Math.min(...values);
|
|
7
|
+
const maxValue = Math.max(...values);
|
|
8
|
+
const range = maxValue - minValue;
|
|
9
|
+
const binWidth = range / numBins;
|
|
10
|
+
// 초기화된 구간 배열 생성
|
|
11
|
+
const bins = Array.from({ length: numBins }, (_, i) => ({
|
|
12
|
+
binRange: `${(minValue + i * binWidth).toFixed(2)}-${(minValue + (i + 1) * binWidth).toFixed(2)}`,
|
|
13
|
+
count: 0
|
|
14
|
+
}));
|
|
15
|
+
// 각 샘플을 적절한 구간에 할당하고 개수를 세어 구간의 개수를 업데이트합니다.
|
|
16
|
+
samples.forEach(sample => {
|
|
17
|
+
const binIndex = Math.min(numBins - 1, Math.floor((sample.value - minValue) / binWidth));
|
|
18
|
+
bins[binIndex].count++;
|
|
19
|
+
});
|
|
20
|
+
return {
|
|
21
|
+
chartType: 'Histogram',
|
|
22
|
+
bins
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
exports.calculateHistogram = calculateHistogram;
|
|
26
|
+
//# sourceMappingURL=histogram.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"histogram.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/histogram.ts"],"names":[],"mappings":";;;AAcA,SAAgB,kBAAkB,CAAC,OAA0B,EAAE,OAAe;IAC5E,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAA;IACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAA;IACpC,MAAM,KAAK,GAAG,QAAQ,GAAG,QAAQ,CAAA;IACjC,MAAM,QAAQ,GAAG,KAAK,GAAG,OAAO,CAAA;IAEhC,gBAAgB;IAChB,MAAM,IAAI,GAAmB,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QACtE,QAAQ,EAAE,GAAG,CAAC,QAAQ,GAAG,CAAC,GAAG,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;QACjG,KAAK,EAAE,CAAC;KACT,CAAC,CAAC,CAAA;IAEH,6CAA6C;IAC7C,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;QACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,GAAG,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAA;QACxF,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,EAAE,CAAA;IACxB,CAAC,CAAC,CAAA;IAEF,OAAO;QACL,SAAS,EAAE,WAAW;QACtB,IAAI;KACL,CAAA;AACH,CAAC;AAvBD,gDAuBC","sourcesContent":["interface HistogramSample {\n value: number\n}\n\ninterface HistogramBin {\n binRange: string // 구간을 나타내는 문자열, 예: \"0-1\"\n count: number // 해당 구간에 속하는 데이터의 개수\n}\n\ninterface HistogramResult {\n chartType: 'Histogram'\n bins: HistogramBin[] // 히스토그램의 각 구간과 해당 구간의 데이터 개수\n}\n\nexport function calculateHistogram(samples: HistogramSample[], numBins: number): HistogramResult {\n const values = samples.map(sample => sample.value)\n const minValue = Math.min(...values)\n const maxValue = Math.max(...values)\n const range = maxValue - minValue\n const binWidth = range / numBins\n\n // 초기화된 구간 배열 생성\n const bins: HistogramBin[] = Array.from({ length: numBins }, (_, i) => ({\n binRange: `${(minValue + i * binWidth).toFixed(2)}-${(minValue + (i + 1) * binWidth).toFixed(2)}`,\n count: 0\n }))\n\n // 각 샘플을 적절한 구간에 할당하고 개수를 세어 구간의 개수를 업데이트합니다.\n samples.forEach(sample => {\n const binIndex = Math.min(numBins - 1, Math.floor((sample.value - minValue) / binWidth))\n bins[binIndex].count++\n })\n\n return {\n chartType: 'Histogram',\n bins\n }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateIChartAnalysisResult = void 0;
|
|
4
|
+
function calculateIChartAnalysisResult(plots) {
|
|
5
|
+
// 각 샘플의 평균을 계산
|
|
6
|
+
plots = plots.map((plot, index) => (Object.assign(Object.assign({}, plot), { i: plot.values[0], mr: index == 0 ? 0 : Math.abs(plot.values[0] - plots[index - 1].values[0]) })));
|
|
7
|
+
// 개별 측정값의 평균을 계산하여 중심선(cl)을 구합니다.
|
|
8
|
+
const cl = plots.reduce((acc, plot) => acc + plot.values[0], 0) / plots.length;
|
|
9
|
+
// 개별 측정값의 표준편차를 계산합니다.
|
|
10
|
+
const standardDeviation = Math.sqrt(plots.reduce((acc, plot) => acc + Math.pow(plot.values[0] - cl, 2), 0) / plots.length);
|
|
11
|
+
// 공정 변동을 고려하여 상한 제어선(ucl)과 하한 제어선(lcl)을 계산합니다.
|
|
12
|
+
// 여기서는 3시그마(3 * 표준편차)를 사용합니다. 상황에 따라 적절한 시그마 수준을 조정할 수 있습니다.
|
|
13
|
+
const ucl = cl + 3 * standardDeviation;
|
|
14
|
+
const lcl = cl - 3 * standardDeviation;
|
|
15
|
+
return {
|
|
16
|
+
chartType: 'I',
|
|
17
|
+
controlLimits: {
|
|
18
|
+
cl,
|
|
19
|
+
ucl,
|
|
20
|
+
lcl
|
|
21
|
+
},
|
|
22
|
+
plots
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
exports.calculateIChartAnalysisResult = calculateIChartAnalysisResult;
|
|
26
|
+
//# sourceMappingURL=i.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"i.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/i.ts"],"names":[],"mappings":";;;AAEA,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,iCAC9B,IAAI,KACP,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EACjB,EAAE,EAAE,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAC1E,CAAC,CAAA;IAEH,kCAAkC;IAClC,MAAM,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAA;IAE9E,uBAAuB;IACvB,MAAM,iBAAiB,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAA;IAE1H,+CAA+C;IAC/C,6DAA6D;IAC7D,MAAM,GAAG,GAAG,EAAE,GAAG,CAAC,GAAG,iBAAiB,CAAA;IACtC,MAAM,GAAG,GAAG,EAAE,GAAG,CAAC,GAAG,iBAAiB,CAAA;IAEtC,OAAO;QACL,SAAS,EAAE,GAAG;QACd,aAAa,EAAE;YACb,EAAE;YACF,GAAG;YACH,GAAG;SACJ;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA5BD,sEA4BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculateIChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map((plot, index) => ({\n ...plot,\n i: plot.values[0],\n mr: index == 0 ? 0 : Math.abs(plot.values[0] - plots[index - 1].values[0])\n }))\n\n // 개별 측정값의 평균을 계산하여 중심선(cl)을 구합니다.\n const cl = plots.reduce((acc, plot) => acc + plot.values[0], 0) / plots.length\n\n // 개별 측정값의 표준편차를 계산합니다.\n const standardDeviation = Math.sqrt(plots.reduce((acc, plot) => acc + Math.pow(plot.values[0] - cl, 2), 0) / plots.length)\n\n // 공정 변동을 고려하여 상한 제어선(ucl)과 하한 제어선(lcl)을 계산합니다.\n // 여기서는 3시그마(3 * 표준편차)를 사용합니다. 상황에 따라 적절한 시그마 수준을 조정할 수 있습니다.\n const ucl = cl + 3 * standardDeviation\n const lcl = cl - 3 * standardDeviation\n\n return {\n chartType: 'I',\n controlLimits: {\n cl,\n ucl,\n lcl\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
const result = {
|
|
2
|
+
dataset: {
|
|
3
|
+
id: 'aaa',
|
|
4
|
+
name: 'bbb'
|
|
5
|
+
},
|
|
6
|
+
query: {},
|
|
7
|
+
analysisResults: [
|
|
8
|
+
{
|
|
9
|
+
chartType: 'Xbar',
|
|
10
|
+
variables: [
|
|
11
|
+
{
|
|
12
|
+
name: 'variable1',
|
|
13
|
+
stats: {
|
|
14
|
+
mean: 22,
|
|
15
|
+
UCL: 25,
|
|
16
|
+
LCL: 19,
|
|
17
|
+
CL: 22
|
|
18
|
+
},
|
|
19
|
+
samples: [
|
|
20
|
+
{ x: '1', values: 22 },
|
|
21
|
+
{ x: '2', values: 23 }
|
|
22
|
+
]
|
|
23
|
+
}
|
|
24
|
+
]
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
chartType: 'R',
|
|
28
|
+
variables: [
|
|
29
|
+
{
|
|
30
|
+
name: 'variable2',
|
|
31
|
+
stats: {
|
|
32
|
+
range: 1.3,
|
|
33
|
+
UCL: 2.1,
|
|
34
|
+
LCL: 0.5,
|
|
35
|
+
CL: 1.3
|
|
36
|
+
},
|
|
37
|
+
samples: [
|
|
38
|
+
{ x: '1', value: 1.2 },
|
|
39
|
+
{ x: '2', value: 1.3 }
|
|
40
|
+
]
|
|
41
|
+
}
|
|
42
|
+
]
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
chartType: 'p',
|
|
46
|
+
variables: [
|
|
47
|
+
{
|
|
48
|
+
name: 'variable3',
|
|
49
|
+
stats: {
|
|
50
|
+
proportion: 0.05,
|
|
51
|
+
UCL: 0.1,
|
|
52
|
+
LCL: 0.01
|
|
53
|
+
},
|
|
54
|
+
samples: [
|
|
55
|
+
{ x: '1', value: 0.05 },
|
|
56
|
+
{ x: '2', value: 0.06 }
|
|
57
|
+
]
|
|
58
|
+
}
|
|
59
|
+
]
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
chartType: 'np',
|
|
63
|
+
variables: [
|
|
64
|
+
{
|
|
65
|
+
name: 'variable4',
|
|
66
|
+
stats: {
|
|
67
|
+
nonconforming: 5,
|
|
68
|
+
UCL: 10,
|
|
69
|
+
LCL: 1
|
|
70
|
+
},
|
|
71
|
+
samples: [
|
|
72
|
+
{ x: '1', value: 5 },
|
|
73
|
+
{ x: '2', value: 4 }
|
|
74
|
+
]
|
|
75
|
+
}
|
|
76
|
+
]
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
chartType: 'c',
|
|
80
|
+
variables: [
|
|
81
|
+
{
|
|
82
|
+
name: 'variable5',
|
|
83
|
+
stats: {
|
|
84
|
+
count: 20,
|
|
85
|
+
UCL: 25,
|
|
86
|
+
LCL: 15
|
|
87
|
+
},
|
|
88
|
+
samples: [
|
|
89
|
+
{ x: '1', value: 20 },
|
|
90
|
+
{ x: '2', value: 21 }
|
|
91
|
+
]
|
|
92
|
+
}
|
|
93
|
+
]
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
chartType: 'u',
|
|
97
|
+
variables: [
|
|
98
|
+
{
|
|
99
|
+
name: 'variable6',
|
|
100
|
+
stats: {
|
|
101
|
+
defectsPerUnit: 1.2,
|
|
102
|
+
UCL: 1.5,
|
|
103
|
+
LCL: 0.9
|
|
104
|
+
},
|
|
105
|
+
samples: [
|
|
106
|
+
{ x: '1', value: 1.2 },
|
|
107
|
+
{ x: '2', value: 1.1 }
|
|
108
|
+
]
|
|
109
|
+
}
|
|
110
|
+
]
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
chartType: 'I',
|
|
114
|
+
variables: [
|
|
115
|
+
{
|
|
116
|
+
name: 'variable7',
|
|
117
|
+
stats: {
|
|
118
|
+
individualValue: 10,
|
|
119
|
+
UCL: 12,
|
|
120
|
+
LCL: 8
|
|
121
|
+
},
|
|
122
|
+
samples: [
|
|
123
|
+
{ x: '1', value: 10 },
|
|
124
|
+
{ x: '2', value: 11 }
|
|
125
|
+
]
|
|
126
|
+
}
|
|
127
|
+
]
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
chartType: 'MR',
|
|
131
|
+
variables: [
|
|
132
|
+
{
|
|
133
|
+
name: 'variable8',
|
|
134
|
+
stats: {
|
|
135
|
+
movingRange: 2,
|
|
136
|
+
UCL: 3,
|
|
137
|
+
LCL: 1
|
|
138
|
+
},
|
|
139
|
+
samples: [
|
|
140
|
+
{ x: '1', value: 2 },
|
|
141
|
+
{ x: '2', value: 2.5 }
|
|
142
|
+
]
|
|
143
|
+
}
|
|
144
|
+
]
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
chartType: 'Histogram',
|
|
148
|
+
variables: [
|
|
149
|
+
{
|
|
150
|
+
name: 'variable9',
|
|
151
|
+
bins: [
|
|
152
|
+
{ binRange: '0-1', count: 5 },
|
|
153
|
+
{ binRange: '1-2', count: 10 }
|
|
154
|
+
]
|
|
155
|
+
}
|
|
156
|
+
]
|
|
157
|
+
},
|
|
158
|
+
{
|
|
159
|
+
chartType: 'Pareto',
|
|
160
|
+
variables: [
|
|
161
|
+
{
|
|
162
|
+
name: 'defectType',
|
|
163
|
+
categories: [
|
|
164
|
+
{ category: 'Scratch', count: 20 },
|
|
165
|
+
{ category: 'Dent', count: 15 }
|
|
166
|
+
]
|
|
167
|
+
}
|
|
168
|
+
]
|
|
169
|
+
}
|
|
170
|
+
]
|
|
171
|
+
};
|
|
172
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/index.ts"],"names":[],"mappings":"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","sourcesContent":["const result = {\n dataset: {\n id: 'aaa',\n name: 'bbb'\n },\n query: {},\n analysisResults: [\n {\n chartType: 'Xbar',\n variables: [\n {\n name: 'variable1',\n stats: {\n mean: 22,\n UCL: 25,\n LCL: 19,\n CL: 22\n },\n samples: [\n { x: '1', values: 22 },\n { x: '2', values: 23 }\n ]\n }\n ]\n },\n {\n chartType: 'R',\n variables: [\n {\n name: 'variable2',\n stats: {\n range: 1.3,\n UCL: 2.1,\n LCL: 0.5,\n CL: 1.3\n },\n samples: [\n { x: '1', value: 1.2 },\n { x: '2', value: 1.3 }\n ]\n }\n ]\n },\n {\n chartType: 'p',\n variables: [\n {\n name: 'variable3',\n stats: {\n proportion: 0.05,\n UCL: 0.1,\n LCL: 0.01\n },\n samples: [\n { x: '1', value: 0.05 },\n { x: '2', value: 0.06 }\n ]\n }\n ]\n },\n {\n chartType: 'np',\n variables: [\n {\n name: 'variable4',\n stats: {\n nonconforming: 5,\n UCL: 10,\n LCL: 1\n },\n samples: [\n { x: '1', value: 5 },\n { x: '2', value: 4 }\n ]\n }\n ]\n },\n {\n chartType: 'c',\n variables: [\n {\n name: 'variable5',\n stats: {\n count: 20,\n UCL: 25,\n LCL: 15\n },\n samples: [\n { x: '1', value: 20 },\n { x: '2', value: 21 }\n ]\n }\n ]\n },\n {\n chartType: 'u',\n variables: [\n {\n name: 'variable6',\n stats: {\n defectsPerUnit: 1.2,\n UCL: 1.5,\n LCL: 0.9\n },\n samples: [\n { x: '1', value: 1.2 },\n { x: '2', value: 1.1 }\n ]\n }\n ]\n },\n {\n chartType: 'I',\n variables: [\n {\n name: 'variable7',\n stats: {\n individualValue: 10,\n UCL: 12,\n LCL: 8\n },\n samples: [\n { x: '1', value: 10 },\n { x: '2', value: 11 }\n ]\n }\n ]\n },\n {\n chartType: 'MR',\n variables: [\n {\n name: 'variable8',\n stats: {\n movingRange: 2,\n UCL: 3,\n LCL: 1\n },\n samples: [\n { x: '1', value: 2 },\n { x: '2', value: 2.5 }\n ]\n }\n ]\n },\n {\n chartType: 'Histogram',\n variables: [\n {\n name: 'variable9',\n bins: [\n { binRange: '0-1', count: 5 },\n { binRange: '1-2', count: 10 }\n ]\n }\n ]\n },\n {\n chartType: 'Pareto',\n variables: [\n {\n name: 'defectType',\n categories: [\n { category: 'Scratch', count: 20 },\n { category: 'Dent', count: 15 }\n ]\n }\n ]\n }\n ]\n}\n"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateMRChartAnalysisResult = void 0;
|
|
4
|
+
function calculateMRChartAnalysisResult(plots) {
|
|
5
|
+
// 각 샘플의 평균을 계산
|
|
6
|
+
plots = plots.map((plot, index) => (Object.assign(Object.assign({}, plot), { i: plot.values[0], mr: index == 0 ? 0 : Math.abs(plot.values[0] - plots[index - 1].values[0]) })));
|
|
7
|
+
// 변동 범위의 평균을 계산하여 중심선(CL)을 구합니다.
|
|
8
|
+
const cl = plots.slice(1).reduce((acc, plot) => acc + plot.mr, 0) / (plots.length - 1);
|
|
9
|
+
// 공정 변동을 고려하여 상한 제어선(UCL)을 계산합니다.
|
|
10
|
+
// MR 차트에서는 3.267 * MR-Bar을 사용합니다 (2개의 측정값을 사용하는 경우).
|
|
11
|
+
const ucl = 3.267 * cl;
|
|
12
|
+
// MR 차트에서 하한 제어선(LCL)은 일반적으로 사용되지 않거나 0으로 설정됩니다.
|
|
13
|
+
const lcl = 0; // 하한 제어선
|
|
14
|
+
return {
|
|
15
|
+
chartType: 'MR',
|
|
16
|
+
controlLimits: {
|
|
17
|
+
cl,
|
|
18
|
+
ucl,
|
|
19
|
+
lcl
|
|
20
|
+
},
|
|
21
|
+
plots
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
exports.calculateMRChartAnalysisResult = calculateMRChartAnalysisResult;
|
|
25
|
+
//# sourceMappingURL=mr.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mr.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/mr.ts"],"names":[],"mappings":";;;AAEA,SAAgB,8BAA8B,CAAC,KAAqB;IAClE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,iCAC9B,IAAI,KACP,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EACjB,EAAE,EAAE,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAC1E,CAAC,CAAA;IAEH,iCAAiC;IACjC,MAAM,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IAEtF,kCAAkC;IAClC,qDAAqD;IACrD,MAAM,GAAG,GAAG,KAAK,GAAG,EAAE,CAAA;IAEtB,iDAAiD;IACjD,MAAM,GAAG,GAAG,CAAC,CAAA,CAAC,SAAS;IAEvB,OAAO;QACL,SAAS,EAAE,IAAI;QACf,aAAa,EAAE;YACb,EAAE;YACF,GAAG;YACH,GAAG;SACJ;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA3BD,wEA2BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculateMRChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map((plot, index) => ({\n ...plot,\n i: plot.values[0],\n mr: index == 0 ? 0 : Math.abs(plot.values[0] - plots[index - 1].values[0])\n }))\n\n // 변동 범위의 평균을 계산하여 중심선(CL)을 구합니다.\n const cl = plots.slice(1).reduce((acc, plot) => acc + plot.mr, 0) / (plots.length - 1)\n\n // 공정 변동을 고려하여 상한 제어선(UCL)을 계산합니다.\n // MR 차트에서는 3.267 * MR-Bar을 사용합니다 (2개의 측정값을 사용하는 경우).\n const ucl = 3.267 * cl\n\n // MR 차트에서 하한 제어선(LCL)은 일반적으로 사용되지 않거나 0으로 설정됩니다.\n const lcl = 0 // 하한 제어선\n\n return {\n chartType: 'MR',\n controlLimits: {\n cl,\n ucl,\n lcl\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateNPChartAnalysisResult = void 0;
|
|
4
|
+
function calculateNPChartAnalysisResult(plots) {
|
|
5
|
+
// 각 샘플의 평균을 계산
|
|
6
|
+
plots = plots.map(plot => (Object.assign(Object.assign({}, plot), { defects: plot.values.reduce((sum, v) => sum + v, 0), n: plot.values.length })));
|
|
7
|
+
const totalNonConforming = plots.reduce((acc, plot) => acc + plot.defects, 0);
|
|
8
|
+
const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0);
|
|
9
|
+
const NPBar = totalNonConforming / plots.length; // 평균 불량품 수
|
|
10
|
+
// p 차트 공식을 사용하여 UCL과 LCL을 계산합니다.
|
|
11
|
+
const pBar = totalNonConforming / totalUnits; // 전체 불량품 비율
|
|
12
|
+
const ucl = NPBar + 3 * Math.sqrt(NPBar * (1 - pBar));
|
|
13
|
+
let lcl = NPBar - 3 * Math.sqrt(NPBar * (1 - pBar));
|
|
14
|
+
lcl = lcl < 0 ? 0 : lcl; // LCL이 음수인 경우 0으로 설정
|
|
15
|
+
return {
|
|
16
|
+
chartType: 'NP',
|
|
17
|
+
controlLimits: {
|
|
18
|
+
ucl,
|
|
19
|
+
lcl,
|
|
20
|
+
cl: NPBar
|
|
21
|
+
},
|
|
22
|
+
plots
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
exports.calculateNPChartAnalysisResult = calculateNPChartAnalysisResult;
|
|
26
|
+
//# sourceMappingURL=np.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"np.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/np.ts"],"names":[],"mappings":";;;AAEA,SAAgB,8BAA8B,CAAC,KAAqB;IAClE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,iCACrB,IAAI,KACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC,EACnD,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,IACrB,CAAC,CAAA;IAEH,MAAM,kBAAkB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;IAC7E,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IAC/D,MAAM,KAAK,GAAG,kBAAkB,GAAG,KAAK,CAAC,MAAM,CAAA,CAAC,WAAW;IAE3D,iCAAiC;IACjC,MAAM,IAAI,GAAG,kBAAkB,GAAG,UAAU,CAAA,CAAC,YAAY;IACzD,MAAM,GAAG,GAAG,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;IACrD,IAAI,GAAG,GAAG,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;IACnD,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAA,CAAC,qBAAqB;IAE7C,OAAO;QACL,SAAS,EAAE,IAAI;QACf,aAAa,EAAE;YACb,GAAG;YACH,GAAG;YACH,EAAE,EAAE,KAAK;SACV;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA3BD,wEA2BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculateNPChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map(plot => ({\n ...plot,\n defects: plot.values.reduce((sum, v) => sum + v, 0),\n n: plot.values.length\n }))\n\n const totalNonConforming = plots.reduce((acc, plot) => acc + plot.defects, 0)\n const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0)\n const NPBar = totalNonConforming / plots.length // 평균 불량품 수\n\n // p 차트 공식을 사용하여 UCL과 LCL을 계산합니다.\n const pBar = totalNonConforming / totalUnits // 전체 불량품 비율\n const ucl = NPBar + 3 * Math.sqrt(NPBar * (1 - pBar))\n let lcl = NPBar - 3 * Math.sqrt(NPBar * (1 - pBar))\n lcl = lcl < 0 ? 0 : lcl // LCL이 음수인 경우 0으로 설정\n\n return {\n chartType: 'NP',\n controlLimits: {\n ucl,\n lcl,\n cl: NPBar\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculatePChartAnalysisResult = void 0;
|
|
4
|
+
function calculatePChartAnalysisResult(plots) {
|
|
5
|
+
// 각 샘플의 평균을 계산
|
|
6
|
+
plots = plots.map(plot => (Object.assign(Object.assign({}, plot), { defects: plot.values.reduce((sum, v) => sum + v, 0), n: plot.values.length })));
|
|
7
|
+
// 결함 있는 단위의 평균 비율(PBar)을 계산합니다.
|
|
8
|
+
const totalDefectiveUnits = plots.reduce((acc, plot) => acc + plot.defects, 0);
|
|
9
|
+
const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0);
|
|
10
|
+
const PBar = totalDefectiveUnits / totalUnits;
|
|
11
|
+
// 샘플 그룹의 크기(n)에 따라 UCL과 LCL을 계산합니다.
|
|
12
|
+
const ucl = PBar + 3 * Math.sqrt((PBar * (1 - PBar)) / totalUnits);
|
|
13
|
+
const lcl = PBar - 3 * Math.sqrt((PBar * (1 - PBar)) / totalUnits) < 0 ? 0 : PBar - 3 * Math.sqrt((PBar * (1 - PBar)) / totalUnits); // LCL이 음수가 되지 않도록 처리
|
|
14
|
+
return {
|
|
15
|
+
chartType: 'P',
|
|
16
|
+
controlLimits: {
|
|
17
|
+
ucl,
|
|
18
|
+
lcl,
|
|
19
|
+
cl: PBar
|
|
20
|
+
},
|
|
21
|
+
plots
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
exports.calculatePChartAnalysisResult = calculatePChartAnalysisResult;
|
|
25
|
+
//# sourceMappingURL=p.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"p.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/p.ts"],"names":[],"mappings":";;;AAEA,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,iCACrB,IAAI,KACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC,EACnD,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,IACrB,CAAC,CAAA;IAEH,gCAAgC;IAChC,MAAM,mBAAmB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;IAC9E,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IAC/D,MAAM,IAAI,GAAG,mBAAmB,GAAG,UAAU,CAAA;IAE7C,oCAAoC;IACpC,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,CAAA;IAClE,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,CAAA,CAAC,qBAAqB;IAEzJ,OAAO;QACL,SAAS,EAAE,GAAG;QACd,aAAa,EAAE;YACb,GAAG;YACH,GAAG;YACH,EAAE,EAAE,IAAI;SACT;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA1BD,sEA0BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculatePChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map(plot => ({\n ...plot,\n defects: plot.values.reduce((sum, v) => sum + v, 0),\n n: plot.values.length\n }))\n\n // 결함 있는 단위의 평균 비율(PBar)을 계산합니다.\n const totalDefectiveUnits = plots.reduce((acc, plot) => acc + plot.defects, 0)\n const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0)\n const PBar = totalDefectiveUnits / totalUnits\n\n // 샘플 그룹의 크기(n)에 따라 UCL과 LCL을 계산합니다.\n const ucl = PBar + 3 * Math.sqrt((PBar * (1 - PBar)) / totalUnits)\n const lcl = PBar - 3 * Math.sqrt((PBar * (1 - PBar)) / totalUnits) < 0 ? 0 : PBar - 3 * Math.sqrt((PBar * (1 - PBar)) / totalUnits) // LCL이 음수가 되지 않도록 처리\n\n return {\n chartType: 'P',\n controlLimits: {\n ucl,\n lcl,\n cl: PBar\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculatePareto = void 0;
|
|
4
|
+
function calculatePareto(data) {
|
|
5
|
+
// 각 카테고리별 데이터 개수 계산
|
|
6
|
+
const categoryCounts = {};
|
|
7
|
+
data.forEach(item => {
|
|
8
|
+
const category = item.category;
|
|
9
|
+
categoryCounts[category] = (categoryCounts[category] || 0) + 1;
|
|
10
|
+
});
|
|
11
|
+
// 카테고리와 데이터 개수를 배열로 변환
|
|
12
|
+
const categories = Object.keys(categoryCounts).map(category => ({
|
|
13
|
+
category,
|
|
14
|
+
count: categoryCounts[category]
|
|
15
|
+
}));
|
|
16
|
+
// 데이터 개수에 따라 내림차순으로 정렬
|
|
17
|
+
categories.sort((a, b) => b.count - a.count);
|
|
18
|
+
return {
|
|
19
|
+
chartType: 'Pareto',
|
|
20
|
+
categories
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
exports.calculatePareto = calculatePareto;
|
|
24
|
+
//# sourceMappingURL=pareto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pareto.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/pareto.ts"],"names":[],"mappings":";;;AAUA,SAAgB,eAAe,CAAC,IAA4B;IAC1D,oBAAoB;IACpB,MAAM,cAAc,GAAmC,EAAE,CAAA;IACzD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;QAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;QAC9B,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAA;IAChE,CAAC,CAAC,CAAA;IAEF,uBAAuB;IACvB,MAAM,UAAU,GAAqB,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAChF,QAAQ;QACR,KAAK,EAAE,cAAc,CAAC,QAAQ,CAAC;KAChC,CAAC,CAAC,CAAA;IAEH,uBAAuB;IACvB,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAA;IAE5C,OAAO;QACL,SAAS,EAAE,QAAQ;QACnB,UAAU;KACX,CAAA;AACH,CAAC;AArBD,0CAqBC","sourcesContent":["interface ParetoCategory {\n category: string // 카테고리 이름\n count: number // 해당 카테고리의 데이터 개수 또는 중요도\n}\n\ninterface ParetoResult {\n chartType: 'Pareto'\n categories: ParetoCategory[] // Pareto 차트에 표시될 카테고리 및 중요도 정보\n}\n\nexport function calculatePareto(data: { category: string }[]): ParetoResult {\n // 각 카테고리별 데이터 개수 계산\n const categoryCounts: { [category: string]: number } = {}\n data.forEach(item => {\n const category = item.category\n categoryCounts[category] = (categoryCounts[category] || 0) + 1\n })\n\n // 카테고리와 데이터 개수를 배열로 변환\n const categories: ParetoCategory[] = Object.keys(categoryCounts).map(category => ({\n category,\n count: categoryCounts[category]\n }))\n\n // 데이터 개수에 따라 내림차순으로 정렬\n categories.sort((a, b) => b.count - a.count)\n\n return {\n chartType: 'Pareto',\n categories\n }\n}\n"]}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateRChartAnalysisResult = void 0;
|
|
4
|
+
function calculateRChartAnalysisResult(plots) {
|
|
5
|
+
var _a;
|
|
6
|
+
// 각 샘플 그룹의 범위를 계산합니다.
|
|
7
|
+
plots = plots.map(plot => {
|
|
8
|
+
return Object.assign(Object.assign({}, plot), { r: Math.max(...plot.values) - Math.min(...plot.values) });
|
|
9
|
+
});
|
|
10
|
+
// 모든 샘플 그룹의 범위의 평균값(R-bar)을 계산합니다.
|
|
11
|
+
const RBar = plots.reduce((acc, plot) => acc + plot.r, 0) / plots.length;
|
|
12
|
+
// 샘플 그룹의 크기(n)에 따라 D3와 D4 값을 설정합니다.
|
|
13
|
+
// 예시에서는 n=5인 경우의 D3와 D4 값을 사용합니다. 실제 구현에서는 샘플 크기에 맞는 값을 사용해야 합니다.
|
|
14
|
+
const n = (_a = plots[0]) === null || _a === void 0 ? void 0 : _a.values.length; // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)
|
|
15
|
+
const D3 = 0; // n=5에 대한 D3 값
|
|
16
|
+
const D4 = 2.114; // n=5에 대한 D4 값
|
|
17
|
+
// UCL과 LCL을 계산합니다.
|
|
18
|
+
const ucl = D4 * RBar;
|
|
19
|
+
const lcl = D3 * RBar; // D3가 0인 경우, LCL은 0이 됩니다.
|
|
20
|
+
return {
|
|
21
|
+
chartType: 'R',
|
|
22
|
+
controlLimits: {
|
|
23
|
+
ucl,
|
|
24
|
+
lcl,
|
|
25
|
+
cl: RBar
|
|
26
|
+
},
|
|
27
|
+
plots
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
exports.calculateRChartAnalysisResult = calculateRChartAnalysisResult;
|
|
31
|
+
//# sourceMappingURL=r.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"r.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/r.ts"],"names":[],"mappings":";;;AAEA,SAAgB,6BAA6B,CAAC,KAAqB;;IACjE,sBAAsB;IACtB,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACvB,uCACK,IAAI,KACP,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,IACvD;IACH,CAAC,CAAC,CAAA;IAEF,mCAAmC;IACnC,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAA;IAExE,oCAAoC;IACpC,kEAAkE;IAClE,MAAM,CAAC,GAAG,MAAA,KAAK,CAAC,CAAC,CAAC,0CAAE,MAAM,CAAC,MAAM,CAAA,CAAC,6BAA6B;IAC/D,MAAM,EAAE,GAAG,CAAC,CAAA,CAAC,eAAe;IAC5B,MAAM,EAAE,GAAG,KAAK,CAAA,CAAC,eAAe;IAEhC,mBAAmB;IACnB,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,CAAA;IACrB,MAAM,GAAG,GAAG,EAAE,GAAG,IAAI,CAAA,CAAC,0BAA0B;IAEhD,OAAO;QACL,SAAS,EAAE,GAAG;QACd,aAAa,EAAE;YACb,GAAG;YACH,GAAG;YACH,EAAE,EAAE,IAAI;SACT;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA/BD,sEA+BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculateRChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플 그룹의 범위를 계산합니다.\n plots = plots.map(plot => {\n return {\n ...plot,\n r: Math.max(...plot.values) - Math.min(...plot.values)\n }\n })\n\n // 모든 샘플 그룹의 범위의 평균값(R-bar)을 계산합니다.\n const RBar = plots.reduce((acc, plot) => acc + plot.r, 0) / plots.length\n\n // 샘플 그룹의 크기(n)에 따라 D3와 D4 값을 설정합니다.\n // 예시에서는 n=5인 경우의 D3와 D4 값을 사용합니다. 실제 구현에서는 샘플 크기에 맞는 값을 사용해야 합니다.\n const n = plots[0]?.values.length // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)\n const D3 = 0 // n=5에 대한 D3 값\n const D4 = 2.114 // n=5에 대한 D4 값\n\n // UCL과 LCL을 계산합니다.\n const ucl = D4 * RBar\n const lcl = D3 * RBar // D3가 0인 경우, LCL은 0이 됩니다.\n\n return {\n chartType: 'R',\n controlLimits: {\n ucl,\n lcl,\n cl: RBar\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateUChartAnalysisResult = void 0;
|
|
4
|
+
function calculateUChartAnalysisResult(plots) {
|
|
5
|
+
// 각 샘플의 평균을 계산
|
|
6
|
+
plots = plots.map(plot => (Object.assign(Object.assign({}, plot), { defects: plot.values.map(Boolean).length, n: plot.values.length })));
|
|
7
|
+
// 단위당 결함 수의 평균(UBar)을 계산합니다.
|
|
8
|
+
const totalDefects = plots.reduce((acc, plot) => acc + plot.defects, 0);
|
|
9
|
+
const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0);
|
|
10
|
+
const UBar = totalDefects / totalUnits;
|
|
11
|
+
// 샘플 그룹의 크기(n)에 따라 상수를 결정합니다. 여기서는 일반적인 상수 값을 사용합니다.
|
|
12
|
+
const n = plots.length; // 샘플 그룹의 수
|
|
13
|
+
// UCL과 LCL 계산을 위한 상수. 실제 값은 샘플 크기와 분포에 따라 달라질 수 있습니다.
|
|
14
|
+
const ucl = UBar + 3 * Math.sqrt(UBar / totalUnits);
|
|
15
|
+
const lcl = UBar - 3 * Math.sqrt(UBar / totalUnits) < 0 ? 0 : UBar - 3 * Math.sqrt(UBar / totalUnits); // LCL이 음수가 되지 않도록 처리
|
|
16
|
+
return {
|
|
17
|
+
chartType: 'U',
|
|
18
|
+
controlLimits: {
|
|
19
|
+
ucl,
|
|
20
|
+
lcl,
|
|
21
|
+
cl: UBar
|
|
22
|
+
},
|
|
23
|
+
plots
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
exports.calculateUChartAnalysisResult = calculateUChartAnalysisResult;
|
|
27
|
+
//# sourceMappingURL=u.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"u.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/u.ts"],"names":[],"mappings":";;;AAEA,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,iCACrB,IAAI,KACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,MAAM,EACxC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,IACrB,CAAC,CAAA;IAEH,6BAA6B;IAC7B,MAAM,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAA;IACvE,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IAC/D,MAAM,IAAI,GAAG,YAAY,GAAG,UAAU,CAAA;IAEtC,qDAAqD;IACrD,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM,CAAA,CAAC,WAAW;IAClC,sDAAsD;IACtD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,CAAA;IACnD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC,CAAA,CAAC,qBAAqB;IAE3H,OAAO;QACL,SAAS,EAAE,GAAG;QACd,aAAa,EAAE;YACb,GAAG;YACH,GAAG;YACH,EAAE,EAAE,IAAI;SACT;QACD,KAAK;KACN,CAAA;AACH,CAAC;AA5BD,sEA4BC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nexport function calculateUChartAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map(plot => ({\n ...plot,\n defects: plot.values.map(Boolean).length,\n n: plot.values.length\n }))\n\n // 단위당 결함 수의 평균(UBar)을 계산합니다.\n const totalDefects = plots.reduce((acc, plot) => acc + plot.defects, 0)\n const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0)\n const UBar = totalDefects / totalUnits\n\n // 샘플 그룹의 크기(n)에 따라 상수를 결정합니다. 여기서는 일반적인 상수 값을 사용합니다.\n const n = plots.length // 샘플 그룹의 수\n // UCL과 LCL 계산을 위한 상수. 실제 값은 샘플 크기와 분포에 따라 달라질 수 있습니다.\n const ucl = UBar + 3 * Math.sqrt(UBar / totalUnits)\n const lcl = UBar - 3 * Math.sqrt(UBar / totalUnits) < 0 ? 0 : UBar - 3 * Math.sqrt(UBar / totalUnits) // LCL이 음수가 되지 않도록 처리\n\n return {\n chartType: 'U',\n controlLimits: {\n ucl,\n lcl,\n cl: UBar\n },\n plots\n }\n}\n"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.calculateXBarAnalysisResult = void 0;
|
|
4
|
+
function getA2Value(sampleSize) {
|
|
5
|
+
const a2Values = {
|
|
6
|
+
2: 1.88,
|
|
7
|
+
3: 1.023,
|
|
8
|
+
4: 0.729,
|
|
9
|
+
5: 0.577,
|
|
10
|
+
6: 0.483
|
|
11
|
+
// 다른 샘플 크기에 대한 A2 값 추가...
|
|
12
|
+
};
|
|
13
|
+
return a2Values[sampleSize] || 0; // 샘플 크기에 대한 A2 값이 정의되지 않은 경우 0을 반환
|
|
14
|
+
}
|
|
15
|
+
function calculateXBarAnalysisResult(plots) {
|
|
16
|
+
var _a, _b;
|
|
17
|
+
// 각 샘플의 평균을 계산
|
|
18
|
+
plots = plots.map(plot => (Object.assign(Object.assign({}, plot), { xbar: plot.values ? plot.values.reduce((sum, val) => sum + val, 0) / plot.values.length : 0, r: Math.max(...plot.values) - Math.min(...plot.values) })));
|
|
19
|
+
const plotSize = (_b = (_a = plots[0]) === null || _a === void 0 ? void 0 : _a.values) === null || _b === void 0 ? void 0 : _b.length; // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)
|
|
20
|
+
// 각 샘플의 범위(R) 계산
|
|
21
|
+
const ranges = plots.map(plot => {
|
|
22
|
+
if (plot.values) {
|
|
23
|
+
return Math.max(...plot.values) - Math.min(...plot.values);
|
|
24
|
+
}
|
|
25
|
+
return 0;
|
|
26
|
+
});
|
|
27
|
+
// 범위(R)의 평균 계산
|
|
28
|
+
const averageRange = ranges.reduce((sum, r) => sum + r, 0) / ranges.length;
|
|
29
|
+
// 전체 평균(중심선, CL) 계산
|
|
30
|
+
const overallMean = plots.reduce((sum, plot) => sum + plot.xbar, 0) / plots.length;
|
|
31
|
+
const A2 = getA2Value(plotSize);
|
|
32
|
+
const ucl = overallMean + A2 * averageRange;
|
|
33
|
+
const lcl = overallMean - A2 * averageRange;
|
|
34
|
+
return {
|
|
35
|
+
chartType: 'Xbar',
|
|
36
|
+
controlLimits: {
|
|
37
|
+
ucl,
|
|
38
|
+
lcl,
|
|
39
|
+
cl: overallMean
|
|
40
|
+
},
|
|
41
|
+
plots
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
exports.calculateXBarAnalysisResult = calculateXBarAnalysisResult;
|
|
45
|
+
//# sourceMappingURL=x-bar-r.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"x-bar-r.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/x-bar-r.ts"],"names":[],"mappings":";;;AAEA,SAAS,UAAU,CAAC,UAAkB;IACpC,MAAM,QAAQ,GAA8B;QAC1C,CAAC,EAAE,IAAI;QACP,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,KAAK;QACR,CAAC,EAAE,KAAK;QACR,0BAA0B;KAC3B,CAAA;IAED,OAAO,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA,CAAC,mCAAmC;AACtE,CAAC;AAED,SAAgB,2BAA2B,CAAC,KAAqB;;IAC/D,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,iCACrB,IAAI,KACP,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAC3F,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,IACtD,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,MAAA,MAAA,KAAK,CAAC,CAAC,CAAC,0CAAE,MAAM,0CAAE,MAAM,CAAA,CAAC,6BAA6B;IAEvE,iBAAiB;IACjB,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QAC9B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAA;SAC3D;QACD,OAAO,CAAC,CAAA;IACV,CAAC,CAAC,CAAA;IAEF,eAAe;IACf,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,CAAA;IAE1E,oBAAoB;IACpB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAA;IAElF,MAAM,EAAE,GAAG,UAAU,CAAC,QAAQ,CAAC,CAAA;IAC/B,MAAM,GAAG,GAAG,WAAW,GAAG,EAAE,GAAG,YAAY,CAAA;IAC3C,MAAM,GAAG,GAAG,WAAW,GAAG,EAAE,GAAG,YAAY,CAAA;IAE3C,OAAO;QACL,SAAS,EAAE,MAAM;QACjB,aAAa,EAAE;YACb,GAAG;YACH,GAAG;YACH,EAAE,EAAE,WAAW;SAChB;QACD,KAAK;KACN,CAAA;AACH,CAAC;AArCD,kEAqCC","sourcesContent":["import { SPCChartPlot, SPCChartAnalysis } from '../../service/spc-chart/spc-chart-type'\n\nfunction getA2Value(sampleSize: number): number {\n const a2Values: { [key: number]: number } = {\n 2: 1.88,\n 3: 1.023,\n 4: 0.729,\n 5: 0.577,\n 6: 0.483\n // 다른 샘플 크기에 대한 A2 값 추가...\n }\n\n return a2Values[sampleSize] || 0 // 샘플 크기에 대한 A2 값이 정의되지 않은 경우 0을 반환\n}\n\nexport function calculateXBarAnalysisResult(plots: SPCChartPlot[]): SPCChartAnalysis {\n // 각 샘플의 평균을 계산\n plots = plots.map(plot => ({\n ...plot,\n xbar: plot.values ? plot.values.reduce((sum, val) => sum + val, 0) / plot.values.length : 0,\n r: Math.max(...plot.values) - Math.min(...plot.values)\n }))\n\n const plotSize = plots[0]?.values?.length // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)\n\n // 각 샘플의 범위(R) 계산\n const ranges = plots.map(plot => {\n if (plot.values) {\n return Math.max(...plot.values) - Math.min(...plot.values)\n }\n return 0\n })\n\n // 범위(R)의 평균 계산\n const averageRange = ranges.reduce((sum, r) => sum + r, 0) / ranges.length\n\n // 전체 평균(중심선, CL) 계산\n const overallMean = plots.reduce((sum, plot) => sum + plot.xbar, 0) / plots.length\n\n const A2 = getA2Value(plotSize)\n const ucl = overallMean + A2 * averageRange\n const lcl = overallMean - A2 * averageRange\n\n return {\n chartType: 'Xbar',\n controlLimits: {\n ucl,\n lcl,\n cl: overallMean\n },\n plots\n }\n}\n"]}
|