formulab 0.5.1 → 0.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (340) hide show
  1. package/CHANGELOG.md +126 -0
  2. package/README.md +122 -32
  3. package/dist/automotive/brakingDistance.d.ts +4 -0
  4. package/dist/automotive/brakingDistance.d.ts.map +1 -1
  5. package/dist/automotive/brakingDistance.js +8 -4
  6. package/dist/automotive/brakingDistance.js.map +1 -1
  7. package/dist/automotive/chargingLoss.d.ts +15 -0
  8. package/dist/automotive/chargingLoss.d.ts.map +1 -0
  9. package/dist/automotive/chargingLoss.js +62 -0
  10. package/dist/automotive/chargingLoss.js.map +1 -0
  11. package/dist/automotive/index.d.ts +2 -1
  12. package/dist/automotive/index.d.ts.map +1 -1
  13. package/dist/automotive/index.js +1 -0
  14. package/dist/automotive/index.js.map +1 -1
  15. package/dist/automotive/types.d.ts +23 -0
  16. package/dist/automotive/types.d.ts.map +1 -1
  17. package/dist/battery/cRate.d.ts.map +1 -1
  18. package/dist/battery/cRate.js +6 -0
  19. package/dist/battery/cRate.js.map +1 -1
  20. package/dist/battery/guards.d.ts +7 -0
  21. package/dist/battery/guards.d.ts.map +1 -0
  22. package/dist/battery/guards.js +17 -0
  23. package/dist/battery/guards.js.map +1 -0
  24. package/dist/battery/index.d.ts +1 -0
  25. package/dist/battery/index.d.ts.map +1 -1
  26. package/dist/battery/index.js +2 -0
  27. package/dist/battery/index.js.map +1 -1
  28. package/dist/chemical/dilution.js +4 -4
  29. package/dist/chemical/dilution.js.map +1 -1
  30. package/dist/chemical/flowControl.d.ts +14 -0
  31. package/dist/chemical/flowControl.d.ts.map +1 -0
  32. package/dist/chemical/flowControl.js +69 -0
  33. package/dist/chemical/flowControl.js.map +1 -0
  34. package/dist/chemical/guards.d.ts +17 -0
  35. package/dist/chemical/guards.d.ts.map +1 -0
  36. package/dist/chemical/guards.js +54 -0
  37. package/dist/chemical/guards.js.map +1 -0
  38. package/dist/chemical/heatTransfer.d.ts +6 -0
  39. package/dist/chemical/heatTransfer.d.ts.map +1 -1
  40. package/dist/chemical/heatTransfer.js +15 -9
  41. package/dist/chemical/heatTransfer.js.map +1 -1
  42. package/dist/chemical/index.d.ts +5 -1
  43. package/dist/chemical/index.d.ts.map +1 -1
  44. package/dist/chemical/index.js +5 -0
  45. package/dist/chemical/index.js.map +1 -1
  46. package/dist/chemical/pid.d.ts +14 -0
  47. package/dist/chemical/pid.d.ts.map +1 -0
  48. package/dist/chemical/pid.js +103 -0
  49. package/dist/chemical/pid.js.map +1 -0
  50. package/dist/chemical/pipeFlow.d.ts +6 -0
  51. package/dist/chemical/pipeFlow.d.ts.map +1 -1
  52. package/dist/chemical/pipeFlow.js +12 -6
  53. package/dist/chemical/pipeFlow.js.map +1 -1
  54. package/dist/chemical/reliefValve.d.ts +14 -0
  55. package/dist/chemical/reliefValve.d.ts.map +1 -0
  56. package/dist/chemical/reliefValve.js +98 -0
  57. package/dist/chemical/reliefValve.js.map +1 -0
  58. package/dist/chemical/types.d.ts +63 -0
  59. package/dist/chemical/types.d.ts.map +1 -1
  60. package/dist/construction/aggregate.d.ts +4 -0
  61. package/dist/construction/aggregate.d.ts.map +1 -1
  62. package/dist/construction/aggregate.js +8 -4
  63. package/dist/construction/aggregate.js.map +1 -1
  64. package/dist/construction/guards.d.ts +7 -0
  65. package/dist/construction/guards.d.ts.map +1 -0
  66. package/dist/construction/guards.js +31 -0
  67. package/dist/construction/guards.js.map +1 -0
  68. package/dist/construction/index.d.ts +1 -0
  69. package/dist/construction/index.d.ts.map +1 -1
  70. package/dist/construction/index.js +2 -0
  71. package/dist/construction/index.js.map +1 -1
  72. package/dist/construction/momentOfInertia.d.ts +7 -0
  73. package/dist/construction/momentOfInertia.d.ts.map +1 -1
  74. package/dist/construction/momentOfInertia.js +19 -12
  75. package/dist/construction/momentOfInertia.js.map +1 -1
  76. package/dist/construction/roof.js +2 -2
  77. package/dist/construction/roof.js.map +1 -1
  78. package/dist/electronics/awg.d.ts +3 -2
  79. package/dist/electronics/awg.d.ts.map +1 -1
  80. package/dist/electronics/awg.js +3 -3
  81. package/dist/electronics/awg.js.map +1 -1
  82. package/dist/electronics/capacitor.js +1 -1
  83. package/dist/electronics/capacitor.js.map +1 -1
  84. package/dist/electronics/guards.d.ts +7 -0
  85. package/dist/electronics/guards.d.ts.map +1 -0
  86. package/dist/electronics/guards.js +17 -0
  87. package/dist/electronics/guards.js.map +1 -0
  88. package/dist/electronics/index.d.ts +1 -0
  89. package/dist/electronics/index.d.ts.map +1 -1
  90. package/dist/electronics/index.js +2 -0
  91. package/dist/electronics/index.js.map +1 -1
  92. package/dist/electronics/led.js +2 -2
  93. package/dist/electronics/led.js.map +1 -1
  94. package/dist/electronics/ohmsLaw.d.ts +3 -0
  95. package/dist/electronics/ohmsLaw.d.ts.map +1 -1
  96. package/dist/electronics/ohmsLaw.js +11 -8
  97. package/dist/electronics/ohmsLaw.js.map +1 -1
  98. package/dist/electronics/stencil.d.ts +2 -1
  99. package/dist/electronics/stencil.d.ts.map +1 -1
  100. package/dist/electronics/stencil.js +4 -3
  101. package/dist/electronics/stencil.js.map +1 -1
  102. package/dist/energy/boilerEfficiency.d.ts +13 -0
  103. package/dist/energy/boilerEfficiency.d.ts.map +1 -0
  104. package/dist/energy/boilerEfficiency.js +46 -0
  105. package/dist/energy/boilerEfficiency.js.map +1 -0
  106. package/dist/energy/cusum.d.ts +15 -0
  107. package/dist/energy/cusum.d.ts.map +1 -0
  108. package/dist/energy/cusum.js +71 -0
  109. package/dist/energy/cusum.js.map +1 -0
  110. package/dist/energy/degreeDay.d.ts +13 -0
  111. package/dist/energy/degreeDay.d.ts.map +1 -0
  112. package/dist/energy/degreeDay.js +46 -0
  113. package/dist/energy/degreeDay.js.map +1 -0
  114. package/dist/energy/heatPump.d.ts +13 -0
  115. package/dist/energy/heatPump.d.ts.map +1 -0
  116. package/dist/energy/heatPump.js +48 -0
  117. package/dist/energy/heatPump.js.map +1 -0
  118. package/dist/energy/index.d.ts +9 -1
  119. package/dist/energy/index.d.ts.map +1 -1
  120. package/dist/energy/index.js +8 -0
  121. package/dist/energy/index.js.map +1 -1
  122. package/dist/energy/insulationRoi.d.ts +14 -0
  123. package/dist/energy/insulationRoi.d.ts.map +1 -0
  124. package/dist/energy/insulationRoi.js +52 -0
  125. package/dist/energy/insulationRoi.js.map +1 -0
  126. package/dist/energy/ledRoi.d.ts +14 -0
  127. package/dist/energy/ledRoi.d.ts.map +1 -0
  128. package/dist/energy/ledRoi.js +49 -0
  129. package/dist/energy/ledRoi.js.map +1 -0
  130. package/dist/energy/solarOutput.d.ts +4 -0
  131. package/dist/energy/solarOutput.d.ts.map +1 -1
  132. package/dist/energy/solarOutput.js +8 -4
  133. package/dist/energy/solarOutput.js.map +1 -1
  134. package/dist/energy/transformerLoss.d.ts +13 -0
  135. package/dist/energy/transformerLoss.d.ts.map +1 -0
  136. package/dist/energy/transformerLoss.js +63 -0
  137. package/dist/energy/transformerLoss.js.map +1 -0
  138. package/dist/energy/types.d.ts +168 -0
  139. package/dist/energy/types.d.ts.map +1 -1
  140. package/dist/energy/windOutput.d.ts +14 -0
  141. package/dist/energy/windOutput.d.ts.map +1 -0
  142. package/dist/energy/windOutput.js +77 -0
  143. package/dist/energy/windOutput.js.map +1 -0
  144. package/dist/environmental/scope2Emissions.d.ts +1 -0
  145. package/dist/environmental/scope2Emissions.d.ts.map +1 -1
  146. package/dist/environmental/scope2Emissions.js +2 -1
  147. package/dist/environmental/scope2Emissions.js.map +1 -1
  148. package/dist/food/index.d.ts +3 -1
  149. package/dist/food/index.d.ts.map +1 -1
  150. package/dist/food/index.js +2 -0
  151. package/dist/food/index.js.map +1 -1
  152. package/dist/food/stabilityStudy.d.ts +15 -0
  153. package/dist/food/stabilityStudy.d.ts.map +1 -0
  154. package/dist/food/stabilityStudy.js +92 -0
  155. package/dist/food/stabilityStudy.js.map +1 -0
  156. package/dist/food/types.d.ts +43 -0
  157. package/dist/food/types.d.ts.map +1 -1
  158. package/dist/food/waterActivity.d.ts +17 -0
  159. package/dist/food/waterActivity.d.ts.map +1 -0
  160. package/dist/food/waterActivity.js +63 -0
  161. package/dist/food/waterActivity.js.map +1 -0
  162. package/dist/logistics/abcAnalysis.d.ts +15 -0
  163. package/dist/logistics/abcAnalysis.d.ts.map +1 -0
  164. package/dist/logistics/abcAnalysis.js +101 -0
  165. package/dist/logistics/abcAnalysis.js.map +1 -0
  166. package/dist/logistics/index.d.ts +4 -1
  167. package/dist/logistics/index.d.ts.map +1 -1
  168. package/dist/logistics/index.js +3 -0
  169. package/dist/logistics/index.js.map +1 -1
  170. package/dist/logistics/inventoryTurnover.d.ts +13 -0
  171. package/dist/logistics/inventoryTurnover.d.ts.map +1 -0
  172. package/dist/logistics/inventoryTurnover.js +36 -0
  173. package/dist/logistics/inventoryTurnover.js.map +1 -0
  174. package/dist/logistics/loadCapacity.d.ts +13 -0
  175. package/dist/logistics/loadCapacity.d.ts.map +1 -0
  176. package/dist/logistics/loadCapacity.js +46 -0
  177. package/dist/logistics/loadCapacity.js.map +1 -0
  178. package/dist/logistics/types.d.ts +78 -0
  179. package/dist/logistics/types.d.ts.map +1 -1
  180. package/dist/machining/boringBarDeflection.d.ts.map +1 -1
  181. package/dist/machining/boringBarDeflection.js +7 -1
  182. package/dist/machining/boringBarDeflection.js.map +1 -1
  183. package/dist/machining/toolDeflection.d.ts.map +1 -1
  184. package/dist/machining/toolDeflection.js +7 -1
  185. package/dist/machining/toolDeflection.js.map +1 -1
  186. package/dist/machining/triangleSolver.d.ts +2 -1
  187. package/dist/machining/triangleSolver.d.ts.map +1 -1
  188. package/dist/machining/triangleSolver.js +6 -5
  189. package/dist/machining/triangleSolver.js.map +1 -1
  190. package/dist/metal/flangeSpec.d.ts +3 -0
  191. package/dist/metal/flangeSpec.d.ts.map +1 -1
  192. package/dist/metal/flangeSpec.js +6 -3
  193. package/dist/metal/flangeSpec.js.map +1 -1
  194. package/dist/metal/guards.d.ts +12 -0
  195. package/dist/metal/guards.d.ts.map +1 -0
  196. package/dist/metal/guards.js +36 -0
  197. package/dist/metal/guards.js.map +1 -0
  198. package/dist/metal/index.d.ts +1 -0
  199. package/dist/metal/index.d.ts.map +1 -1
  200. package/dist/metal/index.js +2 -0
  201. package/dist/metal/index.js.map +1 -1
  202. package/dist/metal/metalWeight.d.ts.map +1 -1
  203. package/dist/metal/metalWeight.js +20 -0
  204. package/dist/metal/metalWeight.js.map +1 -1
  205. package/dist/metal/pipeSpec.d.ts +3 -0
  206. package/dist/metal/pipeSpec.d.ts.map +1 -1
  207. package/dist/metal/pipeSpec.js +6 -3
  208. package/dist/metal/pipeSpec.js.map +1 -1
  209. package/dist/quality/cmk.d.ts +17 -0
  210. package/dist/quality/cmk.d.ts.map +1 -0
  211. package/dist/quality/cmk.js +43 -0
  212. package/dist/quality/cmk.js.map +1 -0
  213. package/dist/quality/controlChart.d.ts +3 -0
  214. package/dist/quality/controlChart.d.ts.map +1 -1
  215. package/dist/quality/controlChart.js +6 -3
  216. package/dist/quality/controlChart.js.map +1 -1
  217. package/dist/quality/gageRR.d.ts +18 -0
  218. package/dist/quality/gageRR.d.ts.map +1 -0
  219. package/dist/quality/gageRR.js +110 -0
  220. package/dist/quality/gageRR.js.map +1 -0
  221. package/dist/quality/index.d.ts +5 -1
  222. package/dist/quality/index.d.ts.map +1 -1
  223. package/dist/quality/index.js +4 -0
  224. package/dist/quality/index.js.map +1 -1
  225. package/dist/quality/oee.js +2 -2
  226. package/dist/quality/oee.js.map +1 -1
  227. package/dist/quality/paretoAnalysis.d.ts +15 -0
  228. package/dist/quality/paretoAnalysis.d.ts.map +1 -0
  229. package/dist/quality/paretoAnalysis.js +92 -0
  230. package/dist/quality/paretoAnalysis.js.map +1 -0
  231. package/dist/quality/types.d.ts +91 -0
  232. package/dist/quality/types.d.ts.map +1 -1
  233. package/dist/quality/weibull.d.ts +17 -0
  234. package/dist/quality/weibull.d.ts.map +1 -0
  235. package/dist/quality/weibull.js +106 -0
  236. package/dist/quality/weibull.js.map +1 -0
  237. package/dist/safety/arcFlash.d.ts +14 -0
  238. package/dist/safety/arcFlash.d.ts.map +1 -0
  239. package/dist/safety/arcFlash.js +90 -0
  240. package/dist/safety/arcFlash.js.map +1 -0
  241. package/dist/safety/confinedSpace.d.ts +15 -0
  242. package/dist/safety/confinedSpace.d.ts.map +1 -0
  243. package/dist/safety/confinedSpace.js +116 -0
  244. package/dist/safety/confinedSpace.js.map +1 -0
  245. package/dist/safety/ergonomicRisk.d.ts +9 -0
  246. package/dist/safety/ergonomicRisk.d.ts.map +1 -0
  247. package/dist/safety/ergonomicRisk.js +208 -0
  248. package/dist/safety/ergonomicRisk.js.map +1 -0
  249. package/dist/safety/illuminance.d.ts +13 -0
  250. package/dist/safety/illuminance.d.ts.map +1 -0
  251. package/dist/safety/illuminance.js +91 -0
  252. package/dist/safety/illuminance.js.map +1 -0
  253. package/dist/safety/index.d.ts +8 -1
  254. package/dist/safety/index.d.ts.map +1 -1
  255. package/dist/safety/index.js +7 -0
  256. package/dist/safety/index.js.map +1 -1
  257. package/dist/safety/ladderAngle.d.ts +16 -0
  258. package/dist/safety/ladderAngle.d.ts.map +1 -0
  259. package/dist/safety/ladderAngle.js +87 -0
  260. package/dist/safety/ladderAngle.js.map +1 -0
  261. package/dist/safety/lel.d.ts +14 -0
  262. package/dist/safety/lel.d.ts.map +1 -0
  263. package/dist/safety/lel.js +66 -0
  264. package/dist/safety/lel.js.map +1 -0
  265. package/dist/safety/thermalComfort.d.ts +14 -0
  266. package/dist/safety/thermalComfort.d.ts.map +1 -0
  267. package/dist/safety/thermalComfort.js +96 -0
  268. package/dist/safety/thermalComfort.js.map +1 -0
  269. package/dist/safety/types.d.ts +164 -0
  270. package/dist/safety/types.d.ts.map +1 -1
  271. package/dist/safety/ventilationRate.d.ts +3 -0
  272. package/dist/safety/ventilationRate.d.ts.map +1 -1
  273. package/dist/safety/ventilationRate.js +6 -3
  274. package/dist/safety/ventilationRate.js.map +1 -1
  275. package/dist/utility/bilinearInterpolation.d.ts +3 -0
  276. package/dist/utility/bilinearInterpolation.d.ts.map +1 -0
  277. package/dist/utility/bilinearInterpolation.js +47 -0
  278. package/dist/utility/bilinearInterpolation.js.map +1 -0
  279. package/dist/utility/correlation.d.ts +3 -0
  280. package/dist/utility/correlation.d.ts.map +1 -0
  281. package/dist/utility/correlation.js +29 -0
  282. package/dist/utility/correlation.js.map +1 -0
  283. package/dist/utility/depreciation.d.ts +3 -0
  284. package/dist/utility/depreciation.d.ts.map +1 -0
  285. package/dist/utility/depreciation.js +57 -0
  286. package/dist/utility/depreciation.js.map +1 -0
  287. package/dist/utility/histogram.d.ts +3 -0
  288. package/dist/utility/histogram.d.ts.map +1 -0
  289. package/dist/utility/histogram.js +42 -0
  290. package/dist/utility/histogram.js.map +1 -0
  291. package/dist/utility/index.d.ts +15 -1
  292. package/dist/utility/index.d.ts.map +1 -1
  293. package/dist/utility/index.js +14 -0
  294. package/dist/utility/index.js.map +1 -1
  295. package/dist/utility/lcc.d.ts +3 -0
  296. package/dist/utility/lcc.d.ts.map +1 -0
  297. package/dist/utility/lcc.js +26 -0
  298. package/dist/utility/lcc.js.map +1 -0
  299. package/dist/utility/linearInterpolation.d.ts +3 -0
  300. package/dist/utility/linearInterpolation.d.ts.map +1 -0
  301. package/dist/utility/linearInterpolation.js +42 -0
  302. package/dist/utility/linearInterpolation.js.map +1 -0
  303. package/dist/utility/movingAverage.d.ts +3 -0
  304. package/dist/utility/movingAverage.d.ts.map +1 -0
  305. package/dist/utility/movingAverage.js +41 -0
  306. package/dist/utility/movingAverage.js.map +1 -0
  307. package/dist/utility/normalize.d.ts +3 -0
  308. package/dist/utility/normalize.d.ts.map +1 -0
  309. package/dist/utility/normalize.js +35 -0
  310. package/dist/utility/normalize.js.map +1 -0
  311. package/dist/utility/npv.d.ts +3 -0
  312. package/dist/utility/npv.d.ts.map +1 -0
  313. package/dist/utility/npv.js +45 -0
  314. package/dist/utility/npv.js.map +1 -0
  315. package/dist/utility/percentile.d.ts +3 -0
  316. package/dist/utility/percentile.d.ts.map +1 -0
  317. package/dist/utility/percentile.js +24 -0
  318. package/dist/utility/percentile.js.map +1 -0
  319. package/dist/utility/regression.d.ts +3 -0
  320. package/dist/utility/regression.d.ts.map +1 -0
  321. package/dist/utility/regression.js +40 -0
  322. package/dist/utility/regression.js.map +1 -0
  323. package/dist/utility/roi.d.ts +3 -0
  324. package/dist/utility/roi.d.ts.map +1 -0
  325. package/dist/utility/roi.js +19 -0
  326. package/dist/utility/roi.js.map +1 -0
  327. package/dist/utility/statistics.d.ts +3 -0
  328. package/dist/utility/statistics.d.ts.map +1 -0
  329. package/dist/utility/statistics.js +34 -0
  330. package/dist/utility/statistics.js.map +1 -0
  331. package/dist/utility/types.d.ts +213 -1
  332. package/dist/utility/types.d.ts.map +1 -1
  333. package/dist/utility/unit.d.ts.map +1 -1
  334. package/dist/utility/unit.js +51 -0
  335. package/dist/utility/unit.js.map +1 -1
  336. package/dist/utility/weightedScore.d.ts +3 -0
  337. package/dist/utility/weightedScore.d.ts.map +1 -0
  338. package/dist/utility/weightedScore.js +35 -0
  339. package/dist/utility/weightedScore.js.map +1 -0
  340. package/package.json +3 -2
@@ -46,6 +46,9 @@ const STEEL_DENSITY = 7850; // kg/m³
46
46
  * Look up pipe specifications from ANSI/ASME standards
47
47
  *
48
48
  * @reference ASME B36.10M, ASME B36.19M
49
+ * @throws {RangeError} Unknown DN size: {nominalSize}
50
+ * @throws {RangeError} Unknown pipe size: {nps}
51
+ * @throws {RangeError} Schedule {schedule} not available for size {nps}
49
52
  * @param input - Pipe standard, nominal size, and schedule
50
53
  * @returns Pipe dimensions (OD, wall thickness, ID, weight, areas)
51
54
  */
@@ -57,7 +60,7 @@ export function pipeSpec(input) {
57
60
  const dnKey = nominalSize.toUpperCase().replace(/\s/g, '');
58
61
  nps = DN_TO_NPS[dnKey];
59
62
  if (!nps) {
60
- throw new Error(`Unknown DN size: ${nominalSize}`);
63
+ throw new RangeError(`Unknown DN size: ${nominalSize}`);
61
64
  }
62
65
  }
63
66
  else {
@@ -66,11 +69,11 @@ export function pipeSpec(input) {
66
69
  }
67
70
  const pipeData = PIPE_DATA[nps];
68
71
  if (!pipeData) {
69
- throw new Error(`Unknown pipe size: ${nps}`);
72
+ throw new RangeError(`Unknown pipe size: ${nps}`);
70
73
  }
71
74
  const wallThickness = pipeData.schedules[schedule];
72
75
  if (wallThickness == null) {
73
- throw new Error(`Schedule ${schedule} not available for size ${nps}`);
76
+ throw new RangeError(`Schedule ${schedule} not available for size ${nps}`);
74
77
  }
75
78
  const od = pipeData.od;
76
79
  const id = roundTo(od - 2 * wallThickness, 2);
@@ -1 +1 @@
1
- {"version":3,"file":"pipeSpec.js","sourceRoot":"","sources":["../../src/metal/pipeSpec.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"pipeSpec.js","sourceRoot":"","sources":["../../src/metal/pipeSpec.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import type { CmkInput, CmkResult } from './types.js';
2
+ /**
3
+ * Calculate Cmk (Machine Capability Index)
4
+ *
5
+ * @formula
6
+ * - Cm = (USL - LSL) / (6σ)
7
+ * - Cmk = min((USL - x̄) / (3σ), (x̄ - LSL) / (3σ))
8
+ * - Threshold: Cmk ≥ 1.67 (stricter than Cpk ≥ 1.33)
9
+ *
10
+ * @reference VDA 5 — Measurement System Analysis
11
+ * @reference ISO 22514-3:2020 — Machine performance studies
12
+ *
13
+ * @param input - Raw measurements and specification limits
14
+ * @returns Machine capability indices
15
+ */
16
+ export declare function cmk(input: CmkInput): CmkResult;
17
+ //# sourceMappingURL=cmk.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cmk.d.ts","sourceRoot":"","sources":["../../src/quality/cmk.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEtD;;;;;;;;;;;;;GAaG;AACH,wBAAgB,GAAG,CAAC,KAAK,EAAE,QAAQ,GAAG,SAAS,CAgC9C"}
@@ -0,0 +1,43 @@
1
+ import { roundTo } from '../utils.js';
2
+ /**
3
+ * Calculate Cmk (Machine Capability Index)
4
+ *
5
+ * @formula
6
+ * - Cm = (USL - LSL) / (6σ)
7
+ * - Cmk = min((USL - x̄) / (3σ), (x̄ - LSL) / (3σ))
8
+ * - Threshold: Cmk ≥ 1.67 (stricter than Cpk ≥ 1.33)
9
+ *
10
+ * @reference VDA 5 — Measurement System Analysis
11
+ * @reference ISO 22514-3:2020 — Machine performance studies
12
+ *
13
+ * @param input - Raw measurements and specification limits
14
+ * @returns Machine capability indices
15
+ */
16
+ export function cmk(input) {
17
+ const { measurements, lsl, usl } = input;
18
+ const n = measurements.length;
19
+ if (n === 0) {
20
+ return { mean: 0, stdDev: 0, cm: 0, cmk: 0, isCapable: false };
21
+ }
22
+ // Mean
23
+ const mean = measurements.reduce((s, v) => s + v, 0) / n;
24
+ // Sample standard deviation (guard n=1 → 0/0)
25
+ const variance = n > 1 ? measurements.reduce((s, v) => s + (v - mean) ** 2, 0) / (n - 1) : 0;
26
+ const stdDev = Math.sqrt(variance);
27
+ if (stdDev <= 0 || !Number.isFinite(stdDev)) {
28
+ return { mean: roundTo(mean, 4), stdDev: 0, cm: 0, cmk: 0, isCapable: false };
29
+ }
30
+ const specWidth = usl - lsl;
31
+ const cm = specWidth / (6 * stdDev);
32
+ const cmkUpper = (usl - mean) / (3 * stdDev);
33
+ const cmkLower = (mean - lsl) / (3 * stdDev);
34
+ const cmkValue = Math.min(cmkUpper, cmkLower);
35
+ return {
36
+ mean: roundTo(mean, 4),
37
+ stdDev: roundTo(stdDev, 4),
38
+ cm: roundTo(cm, 4),
39
+ cmk: roundTo(cmkValue, 4),
40
+ isCapable: cmkValue >= 1.67,
41
+ };
42
+ }
43
+ //# sourceMappingURL=cmk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cmk.js","sourceRoot":"","sources":["../../src/quality/cmk.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGtC;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,GAAG,CAAC,KAAe;IACjC,MAAM,EAAE,YAAY,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC;IACzC,MAAM,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC;IAE9B,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;QACZ,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;IACjE,CAAC;IAED,OAAO;IACP,MAAM,IAAI,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAEzD,8CAA8C;IAC9C,MAAM,QAAQ,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7F,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAEnC,IAAI,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAC5C,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;IAChF,CAAC;IAED,MAAM,SAAS,GAAG,GAAG,GAAG,GAAG,CAAC;IAC5B,MAAM,EAAE,GAAG,SAAS,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;IACpC,MAAM,QAAQ,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;IAC7C,MAAM,QAAQ,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC;IAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;IAE9C,OAAO;QACL,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QACtB,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAC1B,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;QAClB,GAAG,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;QACzB,SAAS,EAAE,QAAQ,IAAI,IAAI;KAC5B,CAAC;AACJ,CAAC"}
@@ -19,6 +19,9 @@ import type { ControlChartInput, ControlChartResult } from './types.js';
19
19
  * @validation Constants verified against AIAG/ASTM tables for n = 2..25:
20
20
  * n=5: A₂=0.577, D₃=0, D₄=2.114, d₂=2.326
21
21
  *
22
+ * @throws {RangeError} At least 2 subgroups are required
23
+ * @throws {RangeError} Subgroup size must be between 2 and 25
24
+ * @throws {RangeError} Subgroup {i} has size {n}, expected {n}
22
25
  * @param input - chart type and subgroup data
23
26
  * @returns control limits, subgroup statistics, out-of-control points
24
27
  */
@@ -1 +1 @@
1
- {"version":3,"file":"controlChart.d.ts","sourceRoot":"","sources":["../../src/quality/controlChart.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAA8B,MAAM,YAAY,CAAC;AA4EpG;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,iBAAiB,GAAG,kBAAkB,CAwBzE"}
1
+ {"version":3,"file":"controlChart.d.ts","sourceRoot":"","sources":["../../src/quality/controlChart.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAA8B,MAAM,YAAY,CAAC;AA4EpG;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,iBAAiB,GAAG,kBAAkB,CAwBzE"}
@@ -88,22 +88,25 @@ function stdDev(arr) {
88
88
  * @validation Constants verified against AIAG/ASTM tables for n = 2..25:
89
89
  * n=5: A₂=0.577, D₃=0, D₄=2.114, d₂=2.326
90
90
  *
91
+ * @throws {RangeError} At least 2 subgroups are required
92
+ * @throws {RangeError} Subgroup size must be between 2 and 25
93
+ * @throws {RangeError} Subgroup {i} has size {n}, expected {n}
91
94
  * @param input - chart type and subgroup data
92
95
  * @returns control limits, subgroup statistics, out-of-control points
93
96
  */
94
97
  export function controlChart(input) {
95
98
  const { chartType, subgroups } = input;
96
99
  if (subgroups.length < 2) {
97
- throw new Error('At least 2 subgroups are required');
100
+ throw new RangeError('At least 2 subgroups are required');
98
101
  }
99
102
  const n = subgroups[0].length;
100
103
  if (n < 2 || n > 25) {
101
- throw new Error('Subgroup size must be between 2 and 25');
104
+ throw new RangeError('Subgroup size must be between 2 and 25');
102
105
  }
103
106
  // Validate consistent subgroup size
104
107
  for (let i = 0; i < subgroups.length; i++) {
105
108
  if (subgroups[i].length !== n) {
106
- throw new Error(`Subgroup ${i + 1} has size ${subgroups[i].length}, expected ${n}`);
109
+ throw new RangeError(`Subgroup ${i + 1} has size ${subgroups[i].length}, expected ${n}`);
107
110
  }
108
111
  }
109
112
  if (chartType === 'xbarR') {
@@ -1 +1 @@
1
- {"version":3,"file":"controlChart.js","sourceRoot":"","sources":["../../src/quality/controlChart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGtC;;;;;GAKG;AACH,MAAM,gBAAgB,GAAuE;IAC3F,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;CACnD,CAAC;AAEF,MAAM,gBAAgB,GAAuE;IAC3F,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,E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"}
1
+ {"version":3,"file":"controlChart.js","sourceRoot":"","sources":["../../src/quality/controlChart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGtC;;;;;GAKG;AACH,MAAM,gBAAgB,GAAuE;IAC3F,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;IAClD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE;CACnD,CAAC;AAEF,MAAM,gBAAgB,GAAuE;IAC3F,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,EAAM,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,CAAC,EAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE;IACnD,EAAE,EAAE,EAAE,EAAE,EAAE,KAAK,EAAE,E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"}
@@ -0,0 +1,18 @@
1
+ import type { GageRRInput, GageRRResult } from './types.js';
2
+ /**
3
+ * Gage R&R (Measurement System Analysis) — AIAG MSA 4th Edition, Average and Range Method
4
+ *
5
+ * @formula
6
+ * - EV = R̄ × K1
7
+ * - AV = √((X̄_diff × K2)² − (EV² / (n×r))) (floored at 0)
8
+ * - GRR = √(EV² + AV²)
9
+ * - PV = Rp × K3
10
+ * - TV = √(GRR² + PV²)
11
+ * - %GRR = GRR/TV × 100
12
+ * - ndc = floor(1.41 × PV/GRR)
13
+ *
14
+ * @reference AIAG Measurement Systems Analysis Reference Manual, 4th Edition
15
+ * @reference IATF 16949:2016 Section 7.1.5.1.1
16
+ */
17
+ export declare function gageRR(input: GageRRInput): GageRRResult;
18
+ //# sourceMappingURL=gageRR.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gageRR.d.ts","sourceRoot":"","sources":["../../src/quality/gageRR.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAc5D;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,MAAM,CAAC,KAAK,EAAE,WAAW,GAAG,YAAY,CA+FvD"}
@@ -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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"}
@@ -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 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, } from './types.js';
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;AAGjD,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,GACnB,MAAM,YAAY,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"}
@@ -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"}
@@ -24,11 +24,11 @@ export function oee(input) {
24
24
  const { plannedTime, runTime, totalCount, goodCount, idealCycleTime } = rawData;
25
25
  // Validate: goodCount cannot exceed totalCount
26
26
  if (goodCount > totalCount) {
27
- throw new Error(`Invalid input: goodCount (${goodCount}) cannot exceed totalCount (${totalCount})`);
27
+ throw new RangeError(`Invalid input: goodCount (${goodCount}) cannot exceed totalCount (${totalCount})`);
28
28
  }
29
29
  // Validate: no negative values allowed
30
30
  if (goodCount < 0) {
31
- throw new Error(`Invalid input: goodCount (${goodCount}) cannot be negative`);
31
+ throw new RangeError(`Invalid input: goodCount (${goodCount}) cannot be negative`);
32
32
  }
33
33
  // Handle edge cases - return zeros for invalid inputs
34
34
  if (plannedTime <= 0 || runTime <= 0 || idealCycleTime <= 0 || totalCount < 0) {
@@ -1 +1 @@
1
- {"version":3,"file":"oee.js","sourceRoot":"","sources":["../../src/quality/oee.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGtC;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,GAAG,CAAC,KAAe;IACjC,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IAC1B,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;IAEhF,+CAA+C;IAC/C,IAAI,SAAS,GAAG,UAAU,EAAE,CAAC;QAC3B,MAAM,IAAI,KAAK,CACb,6BAA6B,SAAS,+BAA+B,UAAU,GAAG,CACnF,CAAC;IACJ,CAAC;IAED,uCAAuC;IACvC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;QAClB,MAAM,IAAI,KAAK,CAAC,6BAA6B,SAAS,sBAAsB,CAAC,CAAC;IAChF,CAAC;IAED,sDAAsD;IACtD,IAAI,WAAW,IAAI,CAAC,IAAI,OAAO,IAAI,CAAC,IAAI,cAAc,IAAI,CAAC,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;QAC9E,OAAO;YACL,OAAO,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;YAChE,WAAW,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;SACrE,CAAC;IACJ,CAAC;IAED,yCAAyC;IACzC,MAAM,YAAY,GAAG,OAAO,GAAG,WAAW,CAAC;IAE3C,4DAA4D;IAC5D,4DAA4D;IAC5D,MAAM,WAAW,GAAG,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,OAAO,CAAC;IAE5D,qCAAqC;IACrC,MAAM,OAAO,GAAG,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IAE5D,6CAA6C;IAC7C,MAAM,QAAQ,GAAG,YAAY,GAAG,WAAW,GAAG,OAAO,CAAC;IAEtD,OAAO;QACL,OAAO,EAAE;YACP,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;YACtC,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;YACpC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;YAC5B,GAAG,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC1B;QACD,WAAW,EAAE;YACX,YAAY,EAAE,OAAO,CAAC,YAAY,GAAG,GAAG,EAAE,CAAC,CAAC;YAC5C,WAAW,EAAE,OAAO,CAAC,WAAW,GAAG,GAAG,EAAE,CAAC,CAAC;YAC1C,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC,CAAC;YAClC,GAAG,EAAE,OAAO,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC;SAChC;KACF,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"oee.js","sourceRoot":"","sources":["../../src/quality/oee.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGtC;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,UAAU,GAAG,CAAC,KAAe;IACjC,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IAC1B,MAAM,EAAE,WAAW,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;IAEhF,+CAA+C;IAC/C,IAAI,SAAS,GAAG,UAAU,EAAE,CAAC;QAC3B,MAAM,IAAI,UAAU,CAClB,6BAA6B,SAAS,+BAA+B,UAAU,GAAG,CACnF,CAAC;IACJ,CAAC;IAED,uCAAuC;IACvC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;QAClB,MAAM,IAAI,UAAU,CAAC,6BAA6B,SAAS,sBAAsB,CAAC,CAAC;IACrF,CAAC;IAED,sDAAsD;IACtD,IAAI,WAAW,IAAI,CAAC,IAAI,OAAO,IAAI,CAAC,IAAI,cAAc,IAAI,CAAC,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;QAC9E,OAAO;YACL,OAAO,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;YAChE,WAAW,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;SACrE,CAAC;IACJ,CAAC;IAED,yCAAyC;IACzC,MAAM,YAAY,GAAG,OAAO,GAAG,WAAW,CAAC;IAE3C,4DAA4D;IAC5D,4DAA4D;IAC5D,MAAM,WAAW,GAAG,CAAC,cAAc,GAAG,UAAU,CAAC,GAAG,OAAO,CAAC;IAE5D,qCAAqC;IACrC,MAAM,OAAO,GAAG,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;IAE5D,6CAA6C;IAC7C,MAAM,QAAQ,GAAG,YAAY,GAAG,WAAW,GAAG,OAAO,CAAC;IAEtD,OAAO;QACL,OAAO,EAAE;YACP,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;YACtC,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;YACpC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;YAC5B,GAAG,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC1B;QACD,WAAW,EAAE;YACX,YAAY,EAAE,OAAO,CAAC,YAAY,GAAG,GAAG,EAAE,CAAC,CAAC;YAC5C,WAAW,EAAE,OAAO,CAAC,WAAW,GAAG,GAAG,EAAE,CAAC,CAAC;YAC1C,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC,CAAC;YAClC,GAAG,EAAE,OAAO,CAAC,QAAQ,GAAG,GAAG,EAAE,CAAC,CAAC;SAChC;KACF,CAAC;AACJ,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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"}