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.
Files changed (258) hide show
  1. package/CHANGELOG.md +84 -0
  2. package/README.md +90 -26
  3. package/dist/automotive/chargingLoss.d.ts +15 -0
  4. package/dist/automotive/chargingLoss.d.ts.map +1 -0
  5. package/dist/automotive/chargingLoss.js +62 -0
  6. package/dist/automotive/chargingLoss.js.map +1 -0
  7. package/dist/automotive/index.d.ts +2 -1
  8. package/dist/automotive/index.d.ts.map +1 -1
  9. package/dist/automotive/index.js +1 -0
  10. package/dist/automotive/index.js.map +1 -1
  11. package/dist/automotive/types.d.ts +23 -0
  12. package/dist/automotive/types.d.ts.map +1 -1
  13. package/dist/battery/guards.d.ts +7 -0
  14. package/dist/battery/guards.d.ts.map +1 -0
  15. package/dist/battery/guards.js +17 -0
  16. package/dist/battery/guards.js.map +1 -0
  17. package/dist/battery/index.d.ts +1 -0
  18. package/dist/battery/index.d.ts.map +1 -1
  19. package/dist/battery/index.js +2 -0
  20. package/dist/battery/index.js.map +1 -1
  21. package/dist/chemical/flowControl.d.ts +14 -0
  22. package/dist/chemical/flowControl.d.ts.map +1 -0
  23. package/dist/chemical/flowControl.js +69 -0
  24. package/dist/chemical/flowControl.js.map +1 -0
  25. package/dist/chemical/guards.d.ts +17 -0
  26. package/dist/chemical/guards.d.ts.map +1 -0
  27. package/dist/chemical/guards.js +54 -0
  28. package/dist/chemical/guards.js.map +1 -0
  29. package/dist/chemical/index.d.ts +5 -1
  30. package/dist/chemical/index.d.ts.map +1 -1
  31. package/dist/chemical/index.js +5 -0
  32. package/dist/chemical/index.js.map +1 -1
  33. package/dist/chemical/pid.d.ts +14 -0
  34. package/dist/chemical/pid.d.ts.map +1 -0
  35. package/dist/chemical/pid.js +103 -0
  36. package/dist/chemical/pid.js.map +1 -0
  37. package/dist/chemical/reliefValve.d.ts +14 -0
  38. package/dist/chemical/reliefValve.d.ts.map +1 -0
  39. package/dist/chemical/reliefValve.js +98 -0
  40. package/dist/chemical/reliefValve.js.map +1 -0
  41. package/dist/chemical/types.d.ts +63 -0
  42. package/dist/chemical/types.d.ts.map +1 -1
  43. package/dist/construction/guards.d.ts +7 -0
  44. package/dist/construction/guards.d.ts.map +1 -0
  45. package/dist/construction/guards.js +31 -0
  46. package/dist/construction/guards.js.map +1 -0
  47. package/dist/construction/index.d.ts +1 -0
  48. package/dist/construction/index.d.ts.map +1 -1
  49. package/dist/construction/index.js +2 -0
  50. package/dist/construction/index.js.map +1 -1
  51. package/dist/electronics/guards.d.ts +7 -0
  52. package/dist/electronics/guards.d.ts.map +1 -0
  53. package/dist/electronics/guards.js +17 -0
  54. package/dist/electronics/guards.js.map +1 -0
  55. package/dist/electronics/index.d.ts +1 -0
  56. package/dist/electronics/index.d.ts.map +1 -1
  57. package/dist/electronics/index.js +2 -0
  58. package/dist/electronics/index.js.map +1 -1
  59. package/dist/energy/boilerEfficiency.d.ts +13 -0
  60. package/dist/energy/boilerEfficiency.d.ts.map +1 -0
  61. package/dist/energy/boilerEfficiency.js +46 -0
  62. package/dist/energy/boilerEfficiency.js.map +1 -0
  63. package/dist/energy/cusum.d.ts +15 -0
  64. package/dist/energy/cusum.d.ts.map +1 -0
  65. package/dist/energy/cusum.js +71 -0
  66. package/dist/energy/cusum.js.map +1 -0
  67. package/dist/energy/degreeDay.d.ts +13 -0
  68. package/dist/energy/degreeDay.d.ts.map +1 -0
  69. package/dist/energy/degreeDay.js +46 -0
  70. package/dist/energy/degreeDay.js.map +1 -0
  71. package/dist/energy/heatPump.d.ts +13 -0
  72. package/dist/energy/heatPump.d.ts.map +1 -0
  73. package/dist/energy/heatPump.js +48 -0
  74. package/dist/energy/heatPump.js.map +1 -0
  75. package/dist/energy/index.d.ts +9 -1
  76. package/dist/energy/index.d.ts.map +1 -1
  77. package/dist/energy/index.js +8 -0
  78. package/dist/energy/index.js.map +1 -1
  79. package/dist/energy/insulationRoi.d.ts +14 -0
  80. package/dist/energy/insulationRoi.d.ts.map +1 -0
  81. package/dist/energy/insulationRoi.js +52 -0
  82. package/dist/energy/insulationRoi.js.map +1 -0
  83. package/dist/energy/ledRoi.d.ts +14 -0
  84. package/dist/energy/ledRoi.d.ts.map +1 -0
  85. package/dist/energy/ledRoi.js +49 -0
  86. package/dist/energy/ledRoi.js.map +1 -0
  87. package/dist/energy/transformerLoss.d.ts +13 -0
  88. package/dist/energy/transformerLoss.d.ts.map +1 -0
  89. package/dist/energy/transformerLoss.js +63 -0
  90. package/dist/energy/transformerLoss.js.map +1 -0
  91. package/dist/energy/types.d.ts +168 -0
  92. package/dist/energy/types.d.ts.map +1 -1
  93. package/dist/energy/windOutput.d.ts +14 -0
  94. package/dist/energy/windOutput.d.ts.map +1 -0
  95. package/dist/energy/windOutput.js +77 -0
  96. package/dist/energy/windOutput.js.map +1 -0
  97. package/dist/food/index.d.ts +3 -1
  98. package/dist/food/index.d.ts.map +1 -1
  99. package/dist/food/index.js +2 -0
  100. package/dist/food/index.js.map +1 -1
  101. package/dist/food/stabilityStudy.d.ts +15 -0
  102. package/dist/food/stabilityStudy.d.ts.map +1 -0
  103. package/dist/food/stabilityStudy.js +92 -0
  104. package/dist/food/stabilityStudy.js.map +1 -0
  105. package/dist/food/types.d.ts +43 -0
  106. package/dist/food/types.d.ts.map +1 -1
  107. package/dist/food/waterActivity.d.ts +17 -0
  108. package/dist/food/waterActivity.d.ts.map +1 -0
  109. package/dist/food/waterActivity.js +63 -0
  110. package/dist/food/waterActivity.js.map +1 -0
  111. package/dist/logistics/abcAnalysis.d.ts +15 -0
  112. package/dist/logistics/abcAnalysis.d.ts.map +1 -0
  113. package/dist/logistics/abcAnalysis.js +101 -0
  114. package/dist/logistics/abcAnalysis.js.map +1 -0
  115. package/dist/logistics/index.d.ts +4 -1
  116. package/dist/logistics/index.d.ts.map +1 -1
  117. package/dist/logistics/index.js +3 -0
  118. package/dist/logistics/index.js.map +1 -1
  119. package/dist/logistics/inventoryTurnover.d.ts +13 -0
  120. package/dist/logistics/inventoryTurnover.d.ts.map +1 -0
  121. package/dist/logistics/inventoryTurnover.js +36 -0
  122. package/dist/logistics/inventoryTurnover.js.map +1 -0
  123. package/dist/logistics/loadCapacity.d.ts +13 -0
  124. package/dist/logistics/loadCapacity.d.ts.map +1 -0
  125. package/dist/logistics/loadCapacity.js +46 -0
  126. package/dist/logistics/loadCapacity.js.map +1 -0
  127. package/dist/logistics/types.d.ts +78 -0
  128. package/dist/logistics/types.d.ts.map +1 -1
  129. package/dist/metal/guards.d.ts +12 -0
  130. package/dist/metal/guards.d.ts.map +1 -0
  131. package/dist/metal/guards.js +36 -0
  132. package/dist/metal/guards.js.map +1 -0
  133. package/dist/metal/index.d.ts +1 -0
  134. package/dist/metal/index.d.ts.map +1 -1
  135. package/dist/metal/index.js +2 -0
  136. package/dist/metal/index.js.map +1 -1
  137. package/dist/quality/cmk.d.ts +17 -0
  138. package/dist/quality/cmk.d.ts.map +1 -0
  139. package/dist/quality/cmk.js +43 -0
  140. package/dist/quality/cmk.js.map +1 -0
  141. package/dist/quality/gageRR.d.ts +18 -0
  142. package/dist/quality/gageRR.d.ts.map +1 -0
  143. package/dist/quality/gageRR.js +110 -0
  144. package/dist/quality/gageRR.js.map +1 -0
  145. package/dist/quality/index.d.ts +5 -1
  146. package/dist/quality/index.d.ts.map +1 -1
  147. package/dist/quality/index.js +4 -0
  148. package/dist/quality/index.js.map +1 -1
  149. package/dist/quality/paretoAnalysis.d.ts +15 -0
  150. package/dist/quality/paretoAnalysis.d.ts.map +1 -0
  151. package/dist/quality/paretoAnalysis.js +92 -0
  152. package/dist/quality/paretoAnalysis.js.map +1 -0
  153. package/dist/quality/types.d.ts +91 -0
  154. package/dist/quality/types.d.ts.map +1 -1
  155. package/dist/quality/weibull.d.ts +17 -0
  156. package/dist/quality/weibull.d.ts.map +1 -0
  157. package/dist/quality/weibull.js +106 -0
  158. package/dist/quality/weibull.js.map +1 -0
  159. package/dist/safety/arcFlash.d.ts +14 -0
  160. package/dist/safety/arcFlash.d.ts.map +1 -0
  161. package/dist/safety/arcFlash.js +90 -0
  162. package/dist/safety/arcFlash.js.map +1 -0
  163. package/dist/safety/confinedSpace.d.ts +15 -0
  164. package/dist/safety/confinedSpace.d.ts.map +1 -0
  165. package/dist/safety/confinedSpace.js +116 -0
  166. package/dist/safety/confinedSpace.js.map +1 -0
  167. package/dist/safety/ergonomicRisk.d.ts +9 -0
  168. package/dist/safety/ergonomicRisk.d.ts.map +1 -0
  169. package/dist/safety/ergonomicRisk.js +208 -0
  170. package/dist/safety/ergonomicRisk.js.map +1 -0
  171. package/dist/safety/illuminance.d.ts +13 -0
  172. package/dist/safety/illuminance.d.ts.map +1 -0
  173. package/dist/safety/illuminance.js +91 -0
  174. package/dist/safety/illuminance.js.map +1 -0
  175. package/dist/safety/index.d.ts +8 -1
  176. package/dist/safety/index.d.ts.map +1 -1
  177. package/dist/safety/index.js +7 -0
  178. package/dist/safety/index.js.map +1 -1
  179. package/dist/safety/ladderAngle.d.ts +16 -0
  180. package/dist/safety/ladderAngle.d.ts.map +1 -0
  181. package/dist/safety/ladderAngle.js +87 -0
  182. package/dist/safety/ladderAngle.js.map +1 -0
  183. package/dist/safety/lel.d.ts +14 -0
  184. package/dist/safety/lel.d.ts.map +1 -0
  185. package/dist/safety/lel.js +66 -0
  186. package/dist/safety/lel.js.map +1 -0
  187. package/dist/safety/thermalComfort.d.ts +14 -0
  188. package/dist/safety/thermalComfort.d.ts.map +1 -0
  189. package/dist/safety/thermalComfort.js +96 -0
  190. package/dist/safety/thermalComfort.js.map +1 -0
  191. package/dist/safety/types.d.ts +164 -0
  192. package/dist/safety/types.d.ts.map +1 -1
  193. package/dist/utility/bilinearInterpolation.d.ts +3 -0
  194. package/dist/utility/bilinearInterpolation.d.ts.map +1 -0
  195. package/dist/utility/bilinearInterpolation.js +47 -0
  196. package/dist/utility/bilinearInterpolation.js.map +1 -0
  197. package/dist/utility/correlation.d.ts +3 -0
  198. package/dist/utility/correlation.d.ts.map +1 -0
  199. package/dist/utility/correlation.js +29 -0
  200. package/dist/utility/correlation.js.map +1 -0
  201. package/dist/utility/depreciation.d.ts +3 -0
  202. package/dist/utility/depreciation.d.ts.map +1 -0
  203. package/dist/utility/depreciation.js +57 -0
  204. package/dist/utility/depreciation.js.map +1 -0
  205. package/dist/utility/histogram.d.ts +3 -0
  206. package/dist/utility/histogram.d.ts.map +1 -0
  207. package/dist/utility/histogram.js +42 -0
  208. package/dist/utility/histogram.js.map +1 -0
  209. package/dist/utility/index.d.ts +15 -1
  210. package/dist/utility/index.d.ts.map +1 -1
  211. package/dist/utility/index.js +14 -0
  212. package/dist/utility/index.js.map +1 -1
  213. package/dist/utility/lcc.d.ts +3 -0
  214. package/dist/utility/lcc.d.ts.map +1 -0
  215. package/dist/utility/lcc.js +26 -0
  216. package/dist/utility/lcc.js.map +1 -0
  217. package/dist/utility/linearInterpolation.d.ts +3 -0
  218. package/dist/utility/linearInterpolation.d.ts.map +1 -0
  219. package/dist/utility/linearInterpolation.js +42 -0
  220. package/dist/utility/linearInterpolation.js.map +1 -0
  221. package/dist/utility/movingAverage.d.ts +3 -0
  222. package/dist/utility/movingAverage.d.ts.map +1 -0
  223. package/dist/utility/movingAverage.js +41 -0
  224. package/dist/utility/movingAverage.js.map +1 -0
  225. package/dist/utility/normalize.d.ts +3 -0
  226. package/dist/utility/normalize.d.ts.map +1 -0
  227. package/dist/utility/normalize.js +35 -0
  228. package/dist/utility/normalize.js.map +1 -0
  229. package/dist/utility/npv.d.ts +3 -0
  230. package/dist/utility/npv.d.ts.map +1 -0
  231. package/dist/utility/npv.js +45 -0
  232. package/dist/utility/npv.js.map +1 -0
  233. package/dist/utility/percentile.d.ts +3 -0
  234. package/dist/utility/percentile.d.ts.map +1 -0
  235. package/dist/utility/percentile.js +24 -0
  236. package/dist/utility/percentile.js.map +1 -0
  237. package/dist/utility/regression.d.ts +3 -0
  238. package/dist/utility/regression.d.ts.map +1 -0
  239. package/dist/utility/regression.js +40 -0
  240. package/dist/utility/regression.js.map +1 -0
  241. package/dist/utility/roi.d.ts +3 -0
  242. package/dist/utility/roi.d.ts.map +1 -0
  243. package/dist/utility/roi.js +19 -0
  244. package/dist/utility/roi.js.map +1 -0
  245. package/dist/utility/statistics.d.ts +3 -0
  246. package/dist/utility/statistics.d.ts.map +1 -0
  247. package/dist/utility/statistics.js +34 -0
  248. package/dist/utility/statistics.js.map +1 -0
  249. package/dist/utility/types.d.ts +213 -1
  250. package/dist/utility/types.d.ts.map +1 -1
  251. package/dist/utility/unit.d.ts.map +1 -1
  252. package/dist/utility/unit.js +51 -0
  253. package/dist/utility/unit.js.map +1 -1
  254. package/dist/utility/weightedScore.d.ts +3 -0
  255. package/dist/utility/weightedScore.d.ts.map +1 -0
  256. package/dist/utility/weightedScore.js +35 -0
  257. package/dist/utility/weightedScore.js.map +1 -0
  258. package/package.json +3 -2
@@ -0,0 +1 @@
1
+ {"version":3,"file":"arcFlash.js","sourceRoot":"","sources":["../../src/safety/arcFlash.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { ConfinedSpaceInput, ConfinedSpaceResult } from './types.js';
2
+ /**
3
+ * Confined Space Atmospheric Assessment — OSHA 29 CFR 1910.146
4
+ *
5
+ * @formula Direct threshold comparison:
6
+ * - O₂: 19.5–23.5% safe, <19.5% deficient, >23.5% enriched
7
+ * - LEL: <10% safe, 10-25% caution, >25% danger
8
+ * - H₂S: <10 ppm safe, 10-20 caution, 20-100 danger, >100 IDLH
9
+ * - CO: <25 ppm safe, 25-50 caution, 50-1200 danger, >1200 IDLH
10
+ *
11
+ * @reference OSHA 29 CFR 1910.146 — Permit-required confined spaces
12
+ * @reference NIOSH Pocket Guide to Chemical Hazards
13
+ */
14
+ export declare function confinedSpace(input: ConfinedSpaceInput): ConfinedSpaceResult;
15
+ //# sourceMappingURL=confinedSpace.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"confinedSpace.d.ts","sourceRoot":"","sources":["../../src/safety/confinedSpace.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAE1E;;;;;;;;;;;GAWG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,kBAAkB,GAAG,mBAAmB,CA+F5E"}
@@ -0,0 +1,116 @@
1
+ /**
2
+ * Confined Space Atmospheric Assessment — OSHA 29 CFR 1910.146
3
+ *
4
+ * @formula Direct threshold comparison:
5
+ * - O₂: 19.5–23.5% safe, <19.5% deficient, >23.5% enriched
6
+ * - LEL: <10% safe, 10-25% caution, >25% danger
7
+ * - H₂S: <10 ppm safe, 10-20 caution, 20-100 danger, >100 IDLH
8
+ * - CO: <25 ppm safe, 25-50 caution, 50-1200 danger, >1200 IDLH
9
+ *
10
+ * @reference OSHA 29 CFR 1910.146 — Permit-required confined spaces
11
+ * @reference NIOSH Pocket Guide to Chemical Hazards
12
+ */
13
+ export function confinedSpace(input) {
14
+ const { oxygenPercent, lelPercent, h2sPpm, coPpm, customGas } = input;
15
+ const warnings = [];
16
+ // Oxygen assessment
17
+ let oxygenStatus;
18
+ if (oxygenPercent >= 19.5 && oxygenPercent <= 23.5) {
19
+ oxygenStatus = 'safe';
20
+ }
21
+ else if (oxygenPercent < 19.5) {
22
+ oxygenStatus = 'deficient';
23
+ warnings.push(`Oxygen deficient: ${oxygenPercent}% (minimum 19.5%)`);
24
+ }
25
+ else {
26
+ oxygenStatus = 'enriched';
27
+ warnings.push(`Oxygen enriched: ${oxygenPercent}% (maximum 23.5%)`);
28
+ }
29
+ // LEL assessment
30
+ let lelStatus;
31
+ if (lelPercent < 10) {
32
+ lelStatus = 'safe';
33
+ }
34
+ else if (lelPercent <= 25) {
35
+ lelStatus = 'caution';
36
+ warnings.push(`LEL elevated: ${lelPercent}% (action level 10%)`);
37
+ }
38
+ else {
39
+ lelStatus = 'danger';
40
+ warnings.push(`LEL dangerous: ${lelPercent}% (exceeds 25%)`);
41
+ }
42
+ // H₂S assessment
43
+ let h2sStatus = null;
44
+ if (h2sPpm != null) {
45
+ if (h2sPpm < 10) {
46
+ h2sStatus = 'safe';
47
+ }
48
+ else if (h2sPpm <= 20) {
49
+ h2sStatus = 'caution';
50
+ warnings.push(`H₂S elevated: ${h2sPpm} ppm (PEL ceiling 20 ppm)`);
51
+ }
52
+ else if (h2sPpm <= 100) {
53
+ h2sStatus = 'danger';
54
+ warnings.push(`H₂S dangerous: ${h2sPpm} ppm (exceeds PEL)`);
55
+ }
56
+ else {
57
+ h2sStatus = 'idlh';
58
+ warnings.push(`H₂S IDLH: ${h2sPpm} ppm (IDLH = 100 ppm)`);
59
+ }
60
+ }
61
+ // CO assessment
62
+ let coStatus = null;
63
+ if (coPpm != null) {
64
+ if (coPpm < 25) {
65
+ coStatus = 'safe';
66
+ }
67
+ else if (coPpm <= 50) {
68
+ coStatus = 'caution';
69
+ warnings.push(`CO elevated: ${coPpm} ppm (PEL 50 ppm)`);
70
+ }
71
+ else if (coPpm <= 1200) {
72
+ coStatus = 'danger';
73
+ warnings.push(`CO dangerous: ${coPpm} ppm (exceeds PEL)`);
74
+ }
75
+ else {
76
+ coStatus = 'idlh';
77
+ warnings.push(`CO IDLH: ${coPpm} ppm (IDLH = 1200 ppm)`);
78
+ }
79
+ }
80
+ // Custom gas assessment
81
+ let customGasStatus = null;
82
+ if (customGas) {
83
+ if (customGas.concentration >= customGas.idlh) {
84
+ customGasStatus = 'idlh';
85
+ warnings.push(`${customGas.name} IDLH: ${customGas.concentration} (IDLH = ${customGas.idlh})`);
86
+ }
87
+ else if (customGas.concentration >= customGas.pel) {
88
+ customGasStatus = 'exceeds_pel';
89
+ warnings.push(`${customGas.name} exceeds PEL: ${customGas.concentration} (PEL = ${customGas.pel})`);
90
+ }
91
+ else {
92
+ customGasStatus = 'safe';
93
+ }
94
+ }
95
+ // Overall status — worst case
96
+ const statuses = [oxygenStatus, lelStatus, h2sStatus, coStatus, customGasStatus].filter(Boolean);
97
+ let overallStatus = 'safe';
98
+ if (statuses.includes('idlh'))
99
+ overallStatus = 'idlh';
100
+ else if (statuses.includes('danger') || oxygenStatus !== 'safe')
101
+ overallStatus = 'danger';
102
+ else if (statuses.includes('caution') || statuses.includes('exceeds_pel'))
103
+ overallStatus = 'caution';
104
+ const entryPermitted = overallStatus === 'safe';
105
+ return {
106
+ oxygenStatus,
107
+ lelStatus,
108
+ h2sStatus,
109
+ coStatus,
110
+ customGasStatus,
111
+ overallStatus,
112
+ entryPermitted,
113
+ warnings,
114
+ };
115
+ }
116
+ //# sourceMappingURL=confinedSpace.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"confinedSpace.js","sourceRoot":"","sources":["../../src/safety/confinedSpace.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type { RebaInput, RebaResult } from './types.js';
2
+ /**
3
+ * REBA (Rapid Entire Body Assessment) — Ergonomic Risk
4
+ *
5
+ * @reference Hignett, S. & McAtamney, L. (2000). REBA, Applied Ergonomics 31(2), 201-205.
6
+ * @reference 중대재해처벌법 시행령 — 인체공학적 유해요인 평가
7
+ */
8
+ export declare function ergonomicRisk(input: RebaInput): RebaResult;
9
+ //# sourceMappingURL=ergonomicRisk.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ergonomicRisk.d.ts","sourceRoot":"","sources":["../../src/safety/ergonomicRisk.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AA4DxD;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,UAAU,CAgH1D"}
@@ -0,0 +1,208 @@
1
+ // REBA Table A: Trunk × Neck × Legs (1-indexed)
2
+ const TABLE_A = [
3
+ // Legs: 1 2 3 4
4
+ /* Trunk=1, Neck=1 */ [1, 2, 3, 4],
5
+ /* Trunk=1, Neck=2 */ [2, 3, 4, 5],
6
+ /* Trunk=1, Neck=3 */ [2, 4, 5, 6],
7
+ /* Trunk=2, Neck=1 */ [3, 4, 5, 6],
8
+ /* Trunk=2, Neck=2 */ [4, 5, 6, 7],
9
+ /* Trunk=2, Neck=3 */ [5, 6, 7, 8],
10
+ /* Trunk=3, Neck=1 */ [5, 6, 7, 8],
11
+ /* Trunk=3, Neck=2 */ [6, 7, 8, 9],
12
+ /* Trunk=3, Neck=3 */ [7, 8, 9, 9],
13
+ /* Trunk=4, Neck=1 */ [7, 8, 9, 9],
14
+ /* Trunk=4, Neck=2 */ [8, 9, 9, 10],
15
+ /* Trunk=4, Neck=3 */ [9, 9, 10, 10],
16
+ /* Trunk=5, Neck=1 */ [8, 9, 10, 10],
17
+ /* Trunk=5, Neck=2 */ [9, 10, 10, 11],
18
+ /* Trunk=5, Neck=3 */ [10, 10, 11, 12],
19
+ ];
20
+ // REBA Table B: Upper Arm × Lower Arm × Wrist (1-indexed)
21
+ const TABLE_B = [
22
+ // Wrist: 1 2 3
23
+ /* UA=1, LA=1 */ [1, 2, 2],
24
+ /* UA=1, LA=2 */ [1, 2, 3],
25
+ /* UA=2, LA=1 */ [3, 4, 5],
26
+ /* UA=2, LA=2 */ [4, 5, 5],
27
+ /* UA=3, LA=1 */ [5, 5, 6],
28
+ /* UA=3, LA=2 */ [6, 7, 7],
29
+ /* UA=4, LA=1 */ [7, 8, 8],
30
+ /* UA=4, LA=2 */ [8, 9, 9],
31
+ /* UA=5, LA=1 */ [9, 9, 9],
32
+ /* UA=5, LA=2 */ [9, 9, 9],
33
+ /* UA=6, LA=1 */ [9, 9, 9],
34
+ /* UA=6, LA=2 */ [9, 9, 9],
35
+ ];
36
+ // REBA Table C: Score A × Score B → Score C
37
+ const TABLE_C = [
38
+ // ScoreB: 1 2 3 4 5 6 7 8 9 10 11 12
39
+ /* A= 1 */ [1, 1, 1, 2, 3, 3, 4, 5, 6, 7, 7, 7],
40
+ /* A= 2 */ [1, 2, 2, 3, 4, 4, 5, 6, 6, 7, 7, 8],
41
+ /* A= 3 */ [2, 3, 3, 3, 4, 5, 6, 7, 7, 8, 8, 8],
42
+ /* A= 4 */ [3, 4, 4, 4, 5, 6, 7, 8, 8, 9, 9, 9],
43
+ /* A= 5 */ [4, 4, 4, 5, 6, 7, 8, 8, 9, 9, 9, 9],
44
+ /* A= 6 */ [6, 6, 6, 7, 8, 8, 9, 9, 10, 10, 10, 10],
45
+ /* A= 7 */ [7, 7, 7, 8, 9, 9, 9, 10, 10, 11, 11, 11],
46
+ /* A= 8 */ [8, 8, 8, 9, 10, 10, 10, 10, 10, 11, 11, 11],
47
+ /* A= 9 */ [9, 9, 9, 10, 10, 10, 11, 11, 11, 12, 12, 12],
48
+ /* A=10 */ [10, 10, 10, 11, 11, 11, 11, 12, 12, 12, 12, 12],
49
+ /* A=11 */ [11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12],
50
+ /* A=12 */ [12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12],
51
+ ];
52
+ function clampIdx(val, min, max) {
53
+ return Math.max(min, Math.min(max, val));
54
+ }
55
+ /**
56
+ * REBA (Rapid Entire Body Assessment) — Ergonomic Risk
57
+ *
58
+ * @reference Hignett, S. & McAtamney, L. (2000). REBA, Applied Ergonomics 31(2), 201-205.
59
+ * @reference 중대재해처벌법 시행령 — 인체공학적 유해요인 평가
60
+ */
61
+ export function ergonomicRisk(input) {
62
+ // --- Trunk Score ---
63
+ const absTA = Math.abs(input.trunkAngle);
64
+ let trunkScore;
65
+ if (absTA === 0)
66
+ trunkScore = 1;
67
+ else if (absTA <= 20)
68
+ trunkScore = 2;
69
+ else if (absTA <= 60)
70
+ trunkScore = 3;
71
+ else
72
+ trunkScore = 4;
73
+ if (input.trunkAngle < 0)
74
+ trunkScore = Math.max(trunkScore, 2); // extension
75
+ if (input.trunkTwisted)
76
+ trunkScore += 1;
77
+ if (input.trunkSideBent)
78
+ trunkScore += 1;
79
+ // --- Neck Score ---
80
+ let neckScore;
81
+ if (input.neckAngle >= 0 && input.neckAngle <= 20)
82
+ neckScore = 1;
83
+ else
84
+ neckScore = 2;
85
+ if (input.neckTwisted)
86
+ neckScore += 1;
87
+ if (input.neckSideBent)
88
+ neckScore += 1;
89
+ // --- Leg Score ---
90
+ let legScore;
91
+ if (input.legSupport === 'bilateral')
92
+ legScore = 1;
93
+ else
94
+ legScore = 2;
95
+ if (input.kneeFlexion > 30 && input.kneeFlexion <= 60)
96
+ legScore += 1;
97
+ else if (input.kneeFlexion > 60)
98
+ legScore += 2;
99
+ // --- Table A lookup ---
100
+ const tIdx = clampIdx(trunkScore, 1, 5) - 1;
101
+ const nIdx = clampIdx(neckScore, 1, 3) - 1;
102
+ const lIdx = clampIdx(legScore, 1, 4) - 1;
103
+ const tableARow = tIdx * 3 + nIdx;
104
+ let scoreA = TABLE_A[clampIdx(tableARow, 0, TABLE_A.length - 1)][lIdx];
105
+ // Load/Force score
106
+ let loadScore = 0;
107
+ if (input.load >= 5 && input.load < 10)
108
+ loadScore = 1;
109
+ else if (input.load >= 10)
110
+ loadScore = 2;
111
+ if (input.shockForce)
112
+ loadScore += 1;
113
+ scoreA += loadScore;
114
+ // --- Upper Arm Score ---
115
+ const absUAA = Math.abs(input.upperArmAngle);
116
+ let upperArmScore;
117
+ if (absUAA <= 20)
118
+ upperArmScore = 1;
119
+ else if (absUAA <= 45)
120
+ upperArmScore = 2;
121
+ else if (absUAA <= 90)
122
+ upperArmScore = 3;
123
+ else
124
+ upperArmScore = 4;
125
+ if (input.shoulderRaised)
126
+ upperArmScore += 1;
127
+ if (input.armAbducted)
128
+ upperArmScore += 1;
129
+ if (input.armSupported)
130
+ upperArmScore -= 1;
131
+ upperArmScore = Math.max(1, upperArmScore);
132
+ // --- Lower Arm Score ---
133
+ let lowerArmScore;
134
+ if (input.lowerArmAngle >= 60 && input.lowerArmAngle <= 100)
135
+ lowerArmScore = 1;
136
+ else
137
+ lowerArmScore = 2;
138
+ // --- Wrist Score ---
139
+ const absWA = Math.abs(input.wristAngle);
140
+ let wristScore;
141
+ if (absWA <= 15)
142
+ wristScore = 1;
143
+ else
144
+ wristScore = 2;
145
+ if (input.wristTwisted)
146
+ wristScore += 1;
147
+ // --- Table B lookup ---
148
+ const uaIdx = clampIdx(upperArmScore, 1, 6) - 1;
149
+ const laIdx = clampIdx(lowerArmScore, 1, 2) - 1;
150
+ const wIdx = clampIdx(wristScore, 1, 3) - 1;
151
+ const tableBRow = uaIdx * 2 + laIdx;
152
+ let scoreB = TABLE_B[clampIdx(tableBRow, 0, TABLE_B.length - 1)][wIdx];
153
+ // Coupling score
154
+ // Simplified: good=0, fair=1, poor=2, unacceptable=3
155
+ // Use 0 as default (good coupling assumed)
156
+ scoreB += 0;
157
+ // --- Table C lookup ---
158
+ const aIdx = clampIdx(scoreA, 1, 12) - 1;
159
+ const bIdx = clampIdx(scoreB, 1, 12) - 1;
160
+ let scoreC = TABLE_C[aIdx][bIdx];
161
+ // Activity score
162
+ let activityScore = 0;
163
+ if (input.staticPosture)
164
+ activityScore += 1;
165
+ if (input.repeatedSmallRange)
166
+ activityScore += 1;
167
+ if (input.rapidLargeChange)
168
+ activityScore += 1;
169
+ const rebaScore = scoreC + activityScore;
170
+ // Risk level and action
171
+ let riskLevel;
172
+ let actionLevel;
173
+ if (rebaScore <= 1) {
174
+ riskLevel = 'negligible';
175
+ actionLevel = 0;
176
+ }
177
+ else if (rebaScore <= 3) {
178
+ riskLevel = 'low';
179
+ actionLevel = 1;
180
+ }
181
+ else if (rebaScore <= 7) {
182
+ riskLevel = 'medium';
183
+ actionLevel = 2;
184
+ }
185
+ else if (rebaScore <= 10) {
186
+ riskLevel = 'high';
187
+ actionLevel = 3;
188
+ }
189
+ else {
190
+ riskLevel = 'very_high';
191
+ actionLevel = 4;
192
+ }
193
+ return {
194
+ trunkScore,
195
+ neckScore,
196
+ legScore,
197
+ upperArmScore,
198
+ lowerArmScore,
199
+ wristScore,
200
+ scoreA,
201
+ scoreB,
202
+ scoreC,
203
+ rebaScore,
204
+ riskLevel,
205
+ actionLevel,
206
+ };
207
+ }
208
+ //# sourceMappingURL=ergonomicRisk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ergonomicRisk.js","sourceRoot":"","sources":["../../src/safety/ergonomicRisk.ts"],"names":[],"mappings":"AAEA,gDAAgD;AAChD,MAAM,OAAO,GAAe;IAC1B,qBAAqB;IACrB,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;IACnC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC;IACpC,qBAAqB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC;IACpC,qBAAqB,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IACrC,qBAAqB,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;CACvC,CAAC;AAEF,0DAA0D;AAC1D,MAAM,OAAO,GAAe;IAC1B,mBAAmB;IACnB,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1B,gBAAgB,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;CAC3B,CAAC;AAEF,4CAA4C;AAC5C,MAAM,OAAO,GAAe;IAC1B,8CAA8C;IAC9C,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC/C,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC/C,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC/C,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC/C,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC/C,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IACnD,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IACpD,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IACvD,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IACxD,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IAC3D,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;IAC3D,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;CAC5D,CAAC;AAEF,SAAS,QAAQ,CAAC,GAAW,EAAE,GAAW,EAAE,GAAW;IACrD,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAC3C,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,aAAa,CAAC,KAAgB;IAC5C,sBAAsB;IACtB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACzC,IAAI,UAAkB,CAAC;IACvB,IAAI,KAAK,KAAK,CAAC;QAAE,UAAU,GAAG,CAAC,CAAC;SAC3B,IAAI,KAAK,IAAI,EAAE;QAAE,UAAU,GAAG,CAAC,CAAC;SAChC,IAAI,KAAK,IAAI,EAAE;QAAE,UAAU,GAAG,CAAC,CAAC;;QAChC,UAAU,GAAG,CAAC,CAAC;IACpB,IAAI,KAAK,CAAC,UAAU,GAAG,CAAC;QAAE,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,YAAY;IAC5E,IAAI,KAAK,CAAC,YAAY;QAAE,UAAU,IAAI,CAAC,CAAC;IACxC,IAAI,KAAK,CAAC,aAAa;QAAE,UAAU,IAAI,CAAC,CAAC;IAEzC,qBAAqB;IACrB,IAAI,SAAiB,CAAC;IACtB,IAAI,KAAK,CAAC,SAAS,IAAI,CAAC,IAAI,KAAK,CAAC,SAAS,IAAI,EAAE;QAAE,SAAS,GAAG,CAAC,CAAC;;QAC5D,SAAS,GAAG,CAAC,CAAC;IACnB,IAAI,KAAK,CAAC,WAAW;QAAE,SAAS,IAAI,CAAC,CAAC;IACtC,IAAI,KAAK,CAAC,YAAY;QAAE,SAAS,IAAI,CAAC,CAAC;IAEvC,oBAAoB;IACpB,IAAI,QAAgB,CAAC;IACrB,IAAI,KAAK,CAAC,UAAU,KAAK,WAAW;QAAE,QAAQ,GAAG,CAAC,CAAC;;QAC9C,QAAQ,GAAG,CAAC,CAAC;IAClB,IAAI,KAAK,CAAC,WAAW,GAAG,EAAE,IAAI,KAAK,CAAC,WAAW,IAAI,EAAE;QAAE,QAAQ,IAAI,CAAC,CAAC;SAChE,IAAI,KAAK,CAAC,WAAW,GAAG,EAAE;QAAE,QAAQ,IAAI,CAAC,CAAC;IAE/C,yBAAyB;IACzB,MAAM,IAAI,GAAG,QAAQ,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAC5C,MAAM,IAAI,GAAG,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAC3C,MAAM,IAAI,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAC1C,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,GAAG,IAAI,CAAC;IAClC,IAAI,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAEvE,mBAAmB;IACnB,IAAI,SAAS,GAAG,CAAC,CAAC;IAClB,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,IAAI,GAAG,EAAE;QAAE,SAAS,GAAG,CAAC,CAAC;SACjD,IAAI,KAAK,CAAC,IAAI,IAAI,EAAE;QAAE,SAAS,GAAG,CAAC,CAAC;IACzC,IAAI,KAAK,CAAC,UAAU;QAAE,SAAS,IAAI,CAAC,CAAC;IACrC,MAAM,IAAI,SAAS,CAAC;IAEpB,0BAA0B;IAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,aAAqB,CAAC;IAC1B,IAAI,MAAM,IAAI,EAAE;QAAE,aAAa,GAAG,CAAC,CAAC;SAC/B,IAAI,MAAM,IAAI,EAAE;QAAE,aAAa,GAAG,CAAC,CAAC;SACpC,IAAI,MAAM,IAAI,EAAE;QAAE,aAAa,GAAG,CAAC,CAAC;;QACpC,aAAa,GAAG,CAAC,CAAC;IACvB,IAAI,KAAK,CAAC,cAAc;QAAE,aAAa,IAAI,CAAC,CAAC;IAC7C,IAAI,KAAK,CAAC,WAAW;QAAE,aAAa,IAAI,CAAC,CAAC;IAC1C,IAAI,KAAK,CAAC,YAAY;QAAE,aAAa,IAAI,CAAC,CAAC;IAC3C,aAAa,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC;IAE3C,0BAA0B;IAC1B,IAAI,aAAqB,CAAC;IAC1B,IAAI,KAAK,CAAC,aAAa,IAAI,EAAE,IAAI,KAAK,CAAC,aAAa,IAAI,GAAG;QAAE,aAAa,GAAG,CAAC,CAAC;;QAC1E,aAAa,GAAG,CAAC,CAAC;IAEvB,sBAAsB;IACtB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACzC,IAAI,UAAkB,CAAC;IACvB,IAAI,KAAK,IAAI,EAAE;QAAE,UAAU,GAAG,CAAC,CAAC;;QAC3B,UAAU,GAAG,CAAC,CAAC;IACpB,IAAI,KAAK,CAAC,YAAY;QAAE,UAAU,IAAI,CAAC,CAAC;IAExC,yBAAyB;IACzB,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAChD,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAChD,MAAM,IAAI,GAAG,QAAQ,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAC5C,MAAM,SAAS,GAAG,KAAK,GAAG,CAAC,GAAG,KAAK,CAAC;IACpC,IAAI,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,CAAC,EAAE,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAEvE,iBAAiB;IACjB,qDAAqD;IACrD,2CAA2C;IAC3C,MAAM,IAAI,CAAC,CAAC;IAEZ,yBAAyB;IACzB,MAAM,IAAI,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IACzC,MAAM,IAAI,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IACzC,IAAI,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;IAEjC,iBAAiB;IACjB,IAAI,aAAa,GAAG,CAAC,CAAC;IACtB,IAAI,KAAK,CAAC,aAAa;QAAE,aAAa,IAAI,CAAC,CAAC;IAC5C,IAAI,KAAK,CAAC,kBAAkB;QAAE,aAAa,IAAI,CAAC,CAAC;IACjD,IAAI,KAAK,CAAC,gBAAgB;QAAE,aAAa,IAAI,CAAC,CAAC;IAE/C,MAAM,SAAS,GAAG,MAAM,GAAG,aAAa,CAAC;IAEzC,wBAAwB;IACxB,IAAI,SAAkC,CAAC;IACvC,IAAI,WAAmB,CAAC;IACxB,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QAAC,SAAS,GAAG,YAAY,CAAC;QAAC,WAAW,GAAG,CAAC,CAAC;IAAC,CAAC;SAC7D,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QAAC,SAAS,GAAG,KAAK,CAAC;QAAC,WAAW,GAAG,CAAC,CAAC;IAAC,CAAC;SAC3D,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QAAC,SAAS,GAAG,QAAQ,CAAC;QAAC,WAAW,GAAG,CAAC,CAAC;IAAC,CAAC;SAC9D,IAAI,SAAS,IAAI,EAAE,EAAE,CAAC;QAAC,SAAS,GAAG,MAAM,CAAC;QAAC,WAAW,GAAG,CAAC,CAAC;IAAC,CAAC;SAC7D,CAAC;QAAC,SAAS,GAAG,WAAW,CAAC;QAAC,WAAW,GAAG,CAAC,CAAC;IAAC,CAAC;IAElD,OAAO;QACL,UAAU;QACV,SAAS;QACT,QAAQ;QACR,aAAa;QACb,aAAa;QACb,UAAU;QACV,MAAM;QACN,MAAM;QACN,MAAM;QACN,SAAS;QACT,SAAS;QACT,WAAW;KACZ,CAAC;AACJ,CAAC"}
@@ -0,0 +1,13 @@
1
+ import type { IlluminanceInput, IlluminanceResult } from './types.js';
2
+ /**
3
+ * Calculate illuminance using the Lumen Method.
4
+ *
5
+ * N = (E × A) / (Φ × CU × MF)
6
+ * Room Index = (L × W) / (Hm × (L + W))
7
+ * Hm = luminaire height − workplane height
8
+ *
9
+ * @param input - Room dimensions and lighting parameters
10
+ * @returns Number of fixtures needed and lighting metrics
11
+ */
12
+ export declare function illuminance(input: IlluminanceInput): IlluminanceResult;
13
+ //# sourceMappingURL=illuminance.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"illuminance.d.ts","sourceRoot":"","sources":["../../src/safety/illuminance.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAgCtE;;;;;;;;;GASG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,gBAAgB,GAAG,iBAAiB,CAqEtE"}
@@ -0,0 +1,91 @@
1
+ import { roundTo } from '../utils.js';
2
+ /**
3
+ * Simple CU lookup by room index (linear interpolation).
4
+ * Based on typical reflectance values (ceiling 70%, wall 50%, floor 20%).
5
+ */
6
+ const CU_TABLE = [
7
+ [0.6, 0.22],
8
+ [1.0, 0.34],
9
+ [1.5, 0.45],
10
+ [2.0, 0.52],
11
+ [2.5, 0.57],
12
+ [3.0, 0.60],
13
+ [4.0, 0.65],
14
+ [5.0, 0.68],
15
+ ];
16
+ function lookupCU(roomIndex) {
17
+ if (roomIndex <= CU_TABLE[0][0])
18
+ return CU_TABLE[0][1];
19
+ if (roomIndex >= CU_TABLE[CU_TABLE.length - 1][0])
20
+ return CU_TABLE[CU_TABLE.length - 1][1];
21
+ for (let i = 0; i < CU_TABLE.length - 1; i++) {
22
+ const [ri0, cu0] = CU_TABLE[i];
23
+ const [ri1, cu1] = CU_TABLE[i + 1];
24
+ if (roomIndex >= ri0 && roomIndex <= ri1) {
25
+ const t = (roomIndex - ri0) / (ri1 - ri0);
26
+ return cu0 + t * (cu1 - cu0);
27
+ }
28
+ }
29
+ return CU_TABLE[CU_TABLE.length - 1][1];
30
+ }
31
+ /**
32
+ * Calculate illuminance using the Lumen Method.
33
+ *
34
+ * N = (E × A) / (Φ × CU × MF)
35
+ * Room Index = (L × W) / (Hm × (L + W))
36
+ * Hm = luminaire height − workplane height
37
+ *
38
+ * @param input - Room dimensions and lighting parameters
39
+ * @returns Number of fixtures needed and lighting metrics
40
+ */
41
+ export function illuminance(input) {
42
+ const { roomLength, roomWidth, luminaireHeight, workplaneHeight = 0.85, targetLux, lumensPerLuminaire, wattsPerLuminaire, cu: cuOverride, mf = 0.8, } = input;
43
+ if (roomLength <= 0 || roomWidth <= 0 || lumensPerLuminaire <= 0 || targetLux <= 0) {
44
+ return {
45
+ fixturesNeeded: 0,
46
+ actualLux: 0,
47
+ roomIndex: 0,
48
+ totalLumens: 0,
49
+ powerDensity: null,
50
+ recommendedSpacing: 0,
51
+ };
52
+ }
53
+ const area = roomLength * roomWidth;
54
+ const hm = luminaireHeight - workplaneHeight;
55
+ if (hm <= 0) {
56
+ return {
57
+ fixturesNeeded: 0,
58
+ actualLux: 0,
59
+ roomIndex: 0,
60
+ totalLumens: 0,
61
+ powerDensity: null,
62
+ recommendedSpacing: 0,
63
+ };
64
+ }
65
+ // Room Index (Cavity Ratio)
66
+ const roomIndex = (roomLength * roomWidth) / (hm * (roomLength + roomWidth));
67
+ // Coefficient of Utilization
68
+ const cu = cuOverride ?? lookupCU(roomIndex);
69
+ // Number of luminaires: N = (E × A) / (Φ × CU × MF)
70
+ const nExact = (targetLux * area) / (lumensPerLuminaire * cu * mf);
71
+ const fixturesNeeded = Math.ceil(nExact);
72
+ // Actual lux with rounded fixture count
73
+ const totalLumens = fixturesNeeded * lumensPerLuminaire;
74
+ const actualLux = (totalLumens * cu * mf) / area;
75
+ // Power density
76
+ let powerDensity = null;
77
+ if (wattsPerLuminaire !== undefined && wattsPerLuminaire > 0) {
78
+ powerDensity = (fixturesNeeded * wattsPerLuminaire) / area;
79
+ }
80
+ // Recommended max spacing = 1.5 × Hm
81
+ const recommendedSpacing = 1.5 * hm;
82
+ return {
83
+ fixturesNeeded,
84
+ actualLux: roundTo(actualLux, 4),
85
+ roomIndex: roundTo(roomIndex, 4),
86
+ totalLumens: roundTo(totalLumens, 4),
87
+ powerDensity: powerDensity !== null ? roundTo(powerDensity, 4) : null,
88
+ recommendedSpacing: roundTo(recommendedSpacing, 4),
89
+ };
90
+ }
91
+ //# sourceMappingURL=illuminance.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"illuminance.js","sourceRoot":"","sources":["../../src/safety/illuminance.ts"],"names":[],"mappings":"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"}
@@ -5,5 +5,12 @@ export { noiseExposure } from './noiseExposure.js';
5
5
  export { wbgtCalculate } from './wbgtCalculate.js';
6
6
  export { havsCalculate } from './havsCalculate.js';
7
7
  export { respiratorCalculate } from './respiratorCalculate.js';
8
- export type { VentilationActivityLevel, SpaceType, VentilationRateInput, VentilationRateResult, FallClearanceInput, FallClearanceResult, CouplingQuality, WorkDuration, NioshInput, NioshResult, NoiseExposure, NoiseExposureInput, NoiseExposureResult, WorkloadIntensity, WbgtInput, WbgtResult, ToolExposure, HavsInput, HavsResult, RespiratorType, RespiratorInput, RespiratorResult, } from './types.js';
8
+ export { ladderAngle } from './ladderAngle.js';
9
+ export { illuminance } from './illuminance.js';
10
+ export { thermalComfort } from './thermalComfort.js';
11
+ export { ergonomicRisk } from './ergonomicRisk.js';
12
+ export { arcFlash } from './arcFlash.js';
13
+ export { confinedSpace } from './confinedSpace.js';
14
+ export { lel } from './lel.js';
15
+ export type { VentilationActivityLevel, SpaceType, VentilationRateInput, VentilationRateResult, FallClearanceInput, FallClearanceResult, CouplingQuality, WorkDuration, NioshInput, NioshResult, NoiseExposure, NoiseExposureInput, NoiseExposureResult, WorkloadIntensity, WbgtInput, WbgtResult, ToolExposure, HavsInput, HavsResult, RespiratorType, RespiratorInput, RespiratorResult, LadderAngleInput, LadderAngleResult, IlluminanceInput, IlluminanceResult, ThermalComfortInput, ThermalComfortResult, RebaInput, RebaResult, ArcFlashInput, ArcFlashResult, ConfinedSpaceInput, ConfinedSpaceResult, GasComponent, LelInput, LelResult, } from './types.js';
9
16
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/safety/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAG/D,YAAY,EAEV,wBAAwB,EACxB,SAAS,EACT,oBAAoB,EACpB,qBAAqB,EAErB,kBAAkB,EAClB,mBAAmB,EAEnB,eAAe,EACf,YAAY,EACZ,UAAU,EACV,WAAW,EAEX,aAAa,EACb,kBAAkB,EAClB,mBAAmB,EAEnB,iBAAiB,EACjB,SAAS,EACT,UAAU,EAEV,YAAY,EACZ,SAAS,EACT,UAAU,EAEV,cAAc,EACd,eAAe,EACf,gBAAgB,GACjB,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/safety/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAG/B,YAAY,EAEV,wBAAwB,EACxB,SAAS,EACT,oBAAoB,EACpB,qBAAqB,EAErB,kBAAkB,EAClB,mBAAmB,EAEnB,eAAe,EACf,YAAY,EACZ,UAAU,EACV,WAAW,EAEX,aAAa,EACb,kBAAkB,EAClB,mBAAmB,EAEnB,iBAAiB,EACjB,SAAS,EACT,UAAU,EAEV,YAAY,EACZ,SAAS,EACT,UAAU,EAEV,cAAc,EACd,eAAe,EACf,gBAAgB,EAEhB,gBAAgB,EAChB,iBAAiB,EAEjB,gBAAgB,EAChB,iBAAiB,EAEjB,mBAAmB,EACnB,oBAAoB,EAEpB,SAAS,EACT,UAAU,EAEV,aAAa,EACb,cAAc,EAEd,kBAAkB,EAClB,mBAAmB,EAEnB,YAAY,EACZ,QAAQ,EACR,SAAS,GACV,MAAM,YAAY,CAAC"}
@@ -6,4 +6,11 @@ export { noiseExposure } from './noiseExposure.js';
6
6
  export { wbgtCalculate } from './wbgtCalculate.js';
7
7
  export { havsCalculate } from './havsCalculate.js';
8
8
  export { respiratorCalculate } from './respiratorCalculate.js';
9
+ export { ladderAngle } from './ladderAngle.js';
10
+ export { illuminance } from './illuminance.js';
11
+ export { thermalComfort } from './thermalComfort.js';
12
+ export { ergonomicRisk } from './ergonomicRisk.js';
13
+ export { arcFlash } from './arcFlash.js';
14
+ export { confinedSpace } from './confinedSpace.js';
15
+ export { lel } from './lel.js';
9
16
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/safety/index.ts"],"names":[],"mappings":"AAAA,yBAAyB;AACzB,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/safety/index.ts"],"names":[],"mappings":"AAAA,yBAAyB;AACzB,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC"}
@@ -0,0 +1,16 @@
1
+ import type { LadderAngleInput, LadderAngleResult } from './types.js';
2
+ /**
3
+ * Calculate ladder setup angle and OSHA compliance.
4
+ *
5
+ * OSHA 4:1 Rule: For every 4 feet of height, the base should be 1 foot out.
6
+ * This gives an ideal angle of atan(4/1) ≈ 75.96° (commonly cited as 75.5°).
7
+ * Compliant range: 70°–80°.
8
+ *
9
+ * Provide ladderLength and either height or baseDistance.
10
+ * If both height and baseDistance are provided, ladderLength is recalculated.
11
+ *
12
+ * @param input - Ladder dimensions (2 of 3 required)
13
+ * @returns Angle, compliance status, and warnings
14
+ */
15
+ export declare function ladderAngle(input: LadderAngleInput): LadderAngleResult;
16
+ //# sourceMappingURL=ladderAngle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ladderAngle.d.ts","sourceRoot":"","sources":["../../src/safety/ladderAngle.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAKtE;;;;;;;;;;;;GAYG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,gBAAgB,GAAG,iBAAiB,CAsEtE"}