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
@@ -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":"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"}
@@ -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"}
@@ -0,0 +1,87 @@
1
+ import { roundTo } from '../utils.js';
2
+ const DEG = 180 / Math.PI;
3
+ const RAD = Math.PI / 180;
4
+ /**
5
+ * Calculate ladder setup angle and OSHA compliance.
6
+ *
7
+ * OSHA 4:1 Rule: For every 4 feet of height, the base should be 1 foot out.
8
+ * This gives an ideal angle of atan(4/1) ≈ 75.96° (commonly cited as 75.5°).
9
+ * Compliant range: 70°–80°.
10
+ *
11
+ * Provide ladderLength and either height or baseDistance.
12
+ * If both height and baseDistance are provided, ladderLength is recalculated.
13
+ *
14
+ * @param input - Ladder dimensions (2 of 3 required)
15
+ * @returns Angle, compliance status, and warnings
16
+ */
17
+ export function ladderAngle(input) {
18
+ let { ladderLength, height, baseDistance } = input;
19
+ const warnings = [];
20
+ // Resolve the third dimension from the other two
21
+ if (height !== undefined && baseDistance !== undefined) {
22
+ // Both given: recalculate ladder length
23
+ ladderLength = Math.sqrt(height * height + baseDistance * baseDistance);
24
+ }
25
+ else if (height !== undefined) {
26
+ // height + ladderLength → baseDistance
27
+ if (ladderLength <= height) {
28
+ baseDistance = 0;
29
+ warnings.push('Ladder length must be greater than height');
30
+ }
31
+ else {
32
+ baseDistance = Math.sqrt(ladderLength * ladderLength - height * height);
33
+ }
34
+ }
35
+ else if (baseDistance !== undefined) {
36
+ // baseDistance + ladderLength → height
37
+ if (ladderLength <= baseDistance) {
38
+ height = 0;
39
+ warnings.push('Ladder length must be greater than base distance');
40
+ }
41
+ else {
42
+ height = Math.sqrt(ladderLength * ladderLength - baseDistance * baseDistance);
43
+ }
44
+ }
45
+ else {
46
+ // Neither height nor baseDistance → assume OSHA ideal angle (75.5°)
47
+ height = ladderLength * Math.sin(75.5 * RAD);
48
+ baseDistance = ladderLength * Math.cos(75.5 * RAD);
49
+ }
50
+ // Calculate angle from horizontal
51
+ let angle = 0;
52
+ if (baseDistance !== undefined && baseDistance > 0 && height !== undefined) {
53
+ angle = Math.atan(height / baseDistance) * DEG;
54
+ }
55
+ else if (height !== undefined && height > 0) {
56
+ angle = 90;
57
+ }
58
+ // Ideal base distance for OSHA 4:1 at given height
59
+ const idealBaseDistance = height !== undefined ? height / 4 : 0;
60
+ // Reach height = wall contact height + ~1m (3 feet) above contact point
61
+ const reachHeight = (height ?? 0) + 1.0;
62
+ // OSHA compliance: 70° - 80°
63
+ const isCompliant = angle >= 70 && angle <= 80;
64
+ // Generate warnings
65
+ if (angle < 70) {
66
+ warnings.push('Angle too shallow (< 70°): ladder may slide out at base');
67
+ }
68
+ else if (angle > 80) {
69
+ warnings.push('Angle too steep (> 80°): ladder may tip backwards');
70
+ }
71
+ if (ladderLength > 0 && (height ?? 0) > 0) {
72
+ if (angle >= 70 && angle <= 80 && (height ?? 0) > ladderLength * 0.97) {
73
+ warnings.push('Ladder may not extend sufficiently above landing surface');
74
+ }
75
+ }
76
+ return {
77
+ angle: roundTo(angle, 4),
78
+ height: roundTo(height ?? 0, 4),
79
+ baseDistance: roundTo(baseDistance ?? 0, 4),
80
+ ladderLength: roundTo(ladderLength, 4),
81
+ idealBaseDistance: roundTo(idealBaseDistance, 4),
82
+ reachHeight: roundTo(reachHeight, 4),
83
+ isCompliant,
84
+ warnings,
85
+ };
86
+ }
87
+ //# sourceMappingURL=ladderAngle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ladderAngle.js","sourceRoot":"","sources":["../../src/safety/ladderAngle.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import type { LelInput, LelResult } from './types.js';
2
+ /**
3
+ * LEL (Lower Explosive Limit) for Mixed Gases — Le Chatelier's Rule
4
+ *
5
+ * @formula
6
+ * - LEL_mix = 1 / Σ(yi / LELi)
7
+ * - yi = concentration_i / total_concentration (mole fraction)
8
+ * - %LEL = totalConcentration / LEL_mix × 100
9
+ *
10
+ * @reference Le Chatelier, H. (1891). Estimation of Firedamp by Flammability Limits.
11
+ * @reference NFPA 69 — Standard on Explosion Prevention Systems
12
+ */
13
+ export declare function lel(input: LelInput): LelResult;
14
+ //# sourceMappingURL=lel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lel.d.ts","sourceRoot":"","sources":["../../src/safety/lel.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEtD;;;;;;;;;;GAUG;AACH,wBAAgB,GAAG,CAAC,KAAK,EAAE,QAAQ,GAAG,SAAS,CA0D9C"}
@@ -0,0 +1,66 @@
1
+ import { roundTo } from '../utils.js';
2
+ /**
3
+ * LEL (Lower Explosive Limit) for Mixed Gases — Le Chatelier's Rule
4
+ *
5
+ * @formula
6
+ * - LEL_mix = 1 / Σ(yi / LELi)
7
+ * - yi = concentration_i / total_concentration (mole fraction)
8
+ * - %LEL = totalConcentration / LEL_mix × 100
9
+ *
10
+ * @reference Le Chatelier, H. (1891). Estimation of Firedamp by Flammability Limits.
11
+ * @reference NFPA 69 — Standard on Explosion Prevention Systems
12
+ */
13
+ export function lel(input) {
14
+ const { gases } = input;
15
+ const totalConcentration = gases.reduce((s, g) => s + g.concentration, 0);
16
+ if (totalConcentration === 0 || gases.length === 0) {
17
+ return {
18
+ mixtureLel: 0,
19
+ totalConcentration: 0,
20
+ percentOfLel: 0,
21
+ status: 'safe',
22
+ safetyMargin: 0,
23
+ contributions: gases.map(g => ({ name: g.name, fraction: 0 })),
24
+ };
25
+ }
26
+ // Le Chatelier's rule: 1 / Σ(yi / LELi)
27
+ let sumFractionOverLel = 0;
28
+ const contributions = [];
29
+ for (const gas of gases) {
30
+ const yi = gas.concentration / totalConcentration;
31
+ if (gas.lel > 0) {
32
+ sumFractionOverLel += yi / gas.lel;
33
+ }
34
+ contributions.push({
35
+ name: gas.name,
36
+ fraction: roundTo(yi * 100, 2),
37
+ });
38
+ }
39
+ const mixtureLel = sumFractionOverLel > 0 ? 1 / sumFractionOverLel : 0;
40
+ const percentOfLel = mixtureLel > 0
41
+ ? (totalConcentration / mixtureLel) * 100
42
+ : 0;
43
+ const safetyMargin = mixtureLel > 0
44
+ ? mixtureLel - totalConcentration
45
+ : 0;
46
+ // Status
47
+ let status;
48
+ if (percentOfLel < 25) {
49
+ status = 'safe';
50
+ }
51
+ else if (percentOfLel < 50) {
52
+ status = 'caution';
53
+ }
54
+ else {
55
+ status = 'danger';
56
+ }
57
+ return {
58
+ mixtureLel: roundTo(mixtureLel, 4),
59
+ totalConcentration: roundTo(totalConcentration, 4),
60
+ percentOfLel: roundTo(percentOfLel, 2),
61
+ status,
62
+ safetyMargin: roundTo(safetyMargin, 4),
63
+ contributions,
64
+ };
65
+ }
66
+ //# sourceMappingURL=lel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lel.js","sourceRoot":"","sources":["../../src/safety/lel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGtC;;;;;;;;;;GAUG;AACH,MAAM,UAAU,GAAG,CAAC,KAAe;IACjC,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC;IAExB,MAAM,kBAAkB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IAE1E,IAAI,kBAAkB,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACnD,OAAO;YACL,UAAU,EAAE,CAAC;YACb,kBAAkB,EAAE,CAAC;YACrB,YAAY,EAAE,CAAC;YACf,MAAM,EAAE,MAAM;YACd,YAAY,EAAE,CAAC;YACf,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC;SAC/D,CAAC;IACJ,CAAC;IAED,wCAAwC;IACxC,IAAI,kBAAkB,GAAG,CAAC,CAAC;IAC3B,MAAM,aAAa,GAAyC,EAAE,CAAC;IAE/D,KAAK,MAAM,GAAG,IAAI,KAAK,EAAE,CAAC;QACxB,MAAM,EAAE,GAAG,GAAG,CAAC,aAAa,GAAG,kBAAkB,CAAC;QAClD,IAAI,GAAG,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC;YAChB,kBAAkB,IAAI,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;QACrC,CAAC;QACD,aAAa,CAAC,IAAI,CAAC;YACjB,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,QAAQ,EAAE,OAAO,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC;SAC/B,CAAC,CAAC;IACL,CAAC;IAED,MAAM,UAAU,GAAG,kBAAkB,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,kBAAkB,CAAC,CAAC,CAAC,CAAC,CAAC;IACvE,MAAM,YAAY,GAAG,UAAU,GAAG,CAAC;QACjC,CAAC,CAAC,CAAC,kBAAkB,GAAG,UAAU,CAAC,GAAG,GAAG;QACzC,CAAC,CAAC,CAAC,CAAC;IAEN,MAAM,YAAY,GAAG,UAAU,GAAG,CAAC;QACjC,CAAC,CAAC,UAAU,GAAG,kBAAkB;QACjC,CAAC,CAAC,CAAC,CAAC;IAEN,SAAS;IACT,IAAI,MAA2B,CAAC;IAChC,IAAI,YAAY,GAAG,EAAE,EAAE,CAAC;QACtB,MAAM,GAAG,MAAM,CAAC;IAClB,CAAC;SAAM,IAAI,YAAY,GAAG,EAAE,EAAE,CAAC;QAC7B,MAAM,GAAG,SAAS,CAAC;IACrB,CAAC;SAAM,CAAC;QACN,MAAM,GAAG,QAAQ,CAAC;IACpB,CAAC;IAED,OAAO;QACL,UAAU,EAAE,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;QAClC,kBAAkB,EAAE,OAAO,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAClD,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;QACtC,MAAM;QACN,YAAY,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;QACtC,aAAa;KACd,CAAC;AACJ,CAAC"}
@@ -0,0 +1,14 @@
1
+ import type { ThermalComfortInput, ThermalComfortResult } from './types.js';
2
+ /**
3
+ * PMV/PPD Thermal Comfort — ISO 7730 / Fanger's Model
4
+ *
5
+ * @formula
6
+ * - PMV = f(M, W, Icl, ta, tr, var, pa) with iterative tcl solve
7
+ * - PPD = 100 − 95 × exp(−0.03353×PMV⁴ − 0.2179×PMV²)
8
+ *
9
+ * @reference ISO 7730:2005 — Ergonomics of the thermal environment
10
+ * @reference ASHRAE Standard 55-2020
11
+ * @reference pythermalcomfort reference implementation
12
+ */
13
+ export declare function thermalComfort(input: ThermalComfortInput): ThermalComfortResult;
14
+ //# sourceMappingURL=thermalComfort.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"thermalComfort.d.ts","sourceRoot":"","sources":["../../src/safety/thermalComfort.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAE5E;;;;;;;;;;GAUG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,mBAAmB,GAAG,oBAAoB,CAkF/E"}