File: any_to_ppm.c

package info (click to toggle)
librsl 1.42-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 3,836 kB
  • sloc: ansic: 16,950; sh: 8,544; yacc: 316; perl: 151; lex: 94; makefile: 61
file content (79 lines) | stat: -rw-r--r-- 1,719 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/*
 * Ingest NEXRAD (wsr88d) data and output images representing
 * all field types found.
 *
 * This example is the most minimum of coding that you need to do
 * to achieve good results from using the RSL code.
 *
 * This is short and sweet to demonstrate the simplicity of use for
 * the RSL.
 *
 */
#include <stdlib.h>

#define USE_RSL_VARS
#include "rsl.h"

int main(int argc, char **argv)
{
  Radar *radar;
  Sweep *sweep;
  Ray   *ray;
  int   i;
  char fname[100];

  if (argc < 2 || argc > 3) {
	fprintf(stderr, "Usage: %s infile [callid_or_firstfile]\n", argv[0]);
	exit(-1);
  }

  RSL_radar_verbose_on(); /* Not needed; it bides the time. */
  RSL_select_fields("all", NULL);
  radar = RSL_anyformat_to_radar(argv[1], argv[2]);

  if (radar == NULL) exit(-1);

  if (0) {
	RSL_write_radar(radar, "rsl.rsl");
	exit(0);
  }

  {
	char time_string[100];
	sprintf(time_string,"%2.2d%2.2d%2.2d_%2.2d%2.2d", 
		    radar->h.month, radar->h.day, radar->h.year-1900, 
		    radar->h.hour, radar->h.minute);
  }

  for (i=0; i<MAX_RADAR_VOLUMES; i++) {
	sweep = RSL_get_first_sweep_of_volume(radar->v[i]);
	ray   = RSL_get_first_ray_of_volume(radar->v[i]);

	if (sweep) {
	  if (i == SW_INDEX)
		RSL_load_sw_color_table();
	  else if (i == VR_INDEX || i == VE_INDEX) {
		RSL_load_vel_color_table();
		RSL_rebin_velocity_volume(radar->v[i]);
	  } else
		RSL_load_refl_color_table();


#undef DO_SWEEP
#define DO_SWEEP
#ifdef DO_SWEEP
	  sprintf(fname, "%s_sweep.ppm", RSL_ftype[i]);
	  RSL_sweep_to_ppm(sweep, fname, 400, 400, 200.0);
	  fprintf(stderr, "Wrote %s\n", fname);
#else	
	  sprintf(fname, "%s_sweep", RSL_ftype[i]);
	  RSL_volume_to_gif(radar->v[i], fname, 400, 400, 200.0);
#endif
	}
  }
  exit(0);

}