formulab 0.5.1 → 0.9.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/CHANGELOG.md +84 -0
- package/README.md +90 -26
- package/dist/automotive/chargingLoss.d.ts +15 -0
- package/dist/automotive/chargingLoss.d.ts.map +1 -0
- package/dist/automotive/chargingLoss.js +62 -0
- package/dist/automotive/chargingLoss.js.map +1 -0
- package/dist/automotive/index.d.ts +2 -1
- package/dist/automotive/index.d.ts.map +1 -1
- package/dist/automotive/index.js +1 -0
- package/dist/automotive/index.js.map +1 -1
- package/dist/automotive/types.d.ts +23 -0
- package/dist/automotive/types.d.ts.map +1 -1
- package/dist/battery/guards.d.ts +7 -0
- package/dist/battery/guards.d.ts.map +1 -0
- package/dist/battery/guards.js +17 -0
- package/dist/battery/guards.js.map +1 -0
- package/dist/battery/index.d.ts +1 -0
- package/dist/battery/index.d.ts.map +1 -1
- package/dist/battery/index.js +2 -0
- package/dist/battery/index.js.map +1 -1
- package/dist/chemical/flowControl.d.ts +14 -0
- package/dist/chemical/flowControl.d.ts.map +1 -0
- package/dist/chemical/flowControl.js +69 -0
- package/dist/chemical/flowControl.js.map +1 -0
- package/dist/chemical/guards.d.ts +17 -0
- package/dist/chemical/guards.d.ts.map +1 -0
- package/dist/chemical/guards.js +54 -0
- package/dist/chemical/guards.js.map +1 -0
- package/dist/chemical/index.d.ts +5 -1
- package/dist/chemical/index.d.ts.map +1 -1
- package/dist/chemical/index.js +5 -0
- package/dist/chemical/index.js.map +1 -1
- package/dist/chemical/pid.d.ts +14 -0
- package/dist/chemical/pid.d.ts.map +1 -0
- package/dist/chemical/pid.js +103 -0
- package/dist/chemical/pid.js.map +1 -0
- package/dist/chemical/reliefValve.d.ts +14 -0
- package/dist/chemical/reliefValve.d.ts.map +1 -0
- package/dist/chemical/reliefValve.js +98 -0
- package/dist/chemical/reliefValve.js.map +1 -0
- package/dist/chemical/types.d.ts +63 -0
- package/dist/chemical/types.d.ts.map +1 -1
- package/dist/construction/guards.d.ts +7 -0
- package/dist/construction/guards.d.ts.map +1 -0
- package/dist/construction/guards.js +31 -0
- package/dist/construction/guards.js.map +1 -0
- package/dist/construction/index.d.ts +1 -0
- package/dist/construction/index.d.ts.map +1 -1
- package/dist/construction/index.js +2 -0
- package/dist/construction/index.js.map +1 -1
- package/dist/electronics/guards.d.ts +7 -0
- package/dist/electronics/guards.d.ts.map +1 -0
- package/dist/electronics/guards.js +17 -0
- package/dist/electronics/guards.js.map +1 -0
- package/dist/electronics/index.d.ts +1 -0
- package/dist/electronics/index.d.ts.map +1 -1
- package/dist/electronics/index.js +2 -0
- package/dist/electronics/index.js.map +1 -1
- package/dist/energy/boilerEfficiency.d.ts +13 -0
- package/dist/energy/boilerEfficiency.d.ts.map +1 -0
- package/dist/energy/boilerEfficiency.js +46 -0
- package/dist/energy/boilerEfficiency.js.map +1 -0
- package/dist/energy/cusum.d.ts +15 -0
- package/dist/energy/cusum.d.ts.map +1 -0
- package/dist/energy/cusum.js +71 -0
- package/dist/energy/cusum.js.map +1 -0
- package/dist/energy/degreeDay.d.ts +13 -0
- package/dist/energy/degreeDay.d.ts.map +1 -0
- package/dist/energy/degreeDay.js +46 -0
- package/dist/energy/degreeDay.js.map +1 -0
- package/dist/energy/heatPump.d.ts +13 -0
- package/dist/energy/heatPump.d.ts.map +1 -0
- package/dist/energy/heatPump.js +48 -0
- package/dist/energy/heatPump.js.map +1 -0
- package/dist/energy/index.d.ts +9 -1
- package/dist/energy/index.d.ts.map +1 -1
- package/dist/energy/index.js +8 -0
- package/dist/energy/index.js.map +1 -1
- package/dist/energy/insulationRoi.d.ts +14 -0
- package/dist/energy/insulationRoi.d.ts.map +1 -0
- package/dist/energy/insulationRoi.js +52 -0
- package/dist/energy/insulationRoi.js.map +1 -0
- package/dist/energy/ledRoi.d.ts +14 -0
- package/dist/energy/ledRoi.d.ts.map +1 -0
- package/dist/energy/ledRoi.js +49 -0
- package/dist/energy/ledRoi.js.map +1 -0
- package/dist/energy/transformerLoss.d.ts +13 -0
- package/dist/energy/transformerLoss.d.ts.map +1 -0
- package/dist/energy/transformerLoss.js +63 -0
- package/dist/energy/transformerLoss.js.map +1 -0
- package/dist/energy/types.d.ts +168 -0
- package/dist/energy/types.d.ts.map +1 -1
- package/dist/energy/windOutput.d.ts +14 -0
- package/dist/energy/windOutput.d.ts.map +1 -0
- package/dist/energy/windOutput.js +77 -0
- package/dist/energy/windOutput.js.map +1 -0
- package/dist/food/index.d.ts +3 -1
- package/dist/food/index.d.ts.map +1 -1
- package/dist/food/index.js +2 -0
- package/dist/food/index.js.map +1 -1
- package/dist/food/stabilityStudy.d.ts +15 -0
- package/dist/food/stabilityStudy.d.ts.map +1 -0
- package/dist/food/stabilityStudy.js +92 -0
- package/dist/food/stabilityStudy.js.map +1 -0
- package/dist/food/types.d.ts +43 -0
- package/dist/food/types.d.ts.map +1 -1
- package/dist/food/waterActivity.d.ts +17 -0
- package/dist/food/waterActivity.d.ts.map +1 -0
- package/dist/food/waterActivity.js +63 -0
- package/dist/food/waterActivity.js.map +1 -0
- package/dist/logistics/abcAnalysis.d.ts +15 -0
- package/dist/logistics/abcAnalysis.d.ts.map +1 -0
- package/dist/logistics/abcAnalysis.js +101 -0
- package/dist/logistics/abcAnalysis.js.map +1 -0
- package/dist/logistics/index.d.ts +4 -1
- package/dist/logistics/index.d.ts.map +1 -1
- package/dist/logistics/index.js +3 -0
- package/dist/logistics/index.js.map +1 -1
- package/dist/logistics/inventoryTurnover.d.ts +13 -0
- package/dist/logistics/inventoryTurnover.d.ts.map +1 -0
- package/dist/logistics/inventoryTurnover.js +36 -0
- package/dist/logistics/inventoryTurnover.js.map +1 -0
- package/dist/logistics/loadCapacity.d.ts +13 -0
- package/dist/logistics/loadCapacity.d.ts.map +1 -0
- package/dist/logistics/loadCapacity.js +46 -0
- package/dist/logistics/loadCapacity.js.map +1 -0
- package/dist/logistics/types.d.ts +78 -0
- package/dist/logistics/types.d.ts.map +1 -1
- package/dist/metal/guards.d.ts +12 -0
- package/dist/metal/guards.d.ts.map +1 -0
- package/dist/metal/guards.js +36 -0
- package/dist/metal/guards.js.map +1 -0
- package/dist/metal/index.d.ts +1 -0
- package/dist/metal/index.d.ts.map +1 -1
- package/dist/metal/index.js +2 -0
- package/dist/metal/index.js.map +1 -1
- package/dist/quality/cmk.d.ts +17 -0
- package/dist/quality/cmk.d.ts.map +1 -0
- package/dist/quality/cmk.js +43 -0
- package/dist/quality/cmk.js.map +1 -0
- package/dist/quality/gageRR.d.ts +18 -0
- package/dist/quality/gageRR.d.ts.map +1 -0
- package/dist/quality/gageRR.js +110 -0
- package/dist/quality/gageRR.js.map +1 -0
- package/dist/quality/index.d.ts +5 -1
- package/dist/quality/index.d.ts.map +1 -1
- package/dist/quality/index.js +4 -0
- package/dist/quality/index.js.map +1 -1
- package/dist/quality/paretoAnalysis.d.ts +15 -0
- package/dist/quality/paretoAnalysis.d.ts.map +1 -0
- package/dist/quality/paretoAnalysis.js +92 -0
- package/dist/quality/paretoAnalysis.js.map +1 -0
- package/dist/quality/types.d.ts +91 -0
- package/dist/quality/types.d.ts.map +1 -1
- package/dist/quality/weibull.d.ts +17 -0
- package/dist/quality/weibull.d.ts.map +1 -0
- package/dist/quality/weibull.js +106 -0
- package/dist/quality/weibull.js.map +1 -0
- package/dist/safety/arcFlash.d.ts +14 -0
- package/dist/safety/arcFlash.d.ts.map +1 -0
- package/dist/safety/arcFlash.js +90 -0
- package/dist/safety/arcFlash.js.map +1 -0
- package/dist/safety/confinedSpace.d.ts +15 -0
- package/dist/safety/confinedSpace.d.ts.map +1 -0
- package/dist/safety/confinedSpace.js +116 -0
- package/dist/safety/confinedSpace.js.map +1 -0
- package/dist/safety/ergonomicRisk.d.ts +9 -0
- package/dist/safety/ergonomicRisk.d.ts.map +1 -0
- package/dist/safety/ergonomicRisk.js +208 -0
- package/dist/safety/ergonomicRisk.js.map +1 -0
- package/dist/safety/illuminance.d.ts +13 -0
- package/dist/safety/illuminance.d.ts.map +1 -0
- package/dist/safety/illuminance.js +91 -0
- package/dist/safety/illuminance.js.map +1 -0
- package/dist/safety/index.d.ts +8 -1
- package/dist/safety/index.d.ts.map +1 -1
- package/dist/safety/index.js +7 -0
- package/dist/safety/index.js.map +1 -1
- package/dist/safety/ladderAngle.d.ts +16 -0
- package/dist/safety/ladderAngle.d.ts.map +1 -0
- package/dist/safety/ladderAngle.js +87 -0
- package/dist/safety/ladderAngle.js.map +1 -0
- package/dist/safety/lel.d.ts +14 -0
- package/dist/safety/lel.d.ts.map +1 -0
- package/dist/safety/lel.js +66 -0
- package/dist/safety/lel.js.map +1 -0
- package/dist/safety/thermalComfort.d.ts +14 -0
- package/dist/safety/thermalComfort.d.ts.map +1 -0
- package/dist/safety/thermalComfort.js +96 -0
- package/dist/safety/thermalComfort.js.map +1 -0
- package/dist/safety/types.d.ts +164 -0
- package/dist/safety/types.d.ts.map +1 -1
- package/dist/utility/bilinearInterpolation.d.ts +3 -0
- package/dist/utility/bilinearInterpolation.d.ts.map +1 -0
- package/dist/utility/bilinearInterpolation.js +47 -0
- package/dist/utility/bilinearInterpolation.js.map +1 -0
- package/dist/utility/correlation.d.ts +3 -0
- package/dist/utility/correlation.d.ts.map +1 -0
- package/dist/utility/correlation.js +29 -0
- package/dist/utility/correlation.js.map +1 -0
- package/dist/utility/depreciation.d.ts +3 -0
- package/dist/utility/depreciation.d.ts.map +1 -0
- package/dist/utility/depreciation.js +57 -0
- package/dist/utility/depreciation.js.map +1 -0
- package/dist/utility/histogram.d.ts +3 -0
- package/dist/utility/histogram.d.ts.map +1 -0
- package/dist/utility/histogram.js +42 -0
- package/dist/utility/histogram.js.map +1 -0
- package/dist/utility/index.d.ts +15 -1
- package/dist/utility/index.d.ts.map +1 -1
- package/dist/utility/index.js +14 -0
- package/dist/utility/index.js.map +1 -1
- package/dist/utility/lcc.d.ts +3 -0
- package/dist/utility/lcc.d.ts.map +1 -0
- package/dist/utility/lcc.js +26 -0
- package/dist/utility/lcc.js.map +1 -0
- package/dist/utility/linearInterpolation.d.ts +3 -0
- package/dist/utility/linearInterpolation.d.ts.map +1 -0
- package/dist/utility/linearInterpolation.js +42 -0
- package/dist/utility/linearInterpolation.js.map +1 -0
- package/dist/utility/movingAverage.d.ts +3 -0
- package/dist/utility/movingAverage.d.ts.map +1 -0
- package/dist/utility/movingAverage.js +41 -0
- package/dist/utility/movingAverage.js.map +1 -0
- package/dist/utility/normalize.d.ts +3 -0
- package/dist/utility/normalize.d.ts.map +1 -0
- package/dist/utility/normalize.js +35 -0
- package/dist/utility/normalize.js.map +1 -0
- package/dist/utility/npv.d.ts +3 -0
- package/dist/utility/npv.d.ts.map +1 -0
- package/dist/utility/npv.js +45 -0
- package/dist/utility/npv.js.map +1 -0
- package/dist/utility/percentile.d.ts +3 -0
- package/dist/utility/percentile.d.ts.map +1 -0
- package/dist/utility/percentile.js +24 -0
- package/dist/utility/percentile.js.map +1 -0
- package/dist/utility/regression.d.ts +3 -0
- package/dist/utility/regression.d.ts.map +1 -0
- package/dist/utility/regression.js +40 -0
- package/dist/utility/regression.js.map +1 -0
- package/dist/utility/roi.d.ts +3 -0
- package/dist/utility/roi.d.ts.map +1 -0
- package/dist/utility/roi.js +19 -0
- package/dist/utility/roi.js.map +1 -0
- package/dist/utility/statistics.d.ts +3 -0
- package/dist/utility/statistics.d.ts.map +1 -0
- package/dist/utility/statistics.js +34 -0
- package/dist/utility/statistics.js.map +1 -0
- package/dist/utility/types.d.ts +213 -1
- package/dist/utility/types.d.ts.map +1 -1
- package/dist/utility/unit.d.ts.map +1 -1
- package/dist/utility/unit.js +51 -0
- package/dist/utility/unit.js.map +1 -1
- package/dist/utility/weightedScore.d.ts +3 -0
- package/dist/utility/weightedScore.d.ts.map +1 -0
- package/dist/utility/weightedScore.js +35 -0
- package/dist/utility/weightedScore.js.map +1 -0
- package/package.json +3 -2
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { roundTo } from '../utils.js';
|
|
2
|
+
// AIAG MSA 4th Ed — K1 constants by number of trials
|
|
3
|
+
const K1 = { 2: 4.56, 3: 3.05 };
|
|
4
|
+
// K2 constants by number of operators
|
|
5
|
+
const K2 = { 2: 3.65, 3: 2.70 };
|
|
6
|
+
// K3 constants by number of parts
|
|
7
|
+
const K3 = {
|
|
8
|
+
2: 3.65, 3: 2.70, 4: 2.30, 5: 2.08,
|
|
9
|
+
6: 1.93, 7: 1.82, 8: 1.74, 9: 1.67, 10: 1.62,
|
|
10
|
+
};
|
|
11
|
+
/**
|
|
12
|
+
* Gage R&R (Measurement System Analysis) — AIAG MSA 4th Edition, Average and Range Method
|
|
13
|
+
*
|
|
14
|
+
* @formula
|
|
15
|
+
* - EV = R̄ × K1
|
|
16
|
+
* - AV = √((X̄_diff × K2)² − (EV² / (n×r))) (floored at 0)
|
|
17
|
+
* - GRR = √(EV² + AV²)
|
|
18
|
+
* - PV = Rp × K3
|
|
19
|
+
* - TV = √(GRR² + PV²)
|
|
20
|
+
* - %GRR = GRR/TV × 100
|
|
21
|
+
* - ndc = floor(1.41 × PV/GRR)
|
|
22
|
+
*
|
|
23
|
+
* @reference AIAG Measurement Systems Analysis Reference Manual, 4th Edition
|
|
24
|
+
* @reference IATF 16949:2016 Section 7.1.5.1.1
|
|
25
|
+
*/
|
|
26
|
+
export function gageRR(input) {
|
|
27
|
+
const { measurements, tolerance } = input;
|
|
28
|
+
const numParts = measurements.length;
|
|
29
|
+
const numOperators = measurements[0].length;
|
|
30
|
+
const numTrials = measurements[0][0].length;
|
|
31
|
+
const k1 = K1[numTrials] ?? K1[3];
|
|
32
|
+
const k2 = K2[numOperators] ?? K2[3];
|
|
33
|
+
const k3 = K3[numParts] ?? K3[10];
|
|
34
|
+
// Compute range per part per operator, then overall R̄
|
|
35
|
+
let rangeSum = 0;
|
|
36
|
+
for (let p = 0; p < numParts; p++) {
|
|
37
|
+
for (let o = 0; o < numOperators; o++) {
|
|
38
|
+
const trials = measurements[p][o];
|
|
39
|
+
const maxVal = Math.max(...trials);
|
|
40
|
+
const minVal = Math.min(...trials);
|
|
41
|
+
rangeSum += maxVal - minVal;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
const rBar = rangeSum / (numParts * numOperators);
|
|
45
|
+
// EV (Equipment Variation / Repeatability)
|
|
46
|
+
const ev = rBar * k1;
|
|
47
|
+
// Operator means
|
|
48
|
+
const operatorMeans = [];
|
|
49
|
+
for (let o = 0; o < numOperators; o++) {
|
|
50
|
+
let sum = 0;
|
|
51
|
+
for (let p = 0; p < numParts; p++) {
|
|
52
|
+
for (let t = 0; t < numTrials; t++) {
|
|
53
|
+
sum += measurements[p][o][t];
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
operatorMeans.push(sum / (numParts * numTrials));
|
|
57
|
+
}
|
|
58
|
+
const xBarDiff = Math.max(...operatorMeans) - Math.min(...operatorMeans);
|
|
59
|
+
// AV (Appraiser Variation / Reproducibility)
|
|
60
|
+
const avSquared = (xBarDiff * k2) ** 2 - (ev ** 2) / (numParts * numTrials);
|
|
61
|
+
const av = avSquared > 0 ? Math.sqrt(avSquared) : 0;
|
|
62
|
+
// GRR
|
|
63
|
+
const grr = Math.sqrt(ev ** 2 + av ** 2);
|
|
64
|
+
// Part means for PV
|
|
65
|
+
const partMeans = [];
|
|
66
|
+
for (let p = 0; p < numParts; p++) {
|
|
67
|
+
let sum = 0;
|
|
68
|
+
for (let o = 0; o < numOperators; o++) {
|
|
69
|
+
for (let t = 0; t < numTrials; t++) {
|
|
70
|
+
sum += measurements[p][o][t];
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
partMeans.push(sum / (numOperators * numTrials));
|
|
74
|
+
}
|
|
75
|
+
const rp = Math.max(...partMeans) - Math.min(...partMeans);
|
|
76
|
+
const pv = rp * k3;
|
|
77
|
+
// TV (Total Variation)
|
|
78
|
+
const tv = Math.sqrt(grr ** 2 + pv ** 2);
|
|
79
|
+
// %GRR
|
|
80
|
+
const percentGRR = tv > 0 ? roundTo((grr / tv) * 100, 2) : 0;
|
|
81
|
+
// %Tolerance
|
|
82
|
+
const percentTolerance = tolerance != null && tolerance > 0
|
|
83
|
+
? roundTo((grr / tolerance) * 100 * 6, 2)
|
|
84
|
+
: null;
|
|
85
|
+
// ndc
|
|
86
|
+
const ndc = grr > 0 ? Math.floor(1.41 * (pv / grr)) : 0;
|
|
87
|
+
// Status
|
|
88
|
+
let status;
|
|
89
|
+
if (percentGRR <= 10) {
|
|
90
|
+
status = 'acceptable';
|
|
91
|
+
}
|
|
92
|
+
else if (percentGRR <= 30) {
|
|
93
|
+
status = 'marginal';
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
status = 'unacceptable';
|
|
97
|
+
}
|
|
98
|
+
return {
|
|
99
|
+
ev: roundTo(ev, 4),
|
|
100
|
+
av: roundTo(av, 4),
|
|
101
|
+
grr: roundTo(grr, 4),
|
|
102
|
+
pv: roundTo(pv, 4),
|
|
103
|
+
tv: roundTo(tv, 4),
|
|
104
|
+
percentGRR,
|
|
105
|
+
percentTolerance,
|
|
106
|
+
ndc,
|
|
107
|
+
status,
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=gageRR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gageRR.js","sourceRoot":"","sources":["../../src/quality/gageRR.ts"],"names":[],"mappings":"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"}
|
package/dist/quality/index.d.ts
CHANGED
|
@@ -12,5 +12,9 @@ export { ppm } from './ppm.js';
|
|
|
12
12
|
export { rpn } from './rpn.js';
|
|
13
13
|
export { yieldCalc } from './yield.js';
|
|
14
14
|
export { controlChart } from './controlChart.js';
|
|
15
|
-
export
|
|
15
|
+
export { gageRR } from './gageRR.js';
|
|
16
|
+
export { cmk } from './cmk.js';
|
|
17
|
+
export { weibull } from './weibull.js';
|
|
18
|
+
export { paretoAnalysis } from './paretoAnalysis.js';
|
|
19
|
+
export type { OeeRawData, OeeInput, OeeResult, CpkInput, CpkResult, CycleTimeInput, CycleTimeResult, TimeUnit, TaktTimeInput, TaktTimeResult, InspectionLevel, AqlInput, AqlResult, DowntimeInput, DowntimeResult, DpmoInput, DpmoResult, BalancingTask, LineBalancingInput, WorkStation, PositionalWeight, LineBalancingResult, MtbfInput, MtbfResult, PpkInput, PpkResult, ConvertFrom, PpmInput, PpmResult, RpnInput, RiskLevel, RpnResult, YieldInput, YieldResult, ControlChartType, ControlChartInput, ControlLimit, SubgroupStat, ControlChartResult, GageRRInput, GageRRResult, CmkInput, CmkResult, WeibullInput, WeibullResult, ParetoItem, ParetoInput, ParetoClassification, ParetoResult, } from './types.js';
|
|
16
20
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/quality/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/quality/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAGrD,YAAY,EAEV,UAAU,EACV,QAAQ,EACR,SAAS,EAET,QAAQ,EACR,SAAS,EAET,cAAc,EACd,eAAe,EAEf,QAAQ,EACR,aAAa,EACb,cAAc,EAEd,eAAe,EACf,QAAQ,EACR,SAAS,EAET,aAAa,EACb,cAAc,EAEd,SAAS,EACT,UAAU,EAEV,aAAa,EACb,kBAAkB,EAClB,WAAW,EACX,gBAAgB,EAChB,mBAAmB,EAEnB,SAAS,EACT,UAAU,EAEV,QAAQ,EACR,SAAS,EAET,WAAW,EACX,QAAQ,EACR,SAAS,EAET,QAAQ,EACR,SAAS,EACT,SAAS,EAET,UAAU,EACV,WAAW,EAEX,gBAAgB,EAChB,iBAAiB,EACjB,YAAY,EACZ,YAAY,EACZ,kBAAkB,EAElB,WAAW,EACX,YAAY,EAEZ,QAAQ,EACR,SAAS,EAET,YAAY,EACZ,aAAa,EAEb,UAAU,EACV,WAAW,EACX,oBAAoB,EACpB,YAAY,GACb,MAAM,YAAY,CAAC"}
|
package/dist/quality/index.js
CHANGED
|
@@ -13,4 +13,8 @@ export { ppm } from './ppm.js';
|
|
|
13
13
|
export { rpn } from './rpn.js';
|
|
14
14
|
export { yieldCalc } from './yield.js';
|
|
15
15
|
export { controlChart } from './controlChart.js';
|
|
16
|
+
export { gageRR } from './gageRR.js';
|
|
17
|
+
export { cmk } from './cmk.js';
|
|
18
|
+
export { weibull } from './weibull.js';
|
|
19
|
+
export { paretoAnalysis } from './paretoAnalysis.js';
|
|
16
20
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/quality/index.ts"],"names":[],"mappings":"AAAA,0BAA0B;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/quality/index.ts"],"names":[],"mappings":"AAAA,0BAA0B;AAC1B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { ParetoInput, ParetoResult } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Pareto Analysis (80/20 Rule) — ABC Classification
|
|
4
|
+
*
|
|
5
|
+
* @formula Cumulative percentage-based classification
|
|
6
|
+
* - Sort items by value descending
|
|
7
|
+
* - Calculate cumulative percentage
|
|
8
|
+
* - Category A: cumulative ≤ thresholdA (default 80%)
|
|
9
|
+
* - Category B: thresholdA < cumulative ≤ thresholdB (default 95%)
|
|
10
|
+
* - Category C: cumulative > thresholdB
|
|
11
|
+
*
|
|
12
|
+
* @reference Juran, J.M. "Juran's Quality Handbook", 5th Ed.
|
|
13
|
+
*/
|
|
14
|
+
export declare function paretoAnalysis(input: ParetoInput): ParetoResult;
|
|
15
|
+
//# sourceMappingURL=paretoAnalysis.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"paretoAnalysis.d.ts","sourceRoot":"","sources":["../../src/quality/paretoAnalysis.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAwB,MAAM,YAAY,CAAC;AAElF;;;;;;;;;;;GAWG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,WAAW,GAAG,YAAY,CAqF/D"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { roundTo } from '../utils.js';
|
|
2
|
+
/**
|
|
3
|
+
* Pareto Analysis (80/20 Rule) — ABC Classification
|
|
4
|
+
*
|
|
5
|
+
* @formula Cumulative percentage-based classification
|
|
6
|
+
* - Sort items by value descending
|
|
7
|
+
* - Calculate cumulative percentage
|
|
8
|
+
* - Category A: cumulative ≤ thresholdA (default 80%)
|
|
9
|
+
* - Category B: thresholdA < cumulative ≤ thresholdB (default 95%)
|
|
10
|
+
* - Category C: cumulative > thresholdB
|
|
11
|
+
*
|
|
12
|
+
* @reference Juran, J.M. "Juran's Quality Handbook", 5th Ed.
|
|
13
|
+
*/
|
|
14
|
+
export function paretoAnalysis(input) {
|
|
15
|
+
const { items, thresholdA = 80, thresholdB = 95 } = input;
|
|
16
|
+
const totalValue = items.reduce((s, item) => s + item.value, 0);
|
|
17
|
+
if (totalValue === 0) {
|
|
18
|
+
const classified = items.map((item, i) => ({
|
|
19
|
+
name: item.name,
|
|
20
|
+
value: item.value,
|
|
21
|
+
percentage: 0,
|
|
22
|
+
cumulative: 0,
|
|
23
|
+
rank: i + 1,
|
|
24
|
+
category: 'C',
|
|
25
|
+
}));
|
|
26
|
+
return {
|
|
27
|
+
items: classified,
|
|
28
|
+
summary: {
|
|
29
|
+
a: { count: 0, totalValue: 0, percentage: 0 },
|
|
30
|
+
b: { count: 0, totalValue: 0, percentage: 0 },
|
|
31
|
+
c: { count: items.length, totalValue: 0, percentage: 0 },
|
|
32
|
+
},
|
|
33
|
+
totalValue: 0,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
// Sort by value descending
|
|
37
|
+
const sorted = [...items].sort((a, b) => b.value - a.value);
|
|
38
|
+
let cumulative = 0;
|
|
39
|
+
const classified = sorted.map((item, i) => {
|
|
40
|
+
const percentage = roundTo((item.value / totalValue) * 100, 2);
|
|
41
|
+
cumulative += percentage;
|
|
42
|
+
let category;
|
|
43
|
+
if (cumulative <= thresholdA) {
|
|
44
|
+
category = 'A';
|
|
45
|
+
}
|
|
46
|
+
else if (cumulative <= thresholdB) {
|
|
47
|
+
category = 'B';
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
category = 'C';
|
|
51
|
+
}
|
|
52
|
+
// First item always goes to A if thresholdA > 0
|
|
53
|
+
if (i === 0 && percentage > thresholdA) {
|
|
54
|
+
category = 'A';
|
|
55
|
+
}
|
|
56
|
+
return {
|
|
57
|
+
name: item.name,
|
|
58
|
+
value: item.value,
|
|
59
|
+
percentage,
|
|
60
|
+
cumulative: roundTo(cumulative, 2),
|
|
61
|
+
rank: i + 1,
|
|
62
|
+
category,
|
|
63
|
+
};
|
|
64
|
+
});
|
|
65
|
+
// Summary
|
|
66
|
+
const summaryA = classified.filter(c => c.category === 'A');
|
|
67
|
+
const summaryB = classified.filter(c => c.category === 'B');
|
|
68
|
+
const summaryC = classified.filter(c => c.category === 'C');
|
|
69
|
+
const sumVal = (arr) => arr.reduce((s, c) => s + c.value, 0);
|
|
70
|
+
return {
|
|
71
|
+
items: classified,
|
|
72
|
+
summary: {
|
|
73
|
+
a: {
|
|
74
|
+
count: summaryA.length,
|
|
75
|
+
totalValue: roundTo(sumVal(summaryA), 2),
|
|
76
|
+
percentage: roundTo((sumVal(summaryA) / totalValue) * 100, 2),
|
|
77
|
+
},
|
|
78
|
+
b: {
|
|
79
|
+
count: summaryB.length,
|
|
80
|
+
totalValue: roundTo(sumVal(summaryB), 2),
|
|
81
|
+
percentage: roundTo((sumVal(summaryB) / totalValue) * 100, 2),
|
|
82
|
+
},
|
|
83
|
+
c: {
|
|
84
|
+
count: summaryC.length,
|
|
85
|
+
totalValue: roundTo(sumVal(summaryC), 2),
|
|
86
|
+
percentage: roundTo((sumVal(summaryC) / totalValue) * 100, 2),
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
totalValue: roundTo(totalValue, 2),
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=paretoAnalysis.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"paretoAnalysis.js","sourceRoot":"","sources":["../../src/quality/paretoAnalysis.ts"],"names":[],"mappings":"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"}
|
package/dist/quality/types.d.ts
CHANGED
|
@@ -289,4 +289,95 @@ export interface YieldResult {
|
|
|
289
289
|
/** Expected output after all steps */
|
|
290
290
|
expectedOutput: number;
|
|
291
291
|
}
|
|
292
|
+
/**
|
|
293
|
+
* Gage R&R (MSA) Types — AIAG MSA 4th Edition
|
|
294
|
+
*/
|
|
295
|
+
export interface GageRRInput {
|
|
296
|
+
measurements: number[][][];
|
|
297
|
+
tolerance?: number;
|
|
298
|
+
}
|
|
299
|
+
export interface GageRRResult {
|
|
300
|
+
ev: number;
|
|
301
|
+
av: number;
|
|
302
|
+
grr: number;
|
|
303
|
+
pv: number;
|
|
304
|
+
tv: number;
|
|
305
|
+
percentGRR: number;
|
|
306
|
+
percentTolerance: number | null;
|
|
307
|
+
ndc: number;
|
|
308
|
+
status: 'acceptable' | 'marginal' | 'unacceptable';
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* Cmk (Machine Capability Index) Types
|
|
312
|
+
*/
|
|
313
|
+
export interface CmkInput {
|
|
314
|
+
measurements: number[];
|
|
315
|
+
lsl: number;
|
|
316
|
+
usl: number;
|
|
317
|
+
}
|
|
318
|
+
export interface CmkResult {
|
|
319
|
+
mean: number;
|
|
320
|
+
stdDev: number;
|
|
321
|
+
cm: number;
|
|
322
|
+
cmk: number;
|
|
323
|
+
isCapable: boolean;
|
|
324
|
+
}
|
|
325
|
+
/**
|
|
326
|
+
* Weibull Reliability Analysis Types
|
|
327
|
+
*/
|
|
328
|
+
export interface WeibullInput {
|
|
329
|
+
failureTimes: number[];
|
|
330
|
+
missionTime?: number;
|
|
331
|
+
}
|
|
332
|
+
export interface WeibullResult {
|
|
333
|
+
beta: number;
|
|
334
|
+
eta: number;
|
|
335
|
+
mttf: number;
|
|
336
|
+
r2: number;
|
|
337
|
+
reliability: number | null;
|
|
338
|
+
b10Life: number;
|
|
339
|
+
b50Life: number;
|
|
340
|
+
failureMode: 'infant' | 'random' | 'wearout';
|
|
341
|
+
}
|
|
342
|
+
/**
|
|
343
|
+
* Pareto Analysis Types
|
|
344
|
+
*/
|
|
345
|
+
export interface ParetoItem {
|
|
346
|
+
name: string;
|
|
347
|
+
value: number;
|
|
348
|
+
}
|
|
349
|
+
export interface ParetoInput {
|
|
350
|
+
items: ParetoItem[];
|
|
351
|
+
thresholdA?: number;
|
|
352
|
+
thresholdB?: number;
|
|
353
|
+
}
|
|
354
|
+
export interface ParetoClassification {
|
|
355
|
+
name: string;
|
|
356
|
+
value: number;
|
|
357
|
+
percentage: number;
|
|
358
|
+
cumulative: number;
|
|
359
|
+
rank: number;
|
|
360
|
+
category: 'A' | 'B' | 'C';
|
|
361
|
+
}
|
|
362
|
+
export interface ParetoResult {
|
|
363
|
+
items: ParetoClassification[];
|
|
364
|
+
summary: {
|
|
365
|
+
a: {
|
|
366
|
+
count: number;
|
|
367
|
+
totalValue: number;
|
|
368
|
+
percentage: number;
|
|
369
|
+
};
|
|
370
|
+
b: {
|
|
371
|
+
count: number;
|
|
372
|
+
totalValue: number;
|
|
373
|
+
percentage: number;
|
|
374
|
+
};
|
|
375
|
+
c: {
|
|
376
|
+
count: number;
|
|
377
|
+
totalValue: number;
|
|
378
|
+
percentage: number;
|
|
379
|
+
};
|
|
380
|
+
};
|
|
381
|
+
totalValue: number;
|
|
382
|
+
}
|
|
292
383
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/quality/types.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/quality/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { WeibullInput, WeibullResult } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Weibull Reliability Analysis — Median Rank Regression
|
|
4
|
+
*
|
|
5
|
+
* @formula
|
|
6
|
+
* - F(i) = (i − 0.3) / (n + 0.4) (Benard's approximation for median rank)
|
|
7
|
+
* - Y = ln(ln(1/(1−F))) vs X = ln(t) → linear regression
|
|
8
|
+
* - β = slope, η = exp(−intercept/slope)
|
|
9
|
+
* - MTTF = η × Γ(1 + 1/β)
|
|
10
|
+
* - R(t) = exp(−(t/η)^β)
|
|
11
|
+
* - B10 = η × (−ln(0.9))^(1/β)
|
|
12
|
+
*
|
|
13
|
+
* @reference Abernethy, R.B. "The New Weibull Handbook", 5th Ed.
|
|
14
|
+
* @reference IEC 61649:2008 — Weibull Analysis
|
|
15
|
+
*/
|
|
16
|
+
export declare function weibull(input: WeibullInput): WeibullResult;
|
|
17
|
+
//# sourceMappingURL=weibull.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"weibull.d.ts","sourceRoot":"","sources":["../../src/quality/weibull.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE9D;;;;;;;;;;;;;GAaG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,YAAY,GAAG,aAAa,CAwE1D"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import { roundTo } from '../utils.js';
|
|
2
|
+
/**
|
|
3
|
+
* Weibull Reliability Analysis — Median Rank Regression
|
|
4
|
+
*
|
|
5
|
+
* @formula
|
|
6
|
+
* - F(i) = (i − 0.3) / (n + 0.4) (Benard's approximation for median rank)
|
|
7
|
+
* - Y = ln(ln(1/(1−F))) vs X = ln(t) → linear regression
|
|
8
|
+
* - β = slope, η = exp(−intercept/slope)
|
|
9
|
+
* - MTTF = η × Γ(1 + 1/β)
|
|
10
|
+
* - R(t) = exp(−(t/η)^β)
|
|
11
|
+
* - B10 = η × (−ln(0.9))^(1/β)
|
|
12
|
+
*
|
|
13
|
+
* @reference Abernethy, R.B. "The New Weibull Handbook", 5th Ed.
|
|
14
|
+
* @reference IEC 61649:2008 — Weibull Analysis
|
|
15
|
+
*/
|
|
16
|
+
export function weibull(input) {
|
|
17
|
+
const { failureTimes, missionTime } = input;
|
|
18
|
+
// Sort failure times ascending
|
|
19
|
+
const sorted = [...failureTimes].sort((a, b) => a - b);
|
|
20
|
+
const n = sorted.length;
|
|
21
|
+
// Median rank regression
|
|
22
|
+
const xVals = []; // ln(t)
|
|
23
|
+
const yVals = []; // ln(ln(1/(1-F)))
|
|
24
|
+
for (let i = 0; i < n; i++) {
|
|
25
|
+
const rank = i + 1;
|
|
26
|
+
const f = (rank - 0.3) / (n + 0.4); // Benard's approximation
|
|
27
|
+
xVals.push(Math.log(sorted[i]));
|
|
28
|
+
yVals.push(Math.log(Math.log(1 / (1 - f))));
|
|
29
|
+
}
|
|
30
|
+
// Linear regression: Y = a + b*X
|
|
31
|
+
const sumX = xVals.reduce((s, v) => s + v, 0);
|
|
32
|
+
const sumY = yVals.reduce((s, v) => s + v, 0);
|
|
33
|
+
const sumXY = xVals.reduce((s, v, i) => s + v * yVals[i], 0);
|
|
34
|
+
const sumX2 = xVals.reduce((s, v) => s + v * v, 0);
|
|
35
|
+
const sumY2 = yVals.reduce((s, v) => s + v * v, 0);
|
|
36
|
+
const beta = (n * sumXY - sumX * sumY) / (n * sumX2 - sumX * sumX);
|
|
37
|
+
const intercept = (sumY - beta * sumX) / n;
|
|
38
|
+
const eta = Math.exp(-intercept / beta);
|
|
39
|
+
// R² (coefficient of determination)
|
|
40
|
+
const yMean = sumY / n;
|
|
41
|
+
const ssTot = sumY2 - n * yMean * yMean;
|
|
42
|
+
const ssRes = yVals.reduce((s, y, i) => {
|
|
43
|
+
const yPred = intercept + beta * xVals[i];
|
|
44
|
+
return s + (y - yPred) ** 2;
|
|
45
|
+
}, 0);
|
|
46
|
+
const r2 = ssTot > 0 ? 1 - ssRes / ssTot : 0;
|
|
47
|
+
// MTTF = η × Γ(1 + 1/β)
|
|
48
|
+
const mttf = eta * gamma(1 + 1 / beta);
|
|
49
|
+
// B10 life: 10% failure life
|
|
50
|
+
const b10Life = eta * Math.pow(-Math.log(0.9), 1 / beta);
|
|
51
|
+
// B50 life: Median life
|
|
52
|
+
const b50Life = eta * Math.pow(-Math.log(0.5), 1 / beta);
|
|
53
|
+
// Reliability at mission time
|
|
54
|
+
const reliability = missionTime != null
|
|
55
|
+
? Math.exp(-Math.pow(missionTime / eta, beta))
|
|
56
|
+
: null;
|
|
57
|
+
// Failure mode classification
|
|
58
|
+
let failureMode;
|
|
59
|
+
if (beta < 0.95) {
|
|
60
|
+
failureMode = 'infant';
|
|
61
|
+
}
|
|
62
|
+
else if (beta <= 1.05) {
|
|
63
|
+
failureMode = 'random';
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
failureMode = 'wearout';
|
|
67
|
+
}
|
|
68
|
+
return {
|
|
69
|
+
beta: roundTo(beta, 4),
|
|
70
|
+
eta: roundTo(eta, 2),
|
|
71
|
+
mttf: roundTo(mttf, 2),
|
|
72
|
+
r2: roundTo(r2, 4),
|
|
73
|
+
reliability: reliability != null ? roundTo(reliability, 4) : null,
|
|
74
|
+
b10Life: roundTo(b10Life, 2),
|
|
75
|
+
b50Life: roundTo(b50Life, 2),
|
|
76
|
+
failureMode,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Gamma function approximation using Lanczos method
|
|
81
|
+
*/
|
|
82
|
+
function gamma(z) {
|
|
83
|
+
if (z < 0.5) {
|
|
84
|
+
return Math.PI / (Math.sin(Math.PI * z) * gamma(1 - z));
|
|
85
|
+
}
|
|
86
|
+
z -= 1;
|
|
87
|
+
const g = 7;
|
|
88
|
+
const c = [
|
|
89
|
+
0.99999999999980993,
|
|
90
|
+
676.5203681218851,
|
|
91
|
+
-1259.1392167224028,
|
|
92
|
+
771.32342877765313,
|
|
93
|
+
-176.61502916214059,
|
|
94
|
+
12.507343278686905,
|
|
95
|
+
-0.13857109526572012,
|
|
96
|
+
9.9843695780195716e-6,
|
|
97
|
+
1.5056327351493116e-7,
|
|
98
|
+
];
|
|
99
|
+
let x = c[0];
|
|
100
|
+
for (let i = 1; i < g + 2; i++) {
|
|
101
|
+
x += c[i] / (z + i);
|
|
102
|
+
}
|
|
103
|
+
const t = z + g + 0.5;
|
|
104
|
+
return Math.sqrt(2 * Math.PI) * Math.pow(t, z + 0.5) * Math.exp(-t) * x;
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=weibull.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"weibull.js","sourceRoot":"","sources":["../../src/quality/weibull.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ArcFlashInput, ArcFlashResult } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Arc Flash Incident Energy Calculator — IEEE 1584-2018 Simplified / NFPA 70E
|
|
4
|
+
*
|
|
5
|
+
* @formula
|
|
6
|
+
* - Ia (arcing current) from empirical IEEE 1584 equations
|
|
7
|
+
* - E (incident energy) = Cf × normalized energy × (t/0.2) × (610^x / D^x)
|
|
8
|
+
* - AFB = distance where E = 1.2 cal/cm²
|
|
9
|
+
*
|
|
10
|
+
* @reference IEEE 1584-2018 — Guide for Performing Arc-Flash Hazard Calculations
|
|
11
|
+
* @reference NFPA 70E-2024 — Standard for Electrical Safety in the Workplace
|
|
12
|
+
*/
|
|
13
|
+
export declare function arcFlash(input: ArcFlashInput): ArcFlashResult;
|
|
14
|
+
//# sourceMappingURL=arcFlash.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arcFlash.d.ts","sourceRoot":"","sources":["../../src/safety/arcFlash.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEhE;;;;;;;;;;GAUG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,aAAa,GAAG,cAAc,CA8E7D"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { roundTo } from '../utils.js';
|
|
2
|
+
/**
|
|
3
|
+
* Arc Flash Incident Energy Calculator — IEEE 1584-2018 Simplified / NFPA 70E
|
|
4
|
+
*
|
|
5
|
+
* @formula
|
|
6
|
+
* - Ia (arcing current) from empirical IEEE 1584 equations
|
|
7
|
+
* - E (incident energy) = Cf × normalized energy × (t/0.2) × (610^x / D^x)
|
|
8
|
+
* - AFB = distance where E = 1.2 cal/cm²
|
|
9
|
+
*
|
|
10
|
+
* @reference IEEE 1584-2018 — Guide for Performing Arc-Flash Hazard Calculations
|
|
11
|
+
* @reference NFPA 70E-2024 — Standard for Electrical Safety in the Workplace
|
|
12
|
+
*/
|
|
13
|
+
export function arcFlash(input) {
|
|
14
|
+
const { voltage, boltedFaultCurrent, workingDistance, faultClearingTime, gapBetweenConductors, enclosureType } = input;
|
|
15
|
+
const Ibf = boltedFaultCurrent; // kA
|
|
16
|
+
const V = voltage;
|
|
17
|
+
const G = gapBetweenConductors; // mm
|
|
18
|
+
const t = faultClearingTime; // seconds
|
|
19
|
+
const D = workingDistance; // mm
|
|
20
|
+
// Enclosure correction factors
|
|
21
|
+
const enclosureCf = {
|
|
22
|
+
open: 1.0,
|
|
23
|
+
box: 1.5,
|
|
24
|
+
mcc: 1.5,
|
|
25
|
+
panel: 1.5,
|
|
26
|
+
cable: 1.0,
|
|
27
|
+
};
|
|
28
|
+
const Cf = enclosureCf[enclosureType] ?? 1.0;
|
|
29
|
+
// Distance exponents by voltage
|
|
30
|
+
const distanceExponent = V <= 1000 ? 1.641 : 0.973;
|
|
31
|
+
// Arcing current estimation (simplified IEEE 1584)
|
|
32
|
+
let Ia;
|
|
33
|
+
if (V <= 1000) {
|
|
34
|
+
// Low voltage
|
|
35
|
+
const logIa = 0.662 * Math.log10(Ibf) + 0.0966 * (V / 1000) + 0.000526 * G + 0.5588 * (V / 1000) * Math.log10(Ibf) - 0.00304 * G * Math.log10(Ibf);
|
|
36
|
+
Ia = Math.pow(10, logIa);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
// Medium voltage (> 1kV)
|
|
40
|
+
const logIa = 0.00402 + 0.983 * Math.log10(Ibf);
|
|
41
|
+
Ia = Math.pow(10, logIa);
|
|
42
|
+
}
|
|
43
|
+
// Normalized incident energy at 610mm, 0.2s (cal/cm²)
|
|
44
|
+
const K1 = enclosureType === 'open' ? -0.792 : -0.555;
|
|
45
|
+
const K2 = 0; // ungrounded/HRG → -0.113, but default grounded
|
|
46
|
+
const logEn = K1 + K2 + 1.081 * Math.log10(Ia) + 0.0011 * G;
|
|
47
|
+
const En = Math.pow(10, logEn);
|
|
48
|
+
// Incident energy at working distance
|
|
49
|
+
const E = Cf * En * (t / 0.2) * Math.pow(610, distanceExponent) / Math.pow(D, distanceExponent);
|
|
50
|
+
// Arc flash boundary (distance where E = 1.2 cal/cm²)
|
|
51
|
+
const Eb = 1.2; // cal/cm² threshold
|
|
52
|
+
const AFB = Math.pow((Cf * En * (t / 0.2) * Math.pow(610, distanceExponent)) / Eb, 1 / distanceExponent);
|
|
53
|
+
// PPE Category per NFPA 70E Table 130.7(C)(15)(a)
|
|
54
|
+
let ppeCategory;
|
|
55
|
+
if (E <= 1.2)
|
|
56
|
+
ppeCategory = 0;
|
|
57
|
+
else if (E <= 4)
|
|
58
|
+
ppeCategory = 1;
|
|
59
|
+
else if (E <= 8)
|
|
60
|
+
ppeCategory = 2;
|
|
61
|
+
else if (E <= 25)
|
|
62
|
+
ppeCategory = 3;
|
|
63
|
+
else
|
|
64
|
+
ppeCategory = 4;
|
|
65
|
+
// Hazard level
|
|
66
|
+
let hazardLevel;
|
|
67
|
+
if (E <= 1.2)
|
|
68
|
+
hazardLevel = 'safe';
|
|
69
|
+
else if (E <= 40)
|
|
70
|
+
hazardLevel = 'danger';
|
|
71
|
+
else
|
|
72
|
+
hazardLevel = 'extreme';
|
|
73
|
+
// Required PPE description
|
|
74
|
+
const ppeDescriptions = {
|
|
75
|
+
0: 'No PPE required (E ≤ 1.2 cal/cm²)',
|
|
76
|
+
1: 'Arc-rated shirt, pants, safety glasses (4 cal/cm²)',
|
|
77
|
+
2: 'Arc flash suit or arc-rated clothing (8 cal/cm²)',
|
|
78
|
+
3: 'Arc flash suit, gloves, face shield (25 cal/cm²)',
|
|
79
|
+
4: 'Arc flash suit rated > 25 cal/cm² (40 cal/cm²)',
|
|
80
|
+
};
|
|
81
|
+
return {
|
|
82
|
+
arcCurrent: roundTo(Ia, 2),
|
|
83
|
+
incidentEnergy: roundTo(E, 2),
|
|
84
|
+
arcFlashBoundary: roundTo(AFB, 0),
|
|
85
|
+
ppeCategory,
|
|
86
|
+
hazardLevel,
|
|
87
|
+
requiredPPE: ppeDescriptions[ppeCategory],
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=arcFlash.js.map
|