DETMON Pipeline Reference Manual  1.2.7
detmon_ronbias.c
1 /* $Id: detmon_ronbias.c,v 1.13 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.13 $
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 "irplib_detmon.h"
38 #include "irplib_plugin.h"
39 
40 /* Define here the DO.CATG keywords */
41 #define DETMON_RONBIAS_RAW "BIAS"
42 
43 #define RECIPE_NAME "detmon_ronbias"
44 
45 /*----------------------------------------------------------------------------
46  Functions prototypes
47  ----------------------------------------------------------------------------*/
48 
49 CPL_RECIPE_DEFINE(detmon_ronbias, DETMON_BINARY_VERSION,
50  irplib_detmon_ronbias_fill_parlist_default(recipe->parameters,
51  "detmon_ronbias",
52  "detmon"),
53  "Lander de Bilbao", "lbilbao@eso.org", "2007",
54  "RON/Bias recipe",
55  irplib_detmon_ronbias_get_description("detmon_ronbias",
56  "DETMON",
57  DETMON_RONBIAS_RAW));
59 /*---------------------------------------------------------------------------*/
60 /*
61  @brief Interpret the command line options and execute the data processing
62  @param frameset the frames list
63  @param parlist the parameters list
64  @return 0 if everything is ok
65  */
66 /*---------------------------------------------------------------------------*/
67 
68 static int detmon_ronbias(cpl_frameset * frameset,
69  const cpl_parameterlist * parlist)
70 {
71  cpl_propertylist * master =
72  irplib_detmon_fill_prolist("MASTER_BIAS", "REDUCED", "TECH", CPL_FALSE);
73 
74  cpl_propertylist * synth =
75  irplib_detmon_fill_prolist("SYNTH", "REDUCED", "TECH", CPL_FALSE);
76 
77  cpl_propertylist * bpmhot =
78  irplib_detmon_fill_prolist("BP_MAP_HP", "REDUCED", "TECH", CPL_FALSE);
79 
80  cpl_propertylist * bpmcold =
81  irplib_detmon_fill_prolist("BP_MAP_CP","REDUCED", "TECH", CPL_FALSE);
82 
83  cpl_propertylist * bpmdev =
84  irplib_detmon_fill_prolist("BP_MAP_DP","REDUCED", "TECH", CPL_FALSE);
85 
86  const cpl_error_code error = irplib_detmon_ronbias(frameset,
87  parlist,
88  DETMON_RONBIAS_RAW,
89  RECIPE_NAME,
90  PACKAGE_TARNAME,
91  REGEXP,
92  master, NULL, NULL,
93  synth, bpmhot,
94  bpmcold, bpmdev,
95  PACKAGE "/" PACKAGE_VERSION,
96  NULL, OPT);
97 
98  cpl_propertylist_delete(master);
99  cpl_propertylist_delete(synth);
100  cpl_propertylist_delete(bpmhot);
101  cpl_propertylist_delete(bpmcold);
102  cpl_propertylist_delete(bpmdev);
103 
104  /* Propagate the error, if any */
105  cpl_ensure_code(!error, error);
106 
107  return CPL_ERROR_NONE;
108 }