formulab 0.5.0 → 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +84 -0
- package/README.md +162 -31
- package/dist/automotive/chargingLoss.d.ts +15 -0
- package/dist/automotive/chargingLoss.d.ts.map +1 -0
- package/dist/automotive/chargingLoss.js +62 -0
- package/dist/automotive/chargingLoss.js.map +1 -0
- package/dist/automotive/index.d.ts +2 -1
- package/dist/automotive/index.d.ts.map +1 -1
- package/dist/automotive/index.js +1 -0
- package/dist/automotive/index.js.map +1 -1
- package/dist/automotive/types.d.ts +23 -0
- package/dist/automotive/types.d.ts.map +1 -1
- package/dist/battery/guards.d.ts +7 -0
- package/dist/battery/guards.d.ts.map +1 -0
- package/dist/battery/guards.js +17 -0
- package/dist/battery/guards.js.map +1 -0
- package/dist/battery/index.d.ts +1 -0
- package/dist/battery/index.d.ts.map +1 -1
- package/dist/battery/index.js +2 -0
- package/dist/battery/index.js.map +1 -1
- package/dist/chemical/flowControl.d.ts +14 -0
- package/dist/chemical/flowControl.d.ts.map +1 -0
- package/dist/chemical/flowControl.js +69 -0
- package/dist/chemical/flowControl.js.map +1 -0
- package/dist/chemical/guards.d.ts +17 -0
- package/dist/chemical/guards.d.ts.map +1 -0
- package/dist/chemical/guards.js +54 -0
- package/dist/chemical/guards.js.map +1 -0
- package/dist/chemical/index.d.ts +5 -1
- package/dist/chemical/index.d.ts.map +1 -1
- package/dist/chemical/index.js +5 -0
- package/dist/chemical/index.js.map +1 -1
- package/dist/chemical/pid.d.ts +14 -0
- package/dist/chemical/pid.d.ts.map +1 -0
- package/dist/chemical/pid.js +103 -0
- package/dist/chemical/pid.js.map +1 -0
- package/dist/chemical/reliefValve.d.ts +14 -0
- package/dist/chemical/reliefValve.d.ts.map +1 -0
- package/dist/chemical/reliefValve.js +98 -0
- package/dist/chemical/reliefValve.js.map +1 -0
- package/dist/chemical/types.d.ts +63 -0
- package/dist/chemical/types.d.ts.map +1 -1
- package/dist/construction/guards.d.ts +7 -0
- package/dist/construction/guards.d.ts.map +1 -0
- package/dist/construction/guards.js +31 -0
- package/dist/construction/guards.js.map +1 -0
- package/dist/construction/index.d.ts +1 -0
- package/dist/construction/index.d.ts.map +1 -1
- package/dist/construction/index.js +2 -0
- package/dist/construction/index.js.map +1 -1
- package/dist/electronics/guards.d.ts +7 -0
- package/dist/electronics/guards.d.ts.map +1 -0
- package/dist/electronics/guards.js +17 -0
- package/dist/electronics/guards.js.map +1 -0
- package/dist/electronics/index.d.ts +1 -0
- package/dist/electronics/index.d.ts.map +1 -1
- package/dist/electronics/index.js +2 -0
- package/dist/electronics/index.js.map +1 -1
- package/dist/energy/boilerEfficiency.d.ts +13 -0
- package/dist/energy/boilerEfficiency.d.ts.map +1 -0
- package/dist/energy/boilerEfficiency.js +46 -0
- package/dist/energy/boilerEfficiency.js.map +1 -0
- package/dist/energy/cusum.d.ts +15 -0
- package/dist/energy/cusum.d.ts.map +1 -0
- package/dist/energy/cusum.js +71 -0
- package/dist/energy/cusum.js.map +1 -0
- package/dist/energy/degreeDay.d.ts +13 -0
- package/dist/energy/degreeDay.d.ts.map +1 -0
- package/dist/energy/degreeDay.js +46 -0
- package/dist/energy/degreeDay.js.map +1 -0
- package/dist/energy/heatPump.d.ts +13 -0
- package/dist/energy/heatPump.d.ts.map +1 -0
- package/dist/energy/heatPump.js +48 -0
- package/dist/energy/heatPump.js.map +1 -0
- package/dist/energy/index.d.ts +9 -1
- package/dist/energy/index.d.ts.map +1 -1
- package/dist/energy/index.js +8 -0
- package/dist/energy/index.js.map +1 -1
- package/dist/energy/insulationRoi.d.ts +14 -0
- package/dist/energy/insulationRoi.d.ts.map +1 -0
- package/dist/energy/insulationRoi.js +52 -0
- package/dist/energy/insulationRoi.js.map +1 -0
- package/dist/energy/ledRoi.d.ts +14 -0
- package/dist/energy/ledRoi.d.ts.map +1 -0
- package/dist/energy/ledRoi.js +49 -0
- package/dist/energy/ledRoi.js.map +1 -0
- package/dist/energy/transformerLoss.d.ts +13 -0
- package/dist/energy/transformerLoss.d.ts.map +1 -0
- package/dist/energy/transformerLoss.js +63 -0
- package/dist/energy/transformerLoss.js.map +1 -0
- package/dist/energy/types.d.ts +168 -0
- package/dist/energy/types.d.ts.map +1 -1
- package/dist/energy/windOutput.d.ts +14 -0
- package/dist/energy/windOutput.d.ts.map +1 -0
- package/dist/energy/windOutput.js +77 -0
- package/dist/energy/windOutput.js.map +1 -0
- package/dist/food/index.d.ts +3 -1
- package/dist/food/index.d.ts.map +1 -1
- package/dist/food/index.js +2 -0
- package/dist/food/index.js.map +1 -1
- package/dist/food/stabilityStudy.d.ts +15 -0
- package/dist/food/stabilityStudy.d.ts.map +1 -0
- package/dist/food/stabilityStudy.js +92 -0
- package/dist/food/stabilityStudy.js.map +1 -0
- package/dist/food/types.d.ts +43 -0
- package/dist/food/types.d.ts.map +1 -1
- package/dist/food/waterActivity.d.ts +17 -0
- package/dist/food/waterActivity.d.ts.map +1 -0
- package/dist/food/waterActivity.js +63 -0
- package/dist/food/waterActivity.js.map +1 -0
- package/dist/logistics/abcAnalysis.d.ts +15 -0
- package/dist/logistics/abcAnalysis.d.ts.map +1 -0
- package/dist/logistics/abcAnalysis.js +101 -0
- package/dist/logistics/abcAnalysis.js.map +1 -0
- package/dist/logistics/index.d.ts +4 -1
- package/dist/logistics/index.d.ts.map +1 -1
- package/dist/logistics/index.js +3 -0
- package/dist/logistics/index.js.map +1 -1
- package/dist/logistics/inventoryTurnover.d.ts +13 -0
- package/dist/logistics/inventoryTurnover.d.ts.map +1 -0
- package/dist/logistics/inventoryTurnover.js +36 -0
- package/dist/logistics/inventoryTurnover.js.map +1 -0
- package/dist/logistics/loadCapacity.d.ts +13 -0
- package/dist/logistics/loadCapacity.d.ts.map +1 -0
- package/dist/logistics/loadCapacity.js +46 -0
- package/dist/logistics/loadCapacity.js.map +1 -0
- package/dist/logistics/types.d.ts +78 -0
- package/dist/logistics/types.d.ts.map +1 -1
- package/dist/metal/guards.d.ts +12 -0
- package/dist/metal/guards.d.ts.map +1 -0
- package/dist/metal/guards.js +36 -0
- package/dist/metal/guards.js.map +1 -0
- package/dist/metal/index.d.ts +1 -0
- package/dist/metal/index.d.ts.map +1 -1
- package/dist/metal/index.js +2 -0
- package/dist/metal/index.js.map +1 -1
- package/dist/quality/cmk.d.ts +17 -0
- package/dist/quality/cmk.d.ts.map +1 -0
- package/dist/quality/cmk.js +43 -0
- package/dist/quality/cmk.js.map +1 -0
- package/dist/quality/gageRR.d.ts +18 -0
- package/dist/quality/gageRR.d.ts.map +1 -0
- package/dist/quality/gageRR.js +110 -0
- package/dist/quality/gageRR.js.map +1 -0
- package/dist/quality/index.d.ts +5 -1
- package/dist/quality/index.d.ts.map +1 -1
- package/dist/quality/index.js +4 -0
- package/dist/quality/index.js.map +1 -1
- package/dist/quality/paretoAnalysis.d.ts +15 -0
- package/dist/quality/paretoAnalysis.d.ts.map +1 -0
- package/dist/quality/paretoAnalysis.js +92 -0
- package/dist/quality/paretoAnalysis.js.map +1 -0
- package/dist/quality/types.d.ts +91 -0
- package/dist/quality/types.d.ts.map +1 -1
- package/dist/quality/weibull.d.ts +17 -0
- package/dist/quality/weibull.d.ts.map +1 -0
- package/dist/quality/weibull.js +106 -0
- package/dist/quality/weibull.js.map +1 -0
- package/dist/safety/arcFlash.d.ts +14 -0
- package/dist/safety/arcFlash.d.ts.map +1 -0
- package/dist/safety/arcFlash.js +90 -0
- package/dist/safety/arcFlash.js.map +1 -0
- package/dist/safety/confinedSpace.d.ts +15 -0
- package/dist/safety/confinedSpace.d.ts.map +1 -0
- package/dist/safety/confinedSpace.js +116 -0
- package/dist/safety/confinedSpace.js.map +1 -0
- package/dist/safety/ergonomicRisk.d.ts +9 -0
- package/dist/safety/ergonomicRisk.d.ts.map +1 -0
- package/dist/safety/ergonomicRisk.js +208 -0
- package/dist/safety/ergonomicRisk.js.map +1 -0
- package/dist/safety/illuminance.d.ts +13 -0
- package/dist/safety/illuminance.d.ts.map +1 -0
- package/dist/safety/illuminance.js +91 -0
- package/dist/safety/illuminance.js.map +1 -0
- package/dist/safety/index.d.ts +8 -1
- package/dist/safety/index.d.ts.map +1 -1
- package/dist/safety/index.js +7 -0
- package/dist/safety/index.js.map +1 -1
- package/dist/safety/ladderAngle.d.ts +16 -0
- package/dist/safety/ladderAngle.d.ts.map +1 -0
- package/dist/safety/ladderAngle.js +87 -0
- package/dist/safety/ladderAngle.js.map +1 -0
- package/dist/safety/lel.d.ts +14 -0
- package/dist/safety/lel.d.ts.map +1 -0
- package/dist/safety/lel.js +66 -0
- package/dist/safety/lel.js.map +1 -0
- package/dist/safety/thermalComfort.d.ts +14 -0
- package/dist/safety/thermalComfort.d.ts.map +1 -0
- package/dist/safety/thermalComfort.js +96 -0
- package/dist/safety/thermalComfort.js.map +1 -0
- package/dist/safety/types.d.ts +164 -0
- package/dist/safety/types.d.ts.map +1 -1
- package/dist/utility/bilinearInterpolation.d.ts +3 -0
- package/dist/utility/bilinearInterpolation.d.ts.map +1 -0
- package/dist/utility/bilinearInterpolation.js +47 -0
- package/dist/utility/bilinearInterpolation.js.map +1 -0
- package/dist/utility/correlation.d.ts +3 -0
- package/dist/utility/correlation.d.ts.map +1 -0
- package/dist/utility/correlation.js +29 -0
- package/dist/utility/correlation.js.map +1 -0
- package/dist/utility/depreciation.d.ts +3 -0
- package/dist/utility/depreciation.d.ts.map +1 -0
- package/dist/utility/depreciation.js +57 -0
- package/dist/utility/depreciation.js.map +1 -0
- package/dist/utility/histogram.d.ts +3 -0
- package/dist/utility/histogram.d.ts.map +1 -0
- package/dist/utility/histogram.js +42 -0
- package/dist/utility/histogram.js.map +1 -0
- package/dist/utility/index.d.ts +15 -1
- package/dist/utility/index.d.ts.map +1 -1
- package/dist/utility/index.js +14 -0
- package/dist/utility/index.js.map +1 -1
- package/dist/utility/lcc.d.ts +3 -0
- package/dist/utility/lcc.d.ts.map +1 -0
- package/dist/utility/lcc.js +26 -0
- package/dist/utility/lcc.js.map +1 -0
- package/dist/utility/linearInterpolation.d.ts +3 -0
- package/dist/utility/linearInterpolation.d.ts.map +1 -0
- package/dist/utility/linearInterpolation.js +42 -0
- package/dist/utility/linearInterpolation.js.map +1 -0
- package/dist/utility/movingAverage.d.ts +3 -0
- package/dist/utility/movingAverage.d.ts.map +1 -0
- package/dist/utility/movingAverage.js +41 -0
- package/dist/utility/movingAverage.js.map +1 -0
- package/dist/utility/normalize.d.ts +3 -0
- package/dist/utility/normalize.d.ts.map +1 -0
- package/dist/utility/normalize.js +35 -0
- package/dist/utility/normalize.js.map +1 -0
- package/dist/utility/npv.d.ts +3 -0
- package/dist/utility/npv.d.ts.map +1 -0
- package/dist/utility/npv.js +45 -0
- package/dist/utility/npv.js.map +1 -0
- package/dist/utility/percentile.d.ts +3 -0
- package/dist/utility/percentile.d.ts.map +1 -0
- package/dist/utility/percentile.js +24 -0
- package/dist/utility/percentile.js.map +1 -0
- package/dist/utility/regression.d.ts +3 -0
- package/dist/utility/regression.d.ts.map +1 -0
- package/dist/utility/regression.js +40 -0
- package/dist/utility/regression.js.map +1 -0
- package/dist/utility/roi.d.ts +3 -0
- package/dist/utility/roi.d.ts.map +1 -0
- package/dist/utility/roi.js +19 -0
- package/dist/utility/roi.js.map +1 -0
- package/dist/utility/statistics.d.ts +3 -0
- package/dist/utility/statistics.d.ts.map +1 -0
- package/dist/utility/statistics.js +34 -0
- package/dist/utility/statistics.js.map +1 -0
- package/dist/utility/types.d.ts +213 -1
- package/dist/utility/types.d.ts.map +1 -1
- package/dist/utility/unit.d.ts.map +1 -1
- package/dist/utility/unit.js +51 -0
- package/dist/utility/unit.js.map +1 -1
- package/dist/utility/weightedScore.d.ts +3 -0
- package/dist/utility/weightedScore.d.ts.map +1 -0
- package/dist/utility/weightedScore.js +35 -0
- package/dist/utility/weightedScore.js.map +1 -0
- package/package.json +3 -2
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { roundTo } from '../utils.js';
|
|
2
|
+
/**
|
|
3
|
+
* Arc Flash Incident Energy Calculator — IEEE 1584-2018 Simplified / NFPA 70E
|
|
4
|
+
*
|
|
5
|
+
* @formula
|
|
6
|
+
* - Ia (arcing current) from empirical IEEE 1584 equations
|
|
7
|
+
* - E (incident energy) = Cf × normalized energy × (t/0.2) × (610^x / D^x)
|
|
8
|
+
* - AFB = distance where E = 1.2 cal/cm²
|
|
9
|
+
*
|
|
10
|
+
* @reference IEEE 1584-2018 — Guide for Performing Arc-Flash Hazard Calculations
|
|
11
|
+
* @reference NFPA 70E-2024 — Standard for Electrical Safety in the Workplace
|
|
12
|
+
*/
|
|
13
|
+
export function arcFlash(input) {
|
|
14
|
+
const { voltage, boltedFaultCurrent, workingDistance, faultClearingTime, gapBetweenConductors, enclosureType } = input;
|
|
15
|
+
const Ibf = boltedFaultCurrent; // kA
|
|
16
|
+
const V = voltage;
|
|
17
|
+
const G = gapBetweenConductors; // mm
|
|
18
|
+
const t = faultClearingTime; // seconds
|
|
19
|
+
const D = workingDistance; // mm
|
|
20
|
+
// Enclosure correction factors
|
|
21
|
+
const enclosureCf = {
|
|
22
|
+
open: 1.0,
|
|
23
|
+
box: 1.5,
|
|
24
|
+
mcc: 1.5,
|
|
25
|
+
panel: 1.5,
|
|
26
|
+
cable: 1.0,
|
|
27
|
+
};
|
|
28
|
+
const Cf = enclosureCf[enclosureType] ?? 1.0;
|
|
29
|
+
// Distance exponents by voltage
|
|
30
|
+
const distanceExponent = V <= 1000 ? 1.641 : 0.973;
|
|
31
|
+
// Arcing current estimation (simplified IEEE 1584)
|
|
32
|
+
let Ia;
|
|
33
|
+
if (V <= 1000) {
|
|
34
|
+
// Low voltage
|
|
35
|
+
const logIa = 0.662 * Math.log10(Ibf) + 0.0966 * (V / 1000) + 0.000526 * G + 0.5588 * (V / 1000) * Math.log10(Ibf) - 0.00304 * G * Math.log10(Ibf);
|
|
36
|
+
Ia = Math.pow(10, logIa);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
// Medium voltage (> 1kV)
|
|
40
|
+
const logIa = 0.00402 + 0.983 * Math.log10(Ibf);
|
|
41
|
+
Ia = Math.pow(10, logIa);
|
|
42
|
+
}
|
|
43
|
+
// Normalized incident energy at 610mm, 0.2s (cal/cm²)
|
|
44
|
+
const K1 = enclosureType === 'open' ? -0.792 : -0.555;
|
|
45
|
+
const K2 = 0; // ungrounded/HRG → -0.113, but default grounded
|
|
46
|
+
const logEn = K1 + K2 + 1.081 * Math.log10(Ia) + 0.0011 * G;
|
|
47
|
+
const En = Math.pow(10, logEn);
|
|
48
|
+
// Incident energy at working distance
|
|
49
|
+
const E = Cf * En * (t / 0.2) * Math.pow(610, distanceExponent) / Math.pow(D, distanceExponent);
|
|
50
|
+
// Arc flash boundary (distance where E = 1.2 cal/cm²)
|
|
51
|
+
const Eb = 1.2; // cal/cm² threshold
|
|
52
|
+
const AFB = Math.pow((Cf * En * (t / 0.2) * Math.pow(610, distanceExponent)) / Eb, 1 / distanceExponent);
|
|
53
|
+
// PPE Category per NFPA 70E Table 130.7(C)(15)(a)
|
|
54
|
+
let ppeCategory;
|
|
55
|
+
if (E <= 1.2)
|
|
56
|
+
ppeCategory = 0;
|
|
57
|
+
else if (E <= 4)
|
|
58
|
+
ppeCategory = 1;
|
|
59
|
+
else if (E <= 8)
|
|
60
|
+
ppeCategory = 2;
|
|
61
|
+
else if (E <= 25)
|
|
62
|
+
ppeCategory = 3;
|
|
63
|
+
else
|
|
64
|
+
ppeCategory = 4;
|
|
65
|
+
// Hazard level
|
|
66
|
+
let hazardLevel;
|
|
67
|
+
if (E <= 1.2)
|
|
68
|
+
hazardLevel = 'safe';
|
|
69
|
+
else if (E <= 40)
|
|
70
|
+
hazardLevel = 'danger';
|
|
71
|
+
else
|
|
72
|
+
hazardLevel = 'extreme';
|
|
73
|
+
// Required PPE description
|
|
74
|
+
const ppeDescriptions = {
|
|
75
|
+
0: 'No PPE required (E ≤ 1.2 cal/cm²)',
|
|
76
|
+
1: 'Arc-rated shirt, pants, safety glasses (4 cal/cm²)',
|
|
77
|
+
2: 'Arc flash suit or arc-rated clothing (8 cal/cm²)',
|
|
78
|
+
3: 'Arc flash suit, gloves, face shield (25 cal/cm²)',
|
|
79
|
+
4: 'Arc flash suit rated > 25 cal/cm² (40 cal/cm²)',
|
|
80
|
+
};
|
|
81
|
+
return {
|
|
82
|
+
arcCurrent: roundTo(Ia, 2),
|
|
83
|
+
incidentEnergy: roundTo(E, 2),
|
|
84
|
+
arcFlashBoundary: roundTo(AFB, 0),
|
|
85
|
+
ppeCategory,
|
|
86
|
+
hazardLevel,
|
|
87
|
+
requiredPPE: ppeDescriptions[ppeCategory],
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=arcFlash.js.map
|
|
@@ -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":"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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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"}
|
package/dist/safety/index.d.ts
CHANGED
|
@@ -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
|
|
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;
|
|
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"}
|
package/dist/safety/index.js
CHANGED
|
@@ -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
|
package/dist/safety/index.js.map
CHANGED
|
@@ -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
|