20 #ifndef ANTKEEPER_PHYSICS_GAS_OZONE_HPP
21 #define ANTKEEPER_PHYSICS_GAS_OZONE_HPP
100 6.88123014503947e-26,
101 9.01478526179051e-26,
102 1.38671804168295e-25,
103 7.28648586727799e-26,
106 3.22298756116943e-26,
107 2.52476541455397e-26,
108 2.96595291121762e-26,
109 2.10981495904366e-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,
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,
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,
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,
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,
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,
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,
221 4.07643587970195e-26,
222 3.84067732691303e-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,
236 6.10573296817762e-26,
237 6.83025566941932e-26,
238 7.51469261186479e-26,
239 8.08197962688924e-26,
240 8.44082645474868e-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,
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,
271 1.56495784865383e-25,
272 1.60012763627009e-25,
273 1.63952588489707e-25,
274 1.67232066912218e-25,
275 1.70167894480834e-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,
308 3.31405330400124e-25,
309 3.34398013095565e-25,
310 3.38005272562664e-25,
311 3.41218557614901e-25,
312 3.45555599852459e-25,
314 3.55984911371566e-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,
328 4.60931329475278e-25,
329 4.66173637960526e-25,
330 4.70665064920011e-25,
331 4.74051362440113e-25,
332 4.75812011867871e-25,
334 4.73747927545327e-25,
335 4.71027119364443e-25,
336 4.66860282624977e-25,
338 4.57997871538082e-25,
339 4.53548773884213e-25,
340 4.49607272653461e-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,
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,
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,
424 1.86388414183128e-25,
425 1.82241187234978e-25,
426 1.78160123951627e-25,
427 1.74179167768809e-25,
428 1.70080577609513e-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,
441 1.30492894377563e-25,
442 1.28681831161393e-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,
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,
469 7.12771524608971e-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,
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,
534 2.94507453632992e-26,
535 3.05247618840877e-26,
553 if (i < 280 || j > 780)
559 return math::lerp<T>(x, y,
wavelength -
static_cast<T
>(i));
575 return cross_section * density;
constexpr T gas
Molar gas constant (R), in joule per kelvin per mole.
constexpr T cross_section_293k(T wavelength)
Returns the cross section of ozone at temperature 293k and a given wavelength in the visible spectrum...
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...
T absorption(T cross_section, T density)
Calculates an ozone absorption coefficient (wavelength-dependent).
T wavelength(T t, T lambda, T c=constants::speed_of_light< T >)
Wavelength variant of Planck's law.