DETMON Pipeline Reference Manual  1.3.0
detmon_opt_lg.c
1 /* $Id: detmon_opt_lg.c,v 1.25 2013-01-29 08:56:40 jtaylor Exp $
2  *
3  * This file is part of the DETMON Pipeline
4  * Copyright (C) 2002,2003 European Southern Observatory
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02111-1307 USA
19  */
20 
21 /*
22  * $Author: jtaylor $
23  * $Date: 2013-01-29 08:56:40 $
24  * $Revision: 1.25 $
25  * $Name: not supported by cvs2svn $
26  */
27 #ifdef HAVE_CONFIG_H
28 #include <config.h>
29 #endif
30 
31 /*----------------------------------------------------------------------------
32  Includes
33  ----------------------------------------------------------------------------*/
34 
35 #include <cpl.h>
36 
37 #include "detmon.h"
38 #include "detmon_lg.h"
39 #include "irplib_plugin.h"
40 
41 #define RECIPE_NAME "detmon_opt_lg"
42 
43 #define OPT FALSE
44 
45 /*----------------------------------------------------------------------------
46  Functions prototypes
47  ----------------------------------------------------------------------------*/
48 
49 CPL_RECIPE_DEFINE(detmon_opt_lg, DETMON_BINARY_VERSION,
50  detmon_lg_fill_parlist_opt_default(recipe->parameters,
51  "detmon_opt_lg", "detmon"),
52  "Lander de Bilbao", "lbilbao@eso.org", "2007",
53  "Linearity/Gain recipe for the optical domain",
54  detmon_lg_get_description("detmon_opt_lg", "DETMON",
55  DETMON_LG_ON_RAW_NEW,
56  DETMON_LG_OFF_RAW_NEW,
57  DETMON_LG_ON_RAW_OLD,
58  DETMON_LG_OFF_RAW_OLD));
60 /*---------------------------------------------------------------------------*/
61 /*
62  @brief Interpret the command line options and execute the data processing
63  @param frameset the frames list
64  @param parlist the parameters list
65  @return 0 if everything is ok
66  */
67 /*---------------------------------------------------------------------------*/
68 
69 static int detmon_opt_lg(cpl_frameset * frameset,
70  const cpl_parameterlist * parlist)
71 {
72 
73  const char * tag_on=NULL;
74  const char * tag_off=NULL;
75  cpl_propertylist * lintbl =
76  detmon_fill_prolist("DET_LIN_INFO", "REDUCED", "TECH", CPL_FALSE);
77 
78  cpl_propertylist * gaintbl =
79  detmon_fill_prolist("GAIN_INFO", "REDUCED", "TECH", CPL_FALSE);
80 
81  cpl_propertylist * coeffscube =
82  detmon_fill_prolist("COEFFS_CUBE", "REDUCED", "TECH", CPL_FALSE);
83 
84  cpl_propertylist * bpm =
85  detmon_fill_prolist("BP_MAP_NL", "REDUCED", "TECH", CPL_FALSE);
86 
87  cpl_propertylist * corr =
88  detmon_fill_prolist("AUTOCORR", "REDUCED", "TECH", CPL_FALSE);
89 
90  cpl_propertylist * diff_flat =
91  detmon_fill_prolist("DIFF_FLAT", "REDUCED", "TECH", CPL_FALSE);
92 
93  cpl_error_code error = CPL_ERROR_NONE;
94  skip_if (detmon_lg_set_tag(frameset, &tag_on, &tag_off));
95 
96  error = detmon_lg(frameset,
97  parlist,
98  tag_on,
99  tag_off,
100  RECIPE_NAME,
101  PACKAGE_TARNAME,
102  REGEXP,
103  lintbl, gaintbl, coeffscube,
104  bpm, corr, diff_flat,
105  PACKAGE "/" PACKAGE_VERSION,
106  NULL, NULL, OPT);
107 
108  end_skip;
109  cpl_propertylist_delete(lintbl);
110  cpl_propertylist_delete(gaintbl);
111  cpl_propertylist_delete(coeffscube);
112  cpl_propertylist_delete(bpm);
113  cpl_propertylist_delete(corr);
114  cpl_propertylist_delete(diff_flat);
115 
116  /* Propagate the error, if any */
117  cpl_ensure_code(!error, error);
118 
119  return CPL_ERROR_NONE;
120 }