source: trunk/src/STCalibration.h @ 2915

Last change on this file since 2915 was 2915, checked in by Takeshi Nakazato, 10 years ago

New Development: No

JIRA Issue: No

Ready for Test: Yes

Interface Changes: No

What Interface Changed: Please list interface changes

Test Programs: List test programs

Put in Release Notes: Yes/No?

Module(s): Module Names change impacts.

Description: Describe your changes here...

Refactoring STCalibration and its derived classes.
Fix for threshold of time gap analysis.


File size: 1.6 KB
Line 
1//
2// C++ Interface: STCalibration
3//
4// Description:
5//
6//
7// Author: Takeshi Nakazato <takeshi.nakazato@nao.ac.jp>, (C) 2012
8//
9// Copyright: See COPYING file that comes with this distribution
10//
11//
12#ifndef ASAPSTCALIBRATION_H
13#define ASAPSTCALIBRATION_H
14
15#include <casa/aips.h>
16#include <casa/Arrays/Vector.h>
17#include <casa/BasicSL/String.h>
18#include <casa/Utilities/CountedPtr.h>
19#include <casa/Logging/LogIO.h>
20#include <casa/Containers/Record.h>
21
22#include <scimath/Mathematics/InterpolateArray1D.h>
23
24#include "Scantable.h"
25#include "STDefs.h"
26#include "STApplyTable.h"
27#include "STSelector.h"
28
29namespace asap {
30
31/**
32 * Calibration operations on Scantable objects
33 * @author TakeshiNakazato
34 */
35class STCalibration {
36public:
37  STCalibration(casa::CountedPtr<Scantable> &s, const casa::String target_column);
38
39  void calibrate();
40
41  virtual ~STCalibration() {;}
42
43  void save(casa::String name) {applytable_->save(name);}
44  //const STApplyTable &applytable() {return *applytable_;}
45  const casa::CountedPtr<STApplyTable> applytable() {return applytable_;}
46
47  void setOption(casa::Record &rec) {options_ = rec;}
48
49protected:
50  virtual void setupSelector(const STSelector &sel) = 0;
51  virtual void fillCalTable();
52  virtual void appenddata(casa::uInt scanno, casa::uInt cycleno,
53                          casa::uInt beamno, casa::uInt ifno, casa::uInt polno,
54                          casa::uInt freqid, casa::Double time, casa::Float elevation,
55                          casa::Vector<casa::Float> any_data) = 0;
56
57  STSelector sel_;
58  casa::CountedPtr<Scantable> scantable_;
59  casa::CountedPtr<STApplyTable> applytable_;
60  casa::LogIO os_;
61  casa::Record options_;
62  const casa::String target_column_;
63};
64 
65}
66#endif
Note: See TracBrowser for help on using the repository browser.