JURASSIC
Functions
limb.c File Reference

Create observation geometry for a limb sounder. More...

#include "jurassic.h"

Go to the source code of this file.

Functions

int main (int argc, char *argv[])
 

Detailed Description

Create observation geometry for a limb sounder.

Definition in file limb.c.

Function Documentation

◆ main()

int main ( int  argc,
char *  argv[] 
)

Definition at line 27 of file limb.c.

29 {
30
31 static ctl_t ctl;
32 static obs_t obs;
33
34 /* Check arguments... */
35 if (argc < 3)
36 ERRMSG("Give parameters: <ctl> <obs>");
37
38 /* Read control parameters... */
39 read_ctl(argc, argv, &ctl);
40 double obsz = scan_ctl(argc, argv, "OBSZ", -1, "780", NULL);
41 double t0 = scan_ctl(argc, argv, "T0", -1, "0", NULL);
42 double t1 = scan_ctl(argc, argv, "T1", -1, "0", NULL);
43 double dt = scan_ctl(argc, argv, "DT", -1, "1", NULL);
44 double z0 = scan_ctl(argc, argv, "Z0", -1, "3", NULL);
45 double z1 = scan_ctl(argc, argv, "Z1", -1, "68", NULL);
46 double dz = scan_ctl(argc, argv, "DZ", -1, "1", NULL);
47
48 /* Create measurement geometry... */
49 for (double t = t0; t <= t1; t += dt)
50 for (double z = z0; z <= z1; z += dz) {
51 obs.time[obs.nr] = t;
52 obs.obsz[obs.nr] = obsz;
53 obs.vpz[obs.nr] = z;
54 obs.vplat[obs.nr] = 180 / M_PI * acos((RE + z) / (RE + obsz));
55 if ((++obs.nr) >= NR)
56 ERRMSG("Too many rays!");
57 }
58
59 /* Write observation data... */
60 write_obs(NULL, argv[2], &ctl, &obs);
61
62 return EXIT_SUCCESS;
63}
void read_ctl(int argc, char *argv[], ctl_t *ctl)
Read forward model control parameters.
Definition: jurassic.c:4561
void write_obs(const char *dirname, const char *filename, ctl_t *ctl, obs_t *obs)
Write observation data.
Definition: jurassic.c:5697
double scan_ctl(int argc, char *argv[], const char *varname, int arridx, const char *defvalue, char *value)
Search control parameter file for variable entry.
Definition: jurassic.c:5138
#define RE
Mean radius of Earth [km].
Definition: jurassic.h:279
#define ERRMSG(...)
Print error message and quit program.
Definition: jurassic.h:217
#define NR
Maximum number of ray paths.
Definition: jurassic.h:348
Forward model control parameters.
Definition: jurassic.h:521
Observation geometry and radiance data.
Definition: jurassic.h:714
double vpz[NR]
View point altitude [km].
Definition: jurassic.h:732
double vplat[NR]
View point latitude [deg].
Definition: jurassic.h:738
double obsz[NR]
Observer altitude [km].
Definition: jurassic.h:723
double time[NR]
Time (seconds since 2000-01-01T00:00Z).
Definition: jurassic.h:720
int nr
Number of ray paths.
Definition: jurassic.h:717
Here is the call graph for this function: