DETMON Pipeline Reference Manual  1.3.0
detmon_ir_lg.c
1 /* $Id: detmon_ir_lg.c,v 1.33 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.33 $
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_ir_lg"
42 
43 #define NIR TRUE
44 
45 /*----------------------------------------------------------------------------
46  Functions prototypes
47  ----------------------------------------------------------------------------*/
48 
49 CPL_RECIPE_DEFINE(detmon_ir_lg, DETMON_BINARY_VERSION,
50  detmon_lg_fill_parlist_nir_default(recipe->parameters,
51  "detmon_ir_lg", "detmon"),
52  "Lander de Bilbao", "lbilbao@eso.org", "2007",
53  "Linearity/Gain recipe for the IR domain",
54  detmon_lg_get_description("detmon_ir_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_ir_lg(cpl_frameset * frameset,
70  const cpl_parameterlist * parlist)
71 {
72 
73 
74  const char * tag_on=NULL;
75  const char * tag_off=NULL;
76  cpl_propertylist * lintbl =
77  detmon_fill_prolist("DET_LIN_INFO", "REDUCED", "TECH", CPL_FALSE);
78 
79  cpl_propertylist * gaintbl =
80  detmon_fill_prolist("GAIN_INFO", "REDUCED", "TECH", CPL_FALSE);
81 
82  cpl_propertylist * coeffscube =
83  detmon_fill_prolist("COEFFS_CUBE", "REDUCED", "TECH", CPL_FALSE);
84 
85  cpl_propertylist * bpm =
86  detmon_fill_prolist("BP_MAP_NL", "REDUCED", "TECH", CPL_FALSE);
87 
88  cpl_propertylist * corr =
89  detmon_fill_prolist("AUTOCORR", "REDUCED", "TECH", CPL_FALSE);
90 
91  cpl_propertylist * diff_flat =
92  detmon_fill_prolist("DIFF_FLAT", "REDUCED", "TECH", CPL_FALSE);
93 
94  cpl_error_code error=CPL_ERROR_NONE;
95  skip_if (detmon_lg_set_tag(frameset, &tag_on, &tag_off));
96 
97  error = detmon_lg(frameset,
98  parlist,
99  tag_on,
100  tag_off,
101  RECIPE_NAME,
102  PACKAGE_TARNAME,
103  REGEXP,
104  lintbl, gaintbl, coeffscube,
105  bpm, corr, diff_flat,
106  PACKAGE "/" PACKAGE_VERSION,
107  NULL, NULL, NIR);
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 }