File: vmifutable.h

package info (click to toggle)
cpl-plugin-vimos 4.1.1%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 28,228 kB
  • sloc: ansic: 169,271; cpp: 16,177; sh: 4,344; python: 3,678; makefile: 1,138; perl: 10
file content (535 lines) | stat: -rw-r--r-- 13,255 bytes parent folder | download | duplicates (5)
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
/* $Id: vmifutable.h,v 1.2 2013-03-25 11:43:04 cgarcia Exp $
 *
 * This file is part of the VIMOS Pipeline
 * Copyright (C) 2002-2004 European Southern Observatory
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 */

/*
 * $Author: cgarcia $
 * $Date: 2013-03-25 11:43:04 $
 * $Revision: 1.2 $
 * $Name: not supported by cvs2svn $
 */

#ifndef VM_IFUTABLE_H
#define VM_IFUTABLE_H

#include <pilmacros.h>

#include <vmtable.h>


PIL_BEGIN_DECLS
/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
   defines of name strings for the IFU Table
 
   Description:
   The following strings are defined to use in the IFU Table for
   identifying the name of the table and of the columns
 
   Values:  
   VM_IFU          string giving the name of the IFU Table
   VM_IFU_x        name of column for fiber x coordinate on mask
   VM_IFU_y        name of column for fiber y coordinate on mask
   VM_IFU_L        name of column for fiber L coordinate on microlens
   VM_IFU_M        name of column for fiber M coordinate on microlens
   VM_IFU_PWIDTH   name of column for FWHM of spectrum on CCD (spatial
                   direction) in frame format
   VM_IFU_QUAD     name of column for vimos quadrant of mask this fiber is on
   VM_IFU_ROW      name of column for slit of fiber in mask plane
   VM_IFU_FIB      name of sequential number of fiber in each slit
   VM_IFU_TRANS    name of column for relative transmission of fiber with
                   respect to reference fiber
   VM_IFU_SIGMAY   name of column for sigma of spectrum on CCD in dispersion
                   direction (Y)
   VM_IFU_SIGMAYGROUP   name of column for grouping spectra on each slit 
                        according to their values of sigmaY (needed for sky
			spectrum determination)


   Updates:
   22 Nov 99: Created (AZ)
 
--------------------------------------------------------------------------------
*/

#define VM_IFU      "IFU"
/* Column names */
#define VM_IFU_x        "x"
#define VM_IFU_y        "y"
#define VM_IFU_L        "L"
#define VM_IFU_M        "M"
#define VM_IFU_PWIDTH   "PWIDTH"
#define VM_IFU_QUAD     "QUAD"
#define VM_IFU_ROW      "ROW"
#define VM_IFU_FIB      "FIB"
#define VM_IFU_TRANS    "TRANS"
#define VM_IFU_SIGMAY      "SIGMAY"
#define VM_IFU_SIGMAYGROUP "SIGMAYGROUP"

/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  stucture VimosIfuFiber

  Description:
  Linked list structure that contains the information of the fibers
  defined for each IFU slit on each mask.

  Layout:
     int   fibNo
     int   fiberL
     int   fiberM
     float fiberx
     float fibery
     float fiberTrans
     float fiberPwidth
     float sigmaY
     int   sigmaYGroup
     VimosIfuFiber *prev
     VimosIfuFiber *next

   Updates:
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

typedef struct _VIMOS_IFU_FIBER_
{
  int   fibNo;
  int   fiberL;
  int   fiberM;
  float fiberx;
  float fibery;
  float fiberTrans;
  float fiberPwidth;
  float sigmaY;
  int   sigmaYGroup;
  struct _VIMOS_IFU_FIBER_ *prev;
  struct _VIMOS_IFU_FIBER_ *next;
} VimosIfuFiber;


/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  stucture VimosIfuSlit

  Description:
  Linked list structure that contains the information of the slits defined
  for each IFU quadrant.

  Layout:
     int   ifuSlitNo
     VimosIfuFiber *fibers
     VimosIfuSlit  *prev
     VimosIfuSlit  *next

   Updates:
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

typedef struct _VIMOS_IFU_SLIT_
{
  int   ifuSlitNo;
  VimosIfuFiber *fibers;
  struct _VIMOS_IFU_SLIT_  *prev;
  struct _VIMOS_IFU_SLIT_  *next;
} VimosIfuSlit;



/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  structure VimosIfuQuad

  Description:
  Linked list structure that contains the information of the
  vimos quadrants.

  Layout:
     int           quadNo
     VimosIfuSlit  *ifuSlits
     int           numIfuSlits
     VimosIfuQuad  *prev
     VimosIfuQuad  *next

  Updates:
  22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

typedef struct _VIMOS_IFU_QUAD_
{
  int           quadNo;
  VimosIfuSlit  *ifuSlits;
  int numIfuSlits;
  struct _VIMOS_IFU_QUAD_  *prev;
  struct _VIMOS_IFU_QUAD_  *next;
} VimosIfuQuad;


/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  structure VimosIfuTable  

  Description:
  Here the true structure of a vimos IFU Table is defined.

  Layout:
     
  char            name
  VimosDescriptor *descs
  VimosIfuQuad    *quads
  int             numIfuQuads
  int             numIfufibs
  fitsfile       *fptr

  Updates:
  22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

typedef struct _VIMOS_IFU_TABLE_
{
  char            name[VM_DESC_LENGTH];
  VimosDescriptor *descs;
  VimosIfuQuad    *quads;
  int             numIfuQuads;
  int             numIfuFibs;
  fitsfile             *fptr;                  
} VimosIfuTable;






/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  VimosIfuFiber *newIfuFiber()

  Description: 
  Returns a pointer to a new IfuFiber structure.

  Input:
  void   

   Return Value (succes):
   Pointer to a newly allocated IfuFiber structure. All fields are
   initialized to 0

   Return Value (error):
   NULL

   Updates:
   13 Jun 00: Return NULL on error instead of exiting (Maura)
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

VimosIfuFiber *newIfuFiber();

/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   
  void deleteIfuFiber(VimosIfuFiber *ifuFiber)

  Description:
  Deletes all VimosIfuFibers contained in the linked list ifuFiber.

  Input:
  VimosIfuFiber *ifuFiber
  Pointer to VimosIfuFiber list to be deleted

  Return Value:
  void
   
  Updates:
  22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

 void deleteIfuFiber(VimosIfuFiber *ifuFiber);

/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   
   VimosIfuSlit  *newIfuSlit()

   Description: 
   Returns a pointer to a new VimosIfuSlit structure.
   
   Input:
   void   
   
   Return Value (success):
   Pointer to a newly allocated VimosIfuSlit structure. All fields are
   initialized to 0
 
   Return Value (error):
   NULL
   
   Updates:
   13 Jun 00: Return NULL on error instead of exiting (Maura)
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

  VimosIfuSlit  *newIfuSlit();

/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   
   void deleteIfuSlit(VimosIfuSlit *ifuSlit);

   Description: 
   Deletes all VimosIfuSlits (and VimosIfuFibers contained in the 
   VimosIfuSlit) contained in the linked list ifuSlit
   
   Input:
   VimosIfuSlit *ifuSlit
   Pointer to VimosIfuSlit list to be deleted

   Return Value:
   void
   
   Updates:
   22 Nov 99: Created (AZ)   

--------------------------------------------------------------------------------
*/

void deleteIfuSlit(VimosIfuSlit *ifuSlit);


/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   
   VimosIfuQuad  *newIfuQuad()

   Description: 
   Returns a pointer to a new VimosIfuQuad structure.
   
   Input:
   void   
   
   Return Value (success):
   Pointer to a newly allocated VimosIfuQuad structure. All fields are
   initialized to 0
 
   Return Value (error):
   NULL
   
   Updates:
   13 Jun 00: Return NULL on error instead of exiting (Maura)
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

  VimosIfuQuad  *newIfuQuad();

/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   
   void deleteIfuQuad(VimosIfuQuad *ifuQuad);

   Description: 
   Deletes all VimosIfuQuads (and VimosIfuSlits, VimosIfuFibers contained
   in the VimosIfuQuad) contained in the linked list ifuQuad
   
   Input:
   VimosIfuQuad *ifuQuad
   Pointer to VimosIfuQuad list to be deleted

   Return Value:
   void
   
   Updates:
   22 Nov 99: Created (AZ)   

--------------------------------------------------------------------------------
*/

void deleteIfuQuad(VimosIfuQuad *ifuQuad);

/*
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
   VimosIfuTable *newIfuTable()

   Description:
   Allocate a new IFU Table. All fields are initialized to 0, except the
   name field is set to VM_IFU

   Input:
   void
   
   Return Value (success):
   Pointer to the new VimosIfuTable

   Return Value (error):
   NULL
      
   Updates:
   13 Jun 00: Return NULL on error instead of exiting (Maura)
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

  VimosIfuTable *newIfuTable();


/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
   void deleteIfuTable(VimosIfuTable *ifuTable)

   Description:
   Delete an IFU Table.


   Input: 
   VimosIfuTable *ifuTable
   Pointer of IFU Table to be deleted
   
   Return Value:
   void
   
   Updates:
   22 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

   void deleteIfuTable(VimosIfuTable *ifuTable);


/* 
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
   VimosIfuSlit *computeIfuslit(int l_start, int m_start, int l_step, 
                               int m_step, int module_step_m, 
                               float x_start, float x_step, float y,
                               float x_module_step)


   Description:
   Computes (L,M) and (X,Y) coordinates of each fiber in a given slit

   Input: 
//   VimosIfuSlit *ifuSlit
   Pointer of IFU Slit
   
   Return Value (succes):
   VimosIfuSlit *ifuSlit

   Return Value (error):
   NULL 
   
   Updates:
   13 Jun 00: Return NULL on error (Maura)
   23 Nov 99: Created (AZ)

--------------------------------------------------------------------------------
*/

VimosIfuSlit *computeIfuSlit(int l_start, int m_start, int l_step, 
                             int m_step, int module_step_m,
                             float x_start, float x_step, float y,
                             float x_module_step);


VimosBool writeTable(VimosIfuTable *anIfuTable);

/* 
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   VimosBool readFitsIfuTable(VimosIfuTable *ifuTable, fitsfile *fptr)

   Description:
   Read a FITS Table into an IFU Table. This requires the FITS file to 
   be already open, and does not close it at the end.

   Input:
   VimosIfuTable *ifuTable
   Pointer to the IFU Table to copy the FITS Table into.

   fitsfile *fptr
   Pointer to the FITS file where the table is to be found

   Return Value:
   VimosBool

   Updates:
   11 Jan 00: Created (AZ)
   02 Feb 00: Changed the handling of the table, from a standalone FITS file,
              to an extension of the primary FITS file (MS)

-------------------------------------------------------------------------------
*/

VimosBool readFitsIfuTable(VimosIfuTable *ifuTable, fitsfile *fptr);


/* 
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
   VimosBool writeFitsIfuTable(VimosIfuTable *ifuTable, fitsfile *fptr)

   Description:
   Write an IFU Table into a FITS Table. This requires the FITS file
   to be already open, and does not close it at the end. If an IFU
   Table extension is already present in the file, it is first removed, and
   then the new one is written into a new extension.

   Input:
   VimosIfuTable *ifuTable
   Pointer to the IFU Table to write to a FITS Table.

   fitsfile *fptr
   Pointer to the FITS file where the table is to be found

   Return Value:
   VimosBool

   Updates:
   11 Jan 00: Created (AZ)
   02 Feb 00: Changed the handling of the table, from a standalone FITS file,
              to an extension of the primary FITS file (MS)

-------------------------------------------------------------------------------
*/

VimosBool writeFitsIfuTable(VimosIfuTable *ifuTable, fitsfile *fptr);

PIL_END_DECLS

#endif /* VM_IFUTABLE_H */