uom/si/
pressure.rs

1//! Pressure (base unit pascal, kg · m⁻¹ · s⁻²).
2
3quantity! {
4    /// Pressure (base unit pascal, kg · m⁻¹ · s⁻²).
5    quantity: Pressure; "pressure";
6    /// Dimension of pressure, L⁻¹MT⁻² (base unit pascal, kg · m⁻¹ · s⁻²).
7    dimension: ISQ<
8        N1,     // length
9        P1,     // mass
10        N2,     // time
11        Z0,     // electric current
12        Z0,     // thermodynamic temperature
13        Z0,     // amount of substance
14        Z0>;    // luminous intensity
15    units {
16        @yottapascal: prefix!(yotta); "YPa", "yottapascal", "yottapascals";
17        @zettapascal: prefix!(zetta); "ZPa", "zettapascal", "zettapascals";
18        @exapascal: prefix!(exa); "EPa", "exapascal", "exapascals";
19        @petapascal: prefix!(peta); "PPa", "petapascal", "petapascals";
20        @terapascal: prefix!(tera); "TPa", "terapascal", "terapascals";
21        @gigapascal: prefix!(giga); "GPa", "gigapascal", "gigapascals";
22        @megapascal: prefix!(mega); "MPa", "megapascal", "megapascals";
23        @kilopascal: prefix!(kilo); "kPa", "kilopascal", "kilopascals";
24        @hectopascal: prefix!(hecto); "hPa", "hectopascal", "hectopascals";
25        @decapascal: prefix!(deca); "daPa", "decapascal", "decapascals";
26        /// Derived unit of pressure.
27        @pascal: prefix!(none); "Pa", "pascal", "pascals";
28        @decipascal: prefix!(deci); "dPa", "decipascal", "decipascals";
29        @centipascal: prefix!(centi); "cPa", "centipascal", "centipascals";
30        @millipascal: prefix!(milli); "mPa", "millipascal", "millipascals";
31        @micropascal: prefix!(micro); "µPa", "micropascal", "micropascals";
32        @nanopascal: prefix!(nano); "nPa", "nanopascal", "nanopascals";
33        @picopascal: prefix!(pico); "pPa", "picopascal", "picopascals";
34        @femtopascal: prefix!(femto); "fPa", "femtopascal", "femtopascals";
35        @attopascal: prefix!(atto); "aPa", "attopascal", "attopascals";
36        @zeptopascal: prefix!(zepto); "zPa", "zeptopascal", "zeptopascals";
37        @yoctopascal: prefix!(yocto); "yPa", "yoctopascal", "yoctopascals";
38
39        @atmosphere: 1.013_25_E5; "atm", "atmosphere", "atmospheres";
40        @atmosphere_technical: 9.806_65_E4; "at", "atmosphere (technical)",
41            "atmospheres (technical)";
42        @bar: 1.0_E5; "bar", "bar", "bar";
43        @centimeter_of_mercury_0: 1.333_22_E3; "cm Hg (0 °C)", "centimeter of mercury (0 °C)",
44            "centimeters of mercury (0 °C)";
45        @centimeter_of_mercury: 1.333_224_E3; "cm Hg", "centimeter of mercury",
46            "centimeters of mercury";
47        @centimeter_of_water_4: 9.806_38_E1; "cm H₂O (4 °C)", "centimeter of water (4 °C)",
48            "centimeters of water (4 °C)";
49        @centimeter_of_water: 9.806_65_E1; "cm H₂O", "centimeter of water", "centimeters of water";
50        @dyne_per_square_centimeter: 1.0_E-1; "dyn/cm²", "dyne per square centimeter",
51            "dynes per square centimeter";
52        @foot_of_mercury: 4.063_666_E4; "ft Hg", "foot of mercury", "feet of mercury";
53        @foot_of_water_39_2: 2.988_98_E3; "ft H₂O (39.2 °F)", "foot of water (39.2 °F)",
54            "feet of water (39.2 °F)";
55        @foot_of_water: 2.989_067_E3; "ft H₂O", "foot of water", "feet of water";
56        @gram_force_per_square_centimeter: 9.806_65_E1; "gf/cm²",
57            "gram-force per square centimeter", "grams-force per square centimeter";
58        @inch_of_mercury_32: 3.386_38_E3; "in Hg (32 °F)", "inch of mercury (32 °F)",
59            "inches of mercury (32 °F)";
60        @inch_of_mercury_60: 3.376_85_E3; "in Hg (60 °F)", "inch of mercury (60 °F)",
61            "inches of mercury (60 °F)";
62        @inch_of_mercury: 3.386_389_E3; "in Hg", "inch of mercury", "inches of mercury";
63        @inch_of_water_39_2: 2.490_82_E2; "in H₂O (39.2 °F)", "inch of water (39.2 °F)",
64            "inches of water (39.2 °F)";
65        @inch_of_water_60: 2.488_4_E2; "in H₂O (60 °F)", "inch of water (60 °F)",
66            "inches of water (60 °F)";
67        @inch_of_water: 2.490_889_E2; "in H₂O", "inch of water", "inches of water";
68        @newton_per_square_millimeter: 1.0_E6; "N/mm²", "newton per square millimeter",
69            "newtons per square millimeter";
70        @kilogram_force_per_square_centimeter: 9.806_65_E4; "kgf/cm²",
71            "kilogram-force per square centimeter", "kilograms-force per square centimeter";
72        @kilogram_force_per_square_meter: 9.806_65_E0; "kgf/m²",
73            "kilogram-force per square meter", "kilograms-force per square meter";
74        @kilogram_force_per_square_millimeter: 9.806_65_E6; "kgf/mm²",
75            "kilogram-force per square millimeter", "kilograms-force per square millimeter";
76        @kip_per_square_inch: 6.894_757_889_515_779_E6; "kip/in²", "kip per square inch",
77            "kips per square inch";
78        @millibar: 1.0_E2; "mbar", "millibar", "millibar";
79        @millimeter_of_mercury: 1.333_224_E2; "mm Hg", "millimeter of mercury",
80            "millimeters of mercury";
81        @millimeter_of_water: 9.806_65_E0; "mm H₂O", "millimeter of water",
82            "millimeters of water";
83        @millitorr: 1.333_224_E-1; "mTorr", "millitorr", "millitorr";
84        @poundal_per_square_foot: 1.488_164_434_662_202_5_E0; "pdl/ft²", "poundal per square foot",
85            "poundals per square foot";
86        @pound_force_per_square_foot: 4.788_026_312_163_735_6_E1; "lbf/ft²", "pound-force per square foot",
87            "pounds-force per square foot";
88        @pound_force_per_square_inch: 6.894_757_889_515_779_E3; "lbf/in²", "pound-force per square inch",
89            "pounds-force per square inch";
90        @psi: 6.894_757_E3; "psi", "pound-force per square inch",
91            "pounds-force per square inch";
92        @torr: 1.333_224_E2; "Torr", "torr", "torr";
93    }
94}
95
96#[cfg(test)]
97mod tests {
98    storage_types! {
99        use crate::num::One;
100        use crate::si::area as a;
101        use crate::si::force as f;
102        use crate::si::pressure as p;
103        use crate::si::quantities::*;
104        use crate::tests::Test;
105
106        #[test]
107        fn check_dimension() {
108            let _: Pressure<V> = Force::new::<f::newton>(V::one())
109                / Area::new::<a::square_meter>(V::one());
110        }
111
112        #[test]
113        fn check_units() {
114            test::<f::yottanewton, a::square_meter, p::yottapascal>();
115            test::<f::zettanewton, a::square_meter, p::zettapascal>();
116            test::<f::exanewton, a::square_meter, p::exapascal>();
117            test::<f::petanewton, a::square_meter, p::petapascal>();
118            test::<f::teranewton, a::square_meter, p::terapascal>();
119            test::<f::giganewton, a::square_meter, p::gigapascal>();
120            test::<f::meganewton, a::square_meter, p::megapascal>();
121            test::<f::kilonewton, a::square_meter, p::kilopascal>();
122            test::<f::hectonewton, a::square_meter, p::hectopascal>();
123            test::<f::decanewton, a::square_meter, p::decapascal>();
124            test::<f::newton, a::square_meter, p::pascal>();
125            test::<f::decinewton, a::square_meter, p::decipascal>();
126            test::<f::centinewton, a::square_meter, p::centipascal>();
127            test::<f::millinewton, a::square_meter, p::millipascal>();
128            test::<f::micronewton, a::square_meter, p::micropascal>();
129            test::<f::nanonewton, a::square_meter, p::nanopascal>();
130            test::<f::piconewton, a::square_meter, p::picopascal>();
131            test::<f::femtonewton, a::square_meter, p::femtopascal>();
132            test::<f::attonewton, a::square_meter, p::attopascal>();
133            test::<f::zeptonewton, a::square_meter, p::zeptopascal>();
134            test::<f::yoctonewton, a::square_meter, p::yoctopascal>();
135
136            test::<f::dyne, a::square_centimeter, p::dyne_per_square_centimeter>();
137            test::<f::newton, a::square_millimeter, p::newton_per_square_millimeter>();
138            test::<f::kilogram_force, a::square_millimeter, p::kilogram_force_per_square_millimeter>();
139            test::<f::kilogram_force, a::square_centimeter, p::kilogram_force_per_square_centimeter>();
140            test::<f::kilogram_force, a::square_meter, p::kilogram_force_per_square_meter>();
141            test::<f::kip, a::square_inch, p::kip_per_square_inch>();
142            test::<f::poundal, a::square_foot, p::poundal_per_square_foot>();
143            test::<f::pound_force, a::square_inch, p::pound_force_per_square_inch>();
144            test::<f::pound_force, a::square_foot, p::pound_force_per_square_foot>();
145
146            fn test<F: f::Conversion<V>, A: a::Conversion<V>, P: p::Conversion<V>>() {
147                Test::assert_approx_eq(&Pressure::new::<P>(V::one()),
148                    &(Force::new::<F>(V::one()) / Area::new::<A>(V::one())));
149            }
150        }
151    }
152}