174#include <gsl/gsl_fft_complex.h>
175#include <gsl/gsl_math.h>
176#include <gsl/gsl_randist.h>
177#include <gsl/gsl_rng.h>
178#include <gsl/gsl_sort.h>
179#include <gsl/gsl_spline.h>
180#include <gsl/gsl_statistics.h>
196#include <netcdf_par.h>
208#include "thrustsort.h"
220#include "SZ3c/sz3c.h"
224#include "cmultiscale.h"
228#include "chem_Parameters.h"
229#include "chem_Global.h"
230#include "chem_Sparse.h"
237#define codes_handle void*
246#define AVO 6.02214076e23
256#define EPS (MH2O / MA)
281#define KB 1.3806504e-23
306#define RA (1e3 * RI / MA)
415#define DD_EX_GLOB (EX * 16)
420#define DD_EY_GLOB (EY * 16)
447#define ALLOC(ptr, type, n) \
448 if(acc_get_num_devices(acc_device_nvidia) <= 0) \
449 ERRMSG("Not running on a GPU device!"); \
450 if((ptr=calloc((size_t)(n), sizeof(type)))==NULL) \
451 ERRMSG("Out of memory!");
453#define ALLOC(ptr, type, n) \
454 if((ptr=calloc((size_t)(n), sizeof(type)))==NULL) \
455 ERRMSG("Out of memory!");
476#define ARRAY_2D(ix, iy, ny) \
495#define ARRAY_3D(ix, iy, ny, iz, nz) \
496 (((ix)*(ny) + (iy)) * (nz) + (iz))
520#define ARRHENIUS(a, b, t) \
521 ((a) * exp( -(b) / (t)))
542#define CLAMP(v, lo, hi) \
543 (((v) < (lo)) ? (lo) : (((v) > (hi)) ? (hi) : (v)))
566#define DEG2DX(dlon, lat) \
567 (RE * DEG2RAD(dlon) * cos(DEG2RAD(lat)))
587#define DEG2DY(dlat) \
604#define DEG2RAD(deg) \
605 ((deg) * (M_PI / 180.0))
629#define DP2DZ(dp, p) \
651#define DX2DEG(dx, lat) \
652 (((lat) < -89.999 || (lat) > 89.999) ? 0 \
653 : (dx) * 180. / (M_PI * RE * cos(DEG2RAD(lat))))
670 ((dy) * 180. / (M_PI * RE))
688#define DZ2DP(dz, p) \
721 ((a[0]-b[0])*(a[0]-b[0])+(a[1]-b[1])*(a[1]-b[1])+(a[2]-b[2])*(a[2]-b[2]))
737 (a[0]*b[0]+a[1]*b[1]+a[2]*b[2])
751 int ecc_result=(cmd); \
753 ERRMSG("ECCODES error: %s", codes_get_error_message(ecc_result)); \
769#define ECC_READ_2D(variable, target, scaling_factor, found_flag) { \
770 if(strcmp(short_name, variable) == 0) { \
771 for (int ix = 0; ix < met->nx; ix++) \
772 for (int iy = 0; iy < met->ny; iy++) \
773 target[ix][iy] = (float)(values[iy * met->nx + ix] * scaling_factor); \
792#define ECC_READ_3D(variable, level, target, scaling_factor, found_flag) { \
793 if(strcmp(short_name, variable) == 0) { \
794 for (int ix = 0; ix < met->nx; ix++) \
795 for (int iy = 0; iy < met->ny; iy++) \
796 target[ix][iy][level] = (float) (values[iy * met->nx + ix] * scaling_factor); \
818 ((x) - (int) ((x) / (y)) * (y))
835#define FREAD(ptr, type, size, in) { \
836 if(fread(ptr, sizeof(type), size, in)!=size) \
837 ERRMSG("Error while reading!"); \
855#define FWRITE(ptr, type, size, out) { \
856 if(fwrite(ptr, sizeof(type), size, out)!=size) \
857 ERRMSG("Error while writing!"); \
871 double cw[4] = {0.0, 0.0, 0.0, 0.0}; int ci[3] = {0, 0, 0};
884#define INTPOL_2D(var, init) \
885 intpol_met_time_2d(met0, met0->var, met1, met1->var, \
886 atm->time[ip], atm->lon[ip], atm->lat[ip], \
901#define INTPOL_3D(var, init) \
902 intpol_met_time_3d(met0, met0->var, met1, met1->var, \
903 atm->time[ip], atm->p[ip], \
904 atm->lon[ip], atm->lat[ip], \
920#define INTPOL_SPACE_ALL(p, lon, lat) { \
921 intpol_met_space_3d(met, met->z, p, lon, lat, &z, ci, cw, 1); \
922 intpol_met_space_3d(met, met->t, p, lon, lat, &t, ci, cw, 0); \
923 intpol_met_space_3d(met, met->u, p, lon, lat, &u, ci, cw, 0); \
924 intpol_met_space_3d(met, met->v, p, lon, lat, &v, ci, cw, 0); \
925 intpol_met_space_3d(met, met->w, p, lon, lat, &w, ci, cw, 0); \
926 intpol_met_space_3d(met, met->pv, p, lon, lat, &pv, ci, cw, 0); \
927 intpol_met_space_3d(met, met->h2o, p, lon, lat, &h2o, ci, cw, 0); \
928 intpol_met_space_3d(met, met->o3, p, lon, lat, &o3, ci, cw, 0); \
929 intpol_met_space_3d(met, met->lwc, p, lon, lat, &lwc, ci, cw, 0); \
930 intpol_met_space_3d(met, met->rwc, p, lon, lat, &rwc, ci, cw, 0); \
931 intpol_met_space_3d(met, met->iwc, p, lon, lat, &iwc, ci, cw, 0); \
932 intpol_met_space_3d(met, met->swc, p, lon, lat, &swc, ci, cw, 0); \
933 intpol_met_space_3d(met, met->cc, p, lon, lat, &cc, ci, cw, 0); \
934 intpol_met_space_2d(met, met->ps, lon, lat, &ps, ci, cw, 0); \
935 intpol_met_space_2d(met, met->ts, lon, lat, &ts, ci, cw, 0); \
936 intpol_met_space_2d(met, met->zs, lon, lat, &zs, ci, cw, 0); \
937 intpol_met_space_2d(met, met->us, lon, lat, &us, ci, cw, 0); \
938 intpol_met_space_2d(met, met->vs, lon, lat, &vs, ci, cw, 0); \
939 intpol_met_space_2d(met, met->ess, ess, lat, &ess, ci, cw, 0); \
940 intpol_met_space_2d(met, met->nss, nss, lat, &nss, ci, cw, 0); \
941 intpol_met_space_2d(met, met->shf, shf, lat, &shf, ci, cw, 0); \
942 intpol_met_space_2d(met, met->lsm, lon, lat, &lsm, ci, cw, 0); \
943 intpol_met_space_2d(met, met->sst, lon, lat, &sst, ci, cw, 0); \
944 intpol_met_space_2d(met, met->pbl, lon, lat, &pbl, ci, cw, 0); \
945 intpol_met_space_2d(met, met->pt, lon, lat, &pt, ci, cw, 0); \
946 intpol_met_space_2d(met, met->tt, lon, lat, &tt, ci, cw, 0); \
947 intpol_met_space_2d(met, met->zt, lon, lat, &zt, ci, cw, 0); \
948 intpol_met_space_2d(met, met->h2ot, lon, lat, &h2ot, ci, cw, 0); \
949 intpol_met_space_2d(met, met->pct, lon, lat, &pct, ci, cw, 0); \
950 intpol_met_space_2d(met, met->pcb, lon, lat, &pcb, ci, cw, 0); \
951 intpol_met_space_2d(met, met->cl, lon, lat, &cl, ci, cw, 0); \
952 intpol_met_space_2d(met, met->plcl, lon, lat, &plcl, ci, cw, 0); \
953 intpol_met_space_2d(met, met->plfc, lon, lat, &plfc, ci, cw, 0); \
954 intpol_met_space_2d(met, met->pel, lon, lat, &pel, ci, cw, 0); \
955 intpol_met_space_2d(met, met->cape, lon, lat, &cape, ci, cw, 0); \
956 intpol_met_space_2d(met, met->cin, lon, lat, &cin, ci, cw, 0); \
957 intpol_met_space_2d(met, met->o3c, lon, lat, &o3c, ci, cw, 0); \
974#define INTPOL_TIME_ALL(time, p, lon, lat) { \
975 intpol_met_time_3d(met0, met0->z, met1, met1->z, time, p, lon, lat, &z, ci, cw, 1); \
976 intpol_met_time_3d(met0, met0->t, met1, met1->t, time, p, lon, lat, &t, ci, cw, 0); \
977 intpol_met_time_3d(met0, met0->u, met1, met1->u, time, p, lon, lat, &u, ci, cw, 0); \
978 intpol_met_time_3d(met0, met0->v, met1, met1->v, time, p, lon, lat, &v, ci, cw, 0); \
979 intpol_met_time_3d(met0, met0->w, met1, met1->w, time, p, lon, lat, &w, ci, cw, 0); \
980 intpol_met_time_3d(met0, met0->pv, met1, met1->pv, time, p, lon, lat, &pv, ci, cw, 0); \
981 intpol_met_time_3d(met0, met0->h2o, met1, met1->h2o, time, p, lon, lat, &h2o, ci, cw, 0); \
982 intpol_met_time_3d(met0, met0->o3, met1, met1->o3, time, p, lon, lat, &o3, ci, cw, 0); \
983 intpol_met_time_3d(met0, met0->lwc, met1, met1->lwc, time, p, lon, lat, &lwc, ci, cw, 0); \
984 intpol_met_time_3d(met0, met0->rwc, met1, met1->rwc, time, p, lon, lat, &rwc, ci, cw, 0); \
985 intpol_met_time_3d(met0, met0->iwc, met1, met1->iwc, time, p, lon, lat, &iwc, ci, cw, 0); \
986 intpol_met_time_3d(met0, met0->swc, met1, met1->swc, time, p, lon, lat, &swc, ci, cw, 0); \
987 intpol_met_time_3d(met0, met0->cc, met1, met1->cc, time, p, lon, lat, &cc, ci, cw, 0); \
988 intpol_met_time_2d(met0, met0->ps, met1, met1->ps, time, lon, lat, &ps, ci, cw, 0); \
989 intpol_met_time_2d(met0, met0->ts, met1, met1->ts, time, lon, lat, &ts, ci, cw, 0); \
990 intpol_met_time_2d(met0, met0->zs, met1, met1->zs, time, lon, lat, &zs, ci, cw, 0); \
991 intpol_met_time_2d(met0, met0->us, met1, met1->us, time, lon, lat, &us, ci, cw, 0); \
992 intpol_met_time_2d(met0, met0->vs, met1, met1->vs, time, lon, lat, &vs, ci, cw, 0); \
993 intpol_met_time_2d(met0, met0->ess, met1, met1->ess, time, lon, lat, &ess, ci, cw, 0); \
994 intpol_met_time_2d(met0, met0->nss, met1, met1->nss, time, lon, lat, &nss, ci, cw, 0); \
995 intpol_met_time_2d(met0, met0->shf, met1, met1->shf, time, lon, lat, &shf, ci, cw, 0); \
996 intpol_met_time_2d(met0, met0->lsm, met1, met1->lsm, time, lon, lat, &lsm, ci, cw, 0); \
997 intpol_met_time_2d(met0, met0->sst, met1, met1->sst, time, lon, lat, &sst, ci, cw, 0); \
998 intpol_met_time_2d(met0, met0->pbl, met1, met1->pbl, time, lon, lat, &pbl, ci, cw, 0); \
999 intpol_met_time_2d(met0, met0->pt, met1, met1->pt, time, lon, lat, &pt, ci, cw, 0); \
1000 intpol_met_time_2d(met0, met0->tt, met1, met1->tt, time, lon, lat, &tt, ci, cw, 0); \
1001 intpol_met_time_2d(met0, met0->zt, met1, met1->zt, time, lon, lat, &zt, ci, cw, 0); \
1002 intpol_met_time_2d(met0, met0->h2ot, met1, met1->h2ot, time, lon, lat, &h2ot, ci, cw, 0); \
1003 intpol_met_time_2d(met0, met0->pct, met1, met1->pct, time, lon, lat, &pct, ci, cw, 0); \
1004 intpol_met_time_2d(met0, met0->pcb, met1, met1->pcb, time, lon, lat, &pcb, ci, cw, 0); \
1005 intpol_met_time_2d(met0, met0->cl, met1, met1->cl, time, lon, lat, &cl, ci, cw, 0); \
1006 intpol_met_time_2d(met0, met0->plcl, met1, met1->plcl, time, lon, lat, &plcl, ci, cw, 0); \
1007 intpol_met_time_2d(met0, met0->plfc, met1, met1->plfc, time, lon, lat, &plfc, ci, cw, 0); \
1008 intpol_met_time_2d(met0, met0->pel, met1, met1->pel, time, lon, lat, &pel, ci, cw, 0); \
1009 intpol_met_time_2d(met0, met0->cape, met1, met1->cape, time, lon, lat, &cape, ci, cw, 0); \
1010 intpol_met_time_2d(met0, met0->cin, met1, met1->cin, time, lon, lat, &cin, ci, cw, 0); \
1011 intpol_met_time_2d(met0, met0->o3c, met1, met1->o3c, time, lon, lat, &o3c, ci, cw, 0); \
1028#define LAPSE(p1, t1, p2, t2) \
1029 (1e3 * G0 / RA * ((t2) - (t1)) / ((t2) + (t1)) \
1030 * ((p2) + (p1)) / ((p2) - (p1)))
1047#define LIN(x0, y0, x1, y1, x) \
1048 ((y0)+((y1)-(y0))/((x1)-(x0))*((x)-(x0)))
1090 "# $1 = time [s]\n" \
1091 "# $2 = altitude [km]\n" \
1092 "# $3 = longitude [deg]\n" \
1093 "# $4 = latitude [deg]\n" \
1094 "# $5 = pressure [hPa]\n" \
1095 "# $6 = temperature [K]\n" \
1096 "# $7 = zonal wind [m/s]\n" \
1097 "# $8 = meridional wind [m/s]\n" \
1098 "# $9 = vertical velocity [hPa/s]\n" \
1099 "# $10 = H2O volume mixing ratio [ppv]\n"); \
1101 "# $11 = O3 volume mixing ratio [ppv]\n" \
1102 "# $12 = geopotential height [km]\n" \
1103 "# $13 = potential vorticity [PVU]\n" \
1104 "# $14 = surface pressure [hPa]\n" \
1105 "# $15 = surface temperature [K]\n" \
1106 "# $16 = surface geopotential height [km]\n" \
1107 "# $17 = surface zonal wind [m/s]\n" \
1108 "# $18 = surface meridional wind [m/s]\n" \
1109 "# $19 = eastward turbulent surface stress [N/m^2]\n" \
1110 "# $20 = northward turbulent surface stress [N/m^2]\n"); \
1112 "# $21 = surface sensible heat flux [W/m^2]\n" \
1113 "# $22 = land-sea mask [1]\n" \
1114 "# $23 = sea surface temperature [K]\n" \
1115 "# $24 = tropopause pressure [hPa]\n" \
1116 "# $25 = tropopause geopotential height [km]\n" \
1117 "# $26 = tropopause temperature [K]\n" \
1118 "# $27 = tropopause water vapor [ppv]\n" \
1119 "# $28 = cloud liquid water content [kg/kg]\n" \
1120 "# $29 = cloud rain water content [kg/kg]\n" \
1121 "# $30 = cloud ice water content [kg/kg]\n"); \
1123 "# $31 = cloud snow water content [kg/kg]\n" \
1124 "# $32 = cloud cover [1]\n" \
1125 "# $33 = total column cloud water [kg/m^2]\n" \
1126 "# $34 = cloud top pressure [hPa]\n" \
1127 "# $35 = cloud bottom pressure [hPa]\n" \
1128 "# $36 = pressure at lifted condensation level (LCL) [hPa]\n" \
1129 "# $37 = pressure at level of free convection (LFC) [hPa]\n" \
1130 "# $38 = pressure at equilibrium level (EL) [hPa]\n" \
1131 "# $39 = convective available potential energy (CAPE) [J/kg]\n" \
1132 "# $40 = convective inhibition (CIN) [J/kg]\n"); \
1134 "# $41 = relative humidity over water [%%]\n" \
1135 "# $42 = relative humidity over ice [%%]\n" \
1136 "# $43 = dew point temperature [K]\n" \
1137 "# $44 = frost point temperature [K]\n" \
1138 "# $45 = NAT temperature [K]\n" \
1139 "# $46 = HNO3 volume mixing ratio [ppv]\n" \
1140 "# $47 = OH volume mixing ratio [ppv]\n" \
1141 "# $48 = H2O2 volume mixing ratio [ppv]\n" \
1142 "# $49 = HO2 volume mixing ratio [ppv]\n" \
1143 "# $50 = O(1D) volume mixing ratio [ppv]\n"); \
1145 "# $51 = boundary layer pressure [hPa]\n" \
1146 "# $52 = total column ozone [DU]\n" \
1147 "# $53 = number of data points\n" \
1148 "# $54 = number of tropopause data points\n" \
1149 "# $55 = number of CAPE data points\n");
1190#define MOLEC_DENS(p,t) \
1191 (AVO * 1e-6 * ((p) * 100) / (RI * (t)))
1205 int nc_result=(cmd); \
1206 if(nc_result!=NC_NOERR) \
1207 ERRMSG("%s", nc_strerror(nc_result)); \
1233#define NC_DEF_VAR(varname, type, ndims, dims, long_name, units, level, quant) { \
1234 NC(nc_def_var(ncid, varname, type, ndims, dims, &varid)); \
1235 NC(nc_put_att_text(ncid, varid, "long_name", strnlen(long_name, LEN), long_name)); \
1236 NC(nc_put_att_text(ncid, varid, "units", strnlen(units, LEN), units)); \
1238 NC(nc_def_var_quantize(ncid, varid, NC_QUANTIZE_GRANULARBR, quant)); \
1239 if((level) != 0) { \
1240 NC(nc_def_var_deflate(ncid, varid, 1, 1, level)); \
1263#define NC_GET_DOUBLE(varname, ptr, force) { \
1265 NC(nc_inq_varid(ncid, varname, &varid)); \
1266 NC(nc_get_var_double(ncid, varid, ptr)); \
1268 if(nc_inq_varid(ncid, varname, &varid) == NC_NOERR) { \
1269 NC(nc_get_var_double(ncid, varid, ptr)); \
1271 WARN("netCDF variable %s is missing!", varname); \
1293#define NC_INQ_DIM(dimname, ptr, min, max, check) { \
1294 int dimid; size_t naux; \
1295 NC(nc_inq_dimid(ncid, dimname, &dimid)); \
1296 NC(nc_inq_dimlen(ncid, dimid, &naux)); \
1299 if ((*ptr) < (min) || (*ptr) > (max)) \
1300 ERRMSG("Dimension %s is out of range!", dimname); \
1317#define NC_PUT_DOUBLE(varname, ptr, hyperslab) { \
1318 NC(nc_inq_varid(ncid, varname, &varid)); \
1320 NC(nc_put_vara_double(ncid, varid, start, count, ptr)); \
1322 NC(nc_put_var_double(ncid, varid, ptr)); \
1341#define NC_PUT_FLOAT(varname, ptr, hyperslab) { \
1342 NC(nc_inq_varid(ncid, varname, &varid)); \
1344 NC(nc_put_vara_float(ncid, varid, start, count, ptr)); \
1346 NC(nc_put_var_float(ncid, varid, ptr)); \
1364#define NC_PUT_INT(varname, ptr, hyperslab) { \
1365 NC(nc_inq_varid(ncid, varname, &varid)); \
1367 NC(nc_put_vara_int(ncid, varid, start, count, ptr)); \
1369 NC(nc_put_var_int(ncid, varid, ptr)); \
1386#define NC_PUT_ATT(varname, attname, text) { \
1387 NC(nc_inq_varid(ncid, varname, &varid)); \
1388 NC(nc_put_att_text(ncid, varid, attname, strnlen(text, LEN), text)); \
1403#define NC_PUT_ATT_GLOBAL(attname, text) \
1404 NC(nc_put_att_text(ncid, NC_GLOBAL, attname, strnlen(text, LEN), text));
1423#define NN(x0, y0, x1, y1, x) \
1424 (fabs((x) - (x0)) <= fabs((x) - (x1)) ? (y0) : (y1))
1442#define PARTICLE_LOOP(ip0, ip1, check_dt, ...) \
1443 const int ip0_const = ip0; \
1444 const int ip1_const = ip1; \
1445 _Pragma(__VA_ARGS__) \
1446 _Pragma("acc parallel loop independent gang vector") \
1447 for (int ip = ip0_const; ip < ip1_const; ip++) \
1448 if (!check_dt || cache->dt[ip] != 0)
1450#define PARTICLE_LOOP(ip0, ip1, check_dt, ...) \
1451 const int ip0_const = ip0; \
1452 const int ip1_const = ip1; \
1453 _Pragma("omp parallel for default(shared)") \
1454 for (int ip = ip0_const; ip < ip1_const; ip++) \
1455 if (!check_dt || cache->dt[ip] != 0)
1481 (P0 * exp(-(z) / H0))
1505 (6.112 * exp(17.62 * ((t) - T0) / (243.12 + (t) - T0)))
1529 (6.112 * exp(22.46 * ((t) - T0) / (272.62 + (t) - T0)))
1556 ((p) * MAX((h2o), 0.1e-6) / (1. + (1. - EPS) * MAX((h2o), 0.1e-6)))
1572#define RAD2DEG(rad) \
1573 ((rad) * (180.0 / M_PI))
1602#define RH(p, t, h2o) \
1603 (PW(p, h2o) / PSAT(t) * 100.)
1632#define RHICE(p, t, h2o) \
1633 (PW(p, h2o) / PSICE(t) * 100.)
1658 (100. * (p) / (RA * (t)))
1676#define SET_ATM(qnt, val) \
1677 if (ctl->qnt >= 0) \
1678 atm->q[ctl->qnt][ip] = val;
1699#define SET_QNT(qnt, name, longname, unit) \
1700 if (strcasecmp(ctl->qnt_name[iq], name) == 0) { \
1702 sprintf(ctl->qnt_longname[iq], longname); \
1703 sprintf(ctl->qnt_unit[iq], unit); \
1721 (EPS * MAX((h2o), 0.1e-6))
1747#define SWAP(x, y, type) \
1748 do {type tmp = x; x = y; y = tmp;} while(0);
1771#define TDEW(p, h2o) \
1772 (T0 + 243.12 * log(PW((p), (h2o)) / 6.112) \
1773 / (17.62 - log(PW((p), (h2o)) / 6.112)))
1796#define TICE(p, h2o) \
1797 (T0 + 272.62 * log(PW((p), (h2o)) / 6.112) \
1798 / (22.46 - log(PW((p), (h2o)) / 6.112)))
1820#define THETA(p, t) \
1821 ((t) * pow(1000. / (p), 0.286))
1849#define THETAVIRT(p, t, h2o) \
1850 (TVIRT(THETA((p), (t)), MAX((h2o), 0.1e-6)))
1870#define TOK(line, tok, format, var) { \
1871 if(((tok)=strtok((line), " \t"))) { \
1872 if(sscanf(tok, format, &(var))!=1) continue; \
1873 } else ERRMSG("Error while reading!"); \
1895#define TVIRT(t, h2o) \
1896 ((t) * (1. + (1. - EPS) * MAX((h2o), 0.1e-6)))
1912 for (iusage = 1; iusage < argc; iusage++) \
1913 if (!strcmp(argv[iusage], "-h") \
1914 || !strcmp(argv[iusage], "--help")) { \
1916 return EXIT_SUCCESS; \
1940 (H0 * log(P0 / (p)))
1970#define ZDIFF(lnp0, t0, h2o0, lnp1, t1, h2o1) \
1971 (RI / MA / G0 * 0.5 * (TVIRT((t0), (h2o0)) + TVIRT((t1), (h2o1))) \
1972 * ((lnp0) - (lnp1)))
1989#define ZETA(ps, p, t) \
1990 (((p) / (ps) <= 0.3 ? 1. : \
1991 sin(M_PI / 2. * (1. - (p) / (ps)) / (1. - 0.3))) \
2032#define LOG(level, ...) { \
2035 if(level <= LOGLEV) { \
2036 printf(__VA_ARGS__); \
2069#define WARN(...) { \
2070 printf("\nWarning (%s, %s, l%d): ", __FILE__, __func__, __LINE__); \
2071 LOG(0, __VA_ARGS__); \
2102#define ERRMSG(...) { \
2103 printf("\nError (%s, %s, l%d): ", __FILE__, __func__, __LINE__); \
2104 LOG(0, __VA_ARGS__); \
2105 exit(EXIT_FAILURE); \
2137#define PRINT(format, var) \
2138 printf("Print (%s, %s, l%d): %s= "format"\n", \
2139 __FILE__, __func__, __LINE__, #var, var);
2161#define PRINT_TIMERS \
2162 timer("END", "END", 1);
2176#define SELECT_TIMER(id, group) \
2177 timer(id, group, 0);
2843 char clim_ccl4_timeseries[
LEN];
2846 char clim_ccl3f_timeseries[
LEN];
2849 char clim_ccl2f2_timeseries[
LEN];
2852 char clim_n2o_timeseries[
LEN];
2855 char clim_sf6_timeseries[
LEN];
2945 double wet_depo_pre[2];
2960 double wet_depo_ic_h[2];
2963 double wet_depo_bc_h[2];
3445 double tropo_time[12];
3448 double tropo_lat[73];
3451 double tropo[12][73];
3692 size_t subdomain_start[4];
3695 size_t subdomain_count[4];
3698 size_t halo_bnd_start[4];
3701 size_t halo_bnd_count[4];
3716 MPI_Datatype MPI_Particle;
3719 double sort_key[
NP];
4011 const char *varname,
4017 const int decompress,
4053 const char *varname,
4057 const int decompress,
4090 const char *varname,
4095 const int precision,
4096 const double tolerance,
4097 const int decompress,
4139 const char *varname,
4144 const int precision,
4145 const double tolerance,
4146 const int decompress,
4171 const char *varname,
4174 const int decompress,
4797 const char *metbase,
4798 const double dt_met,
4866 const int met_tropo,
4955 float height0[
EX][
EY][
EP],
4956 float array0[
EX][
EY][
EP],
4958 float height1[
EX][
EY][
EP],
4959 float array1[
EX][
EY][
EP],
4961 const double height,
5050 float array[
EX][
EY],
5093 float array0[
EX][
EY][
EP],
5095 float array1[
EX][
EY][
EP],
5141 float array0[
EX][
EY],
5143 float array1[
EX][
EY],
5191 float array0[
EX][
EY],
5193 float array1[
EX][
EY],
5194 const double lons[
EX],
5195 const double lats[
EY],
5268 const double kz[
EP],
5269 const double kw[
EP],
5446 float profiles[
EX][
EY][
EP],
5448 const int lon_ap_ind,
5449 const int lat_ap_ind,
5450 const double alt_ap,
6137 const int use_ensemble);
6704 const char *filename,
6773 const char *filename,
6809 const char *filename,
6875 const char *filename,
6918 const char *filename,
6956 const char *dirname,
7130 const char *filename,
7165 const char *filename,
7194 const char *filename,
7228 const char *filename,
7261 const char *filename,
7282 const char *varname,
7310 const char *filename,
7340 const char *filename,
7341 const char *varname,
7372 const char *filename,
7409 const char *filename,
7442 const char *varname);
7486 const char *varname,
7487 const float bound_min,
7488 const float bound_max);
7658 const char *filename,
7708 const int num_messages,
7743 const int num_messages,
7779 const char *varname);
7837 const char *filename,
7877 const char *filename,
8039 const char *varname,
8040 const char *varname2,
8041 const char *varname3,
8042 const char *varname4,
8043 const char *varname5,
8044 const char *varname6,
8083 const char *varname,
8084 const char *varname2,
8085 const char *varname3,
8086 const char *varname4,
8363 const char *filename,
8400 const char *filename,
8435 const char *filename,
8477 const char *filename,
8480 const char *varname,
8482 const char *defvalue,
8612 const double remain,
8674 const char *filename,
8722 const char *filename,
8751 const char *filename,
8779 const char *filename,
8808 const char *dirname,
8837 const char *filename,
8870 const char *filename,
8916 const char *filename,
8949 const char *filename,
8993 const char *filename,
9046 const char *filename,
9051 const double *vmr_impl,
9103 const char *filename,
9108 const double *vmr_impl,
9147 const char *filename,
9182 const char *varname);
9226 const char *varname,
9227 const int precision,
9228 const double tolerance);
9258 const char *filename,
9286 const char *varname,
9316 const char *varname,
9352 const char *filename,
9391 const char *filename,
9425 const char *filename,
9459 const char *filename,
9469#pragma acc routine (clim_oh)
9470#pragma acc routine (clim_photo)
9471#pragma acc routine (clim_tropo)
9472#pragma acc routine (clim_ts)
9473#pragma acc routine (clim_zm)
9474#pragma acc routine (cos_sza)
9475#pragma acc routine (dd_calc_subdomain_from_coords)
9476#pragma acc routine (dd_normalize_lon_lat)
9477#pragma acc routine (intpol_check_lon_lat)
9478#pragma acc routine (intpol_met_4d_zeta)
9479#pragma acc routine (intpol_met_space_3d)
9480#pragma acc routine (intpol_met_space_2d)
9481#pragma acc routine (intpol_met_time_3d)
9482#pragma acc routine (intpol_met_time_2d)
9483#pragma acc routine (kernel_weight)
9484#pragma acc routine (lapse_rate)
9485#pragma acc routine (locate_irr)
9486#pragma acc routine (locate_irr_float)
9487#pragma acc routine (locate_reg)
9488#pragma acc routine (locate_vert)
9489#pragma acc routine (nat_temperature)
9490#pragma acc routine (pbl_weight)
9491#pragma acc routine (sedi)
9492#pragma acc routine (stddev)
9493#pragma acc routine (tropo_weight)
void read_met_geopot(const ctl_t *ctl, met_t *met)
Calculates geopotential heights from meteorological data.
void dd_init(const ctl_t *ctl, dd_t *dd, atm_t *atm)
Initialize the domain decomposition infrastructure.
void compress_zstd(const char *varname, float *array, const size_t n, const int decompress, const int level, FILE *inout)
Compresses or decompresses a float array using Zstandard (ZSTD).
#define LEN
Maximum length of ASCII data lines.
void mptrac_alloc(ctl_t **ctl, cache_t **cache, clim_t **clim, met_t **met0, met_t **met1, atm_t **atm, dd_t **dd)
Allocates and initializes memory resources for MPTRAC.
void mptrac_write_atm(const char *filename, const ctl_t *ctl, const atm_t *atm, const double t)
Writes air parcel data to a file in various formats.
void day2doy(const int year, const int mon, const int day, int *doy)
Get day of year from date.
void read_met_grib_surface(codes_handle **handles, const int num_messages, const ctl_t *ctl, met_t *met)
Reads surface meteorological data from a grib file and stores it in the meteorological data structure...
void read_met_extrapolate(met_t *met)
Extrapolates meteorological data.
void write_atm_clams_traj(const char *dirname, const ctl_t *ctl, const atm_t *atm, const double t)
Writes CLaMS trajectory data to a NetCDF file.
int read_met_nc_2d(const int ncid, const char *varname, const char *varname2, const char *varname3, const char *varname4, const char *varname5, const char *varname6, const ctl_t *ctl, const met_t *met, dd_t *dd, float dest[EX][EY], const float scl, const int init)
Reads a 2-dimensional meteorological variable from a NetCDF file.
void write_met_nc_2d(const int ncid, const char *varname, met_t *met, float var[EX][EY], const float scl)
Writes a 2D meteorological variable to a NetCDF file.
void read_met_sample(const ctl_t *ctl, met_t *met)
Downsamples meteorological data based on specified parameters.
void write_met_bin_3d(FILE *out, const ctl_t *ctl, met_t *met, float var[EX][EY][EP], const char *varname, const int precision, const double tolerance)
Writes a 3-dimensional meteorological variable to a binary file.
void read_obs(const char *filename, const ctl_t *ctl, double *rt, double *rz, double *rlon, double *rlat, double *robs, int *nobs)
Reads observation data from a file and stores it in arrays.
void module_advect(const ctl_t *ctl, const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Advances particle positions using different advection schemes.
void module_timesteps(const ctl_t *ctl, cache_t *cache, met_t *met0, atm_t *atm, const double t)
Calculate time steps for air parcels based on specified conditions.
void module_meteo(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Update atmospheric properties using meteorological data.
void read_clim_photo(const char *filename, clim_photo_t *photo)
Reads photolysis rates from a NetCDF file and populates the given photolysis structure.
void read_met_cloud(met_t *met)
Calculates cloud-related variables for each grid point.
void module_decay(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, atm_t *atm)
Simulate exponential decay processes for atmospheric particles.
double sedi(const double p, const double T, const double rp, const double rhop)
Calculates the sedimentation velocity of a particle in air.
double cos_sza(const double sec, const double lon, const double lat)
Calculates the cosine of the solar zenith angle.
#define METVAR
Number of 3-D meteorological variables.
void intpol_met_space_2d(const met_t *met, float array[EX][EY], const double lon, const double lat, double *var, int *ci, double *cw, const int init)
Interpolates meteorological variables in 2D space.
int read_met_nc_3d(const int ncid, const char *varname, const char *varname2, const char *varname3, const char *varname4, const ctl_t *ctl, const met_t *met, dd_t *dd, float dest[EX][EY][EP], const float scl)
Reads a 3-dimensional meteorological variable from a NetCDF file.
int read_atm_nc(const char *filename, const ctl_t *ctl, atm_t *atm)
Reads air parcel data from a generic netCDF file and populates the given atmospheric structure.
void write_csi_ens(const char *filename, const ctl_t *ctl, const atm_t *atm, const double t)
Writes ensemble-based Critical Success Index (CSI) and other verification statistics to an output fil...
void read_met_pbl(const ctl_t *ctl, met_t *met)
Computes the planetary boundary layer (PBL) pressure based on meteorological data.
void read_met_detrend(const ctl_t *ctl, met_t *met)
Detrends meteorological data.
void read_met_tropo(const ctl_t *ctl, const clim_t *clim, met_t *met)
Calculates the tropopause and related meteorological variables based on various methods and stores th...
void read_obs_asc(const char *filename, double *rt, double *rz, double *rlon, double *rlat, double *robs, int *nobs)
Reads observation data from an ASCII file.
void module_chem_init(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Initializes the chemistry modules by setting atmospheric composition.
int locate_reg(const double *xx, const int n, const double x)
Locate the index of the interval containing a given value in a regular grid.
void locate_vert(float profiles[EX][EY][EP], const int np, const int lon_ap_ind, const int lat_ap_ind, const double alt_ap, int *ind)
Locate the four vertical indizes of a box for a given height value.
void compress_cms(const ctl_t *ctl, const char *varname, float *array, const size_t nx, const size_t ny, const size_t np, const double *plev, const int decompress, FILE *inout)
Compresses or decompresses a 3-D meteorological field using cmultiscale.
void read_met_nc_levels(const int ncid, const ctl_t *ctl, met_t *met, dd_t *dd)
Reads and processes meteorological level data from NetCDF files with domain decomposition.
void read_met_monotonize(const ctl_t *ctl, met_t *met)
Makes zeta and pressure profiles monotone.
int dd_calc_subdomain_from_coords(const ctl_t *ctl, const dd_t *dd, const double lon, const double lat)
Determine MPI subdomain from particle coordinates.
#define DD_EY_GLOB
Maximum number of latitudes of global meteo data.
int read_clim_ts(const char *filename, clim_ts_t *ts)
Reads a climatological time series from a file and populates the given time series structure.
void read_met_periodic(met_t *met)
Applies periodic boundary conditions to meteorological data along longitudinal axis.
void mptrac_run_timestep(ctl_t *ctl, cache_t *cache, clim_t *clim, met_t **met0, met_t **met1, atm_t *atm, double t, dd_t *dd)
Executes a single timestep of the MPTRAC model simulation.
void module_timesteps_init(ctl_t *ctl, const atm_t *atm)
Initialize start time and time interval for time-stepping.
void write_ens(const char *filename, const ctl_t *ctl, const atm_t *atm, const double t)
Writes ensemble data to a file.
void module_mixing(const ctl_t *ctl, const clim_t *clim, atm_t *atm, const double t)
Update atmospheric properties through interparcel mixing.
void compress_zfp(const char *varname, float *array, const int nx, const int ny, const int nz, const int precision, const double tolerance, const int decompress, FILE *inout)
Compresses or decompresses a 3D array of floats using the ZFP library.
double clim_zm(const clim_zm_t *zm, const double t, const double lat, const double p)
Interpolates monthly mean zonal mean climatological variables.
#define EY
Maximum number of latitudes for meteo data.
void module_mixing_help(const ctl_t *ctl, const clim_t *clim, atm_t *atm, const int *ixs, const int *iys, const int *izs, const int qnt_idx, const int use_ensemble)
Perform subgrid-scale interparcel mixing of a given quantity.
void read_clim_photo_help(const int ncid, const char *varname, const clim_photo_t *photo, double var[CP][CSZA][CO3])
Reads a 3D climatological photochemistry variable from a NetCDF file.
void read_met_ml2pl(const ctl_t *ctl, const met_t *met, float var[EX][EY][EP], const char *varname)
Interpolates meteorological data to specified pressure levels.
double clim_tropo(const clim_t *clim, const double t, const double lat)
Calculates the tropopause pressure based on climatological data.
void read_obs_nc(const char *filename, double *rt, double *rz, double *rlon, double *rlat, double *robs, int *nobs)
Reads observation data from a NetCDF file.
void read_met_bin_2d(FILE *in, const met_t *met, float var[EX][EY], const char *varname)
Reads a 2-dimensional meteorological variable from a binary file and stores it in the provided array.
int locate_irr(const double *xx, const int n, const double x)
Locate the index of the interval containing a given value in a sorted array.
void module_isosurf_init(const ctl_t *ctl, cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Initialize the isosurface module based on atmospheric data.
void level_definitions(ctl_t *ctl)
Defines pressure levels for meteorological data.
void intpol_met_4d_zeta(const met_t *met0, float height0[EX][EY][EP], float array0[EX][EY][EP], const met_t *met1, float height1[EX][EY][EP], float array1[EX][EY][EP], const double ts, const double height, const double lon, const double lat, double *var, int *ci, double *cw, const int init)
Interpolates meteorological variables to a given position and time.
void write_grid_asc(const char *filename, const ctl_t *ctl, const double *cd, double *mean[NQ], double *sigma[NQ], const double *vmr_impl, const double t, const double *z, const double *lon, const double *lat, const double *area, const double dz, const int *np)
Writes grid data to an ASCII file.
void mptrac_update_device(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t **met0, met_t **met1, const atm_t *atm)
Updates device memory for specified data structures.
void time2jsec(const int year, const int mon, const int day, const int hour, const int min, const int sec, const double remain, double *jsec)
Converts time components to seconds since January 1, 2000, 12:00:00 UTC.
void mptrac_init(ctl_t *ctl, cache_t *cache, clim_t *clim, atm_t *atm, const int ntask)
Initializes the MPTRAC model and its associated components.
void intpol_met_time_3d(const met_t *met0, float array0[EX][EY][EP], const met_t *met1, float array1[EX][EY][EP], const double ts, const double p, const double lon, const double lat, double *var, int *ci, double *cw, const int init)
Interpolates meteorological data in 3D space and time.
#define codes_handle
Placeholder when ECCODES is not available.
void get_met_filename(const ctl_t *ctl, const double t, const int direct, const char *metbase, const double dt_met, char *filename)
Generates a formatted filename for meteorological data files based on the input parameters.
void fft_help(double *fcReal, double *fcImag, const int n)
Computes the Fast Fourier Transform (FFT) of a complex sequence.
void module_wet_depo(const ctl_t *ctl, const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Perform wet deposition calculations for air parcels.
void compress_pck(const char *varname, float *array, const size_t nxy, const size_t nz, const int decompress, FILE *inout)
Compresses or decompresses a 3D array of floats.
double nat_temperature(const double p, const double h2o, const double hno3)
Calculates the nitric acid trihydrate (NAT) temperature.
void spline(const double *x, const double *y, const int n, const double *x2, double *y2, const int n2, const int method)
Performs spline interpolation or linear interpolation.
#define CP
Maximum number of pressure levels for climatological data.
#define NQ
Maximum number of quantities per data point.
void dd_assign_subdomains(const ctl_t *ctl, const dd_t *dd, atm_t *atm, const int init)
Assign or update particle subdomain ownership.
double clim_photo(const double rate[CP][CSZA][CO3], const clim_photo_t *photo, const double p, const double sza, const double o3c)
Calculates the photolysis rate for a given set of atmospheric conditions.
void read_clim_zm(const char *filename, const char *varname, clim_zm_t *zm)
Reads zonally averaged climatological data from a netCDF file and populates the given structure.
#define EX
Maximum number of longitudes for meteo data.
void read_met_nc_grid_dd_naive(dd_t *dd, const ctl_t *ctl, met_t *met, const int ncid)
Read meteorological grid information and construct the domain-decomposed grid with halo regions.
void module_sedi(const ctl_t *ctl, const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Simulate sedimentation of particles in the atmosphere.
int read_met_nc(const char *filename, const ctl_t *ctl, met_t *met, dd_t *dd)
Reads meteorological data from a NetCDF file and processes it.
void timer(const char *name, const char *group, const int output)
Measures and reports elapsed time for named and grouped timers.
void write_atm_asc(const char *filename, const ctl_t *ctl, const atm_t *atm, const double t)
Writes air parcel data to an ASCII file or gnuplot.
void intpol_met_space_3d(const met_t *met, float array[EX][EY][EP], const double p, const double lon, const double lat, double *var, int *ci, double *cw, const int init)
Interpolates meteorological variables in 3D space.
void module_sort(const ctl_t *ctl, const met_t *met0, atm_t *atm)
Sort particles according to box index.
void module_convection(const ctl_t *ctl, cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Performs convective mixing of atmospheric particles.
void read_kernel(const char *filename, double kz[EP], double kw[EP], int *nk)
Reads kernel function data from a file and populates the provided arrays.
void module_bound_cond(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Apply boundary conditions to particles based on meteorological and climatological data.
double scan_ctl(const char *filename, int argc, char *argv[], const char *varname, const int arridx, const char *defvalue, char *value)
Scans a control file or command-line arguments for a specified variable.
void dd_normalize_lon_lat(const dd_t *dd, double *lon, double *lat)
Normalize geographic coordinates to the global grid convention.
#define CT
Maximum number of time steps for climatological data.
void module_advect_init(const ctl_t *ctl, const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Initializes the advection module by setting up pressure fields.
void module_radio_decay(const ctl_t *ctl, const cache_t *cache, atm_t *atm)
Apply radioactive decay to atmospheric tracer species.
int read_met_grib(const char *filename, const ctl_t *ctl, met_t *met)
Reads meteorological data from a grib file and processes it.
void dd_sort(const ctl_t *ctl, const met_t *met0, atm_t *atm, dd_t *dd, int *npart)
Sort local atmospheric particles and determine export counts for domain decomposition.
void mptrac_get_met(ctl_t *ctl, clim_t *clim, const double t, met_t **met0, met_t **met1, dd_t *dd)
Retrieves meteorological data for the specified time.
void module_sort_help(double *a, const int *p, const int np)
Reorder an array based on a given permutation.
void dd_particles2atm(const ctl_t *ctl, cache_t *cache, const particle_t *particles, const int npart, atm_t *atm)
Copy received particles from the communication buffer into the atmospheric state.
float stddev(const float *data, const int n)
Calculates the standard deviation of a set of data.
void intpol_tropo_3d(const double time0, float array0[EX][EY], const double time1, float array1[EX][EY], const double lons[EX], const double lats[EY], const int nlon, const int nlat, const double time, const double lon, const double lat, const int method, double *var, double *sigma)
Interpolates tropopause data in 3D (latitude, longitude, and time).
void read_met_bin_3d(FILE *in, const ctl_t *ctl, const met_t *met, float var[EX][EY][EP], const char *varname, const float bound_min, const float bound_max)
Reads 3D meteorological data from a binary file, potentially using different compression methods.
int locate_irr_float(const float *xx, const int n, const double x, const int ig)
Locate the index of the interval containing a given value in an irregularly spaced array.
double time_from_filename(const char *filename, const int offset)
Extracts and converts a timestamp from a filename to Julian seconds.
void write_prof(const char *filename, const ctl_t *ctl, met_t *met0, met_t *met1, const atm_t *atm, const double t)
Writes profile data to a specified file.
void mptrac_read_clim(const ctl_t *ctl, clim_t *clim)
Reads various climatological data and populates the given climatology structure.
void module_chem_grid(const ctl_t *ctl, met_t *met0, met_t *met1, atm_t *atm, const double t)
Computes gridded chemical tracer concentrations (volume mixing ratio) from individual air parcel mass...
double tropo_weight(const clim_t *clim, const atm_t *atm, const int ip)
Computes a weighting factor based on tropopause pressure.
void write_met_nc(const char *filename, const ctl_t *ctl, met_t *met)
Writes meteorological data to a NetCDF file.
void module_rng_init(const int ntask)
Initialize random number generators for parallel tasks.
int mptrac_read_atm(const char *filename, const ctl_t *ctl, atm_t *atm)
Reads air parcel data from a specified file into the given atmospheric structure.
void mptrac_update_host(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t **met0, met_t **met1, const atm_t *atm)
Updates host memory for specified data structures.
void mptrac_write_output(const char *dirname, const ctl_t *ctl, met_t *met0, met_t *met1, atm_t *atm, const double t)
Writes various types of output data to files in a specified directory.
double clim_oh(const ctl_t *ctl, const clim_t *clim, const double t, const double lon, const double lat, const double p)
Calculates the hydroxyl radical (OH) concentration from climatology data, with an optional diurnal co...
void read_met_grib_levels(codes_handle **handles, const int num_messages, const ctl_t *ctl, met_t *met)
Reads meteorological variables at different vertical levels from a grib file.
#define CTS
Maximum number of data points of climatological time series.
void read_met_ozone(met_t *met)
Calculates the total column ozone from meteorological ozone data.
void broadcast_large_data(void *data, size_t N)
Broadcasts large data across all processes in an MPI communicator.
void read_met_nc_surface(const int ncid, const ctl_t *ctl, met_t *met, dd_t *dd)
Reads and processes surface meteorological data from NetCDF files with domain decomposition.
void clim_tropo_init(clim_t *clim)
Initializes the tropopause data in the climatology structure.
void module_rng(const ctl_t *ctl, double *rs, const size_t n, const int method)
Generate random numbers using various methods and distributions.
void write_station(const char *filename, const ctl_t *ctl, atm_t *atm, const double t)
Writes station data to a specified file.
void cart2geo(const double *x, double *z, double *lon, double *lat)
Converts Cartesian coordinates to geographic coordinates.
void dd_atm2particles(const ctl_t *ctl, cache_t *cache, atm_t *atm, particle_t *particles, const int npart)
Copy migratable atmospheric particles from the ATM state into a particle buffer.
#define NP
Maximum number of atmospheric data points.
void dd_communicate_particles(const ctl_t *ctl, const dd_t *dd, particle_t **particles, int *npart, int *capacity)
Exchange particles between MPI ranks according to their destination rank.
void doy2day(const int year, const int doy, int *mon, int *day)
Converts a given day of the year (DOY) to a date (month and day).
void intpol_met_time_2d(const met_t *met0, float array0[EX][EY], const met_t *met1, float array1[EX][EY], const double ts, const double lon, const double lat, double *var, int *ci, double *cw, const int init)
Interpolates meteorological data in 2D space and time.
void module_position(const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Update the positions and pressure levels of atmospheric particles.
void clim_oh_diurnal_correction(const ctl_t *ctl, clim_t *clim)
Applies a diurnal correction to the hydroxyl radical (OH) concentration in climatology data.
void module_dd(const ctl_t *ctl, cache_t *cache, dd_t *dd, atm_t *atm, met_t **met)
Perform domain decomposition and exchange particles between MPI ranks.
void write_met_bin_2d(FILE *out, met_t *met, float var[EX][EY], const char *varname)
Writes a 2-dimensional meteorological variable to a binary file.
void read_met_pv(met_t *met)
Calculates potential vorticity (PV) from meteorological data.
#define DD_EX_GLOB
Maximum number of longitudes of global meteo data.
int read_atm_bin(const char *filename, const ctl_t *ctl, atm_t *atm)
Reads air parcel data from a binary file and populates the given atmospheric structure.
#define CY
Maximum number of latitudes for climatological data.
void module_diff_meso(const ctl_t *ctl, cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Simulate mesoscale diffusion for atmospheric particles.
void dd_sort_help(double *a, dd_t *dd, const int np)
Apply the sorting permutation to a particle data array.
double clim_ts(const clim_ts_t *ts, const double t)
Interpolates a time series of climatological variables.
void jsec2time(const double jsec, int *year, int *mon, int *day, int *hour, int *min, int *sec, double *remain)
Converts Julian seconds to calendar date and time components.
int read_met_bin(const char *filename, const ctl_t *ctl, met_t *met)
Reads meteorological data from a binary file.
void write_atm_clams(const char *filename, const ctl_t *ctl, const atm_t *atm)
Writes air parcel data to a NetCDF file in the CLaMS format.
void get_met_replace(char *orig, const char *search, const char *repl)
Replaces occurrences of a substring in a string with another substring.
void module_diff_turb(const ctl_t *ctl, cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Applies turbulent diffusion processes to atmospheric particles.
int read_atm_clams(const char *filename, const ctl_t *ctl, atm_t *atm)
Reads atmospheric data from a CLAMS NetCDF file.
int mptrac_read_met(const char *filename, const ctl_t *ctl, const clim_t *clim, met_t *met, dd_t *dd)
Reads meteorological data from a file, supporting multiple formats and MPI broadcasting.
void write_vtk(const char *filename, const ctl_t *ctl, const atm_t *atm, const double t)
Writes VTK (Visualization Toolkit) data to a specified file.
#define EP
Maximum number of pressure levels for meteo data.
void module_tracer_chem(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Simulate chemical reactions involving long-lived atmospheric tracers.
void mptrac_read_ctl(const char *filename, int argc, char *argv[], ctl_t *ctl)
Reads control parameters from a configuration file and populates the given structure.
void mptrac_free(ctl_t *ctl, cache_t *cache, clim_t *clim, met_t *met0, met_t *met1, atm_t *atm, dd_t *dd)
Frees memory resources allocated for MPTRAC.
void read_met_polar_winds(met_t *met)
Applies a fix for polar winds in meteorological data.
void module_h2o2_chem(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Perform chemical reactions involving H2O2 within cloud particles.
void write_grid_nc(const char *filename, const ctl_t *ctl, const double *cd, double *mean[NQ], double *sigma[NQ], const double *vmr_impl, const double t, const double *z, const double *lon, const double *lat, const double *area, const double dz, const int *np)
Writes grid data to a NetCDF file.
double pbl_weight(const ctl_t *ctl, const atm_t *atm, const int ip, const double pbl, const double ps)
Computes a weighting factor based on planetary boundary layer pressure.
void module_diff_pbl(const ctl_t *ctl, cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Computes particle diffusion within the planetary boundary layer (PBL).
void write_met_nc_3d(const int ncid, const char *varname, met_t *met, float var[EX][EY][EP], const float scl)
Writes a 3D meteorological variable to a NetCDF file.
void module_isosurf(const ctl_t *ctl, const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Apply the isosurface module to adjust atmospheric properties.
void module_kpp_chem(ctl_t *ctl, cache_t *cache, clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
KPP chemistry module.
#define CO3
Maximum number of total column ozone data for climatological data.
void module_oh_chem(const ctl_t *ctl, const cache_t *cache, const clim_t *clim, met_t *met0, met_t *met1, atm_t *atm)
Perform hydroxyl chemistry calculations for atmospheric particles.
void read_met_grib_grid(codes_handle **handles, int count_handles, met_t *met)
Reads global meteorological information from a grib file.
void geo2cart(const double z, const double lon, const double lat, double *x)
Converts geographic coordinates (longitude, latitude, altitude) to Cartesian coordinates.
void read_met_nc_grid(const char *filename, const int ncid, const ctl_t *ctl, met_t *met, dd_t *dd)
Reads meteorological grid data from NetCDF files with domain decomposition.
void get_tropo(const int met_tropo, ctl_t *ctl, const clim_t *clim, met_t *met, const double *lons, const int nx, const double *lats, const int ny, double *pt, double *zt, double *tt, double *qt, double *o3t, double *ps, double *zs)
Calculate tropopause data.
double kernel_weight(const double kz[EP], const double kw[EP], const int nk, const double p)
Calculates the kernel weight based on altitude and given kernel data.
void compress_sz3(const char *varname, float *array, const int nx, const int ny, const int nz, const int precision, const double tolerance, const int decompress, FILE *inout)
Compresses or decompresses a 3-D float array using the SZ3 library.
int read_atm_asc(const char *filename, const ctl_t *ctl, atm_t *atm)
Reads air parcel data from an ASCII file and populates the given atmospheric structure.
void intpol_check_lon_lat(const double *lons, const int nlon, const double *lats, const int nlat, const double lon, const double lat, double *lon2, double *lat2)
Adjusts longitude and latitude to ensure they fall within valid bounds.
void write_sample(const char *filename, const ctl_t *ctl, met_t *met0, met_t *met1, const atm_t *atm, const double t)
Writes sample data to a specified file.
void write_grid(const char *filename, const ctl_t *ctl, met_t *met0, met_t *met1, const atm_t *atm, const double t)
Writes grid data to a file in ASCII or netCDF format.
void module_dry_depo(const ctl_t *ctl, const cache_t *cache, met_t *met0, met_t *met1, atm_t *atm)
Simulate dry deposition of atmospheric particles.
void write_met_bin(const char *filename, const ctl_t *ctl, met_t *met)
Writes meteorological data in binary format to a specified file.
void write_atm_bin(const char *filename, const ctl_t *ctl, const atm_t *atm)
Writes air parcel data to a binary file.
void read_met_cape(const ctl_t *ctl, const clim_t *clim, met_t *met)
Calculates Convective Available Potential Energy (CAPE) for each grid point.
void mptrac_write_met(const char *filename, const ctl_t *ctl, met_t *met)
Writes meteorological data to a file, supporting multiple formats and compression options.
#define CSZA
Maximum number of solar zenith angles for climatological data.
double lapse_rate(const double t, const double h2o)
Calculates the moist adiabatic lapse rate in Kelvin per kilometer.
void write_csi(const char *filename, const ctl_t *ctl, const atm_t *atm, const double t)
Writes Critical Success Index (CSI) data to a file.
void write_atm_nc(const char *filename, const ctl_t *ctl, const atm_t *atm)
Writes air parcel data to a NetCDF file.
int np
Number of air parcels.
int iso_n
Isosurface balloon number of data points.
Climatological data in the form of photolysis rates.
int nsza
Number of solar zenith angles.
int np
Number of pressure levels.
int no3c
Number of total ozone columns.
clim_ts_t ccl2f2
CFC-12 time series.
clim_photo_t photo
Photolysis rates.
clim_zm_t ho2
HO2 zonal means.
clim_zm_t hno3
HNO3 zonal means.
int tropo_ntime
Number of tropopause timesteps.
clim_ts_t sf6
SF6 time series.
clim_ts_t ccl4
CFC-10 time series.
clim_ts_t ccl3f
CFC-11 time series.
clim_zm_t o1d
O(1D) zonal means.
clim_zm_t h2o2
H2O2 zonal means.
int tropo_nlat
Number of tropopause latitudes.
clim_zm_t oh
OH zonal means.
clim_ts_t n2o
N2O time series.
Climatological data in the form of time series.
int ntime
Number of timesteps.
Climatological data in the form of zonal means.
int np
Number of pressure levels.
int ntime
Number of timesteps.
int nlat
Number of latitudes.
double grid_z0
Lower altitude of gridded data [km].
int qnt_o3
Quantity array index for ozone volume mixing ratio.
double csi_lat1
Upper latitude of gridded CSI data [deg].
int qnt_Coh
Quantity array index for OH volume mixing ratio (chemistry code).
double wet_depo_ic_a
Coefficient A for wet deposition in cloud (exponential form).
int met_nc_scale
Check netCDF scaling factors (0=no, 1=yes).
int qnt_pel
Quantity array index for pressure at equilibrium level (EL).
int csi_nz
Number of altitudes of gridded CSI data.
double molmass
Molar mass [g/mol].
int qnt_p
Quantity array index for pressure.
int qnt_Cccl2f2
Quantity array index for CFC-12 volume mixing ratio (chemistry code).
int dd_halos_size
Domain decomposition size of halos given in grid-points.
int mixing_nx
Number of longitudes of mixing grid.
double chemgrid_z1
Upper altitude of chemistry grid [km].
int qnt_m
Quantity array index for mass.
int qnt_aoa
Quantity array index for age of air.
int qnt_rhop
Quantity array index for particle density.
int qnt_swc
Quantity array index for cloud snow water content.
double csi_obsmin
Minimum observation index to trigger detection.
int qnt_pcb
Quantity array index for cloud bottom pressure.
double bound_dzs
Boundary conditions surface layer depth [km].
double csi_lon1
Upper longitude of gridded CSI data [deg].
int qnt_u
Quantity array index for zonal wind.
double stat_lon
Longitude of station [deg].
double mixing_trop
Interparcel exchange parameter for mixing in the troposphere.
double sort_dt
Time step for sorting of particle data [s].
double mixing_z1
Upper altitude of mixing grid [km].
double stat_r
Search radius around station [km].
double wet_depo_bc_a
Coefficient A for wet deposition below cloud (exponential form).
int met_zstd_level
ZSTD compression level (from -5 to 22).
int csi_ny
Number of latitudes of gridded CSI data.
int vtk_sphere
Spherical projection for VTK data (0=no, 1=yes).
double chemgrid_z0
Lower altitude of chemistry grid [km].
double met_pbl_min
Minimum depth of planetary boundary layer [km].
int qnt_iwc
Quantity array index for cloud ice water content.
double chemgrid_lat0
Lower latitude of chemistry grid [deg].
double conv_cape
CAPE threshold for convection module [J/kg].
int qnt_Co1d
Quantity array index for O(1D) volume mixing ratio (chemistry code).
double met_cms_eps_pv
cmultiscale compression epsilon for potential vorticity.
int qnt_pw
Quantity array index for partial water vapor pressure.
double grid_z1
Upper altitude of gridded data [km].
int direction
Direction flag (1=forward calculation, -1=backward calculation).
int qnt_Cccl4
Quantity array index for CFC-10 volume mixing ratio (chemistry code).
int met_dp
Stride for pressure levels.
double met_dt_out
Time step for sampling of meteo data along trajectories [s].
int qnt_h2o2
Quantity array index for H2O2 volume mixing ratio (climatology).
int qnt_vh
Quantity array index for horizontal wind.
int csi_nx
Number of longitudes of gridded CSI data.
double csi_lat0
Lower latitude of gridded CSI data [deg].
double turb_dz_trop
Vertical turbulent diffusion coefficient (troposphere) [m^2/s].
int met_pbl
Planetary boundary layer data (0=file, 1=z2p, 2=Richardson, 3=theta).
int qnt_lwc
Quantity array index for cloud liquid water content.
double turb_mesoz
Vertical scaling factor for mesoscale wind fluctuations.
int grid_nc_level
zlib compression level of netCDF grid data files (0=off).
int grid_nx
Number of longitudes of gridded data.
int atm_type
Type of atmospheric data files (0=ASCII, 1=binary, 2=netCDF, 3=CLaMS_traj, 4=CLaMS_pos).
double bound_mass
Boundary conditions mass per particle [kg].
double grid_lat0
Lower latitude of gridded data [deg].
int qnt_ts
Quantity array index for surface temperature.
int qnt_loss_rate
Quantity array index for total loss rate.
double met_cms_eps_h2o
cmultiscale compression epsilon for water vapor.
int qnt_plfc
Quantity array index for pressure at level of free convection (LCF).
int qnt_Acs137
Quantity array index for radioactive activity of Cs-137.
double grid_lon0
Lower longitude of gridded data [deg].
int qnt_o1d
Quantity array index for O(1D) volume mixing ratio (climatology).
int met_tropo_spline
Tropopause interpolation method (0=linear, 1=spline).
int qnt_tvirt
Quantity array index for virtual temperature.
double dt_met
Time step of meteo data [s].
double chemgrid_lat1
Upper latitude of chemistry grid [deg].
int met_geopot_sy
Latitudinal smoothing of geopotential heights.
double met_cms_eps_u
cmultiscale compression epsilon for zonal wind.
double turb_dx_strat
Horizontal turbulent diffusion coefficient (stratosphere) [m^2/s].
int qnt_vmr
Quantity array index for volume mixing ratio.
int qnt_lsm
Quantity array index for land-sea mask.
int qnt_theta
Quantity array index for potential temperature.
double bound_lat1
Boundary conditions maximum longitude [deg].
double stat_t1
Stop time for station output [s].
double turb_dx_trop
Horizontal turbulent diffusion coefficient (troposphere) [m^2/s].
int grid_type
Type of grid data files (0=ASCII, 1=netCDF).
double csi_lon0
Lower longitude of gridded CSI data [deg].
int qnt_pbl
Quantity array index for boundary layer pressure.
int grid_stddev
Include standard deviations in grid output (0=no, 1=yes).
int qnt_psice
Quantity array index for saturation pressure over ice.
double chemgrid_lon0
Lower longitude of chemistry grid [deg].
int bound_pbl
Boundary conditions planetary boundary layer (0=no, 1=yes).
int qnt_mloss_wet
Quantity array index for total mass loss due to wet deposition.
int radio_decay
Switch for radioactive decay module (0=off, 1=on).
int met_geopot_sx
Longitudinal smoothing of geopotential heights.
int met_sy
Smoothing for latitudes.
int qnt_ps
Quantity array index for surface pressure.
int rng_type
Random number generator (0=GSL, 1=Squares, 2=cuRAND).
int isosurf
Isosurface parameter (0=none, 1=pressure, 2=density, 3=theta, 4=balloon).
double bound_p1
Boundary conditions top pressure [hPa].
int qnt_zs
Quantity array index for surface geopotential height.
int prof_nz
Number of altitudes of gridded profile data.
double csi_dt_out
Time step for CSI output [s].
int met_cape
Convective available potential energy data (0=file, 1=calculate).
double csi_modmin
Minimum column density to trigger detection [kg/m^2].
int met_sx
Smoothing for longitudes.
double chemgrid_lon1
Upper longitude of chemistry grid [deg].
double turb_mesox
Horizontal scaling factor for mesoscale wind fluctuations.
double met_cms_eps_iwc
cmultiscale compression epsilon for cloud ice water content.
double met_cms_eps_swc
cmultiscale compression epsilon for cloud snow water content.
double met_cms_eps_v
cmultiscale compression epsilon for meridional wind.
double prof_z0
Lower altitude of gridded profile data [km].
int qnt_w
Quantity array index for vertical velocity.
double bound_vmr
Boundary conditions volume mixing ratio [ppv].
double met_tropo_pv
Dynamical tropopause potential vorticity threshold [PVU].
int prof_nx
Number of longitudes of gridded profile data.
int qnt_stat
Quantity array index for station flag.
int met_tropo
Tropopause definition (0=none, 1=clim, 2=cold point, 3=WMO_1st, 4=WMO_2nd, 5=dynamical).
int qnt_rp
Quantity array index for particle radius.
int met_mpi_share
Use MPI to share meteo (0=no, 1=yes).
double mixing_strat
Interparcel exchange parameter for mixing in the stratosphere.
int qnt_vz
Quantity array index for vertical velocity.
int qnt_ho2
Quantity array index for HO2 volume mixing ratio (climatology).
double csi_z1
Upper altitude of gridded CSI data [km].
double stat_t0
Start time for station output [s].
double oh_chem_beta
Beta parameter for diurnal variablity of OH.
int dd
Domain decomposition (0=no, 1=yes, with 2x2 if not specified).
int qnt_eta
Quantity array index for eta vertical coordinate.
double wet_depo_so2_ph
pH value used to calculate effective Henry constant of SO2.
double mixing_z0
Lower altitude of mixing grid [km].
int qnt_mloss_decay
Quantity array index for total mass loss due to exponential decay.
int atm_type_out
Type of atmospheric data files for output (-1=same as ATM_TYPE, 0=ASCII, 1=binary,...
int met_cms_nd0x
cmultiscale number of cells of coarsest grid in x-direction.
int met_nlev
Number of meteo data model levels.
double dt_kpp
Time step for KPP chemistry [s].
double dry_depo_dp
Dry deposition surface layer [hPa].
int qnt_shf
Quantity array index for surface sensible heat flux.
int qnt_vs
Quantity array index for surface meridional wind.
int qnt_Cco
Quantity array index for CO volume mixing ratio (chemistry code).
double vtk_dt_out
Time step for VTK data output [s].
double t_stop
Stop time of simulation [s].
double conv_dt
Time interval for convection module [s].
int qnt_hno3
Quantity array index for HNO3 volume mixing ratio (climatology).
int met_clams
Read MPTRAC or CLaMS meteo data (0=MPTRAC, 1=CLaMS).
int qnt_h2ot
Quantity array index for tropopause water vapor volume mixing ratio.
int qnt_rh
Quantity array index for relative humidity over water.
double met_cms_eps_cc
cmultiscale compression epsilon for cloud cover.
double bound_lat0
Boundary conditions minimum longitude [deg].
double met_pbl_max
Maximum depth of planetary boundary layer [km].
int met_dx
Stride for longitudes.
int qnt_destination
Quantity array index for destination subdomain in domain decomposition.
int mixing_ny
Number of latitudes of mixing grid.
int met_convention
Meteo data layout (0=[lev, lat, lon], 1=[lon, lat, lev]).
int qnt_zeta_d
Quantity array index for diagnosed zeta vertical coordinate.
int tracer_chem
Switch for first order tracer chemistry module (0=off, 1=on).
double dt_mod
Time step of simulation [s].
int diffusion
Diffusion scheme (0=off, 1=fixed-K, 2=PBL).
int qnt_tnat
Quantity array index for T_NAT.
int qnt_eta_dot
Quantity array index for velocity of eta vertical coordinate.
int qnt_tice
Quantity array index for T_ice.
int qnt_zg
Quantity array index for geopotential height.
double vtk_offset
Vertical offset for VTK data [km].
int qnt_v
Quantity array index for meridional wind.
int qnt_mloss_dry
Quantity array index for total mass loss due to dry deposition.
double bound_vmr_trend
Boundary conditions volume mixing ratio trend [ppv/s].
int met_cache
Preload meteo data into disk cache (0=no, 1=yes).
int qnt_oh
Quantity array index for OH volume mixing ratio (climatology).
int qnt_Ch
Quantity array index for H volume mixing ratio (chemistry code).
int met_press_level_def
Use predefined pressure levels or not.
int oh_chem_reaction
Reaction type for OH chemistry (0=none, 2=bimolecular, 3=termolecular).
int qnt_h2o
Quantity array index for water vapor volume mixing ratio.
int prof_ny
Number of latitudes of gridded profile data.
int qnt_rhice
Quantity array index for relative humidity over ice.
int qnt_rho
Quantity array index for density of air.
double sample_dz
Layer depth for sample output [km].
double tdec_strat
Life time of particles in the stratosphere [s].
int obs_type
Type of observation data files (0=ASCII, 1=netCDF).
double met_cms_eps_lwc
cmultiscale compression epsilon for cloud liquid water content.
int qnt_us
Quantity array index for surface zonal wind.
double met_cms_eps_z
cmultiscale compression epsilon for geopotential height.
double grid_lon1
Upper longitude of gridded data [deg].
int qnt_Cn2o
Quantity array index for N2O volume mixing ratio (chemistry code).
int qnt_Cccl3f
Quantity array index for CFC-11 volume mixing ratio (chemistry code).
double mixing_lat0
Lower latitude of mixing grid [deg].
int nens
Number of ensembles.
int qnt_pt
Quantity array index for tropopause pressure.
int qnt_cl
Quantity array index for total column cloud water.
int advect
Advection scheme (0=off, 1=Euler, 2=midpoint, 4=Runge-Kutta).
double prof_z1
Upper altitude of gridded profile data [km].
int qnt_t
Quantity array index for temperature.
int atm_filter
Time filter for atmospheric data output (0=none, 1=missval, 2=remove).
int kpp_chem
Switch for KPP chemistry module (0=off, 1=on).
int qnt_zeta
Quantity array index for zeta vertical coordinate.
double conv_pbl_trans
Depth of PBL transition layer (fraction of PBL depth).
int qnt_Ai131
Quantity array index for radioactive activity of I-131.
int met_vert_coord
Vertical coordinate of input meteo data (0=plev, 1=mlev_p_file, 2=mlev_ab_file, 3=mlev_ab_full,...
double csi_z0
Lower altitude of gridded CSI data [km].
int qnt_lapse
Quantity array index for lapse rate.
int qnt_Apb210
Quantity array index for radioactive activity of Pb-210.
double stat_lat
Latitude of station [deg].
int qnt_Cho2
Quantity array index for HO2 volume mixing ratio (chemistry code).
int grid_ny
Number of latitudes of gridded data.
int qnt_Csf6
Quantity array index for SF6 volume mixing ratio (chemistry code).
int qnt_Ch2o
Quantity array index for H2O volume mixing ratio (chemistry code).
double met_detrend
FWHM of horizontal Gaussian used for detrending [km].
int conv_mix_pbl
Vertical mixing in the PBL (0=off, 1=on).
double bound_dps
Boundary conditions surface layer depth [hPa].
double met_cms_eps_t
cmultiscale compression epsilon for temperature.
int chemgrid_nz
Number of altitudes of chemistry grid.
int qnt_cape
Quantity array index for convective available potential energy (CAPE).
int qnt_zeta_dot
Quantity array index for velocity of zeta vertical coordinate.
double bound_mass_trend
Boundary conditions mass per particle trend [kg/s].
int met_cms_nd0y
cmultiscale number of cells of coarsest grid in y-direction.
int mixing_nz
Number of altitudes of mixing grid.
int qnt_o3c
Quantity array index for total column ozone.
double bound_p0
Boundary conditions bottom pressure [hPa].
double mixing_lon0
Lower longitude of mixing grid [deg].
int qnt_Co3
Quantity array index for O3 volume mixing ratio (chemistry code).
int qnt_tsts
Quantity array index for T_STS.
int grid_nz
Number of altitudes of gridded data.
int qnt_nss
Quantity array index for northward turbulent surface stress.
double ens_dt_out
Time step for ensemble output [s].
int atm_stride
Particle index stride for atmospheric data files.
int met_relhum
Try to read relative humidity (0=no, 1=yes).
double mixing_lat1
Upper latitude of mixing grid [deg].
double atm_dt_out
Time step for atmospheric data output [s].
double prof_lat1
Upper latitude of gridded profile data [deg].
int met_cms_batch
cmultiscale batch size.
double psc_h2o
H2O volume mixing ratio for PSC analysis.
int met_sp
Smoothing for pressure levels.
double prof_lon0
Lower longitude of gridded profile data [deg].
int qnt_Axe133
Quantity array index for radioactive activity of Xe-133.
int chemgrid_nx
Number of longitudes of chemistry grid.
int qnt_pct
Quantity array index for cloud top pressure.
int qnt_mloss_kpp
Quantity array index for total mass loss due to KPP chemistry.
int qnt_psat
Quantity array index for saturation pressure over water.
int qnt_subdomain
Quantity array index for current subdomain in domain decomposition.
double prof_lat0
Lower latitude of gridded profile data [deg].
int qnt_cin
Quantity array index for convective inhibition (CIN).
double psc_hno3
HNO3 volume mixing ratio for PSC analysis.
double prof_lon1
Upper longitude of gridded profile data [deg].
double met_cms_eps_rwc
cmultiscale compression epsilon for cloud rain water content.
int met_nc_quant
Number of digits for quantization of netCDF meteo files (0=off).
int h2o2_chem_reaction
Reaction type for H2O2 chemistry (0=none, 1=SO2).
int qnt_Co3p
Quantity array index for O(3P) volume mixing ratio (chemistry code).
double wet_depo_bc_ret_ratio
Coefficients for wet deposition below cloud: retention ratio.
int chemgrid_ny
Number of latitudes of chemistry grid.
int qnt_Abe7
Quantity array index for radioactive activity of Be-7.
double met_cms_eps_o3
cmultiscale compression epsilon for ozone.
int met_cms_zstd
cmultiscale ZSTD compression (0=off, 1=on).
int met_cms_maxlev
cmultiscale maximum refinement level.
int grid_sparse
Sparse output in grid data files (0=no, 1=yes).
double dry_depo_vdep
Dry deposition velocity [m/s].
int qnt_tt
Quantity array index for tropopause temperature.
int met_np
Number of target pressure levels.
int qnt_ens
Quantity array index for ensemble IDs.
int met_nc_level
zlib compression level of netCDF meteo files (0=off).
double mixing_dt
Time interval for mixing [s].
int qnt_Arn222
Quantity array index for radioactive activity of Rn-222.
int qnt_mloss_h2o2
Quantity array index for total mass loss due to H2O2 chemistry.
double vtk_scale
Vertical scaling factor for VTK data.
double met_cms_eps_w
cmultiscale compression epsilon for vertical velocity.
double turb_dx_pbl
Horizontal turbulent diffusion coefficient (PBL) [m^2/s].
double conv_cin
CIN threshold for convection module [J/kg].
int qnt_pv
Quantity array index for potential vorticity.
int advect_vert_coord
Vertical velocity of air parcels (0=omega_on_plev, 1=zetadot_on_mlev, 2=omega_on_mlev,...
int qnt_mloss_oh
Quantity array index for total mass loss due to OH chemistry.
int qnt_Ch2o2
Quantity array index for H2O2 volume mixing ratio (chemistry code).
int qnt_sst
Quantity array index for sea surface temperature.
double mixing_lon1
Upper longitude of mixing grid [deg].
int atm_nc_level
zlib compression level of netCDF atmospheric data files (0=off).
double wet_depo_ic_ret_ratio
Coefficients for wet deposition in cloud: retention ratio.
int qnt_sh
Quantity array index for specific humidity.
int qnt_ess
Quantity array index for eastward turbulent surface stress.
double wet_depo_ic_b
Coefficient B for wet deposition in cloud (exponential form).
double wet_depo_bc_b
Coefficient B for wet deposition below cloud (exponential form).
int met_dy
Stride for latitudes.
int qnt_Cx
Quantity array index for trace species x volume mixing ratio (chemistry code).
double turb_dz_strat
Vertical turbulent diffusion coefficient (stratosphere) [m^2/s].
double bound_zetas
Boundary conditions surface layer zeta [K].
int dd_subdomains_zonal
Domain decomposition zonal subdomain number.
int qnt_idx
Quantity array index for air parcel IDs.
double met_tropo_theta
Dynamical tropopause potential temperature threshold [K].
int qnt_rwc
Quantity array index for cloud rain water content.
double t_start
Start time of simulation [s].
int nq
Number of quantities.
double tdec_trop
Life time of particles in the troposphere [s].
double sample_dx
Horizontal radius for sample output [km].
int vtk_stride
Particle index stride for VTK data.
double turb_dz_pbl
Vertical turbulent diffusion coefficient (PBL) [m^2/s].
double grid_lat1
Upper latitude of gridded data [deg].
int dd_subdomains_meridional
Domain decomposition meridional subdomain number.
int qnt_zt
Quantity array index for tropopause geopotential height.
int met_type
Type of meteo data files (0=netCDF, 1=binary, 2=pck, 3=ZFP, 4=ZSTD, 5=cms, 6=grib,...
int qnt_cc
Quantity array index for cloud cover.
int qnt_plcl
Quantity array index for pressure at lifted condensation level (LCL).
double grid_dt_out
Time step for gridded data output [s].
int qnt_tdew
Quantity array index for dew point temperature.
Domain decomposition data structure.
int halo_offset_end
Offset of the periodic halo block at the end of the local x-array.
int nx_glob
Number of global longitudes.
int halo_offset_start
Offset of the periodic halo block at the beginning of the local x-array.
int ny_glob
Number of global latitudes.
int nx
Number of longitudes.
int ny
Number of latitudes.
int np
Number of pressure levels.
int npl
Number of model levels.
double lat
Latitude [deg].
double lon
Longitude [deg].