29 {
30
33
34 double clk[
NCL], sfeps[
NSF];
35
36
37 if (argc < 3)
38 ERRMSG(
"Give parameters: <ctl> <atm>");
39
40
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 double clz =
scan_ctl(argc, argv,
"CLZ", -1,
"0", NULL);
49 const double cldz =
scan_ctl(argc, argv,
"CLDZ", -1,
"0", NULL);
50 for (
int icl = 0; icl < ctl.
ncl; icl++)
51 clk[icl] =
scan_ctl(argc, argv,
"CLK", icl,
"0", NULL);
52 const double sft =
scan_ctl(argc, argv,
"SFT", -1,
"0", NULL);
53 for (
int isf = 0; isf < ctl.
nsf; isf++)
54 sfeps[isf] =
scan_ctl(argc, argv,
"SFEPS", isf,
"1", NULL);
55
56
57 for (double t = t0; t <= t1; t += dt)
58 for (double z = z0; z <= z1; z += dz) {
62 ERRMSG(
"Too many atmospheric grid points!");
63 }
64
65
67
68
71 for (
int icl = 0; icl < ctl.
ncl; icl++)
72 atm.
clk[icl] = clk[icl];
73
74
76 for (
int isf = 0; isf < ctl.
nsf; isf++)
77 atm.
sfeps[isf] = sfeps[isf];
78
79
81
82 return EXIT_SUCCESS;
83}
void write_atm(const char *dirname, const char *filename, const ctl_t *ctl, const atm_t *atm)
Write atmospheric profile data to a text 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.
#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.