46#ifndef HEP_SYSTEM_OF_UNITS_H
47#define HEP_SYSTEM_OF_UNITS_H
54 static constexpr double pi = 3.14159265358979323846;
55 static constexpr double twopi = 2*pi;
56 static constexpr double halfpi = pi/2;
57 static constexpr double pi2 = pi*pi;
62 static constexpr double millimeter = 1.;
63 static constexpr double millimeter2 = millimeter*millimeter;
64 static constexpr double millimeter3 = millimeter*millimeter*millimeter;
66 static constexpr double centimeter = 10.*millimeter;
67 static constexpr double centimeter2 = centimeter*centimeter;
68 static constexpr double centimeter3 = centimeter*centimeter*centimeter;
70 static constexpr double meter = 1000.*millimeter;
71 static constexpr double meter2 = meter*meter;
72 static constexpr double meter3 = meter*meter*meter;
74 static constexpr double kilometer = 1000.*meter;
75 static constexpr double kilometer2 = kilometer*kilometer;
76 static constexpr double kilometer3 = kilometer*kilometer*kilometer;
78 static constexpr double parsec = 3.0856775807e+16*meter;
80 static constexpr double micrometer = 1.e-6 *meter;
81 static constexpr double nanometer = 1.e-9 *meter;
82 static constexpr double angstrom = 1.e-10*meter;
83 static constexpr double fermi = 1.e-15*meter;
85 static constexpr double barn = 1.e-28*meter2;
86 static constexpr double millibarn = 1.e-3 *barn;
87 static constexpr double microbarn = 1.e-6 *barn;
88 static constexpr double nanobarn = 1.e-9 *barn;
89 static constexpr double picobarn = 1.e-12*barn;
92 static constexpr double nm = nanometer;
93 static constexpr double um = micrometer;
95 static constexpr double mm = millimeter;
96 static constexpr double mm2 = millimeter2;
97 static constexpr double mm3 = millimeter3;
99 static constexpr double cm = centimeter;
100 static constexpr double cm2 = centimeter2;
101 static constexpr double cm3 = centimeter3;
103 static constexpr double liter = 1.e+3*cm3;
104 static constexpr double L = liter;
105 static constexpr double dL = 1.e-1*liter;
106 static constexpr double cL = 1.e-2*liter;
107 static constexpr double mL = 1.e-3*liter;
109 static constexpr double m = meter;
110 static constexpr double m2 = meter2;
111 static constexpr double m3 = meter3;
113 static constexpr double km = kilometer;
114 static constexpr double km2 = kilometer2;
115 static constexpr double km3 = kilometer3;
117 static constexpr double pc = parsec;
122 static constexpr double radian = 1.;
123 static constexpr double milliradian = 1.e-3*radian;
124 static constexpr double degree = (pi/180.0)*radian;
126 static constexpr double steradian = 1.;
129 static constexpr double rad = radian;
130 static constexpr double mrad = milliradian;
131 static constexpr double sr = steradian;
132 static constexpr double deg = degree;
137 static constexpr double nanosecond = 1.;
138 static constexpr double second = 1.e+9 *nanosecond;
139 static constexpr double millisecond = 1.e-3 *second;
140 static constexpr double microsecond = 1.e-6 *second;
141 static constexpr double picosecond = 1.e-12*second;
143 static constexpr double hertz = 1./second;
144 static constexpr double kilohertz = 1.e+3*hertz;
145 static constexpr double megahertz = 1.e+6*hertz;
148 static constexpr double ns = nanosecond;
149 static constexpr double s = second;
150 static constexpr double ms = millisecond;
151 static constexpr double us = microsecond;
152 static constexpr double ps = picosecond;
157 static constexpr double eplus = 1. ;
158 static constexpr double e_SI = 1.602176634e-19;
159 static constexpr double coulomb = eplus/e_SI;
164 static constexpr double megaelectronvolt = 1. ;
165 static constexpr double electronvolt = 1.e-6*megaelectronvolt;
166 static constexpr double kiloelectronvolt = 1.e-3*megaelectronvolt;
167 static constexpr double gigaelectronvolt = 1.e+3*megaelectronvolt;
168 static constexpr double teraelectronvolt = 1.e+6*megaelectronvolt;
169 static constexpr double petaelectronvolt = 1.e+9*megaelectronvolt;
171 static constexpr double joule = electronvolt/e_SI;
174 static constexpr double MeV = megaelectronvolt;
175 static constexpr double eV = electronvolt;
176 static constexpr double keV = kiloelectronvolt;
177 static constexpr double GeV = gigaelectronvolt;
178 static constexpr double TeV = teraelectronvolt;
179 static constexpr double PeV = petaelectronvolt;
184 static constexpr double kilogram = joule*second*second/(meter*meter);
185 static constexpr double gram = 1.e-3*kilogram;
186 static constexpr double milligram = 1.e-3*gram;
189 static constexpr double kg = kilogram;
190 static constexpr double g = gram;
191 static constexpr double mg = milligram;
196 static constexpr double watt = joule/second;
201 static constexpr double newton = joule/meter;
206#define pascal hep_pascal
207 static constexpr double hep_pascal = newton/m2;
208 static constexpr double bar = 100000*
pascal;
209 static constexpr double atmosphere = 101325*
pascal;
214 static constexpr double ampere = coulomb/second;
215 static constexpr double milliampere = 1.e-3*ampere;
216 static constexpr double microampere = 1.e-6*ampere;
217 static constexpr double nanoampere = 1.e-9*ampere;
222 static constexpr double megavolt = megaelectronvolt/eplus;
223 static constexpr double kilovolt = 1.e-3*megavolt;
224 static constexpr double volt = 1.e-6*megavolt;
229 static constexpr double ohm = volt/ampere;
234 static constexpr double farad = coulomb/volt;
235 static constexpr double millifarad = 1.e-3*farad;
236 static constexpr double microfarad = 1.e-6*farad;
237 static constexpr double nanofarad = 1.e-9*farad;
238 static constexpr double picofarad = 1.e-12*farad;
243 static constexpr double weber = volt*second;
248 static constexpr double tesla = volt*second/meter2;
250 static constexpr double gauss = 1.e-4*tesla;
251 static constexpr double kilogauss = 1.e-1*tesla;
256 static constexpr double henry = weber/ampere;
261 static constexpr double kelvin = 1.;
266 static constexpr double mole = 1.;
271 static constexpr double becquerel = 1./second ;
272 static constexpr double curie = 3.7e+10 * becquerel;
273 static constexpr double kilobecquerel = 1.e+3*becquerel;
274 static constexpr double megabecquerel = 1.e+6*becquerel;
275 static constexpr double gigabecquerel = 1.e+9*becquerel;
276 static constexpr double millicurie = 1.e-3*curie;
277 static constexpr double microcurie = 1.e-6*curie;
278 static constexpr double Bq = becquerel;
279 static constexpr double kBq = kilobecquerel;
280 static constexpr double MBq = megabecquerel;
281 static constexpr double GBq = gigabecquerel;
282 static constexpr double Ci = curie;
283 static constexpr double mCi = millicurie;
284 static constexpr double uCi = microcurie;
289 static constexpr double gray = joule/kilogram ;
290 static constexpr double kilogray = 1.e+3*gray;
291 static constexpr double milligray = 1.e-3*gray;
292 static constexpr double microgray = 1.e-6*gray;
297 static constexpr double candela = 1.;
302 static constexpr double lumen = candela*steradian;
307 static constexpr double lux = lumen/meter2;
312 static constexpr double perCent = 0.01 ;
313 static constexpr double perThousand = 0.001;
314 static constexpr double perMillion = 0.000001;