Antkeeper  0.0.1
ozone.hpp
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2023 Christopher J. Howard
3  *
4  * This file is part of Antkeeper source code.
5  *
6  * Antkeeper source code is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * Antkeeper source code is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Antkeeper source code. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
20 #ifndef ANTKEEPER_PHYSICS_GAS_OZONE_HPP
21 #define ANTKEEPER_PHYSICS_GAS_OZONE_HPP
22 
24 
25 namespace physics {
26 namespace gas {
27 
29 namespace ozone {
30 
36 constexpr double cross_sections_280nm_780nm_293k[781 - 280] =
37 {
38  4.08020162329358e-22,
39  3.71300005805609e-22,
40  3.33329613050011e-22,
41  3.08830771169272e-22,
42  2.7952452827933e-22,
43  2.54507006594824e-22,
44  2.31059906830132e-22,
45  2.06098663896454e-22,
46  1.77641837487505e-22,
47  1.60649162987982e-22,
48  1.43573256268989e-22,
49  1.28028940869356e-22,
50  1.11222715354512e-22,
51  1.00812840644175e-22,
52  8.62757275283743e-23,
53  7.74492225274189e-23,
54  6.74998572150431e-23,
55  5.92584261096169e-23,
56  5.09573191001311e-23,
57  4.58263122360992e-23,
58  3.90608822487099e-23,
59  3.4712884682176e-23,
60  3.05004947986011e-23,
61  2.61948471583207e-23,
62  2.35950204633063e-23,
63  2.01696279467763e-23,
64  1.77716671613151e-23,
65  1.57884103804348e-23,
66  1.35332466460157e-23,
67  1.23148992566335e-23,
68  1.00674476685553e-23,
69  9.14966132477946e-24,
70  8.0373280016411e-24,
71  6.82346538467894e-24,
72  6.42747947320284e-24,
73  5.12300259416845e-24,
74  4.77060350699273e-24,
75  4.0011431423959e-24,
76  3.72184265884461e-24,
77  2.71828160861414e-24,
78  3.14980819763314e-24,
79  2.01180905161078e-24,
80  2.23741500460792e-24,
81  2.04586872483057e-24,
82  1.14774957440809e-24,
83  1.7873766001915e-24,
84  1.14326155695545e-24,
85  7.61393733215954e-25,
86  1.30841854222986e-24,
87  6.50013011248201e-25,
88  4.47253301018733e-25,
89  7.22254319278391e-25,
90  4.42923420258652e-25,
91  3.22168537281097e-25,
92  5.60700006481047e-25,
93  2.51991724359347e-25,
94  1.64975530971913e-25,
95  2.69863618345909e-25,
96  2.2962216595934e-25,
97  1.2768604186372e-25,
98  1.6428080690911e-25,
99  1.15252741016694e-25,
100  6.88123014503947e-26,
101  9.01478526179051e-26,
102  1.38671804168295e-25,
103  7.28648586727799e-26,
104  6.3468766437083e-26,
105  4.1705109317344e-26,
106  3.22298756116943e-26,
107  2.52476541455397e-26,
108  2.96595291121762e-26,
109  2.10981495904366e-26,
110  3.0696184107227e-26,
111  2.38627682184272e-26,
112  1.35645160962203e-26,
113  1.14737436955784e-26,
114  1.00293019429341e-26,
115  1.42699666872085e-26,
116  1.03892014298915e-26,
117  7.46029500400895e-27,
118  7.86729405487508e-27,
119  6.49493671023213e-27,
120  3.90586420068501e-27,
121  3.3969327080211e-27,
122  2.69156849765275e-27,
123  4.89998022220222e-27,
124  4.18363151355665e-27,
125  2.41505691668684e-27,
126  1.52926807176976e-27,
127  1.74010836686791e-27,
128  1.43997701486263e-27,
129  1.61611242687813e-27,
130  1.09444991940235e-27,
131  8.68337506495441e-28,
132  1.28660044051837e-27,
133  1.07534571825705e-27,
134  7.59223090396554e-28,
135  6.75850905941831e-28,
136  6.05594086115429e-28,
137  7.40387066310015e-28,
138  6.04999720618854e-28,
139  5.17923583652293e-28,
140  4.0858846895433e-28,
141  6.47448369216067e-28,
142  5.29992493931534e-28,
143  5.63128808710364e-28,
144  4.17695119955099e-28,
145  5.15330384762416e-28,
146  5.25185850011986e-28,
147  6.17618171380047e-28,
148  6.37119303086457e-28,
149  6.8496876006444e-28,
150  5.9229625229341e-28,
151  5.99998795876176e-28,
152  7.06136396740756e-28,
153  9.93040926727483e-28,
154  1.03668944015898e-27,
155  9.60158757124091e-28,
156  9.00247643555494e-28,
157  1.01801330597124e-27,
158  1.0893103182854e-27,
159  1.30096252080506e-27,
160  1.42018105948242e-27,
161  1.53477820553937e-27,
162  1.60452920542724e-27,
163  1.45613806382105e-27,
164  1.63671034304492e-27,
165  1.88680147053984e-27,
166  2.26659932677371e-27,
167  2.57113808884621e-27,
168  2.73584069155576e-27,
169  2.84524835939992e-27,
170  2.65294565386989e-27,
171  2.52007318042733e-27,
172  2.56347774832346e-27,
173  2.73272493525925e-27,
174  3.21972108535573e-27,
175  3.64879308272645e-27,
176  3.86875166703077e-27,
177  3.77657059174972e-27,
178  3.67917967079418e-27,
179  3.84603321414093e-27,
180  4.47110813921024e-27,
181  5.19879478264214e-27,
182  6.13707395634462e-27,
183  6.88229484256763e-27,
184  7.11935416561536e-27,
185  7.15812015493665e-27,
186  6.67142397990209e-27,
187  6.35218112458219e-27,
188  6.34510826220203e-27,
189  6.90321809802859e-27,
190  7.82871587803871e-27,
191  8.52938477234511e-27,
192  8.74335964163491e-27,
193  8.6718822639457e-27,
194  8.59495406258221e-27,
195  8.90719500501358e-27,
196  9.90176156668504e-27,
197  1.14857395824068e-26,
198  1.36017282525383e-26,
199  1.53232356175871e-26,
200  1.75024000506424e-26,
201  1.8179765858316e-26,
202  1.80631911188605e-26,
203  1.70102948254892e-26,
204  1.56536231218255e-26,
205  1.51141962474665e-26,
206  1.57847025841346e-26,
207  1.72161452840856e-26,
208  1.90909798194127e-26,
209  1.96774621921165e-26,
210  1.99812678813396e-26,
211  1.96900102296014e-26,
212  1.95126617395258e-26,
213  2.06408915381352e-26,
214  2.28866836725858e-26,
215  2.57662977048169e-26,
216  2.96637551360212e-26,
217  3.34197426701549e-26,
218  3.73735792971477e-26,
219  4.03453827718193e-26,
220  4.1291323324037e-26,
221  4.07643587970195e-26,
222  3.84067732691303e-26,
223  3.6271000065179e-26,
224  3.50502931147362e-26,
225  3.48851626868318e-26,
226  3.73778737646723e-26,
227  3.97091132121154e-26,
228  4.21773978585713e-26,
229  4.21620738550362e-26,
230  4.22087900183437e-26,
231  4.27973060694892e-26,
232  4.36010682588909e-26,
233  4.60584575680881e-26,
234  4.91428506793045e-26,
235  5.4918846417406e-26,
236  6.10573296817762e-26,
237  6.83025566941932e-26,
238  7.51469261186479e-26,
239  8.08197962688924e-26,
240  8.44082645474868e-26,
241  8.4843465766735e-26,
242  8.4126775729461e-26,
243  8.14411830190209e-26,
244  7.83636723569755e-26,
245  7.60974711104334e-26,
246  7.57877917471603e-26,
247  7.77887132347866e-26,
248  8.07522339055262e-26,
249  8.32310316258138e-26,
250  8.59015818152486e-26,
251  8.67834106505007e-26,
252  8.72244226406716e-26,
253  8.84734167611993e-26,
254  9.0711580597939e-26,
255  9.51778147590566e-26,
256  1.01490385328969e-25,
257  1.09448341447976e-25,
258  1.18257044868557e-25,
259  1.28105938778111e-25,
260  1.37732704252934e-25,
261  1.47491161151436e-25,
262  1.55090701035304e-25,
263  1.60575752538508e-25,
264  1.62886093543744e-25,
265  1.62802718439262e-25,
266  1.60288510229631e-25,
267  1.57216917046401e-25,
268  1.54475957021763e-25,
269  1.534341089264e-25,
270  1.5409967492982e-25,
271  1.56495784865383e-25,
272  1.60012763627009e-25,
273  1.63952588489707e-25,
274  1.67232066912218e-25,
275  1.70167894480834e-25,
276  1.7335194060265e-25,
277  1.7602731663686e-25,
278  1.79953556347172e-25,
279  1.84084607422109e-25,
280  1.89999243847493e-25,
281  1.97490644310087e-25,
282  2.05279021301286e-25,
283  2.14427839223598e-25,
284  2.24098369182092e-25,
285  2.34362490982003e-25,
286  2.44138366650567e-25,
287  2.53826212075759e-25,
288  2.62577562731292e-25,
289  2.70621837640467e-25,
290  2.76622780914432e-25,
291  2.80661519633223e-25,
292  2.82737499370866e-25,
293  2.82968166962191e-25,
294  2.82659484597549e-25,
295  2.81717325255129e-25,
296  2.82197485088881e-25,
297  2.84600833360439e-25,
298  2.88048754046166e-25,
299  2.92686210579676e-25,
300  2.98551267943544e-25,
301  3.04464034622896e-25,
302  3.09724266051229e-25,
303  3.14551726028915e-25,
304  3.18670379817661e-25,
305  3.22330249380314e-25,
306  3.25463784914917e-25,
307  3.2854797958699e-25,
308  3.31405330400124e-25,
309  3.34398013095565e-25,
310  3.38005272562664e-25,
311  3.41218557614901e-25,
312  3.45555599852459e-25,
313  3.5043277615423e-25,
314  3.55984911371566e-25,
315  3.6264721972979e-25,
316  3.70647322984569e-25,
317  3.79188179306458e-25,
318  3.88981479760571e-25,
319  3.98973596432023e-25,
320  4.08527421216539e-25,
321  4.17464990288797e-25,
322  4.25462181228461e-25,
323  4.32317712812093e-25,
324  4.38401384845366e-25,
325  4.44216978945654e-25,
326  4.49508440820886e-25,
327  4.5516564927479e-25,
328  4.60931329475278e-25,
329  4.66173637960526e-25,
330  4.70665064920011e-25,
331  4.74051362440113e-25,
332  4.75812011867871e-25,
333  4.7570031038151e-25,
334  4.73747927545327e-25,
335  4.71027119364443e-25,
336  4.66860282624977e-25,
337  4.6288533265784e-25,
338  4.57997871538082e-25,
339  4.53548773884213e-25,
340  4.49607272653461e-25,
341  4.4568818824566e-25,
342  4.42881930827398e-25,
343  4.40157474149992e-25,
344  4.38677564524713e-25,
345  4.37182142194489e-25,
346  4.37104565551326e-25,
347  4.37919711899623e-25,
348  4.39683352146027e-25,
349  4.42484514000691e-25,
350  4.47212673326828e-25,
351  4.53157968174371e-25,
352  4.60815452736499e-25,
353  4.69376508835705e-25,
354  4.78054316070552e-25,
355  4.87030272266768e-25,
356  4.95220907227656e-25,
357  5.02898332230558e-25,
358  5.09027352924287e-25,
359  5.13210890748271e-25,
360  5.15374454317407e-25,
361  5.15075653533686e-25,
362  5.13171378996911e-25,
363  5.09303097809138e-25,
364  5.03697164998998e-25,
365  4.97218676726656e-25,
366  4.89461758141549e-25,
367  4.80937594526597e-25,
368  4.72371968798565e-25,
369  4.63859449875443e-25,
370  4.55132403268817e-25,
371  4.46787830232533e-25,
372  4.38816245012175e-25,
373  4.31406743009557e-25,
374  4.24483372714822e-25,
375  4.17474755876221e-25,
376  4.11305082072427e-25,
377  4.05554427636835e-25,
378  4.0030863998631e-25,
379  3.95393149188544e-25,
380  3.90576318741963e-25,
381  3.86085282288514e-25,
382  3.81425489414328e-25,
383  3.76584427585746e-25,
384  3.71837025816073e-25,
385  3.66911165810168e-25,
386  3.61941817240908e-25,
387  3.56533744970388e-25,
388  3.51159798289664e-25,
389  3.46140984744989e-25,
390  3.41173597486151e-25,
391  3.36073006491665e-25,
392  3.30753716054224e-25,
393  3.25252799457143e-25,
394  3.19530424634748e-25,
395  3.13651908668849e-25,
396  3.07841534489121e-25,
397  3.01880275032991e-25,
398  2.95965464815758e-25,
399  2.90194743931008e-25,
400  2.84696394478385e-25,
401  2.79488978476361e-25,
402  2.74800171431914e-25,
403  2.70053589638645e-25,
404  2.65588371839819e-25,
405  2.6091795190684e-25,
406  2.56708069403319e-25,
407  2.52375403058723e-25,
408  2.48382556862202e-25,
409  2.44458617524673e-25,
410  2.40594587498642e-25,
411  2.36627105488787e-25,
412  2.32528309566254e-25,
413  2.28436716651676e-25,
414  2.24424313328781e-25,
415  2.20515093141858e-25,
416  2.16647251017334e-25,
417  2.12914125517962e-25,
418  2.09073684368918e-25,
419  2.05335637747553e-25,
420  2.01912040845123e-25,
421  1.98301051757051e-25,
422  1.94465669006103e-25,
423  1.9057000954812e-25,
424  1.86388414183128e-25,
425  1.82241187234978e-25,
426  1.78160123951627e-25,
427  1.74179167768809e-25,
428  1.70080577609513e-25,
429  1.6615348247565e-25,
430  1.62305192083274e-25,
431  1.58738563014106e-25,
432  1.55171430112041e-25,
433  1.51949383874537e-25,
434  1.48607225456117e-25,
435  1.45360366466218e-25,
436  1.42252183610792e-25,
437  1.39462753606039e-25,
438  1.36820899679147e-25,
439  1.34377836247288e-25,
440  1.3233906891166e-25,
441  1.30492894377563e-25,
442  1.28681831161393e-25,
443  1.2663174075999e-25,
444  1.2420229295933e-25,
445  1.21412305909061e-25,
446  1.18502869999655e-25,
447  1.15382448376731e-25,
448  1.12540171803974e-25,
449  1.09558453899584e-25,
450  1.06672010609186e-25,
451  1.03896476876362e-25,
452  1.01172047316729e-25,
453  9.84602582159865e-26,
454  9.58059205575365e-26,
455  9.33099533469407e-26,
456  9.08936155224937e-26,
457  8.8491955813636e-26,
458  8.64349280941688e-26,
459  8.44550335501804e-26,
460  8.25653238461191e-26,
461  8.08238949115334e-26,
462  7.94009406468206e-26,
463  7.80797137891831e-26,
464  7.67364989571709e-26,
465  7.54965718671858e-26,
466  7.43779079827743e-26,
467  7.31964666857758e-26,
468  7.2232944312979e-26,
469  7.12771524608971e-26,
470  7.0510155861502e-26,
471  6.99911412369698e-26,
472  6.96383131319201e-26,
473  6.92914966812787e-26,
474  6.85928437919081e-26,
475  6.74428511228458e-26,
476  6.59224480420957e-26,
477  6.38840433633278e-26,
478  6.15855599572905e-26,
479  5.95772659493798e-26,
480  5.76494205198861e-26,
481  5.60397496087846e-26,
482  5.46017309852595e-26,
483  5.32285644696103e-26,
484  5.22365816180628e-26,
485  5.07899578121548e-26,
486  4.93592723237266e-26,
487  4.79667132541204e-26,
488  4.68132550170927e-26,
489  4.56404612656666e-26,
490  4.48276475068268e-26,
491  4.40173864033052e-26,
492  4.35417448301629e-26,
493  4.30681941574933e-26,
494  4.28871372503407e-26,
495  4.24230311436515e-26,
496  4.22301315090103e-26,
497  4.19685390394596e-26,
498  4.18917236558952e-26,
499  4.17687017488352e-26,
500  4.22019512128238e-26,
501  4.2557462015274e-26,
502  4.31172890769302e-26,
503  4.36741466155527e-26,
504  4.41740590419353e-26,
505  4.44874945269751e-26,
506  4.42029497925774e-26,
507  4.34317624813875e-26,
508  4.21853858585038e-26,
509  4.01907542789597e-26,
510  3.80281792816081e-26,
511  3.60902775684479e-26,
512  3.41921953398109e-26,
513  3.25291539681547e-26,
514  3.10743399295997e-26,
515  2.99157340432027e-26,
516  2.89660087626517e-26,
517  2.82185391364051e-26,
518  2.76872520775773e-26,
519  2.72983807771732e-26,
520  2.65963957090044e-26,
521  2.62737083974039e-26,
522  2.56625477748644e-26,
523  2.53980768456023e-26,
524  2.49759827680602e-26,
525  2.47017705195044e-26,
526  2.47697548770545e-26,
527  2.46973660414457e-26,
528  2.47714280793403e-26,
529  2.50190654239581e-26,
530  2.56196471101148e-26,
531  2.64525680175745e-26,
532  2.72275203692747e-26,
533  2.826728922873e-26,
534  2.94507453632992e-26,
535  3.05247618840877e-26,
536  3.1005889405393e-26,
537  3.1508637563266e-26,
538  3.13148927506362e-26
539 };
540 
547 template <class T>
549 {
550  int i = static_cast<int>(wavelength);
551  int j = static_cast<int>(wavelength + T(1));
552 
553  if (i < 280 || j > 780)
554  return T(0);
555 
556  const T x = static_cast<T>(cross_sections_280nm_780nm_293k[i - 280]);
557  const T y = static_cast<T>(cross_sections_280nm_780nm_293k[j - 280]);
558 
559  return math::lerp<T>(x, y, wavelength - static_cast<T>(i));
560 }
561 
572 template <class T>
573 T absorption(T cross_section, T density)
574 {
575  return cross_section * density;
576 }
577 
578 } // namespace ozone
579 
580 } // namespace gas
581 } // namespace physics
582 
583 #endif // ANTKEEPER_PHYSICS_GAS_OZONE_HPP
constexpr T gas
Molar gas constant (R), in joule per kelvin per mole.
Definition: constants.hpp:50
constexpr T cross_section_293k(T wavelength)
Returns the cross section of ozone at temperature 293k and a given wavelength in the visible spectrum...
Definition: ozone.hpp:548
constexpr double cross_sections_280nm_780nm_293k[781 - 280]
Cross sections of ozone from wavelength 280nm to 780nm, in increments of 1nm, at a temperature of 293...
Definition: ozone.hpp:36
T absorption(T cross_section, T density)
Calculates an ozone absorption coefficient (wavelength-dependent).
Definition: ozone.hpp:573
T wavelength(T t, T lambda, T c=constants::speed_of_light< T >)
Wavelength variant of Planck's law.
Definition: planck.hpp:43
Physics.
Definition: constants.hpp:23