@things-factory/spc 9.0.0-beta.8 → 9.0.0-beta.80
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/dist-client/pages/spc-chart-page.js +32 -27
- package/dist-client/pages/spc-chart-page.js.map +1 -1
- package/dist-client/tsconfig.tsbuildinfo +1 -1
- package/dist-server/controllers/spc-chart/c.js +5 -1
- package/dist-server/controllers/spc-chart/c.js.map +1 -1
- package/dist-server/controllers/spc-chart/i.js +5 -1
- package/dist-server/controllers/spc-chart/i.js.map +1 -1
- package/dist-server/controllers/spc-chart/mr.js +5 -1
- package/dist-server/controllers/spc-chart/mr.js.map +1 -1
- package/dist-server/controllers/spc-chart/np.js +5 -1
- package/dist-server/controllers/spc-chart/np.js.map +1 -1
- package/dist-server/controllers/spc-chart/p.js +5 -1
- package/dist-server/controllers/spc-chart/p.js.map +1 -1
- package/dist-server/controllers/spc-chart/r.js +5 -3
- package/dist-server/controllers/spc-chart/r.js.map +1 -1
- package/dist-server/controllers/spc-chart/u.js +5 -1
- package/dist-server/controllers/spc-chart/u.js.map +1 -1
- package/dist-server/controllers/spc-chart/x-bar-r.js +6 -3
- package/dist-server/controllers/spc-chart/x-bar-r.js.map +1 -1
- package/dist-server/controllers/spc-chart/x-bar.js +6 -3
- package/dist-server/controllers/spc-chart/x-bar.js.map +1 -1
- package/dist-server/service/spc-chart/spc-chart-query.js +1 -1
- package/dist-server/service/spc-chart/spc-chart-query.js.map +1 -1
- package/dist-server/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -4
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.calculateCChartAnalysisResult = calculateCChartAnalysisResult;
|
|
4
4
|
function calculateCChartAnalysisResult(plots) {
|
|
5
5
|
// 각 샘플의 평균을 계산
|
|
6
|
-
plots = plots.map(plot => (
|
|
6
|
+
plots = plots.map(plot => ({
|
|
7
|
+
...plot,
|
|
8
|
+
defects: plot.values.map(Boolean).length,
|
|
9
|
+
n: plot.values.length
|
|
10
|
+
}));
|
|
7
11
|
// 총 결함 수를 계산합니다.
|
|
8
12
|
const totalDefects = plots.reduce((sum, { defects }) => sum + defects, 0);
|
|
9
13
|
// 평균 결함 수(C-bar)를 계산합니다.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"c.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/c.ts"],"names":[],"mappings":";;AAEA,sEA4BC;AA5BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"c.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/c.ts"],"names":[],"mappings":";;AAEA,sEA4BC;AA5BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,GAAG,IAAI;QACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,MAAM;QACxC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;KACtB,CAAC,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","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"]}
|
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.calculateIChartAnalysisResult = calculateIChartAnalysisResult;
|
|
4
4
|
function calculateIChartAnalysisResult(plots) {
|
|
5
5
|
// 각 샘플의 평균을 계산
|
|
6
|
-
plots = plots.map((plot, index) => (
|
|
6
|
+
plots = plots.map((plot, index) => ({
|
|
7
|
+
...plot,
|
|
8
|
+
i: plot.values[0],
|
|
9
|
+
mr: index == 0 ? 0 : Math.abs(plot.values[0] - plots[index - 1].values[0])
|
|
10
|
+
}));
|
|
7
11
|
// 개별 측정값의 평균을 계산하여 중심선(cl)을 구합니다.
|
|
8
12
|
const cl = plots.reduce((acc, plot) => acc + plot.values[0], 0) / plots.length;
|
|
9
13
|
// 개별 측정값의 표준편차를 계산합니다.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"i.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/i.ts"],"names":[],"mappings":";;AAEA,sEA4BC;AA5BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"i.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/i.ts"],"names":[],"mappings":";;AAEA,sEA4BC;AA5BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QAClC,GAAG,IAAI;QACP,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QACjB,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;KAC3E,CAAC,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","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"]}
|
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.calculateMRChartAnalysisResult = calculateMRChartAnalysisResult;
|
|
4
4
|
function calculateMRChartAnalysisResult(plots) {
|
|
5
5
|
// 각 샘플의 평균을 계산
|
|
6
|
-
plots = plots.map((plot, index) => (
|
|
6
|
+
plots = plots.map((plot, index) => ({
|
|
7
|
+
...plot,
|
|
8
|
+
i: plot.values[0],
|
|
9
|
+
mr: index == 0 ? 0 : Math.abs(plot.values[0] - plots[index - 1].values[0])
|
|
10
|
+
}));
|
|
7
11
|
// 변동 범위의 평균을 계산하여 중심선(CL)을 구합니다.
|
|
8
12
|
const cl = plots.slice(1).reduce((acc, plot) => acc + plot.mr, 0) / (plots.length - 1);
|
|
9
13
|
// 공정 변동을 고려하여 상한 제어선(UCL)을 계산합니다.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mr.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/mr.ts"],"names":[],"mappings":";;AAEA,wEA2BC;AA3BD,SAAgB,8BAA8B,CAAC,KAAqB;IAClE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"mr.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/mr.ts"],"names":[],"mappings":";;AAEA,wEA2BC;AA3BD,SAAgB,8BAA8B,CAAC,KAAqB;IAClE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;QAClC,GAAG,IAAI;QACP,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;QACjB,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;KAC3E,CAAC,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","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"]}
|
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.calculateNPChartAnalysisResult = calculateNPChartAnalysisResult;
|
|
4
4
|
function calculateNPChartAnalysisResult(plots) {
|
|
5
5
|
// 각 샘플의 평균을 계산
|
|
6
|
-
plots = plots.map(plot => (
|
|
6
|
+
plots = plots.map(plot => ({
|
|
7
|
+
...plot,
|
|
8
|
+
defects: plot.values.reduce((sum, v) => sum + v, 0),
|
|
9
|
+
n: plot.values.length
|
|
10
|
+
}));
|
|
7
11
|
const totalNonConforming = plots.reduce((acc, plot) => acc + plot.defects, 0);
|
|
8
12
|
const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0);
|
|
9
13
|
const NPBar = totalNonConforming / plots.length; // 평균 불량품 수
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"np.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/np.ts"],"names":[],"mappings":";;AAEA,wEA2BC;AA3BD,SAAgB,8BAA8B,CAAC,KAAqB;IAClE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"np.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/np.ts"],"names":[],"mappings":";;AAEA,wEA2BC;AA3BD,SAAgB,8BAA8B,CAAC,KAAqB;IAClE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,GAAG,IAAI;QACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;QACnD,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;KACtB,CAAC,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","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"]}
|
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.calculatePChartAnalysisResult = calculatePChartAnalysisResult;
|
|
4
4
|
function calculatePChartAnalysisResult(plots) {
|
|
5
5
|
// 각 샘플의 평균을 계산
|
|
6
|
-
plots = plots.map(plot => (
|
|
6
|
+
plots = plots.map(plot => ({
|
|
7
|
+
...plot,
|
|
8
|
+
defects: plot.values.reduce((sum, v) => sum + v, 0),
|
|
9
|
+
n: plot.values.length
|
|
10
|
+
}));
|
|
7
11
|
// 결함 있는 단위의 평균 비율(PBar)을 계산합니다.
|
|
8
12
|
const totalDefectiveUnits = plots.reduce((acc, plot) => acc + plot.defects, 0);
|
|
9
13
|
const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"p.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/p.ts"],"names":[],"mappings":";;AAEA,sEA0BC;AA1BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"p.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/p.ts"],"names":[],"mappings":";;AAEA,sEA0BC;AA1BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,GAAG,IAAI;QACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;QACnD,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;KACtB,CAAC,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","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"]}
|
|
@@ -2,16 +2,18 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.calculateRChartAnalysisResult = calculateRChartAnalysisResult;
|
|
4
4
|
function calculateRChartAnalysisResult(plots) {
|
|
5
|
-
var _a;
|
|
6
5
|
// 각 샘플 그룹의 범위를 계산합니다.
|
|
7
6
|
plots = plots.map(plot => {
|
|
8
|
-
return
|
|
7
|
+
return {
|
|
8
|
+
...plot,
|
|
9
|
+
r: Math.max(...plot.values) - Math.min(...plot.values)
|
|
10
|
+
};
|
|
9
11
|
});
|
|
10
12
|
// 모든 샘플 그룹의 범위의 평균값(R-bar)을 계산합니다.
|
|
11
13
|
const RBar = plots.reduce((acc, plot) => acc + plot.r, 0) / plots.length;
|
|
12
14
|
// 샘플 그룹의 크기(n)에 따라 D3와 D4 값을 설정합니다.
|
|
13
15
|
// 예시에서는 n=5인 경우의 D3와 D4 값을 사용합니다. 실제 구현에서는 샘플 크기에 맞는 값을 사용해야 합니다.
|
|
14
|
-
const n =
|
|
16
|
+
const n = plots[0]?.values.length; // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)
|
|
15
17
|
const D3 = 0; // n=5에 대한 D3 값
|
|
16
18
|
const D4 = 2.114; // n=5에 대한 D4 값
|
|
17
19
|
// UCL과 LCL을 계산합니다.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"r.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/r.ts"],"names":[],"mappings":";;AAEA,sEA+BC;AA/BD,SAAgB,6BAA6B,CAAC,KAAqB
|
|
1
|
+
{"version":3,"file":"r.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/r.ts"],"names":[],"mappings":";;AAEA,sEA+BC;AA/BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,sBAAsB;IACtB,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACvB,OAAO;YACL,GAAG,IAAI;YACP,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;SACvD,CAAA;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,KAAK,CAAC,CAAC,CAAC,EAAE,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","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"]}
|
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.calculateUChartAnalysisResult = calculateUChartAnalysisResult;
|
|
4
4
|
function calculateUChartAnalysisResult(plots) {
|
|
5
5
|
// 각 샘플의 평균을 계산
|
|
6
|
-
plots = plots.map(plot => (
|
|
6
|
+
plots = plots.map(plot => ({
|
|
7
|
+
...plot,
|
|
8
|
+
defects: plot.values.map(Boolean).length,
|
|
9
|
+
n: plot.values.length
|
|
10
|
+
}));
|
|
7
11
|
// 단위당 결함 수의 평균(UBar)을 계산합니다.
|
|
8
12
|
const totalDefects = plots.reduce((acc, plot) => acc + plot.defects, 0);
|
|
9
13
|
const totalUnits = plots.reduce((acc, plot) => acc + plot.n, 0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"u.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/u.ts"],"names":[],"mappings":";;AAEA,sEA4BC;AA5BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,
|
|
1
|
+
{"version":3,"file":"u.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/u.ts"],"names":[],"mappings":";;AAEA,sEA4BC;AA5BD,SAAgB,6BAA6B,CAAC,KAAqB;IACjE,eAAe;IACf,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzB,GAAG,IAAI;QACP,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,MAAM;QACxC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;KACtB,CAAC,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","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"]}
|
|
@@ -13,10 +13,13 @@ function getA2Value(sampleSize) {
|
|
|
13
13
|
return a2Values[sampleSize] || 0; // 샘플 크기에 대한 A2 값이 정의되지 않은 경우 0을 반환
|
|
14
14
|
}
|
|
15
15
|
function calculateXBarAnalysisResult(plots) {
|
|
16
|
-
var _a, _b;
|
|
17
16
|
// 각 샘플의 평균을 계산
|
|
18
|
-
plots = plots.map(plot => (
|
|
19
|
-
|
|
17
|
+
plots = plots.map(plot => ({
|
|
18
|
+
...plot,
|
|
19
|
+
xbar: plot.values ? plot.values.reduce((sum, val) => sum + val, 0) / plot.values.length : 0,
|
|
20
|
+
r: Math.max(...plot.values) - Math.min(...plot.values)
|
|
21
|
+
}));
|
|
22
|
+
const plotSize = plots[0]?.values?.length; // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)
|
|
20
23
|
// 각 샘플의 범위(R) 계산
|
|
21
24
|
const ranges = plots.map(plot => {
|
|
22
25
|
if (plot.values) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"x-bar-r.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/x-bar-r.ts"],"names":[],"mappings":";;AAeA,kEAqCC;AAlDD,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
|
|
1
|
+
{"version":3,"file":"x-bar-r.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/x-bar-r.ts"],"names":[],"mappings":";;AAeA,kEAqCC;AAlDD,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,CAAC;QACzB,GAAG,IAAI;QACP,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;QAC3F,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;KACvD,CAAC,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAA,CAAC,6BAA6B;IAEvE,iBAAiB;IACjB,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QAC9B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAA;QAC5D,CAAC;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","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"]}
|
|
@@ -13,10 +13,13 @@ function getA2Value(sampleSize) {
|
|
|
13
13
|
return a2Values[sampleSize] || 0; // 샘플 크기에 대한 A2 값이 정의되지 않은 경우 0을 반환
|
|
14
14
|
}
|
|
15
15
|
function calculateXBarAnalysisResult(plots) {
|
|
16
|
-
var _a, _b;
|
|
17
16
|
// 각 샘플의 평균을 계산
|
|
18
|
-
plots = plots.map(plot => (
|
|
19
|
-
|
|
17
|
+
plots = plots.map(plot => ({
|
|
18
|
+
...plot,
|
|
19
|
+
xbar: plot.values ? plot.values.reduce((sum, val) => sum + val, 0) / plot.values.length : 0,
|
|
20
|
+
r: Math.max(...plot.values) - Math.min(...plot.values)
|
|
21
|
+
}));
|
|
22
|
+
const plotSize = plots[0]?.values?.length; // 샘플 크기 추정(모든 그룹이 같은 크기를 가정)
|
|
20
23
|
// 각 샘플의 범위(R) 계산
|
|
21
24
|
const ranges = plots.map(plot => {
|
|
22
25
|
if (plot.values) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"x-bar.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/x-bar.ts"],"names":[],"mappings":";;AAeA,kEAqCC;AAlDD,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
|
|
1
|
+
{"version":3,"file":"x-bar.js","sourceRoot":"","sources":["../../../server/controllers/spc-chart/x-bar.ts"],"names":[],"mappings":";;AAeA,kEAqCC;AAlDD,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,CAAC;QACzB,GAAG,IAAI;QACP,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;QAC3F,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;KACvD,CAAC,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,MAAM,CAAA,CAAC,6BAA6B;IAEvE,iBAAiB;IACjB,MAAM,MAAM,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QAC9B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAA;QAC5D,CAAC;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","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"]}
|
|
@@ -48,7 +48,7 @@ let SpcChartQuery = class SpcChartQuery {
|
|
|
48
48
|
})
|
|
49
49
|
.filter(sample => {
|
|
50
50
|
const { x, values } = sample;
|
|
51
|
-
return x && values && values.length > 0 && values.every(v => v
|
|
51
|
+
return x && values && values.length > 0 && values.every(v => v ?? false);
|
|
52
52
|
});
|
|
53
53
|
const charts = [];
|
|
54
54
|
switch (chartType) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spc-chart-query.js","sourceRoot":"","sources":["../../../server/service/spc-chart/spc-chart-query.ts"],"names":[],"mappings":";;;;AAAA,+CAAwD;AACxD,qCAAqC;AAErC,iDAAqD;AAErD,qDAA6D;AAE7D,qDAA2E;AAC3E,6DAA+E;AAC/E,qDAA6E;AAC7E,qDAA6E;AAC7E,uDAA+E;AAC/E,qDAA6E;AAC7E,qDAA6E;AAC7E,qDAA6E;AAC7E,uDAA+E;AAGxE,IAAM,aAAa,GAAnB,MAAM,aAAa;IAElB,AAAN,KAAK,CAAC,QAAQ,CACM,SAAiB,EAClB,QAAgB,EACf,SAAiB,EAClB,QAAgB,EAClB,MAAc,EACtB,OAAwB;QAE/B,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAA;QAEhC,MAAM,OAAO,GAAG,CAAC,MAAM,IAAA,qBAAa,EAAC,iBAAO,CAAC,CAAC,OAAO,CAAC;YACpD,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,IAAA,YAAE,EAAC,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE;SAC3F,CAAC,CAAY,CAAA;QAEd,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,kBAAkB,CAAA;QAC1B,CAAC;QAED,MAAM,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAA;QAE9E,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,mCAAmC,CAAA;QAC3C,CAAC;QAED,gBAAgB;QAChB,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAA,CAAC,4BAA4B;QAChE,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,CAAA,CAAC,oBAAoB;QAEpD,MAAM,WAAW,GAAG,CAAC,MAAM,IAAA,qBAAa,EAAC,oBAAU,CAAC,CAAC,IAAI,CAAC;YACxD,KAAK,EAAE;gBACL,OAAO,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE;gBAC3B,SAAS,EAAE,IAAA,iBAAO,EAAC,QAAQ,EAAE,MAAM,CAAC;aACrC;SACF,CAAC,CAAiB,CAAA;QAEnB,MAAM,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAA;QACxB,MAAM,OAAO,GAAG,WAAW;aACxB,GAAG,CAAC,UAAU,CAAC,EAAE;YAChB,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YAEjC,OAAO;gBACL,CAAC,EAAE,UAAU,CAAC,SAAS;gBACvB,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;aAC5C,CAAA;QACH,CAAC,CAAC;aACD,MAAM,CAAC,MAAM,CAAC,EAAE;YACf,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,CAAA;YAC5B,OAAO,CAAC,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"spc-chart-query.js","sourceRoot":"","sources":["../../../server/service/spc-chart/spc-chart-query.ts"],"names":[],"mappings":"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","sourcesContent":["import { Resolver, Query, Arg, Ctx } from 'type-graphql'\nimport { Between, In } from 'typeorm'\n\nimport { getRepository } from '@things-factory/shell'\nimport { User } from '@things-factory/auth-base'\nimport { DataSet, DataSample } from '@things-factory/dataset'\n\nimport { SPCChartAnalysis, SPCChartAnalysisResult } from './spc-chart-type'\nimport { calculateXBarAnalysisResult } from '../../controllers/spc-chart/x-bar'\nimport { calculateRChartAnalysisResult } from '../../controllers/spc-chart/r'\nimport { calculateIChartAnalysisResult } from '../../controllers/spc-chart/i'\nimport { calculateMRChartAnalysisResult } from '../../controllers/spc-chart/mr'\nimport { calculateUChartAnalysisResult } from '../../controllers/spc-chart/u'\nimport { calculateCChartAnalysisResult } from '../../controllers/spc-chart/c'\nimport { calculatePChartAnalysisResult } from '../../controllers/spc-chart/p'\nimport { calculateNPChartAnalysisResult } from '../../controllers/spc-chart/np'\n\n@Resolver(DataSet)\nexport class SpcChartQuery {\n @Query(returns => SPCChartAnalysisResult!, { nullable: true, description: 'To fetch a SpcChart' })\n async spcChart(\n @Arg('dataSetId') dataSetId: string,\n @Arg('variable') variable: string,\n @Arg('chartType') chartType: string,\n @Arg('fromDate') fromDate: string,\n @Arg('toDate') toDate: string,\n @Ctx() context: ResolverContext\n ): Promise<SPCChartAnalysisResult> {\n const { domain } = context.state\n\n const dataSet = (await getRepository(DataSet).findOne({\n where: { domain: { id: In([domain.id, domain.parentId].filter(Boolean)) }, id: dataSetId }\n })) as DataSet\n\n if (!dataSet) {\n throw 'no given dataset'\n }\n\n const dataItem = dataSet.dataItems.find(dataItem => dataItem.name == variable)\n\n if (!dataItem) {\n throw 'no given variables in the dataset'\n }\n\n // TODO timezone\n const fromTime = new Date(fromDate) /* default: 30days before */\n const toTime = new Date(toDate) /* default: today */\n\n const dataSamples = (await getRepository(DataSample).find({\n where: {\n dataSet: { id: dataSet.id },\n createdAt: Between(fromTime, toTime)\n }\n })) as DataSample[]\n\n const tag = dataItem.tag\n const samples = dataSamples\n .map(dataSample => {\n const data = dataSample.data[tag]\n\n return {\n x: dataSample.createdAt,\n values: Array.isArray(data) ? data : [data]\n }\n })\n .filter(sample => {\n const { x, values } = sample\n return x && values && values.length > 0 && values.every(v => v ?? false)\n })\n\n const charts = [] as SPCChartAnalysis[]\n\n switch (chartType) {\n case 'Xbar-R':\n charts.push(calculateXBarAnalysisResult(samples as any))\n charts.push(calculateRChartAnalysisResult(samples as any))\n break\n case 'I-MR':\n charts.push(calculateIChartAnalysisResult(samples as any))\n charts.push(calculateMRChartAnalysisResult(samples as any))\n break\n case 'C':\n charts.push(calculateUChartAnalysisResult(samples as any))\n break\n case 'U':\n charts.push(calculateCChartAnalysisResult(samples as any))\n break\n case 'P':\n charts.push(calculatePChartAnalysisResult(samples as any))\n break\n case 'NP':\n charts.push(calculateNPChartAnalysisResult(samples as any))\n break\n }\n\n return {\n dataSet,\n variable,\n charts\n }\n }\n}\n"]}
|