34 double clk[
NCL], sfeps[
NSF];
38 ERRMSG(
"Give parameters: <ctl> <atm>");
42 const double t0 =
scan_ctl(argc, argv,
"T0", -1,
"0", NULL);
43 const double t1 =
scan_ctl(argc, argv,
"T1", -1,
"0", NULL);
44 const double dt =
scan_ctl(argc, argv,
"DT", -1,
"1", NULL);
45 const double z0 =
scan_ctl(argc, argv,
"Z0", -1,
"0", NULL);
46 const double z1 =
scan_ctl(argc, argv,
"Z1", -1,
"90", NULL);
47 const double dz =
scan_ctl(argc, argv,
"DZ", -1,
"1", NULL);
48 const int zsurf = (int)
scan_ctl(argc, argv,
"ZSURF", -1,
"0", NULL);
49 const double clz =
scan_ctl(argc, argv,
"CLZ", -1,
"0", NULL);
50 const double cldz =
scan_ctl(argc, argv,
"CLDZ", -1,
"0", NULL);
51 for (
int icl = 0; icl < ctl.
ncl; icl++)
52 clk[icl] =
scan_ctl(argc, argv,
"CLK", icl,
"0", NULL);
53 const double sft =
scan_ctl(argc, argv,
"SFT", -1,
"0", NULL);
54 for (
int isf = 0; isf < ctl.
nsf; isf++)
55 sfeps[isf] =
scan_ctl(argc, argv,
"SFEPS", isf,
"1", NULL);
58 for (
double t = t0; t <= t1 + 0.5 * dt; t += dt) {
71 for (
double z = 0.1; z <= 1.0 + 1e-9; z += 0.1)
72 atm.
z[atm.
np++] = z0 + z;
74 for (
double z = 1.2; z <= 2.0 + 1e-9; z += 0.2)
75 atm.
z[atm.
np++] = z0 + z;
77 ERRMSG(
"Too many atmospheric grid points!");
81 for (
double z = z0; z <= z1; z += dz)
82 if (atm.
np == 0 || z > atm.
z[atm.
np - 1] + 1e-9) {
85 ERRMSG(
"Too many atmospheric grid points!");
89 for (
int ip = 0; ip < atm.
np; ip++)
99 for (
int icl = 0; icl < ctl.
ncl; icl++)
100 atm.
clk[icl] = clk[icl];
104 for (
int isf = 0; isf < ctl.
nsf; isf++)
105 atm.
sfeps[isf] = sfeps[isf];
int main(int argc, char *argv[])
void write_atm(const char *dirname, const char *filename, const ctl_t *ctl, const atm_t *atm)
Write atmospheric data to a file.
void read_ctl(int argc, char *argv[], ctl_t *ctl)
Read model control parameters from command-line and configuration input.
double scan_ctl(int argc, char *argv[], const char *varname, const int arridx, const char *defvalue, char *value)
Scan control file or command-line arguments for a configuration variable.
void climatology(const ctl_t *ctl, atm_t *atm)
Initializes atmospheric climatology profiles.
JURASSIC library declarations.
#define ERRMSG(...)
Print an error message with contextual information and terminate the program.
#define NP
Maximum number of atmospheric data points.
#define NSF
Maximum number of surface layer spectral grid points.
#define NCL
Maximum number of cloud layer spectral grid points.
Atmospheric profile data.
double time[NP]
Time (seconds since 2000-01-01T00:00Z).
double sfeps[NSF]
Surface emissivity.
double clz
Cloud layer height [km].
int np
Number of data points.
double cldz
Cloud layer depth [km].
double sft
Surface temperature [K].
double z[NP]
Altitude [km].
double clk[NCL]
Cloud layer extinction [km^-1].
int ncl
Number of cloud layer spectral grid points.
int nsf
Number of surface layer spectral grid points.