source: branches/hpc33/src/STGrid.h@ 2493

Last change on this file since 2493 was 2459, checked in by Kana Sugimoto, 13 years ago

merged Takeshi's fix to asapgrid and STGrid class form trunk

File size: 7.0 KB
RevLine 
[2356]1//
2// C++ Interface: STGrid
3//
4// Description:
5//
6//
7// Author: Takeshi Nakazato <takeshi.nakazato@nao.ac.jp>, (C) 2011
8//
9// Copyright: See COPYING file that comes with this distribution
10//
11//
12#ifndef ASAPSTGRID_H
13#define ASAPSTGRID_H
14
15#include <iostream>
16#include <fstream>
17#include <string>
[2360]18#include <vector>
[2356]19
20#include <casa/BasicSL/String.h>
[2381]21#include <casa/Arrays/Array.h>
[2356]22#include <casa/Arrays/Vector.h>
[2381]23#include <casa/Containers/RecordField.h>
[2356]24
25#include <tables/Tables/Table.h>
[2379]26#include <tables/Tables/ScalarColumn.h>
27#include <tables/Tables/ArrayColumn.h>
[2393]28
29#include "concurrent.h"
[2356]30
31using namespace std ;
32using namespace casa ;
33
34namespace asap {
35class STGrid
36{
37public:
38 STGrid() ;
39 STGrid( const string infile ) ;
[2390]40 STGrid( const vector<string> infile ) ;
[2356]41 virtual ~STGrid() {} ;
42
43 void setFileIn( const string infile ) ;
[2390]44 void setFileList( const vector<string> infile ) ;
[2356]45
[2362]46 void setIF( unsigned int ifno ) { ifno_ = ifno ; } ;
47
[2360]48 void setPolList( vector<unsigned int> pols ) ;
49
[2364]50 void setScanList( vector<unsigned int> scans ) ;
51
[2356]52 void defineImage( int nx=-1,
53 int ny=-1,
54 string scellx="",
55 string scelly="",
56 string scenter="" ) ;
[2364]57 void setFunc( string convtype="box",
58 int convsupport=-1 ) ;
[2361]59
60 void setWeight( const string wType="uniform" ) ;
61
[2396]62 void enableClip() { doclip_ = True ; } ;
63 void disableClip() { doclip_ = False ; } ;
64
[2356]65 void grid() ;
66
67 string saveData( string outfile="" ) ;
68
69private:
70 void init() ;
71
[2382]72 // actual gridding
73 void gridPerRow() ;
[2396]74 void gridPerRowWithClipping() ;
[2382]75
[2396]76 // clipping
77 void clipMinMax( Array<Complex> &data,
78 Array<Float> &weight,
79 Array<Int> &npoints,
80 Array<Complex> &clipmin,
81 Array<Float> &clipwmin,
82 Array<Float> &clipcmin,
83 Array<Complex> &clipmax,
84 Array<Float> &clipwmax,
85 Array<Float> &clipcmax ) ;
86
87
[2388]88 void setupGrid() ;
[2356]89 void setupGrid( Int &nx,
90 Int &ny,
91 String &cellx,
92 String &celly,
93 Double &xmin,
94 Double &xmax,
95 Double &ymin,
96 Double &ymax,
97 String &center ) ;
[2388]98 void mapExtent( Double &xmin, Double &xmax,
99 Double &ymin, Double &ymax ) ;
[2368]100
[2378]101 void setData( Array<Complex> &gdata,
[2368]102 Array<Float> &gwgt ) ;
[2356]103
[2393]104 Int getDataChunk( IPosition const &wshape,
105 IPosition const &vshape,
106 IPosition const &dshape,
107 Array<Complex> &spectra,
108 Array<Double> &direction,
109 Array<Int> &flagtra,
110 Array<Int> &rflag,
111 Array<Float> &weight ) ;
[2379]112 Int getDataChunk( Array<Complex> &spectra,
113 Array<Double> &direction,
114 Array<Int> &flagtra,
115 Array<Int> &rflag,
116 Array<Float> &weight ) ;
117 Int getDataChunk( Array<Float> &spectra,
118 Array<Double> &direction,
119 Array<uChar> &flagtra,
120 Array<uInt> &rflag,
121 Array<Float> &weight ) ;
[2356]122
[2375]123 void getWeight( Array<Float> &w,
124 Array<Float> &tsys,
125 Array<Double> &tint ) ;
[2382]126
[2375]127 void toInt( Array<uChar> &u, Array<Int> &v ) ;
128 void toInt( Array<uInt> &u, Array<Int> &v ) ;
[2356]129
[2375]130 void toPixel( Array<Double> &world, Array<Double> &pixel ) ;
[2356]131
132 void boxFunc( Vector<Float> &convFunc, Int &convSize ) ;
133 void spheroidalFunc( Vector<Float> &convFunc ) ;
134 void gaussFunc( Vector<Float> &convFunc ) ;
135 void pbFunc( Vector<Float> &convFunc ) ;
136 void setConvFunc( Vector<Float> &convFunc ) ;
137
[2371]138 void prepareTable( Table &tab, String &name ) ;
139
[2379]140 void selectData() ;
141 void setupArray() ;
[2378]142
[2398]143 void updateChunkShape() ;
[2382]144 void attach( Table &tab ) ;
[2379]145
[2384]146 void call_ggridsd( Array<Double> &xy,
147 Array<Complex> &values,
148 Int &nvispol,
149 Int &nvischan,
150 Array<Int> &flag,
151 Array<Int> &rflag,
152 Array<Float> &weight,
153 Int &nrow,
154 Int &irow,
155 Array<Complex> &grid,
156 Array<Float> &wgrid,
157 Int &nx,
158 Int &ny,
159 Int &npol,
160 Int &nchan,
161 Int &support,
162 Int &sampling,
163 Vector<Float> &convFunc,
[2381]164 Int *chanMap,
165 Int *polMap ) ;
[2396]166 void call_ggridsd2( Array<Double> &xy,
167 Array<Complex> &values,
168 Int &nvispol,
169 Int &nvischan,
170 Array<Int> &flag,
171 Array<Int> &rflag,
172 Array<Float> &weight,
173 Int &nrow,
174 Int &irow,
175 Array<Complex> &grid,
176 Array<Float> &wgrid,
177 Array<Int> &npoints,
178 Array<Complex> &clipmin,
179 Array<Float> &clipwmin,
180 Array<Float> &clipcmin,
181 Array<Complex> &clipmax,
182 Array<Float> &clipwmax,
183 Array<Float> &clipcmax,
184 Int &nx,
185 Int &ny,
186 Int &npol,
187 Int &nchan,
188 Int &support,
189 Int &sampling,
190 Vector<Float> &convFunc,
191 Int *chanMap,
192 Int *polMap ) ;
[2379]193
[2382]194 void initPol( Int ipol ) ;
[2390]195 void initTable( uInt idx ) ;
[2386]196 Bool isMultiIF( Table &tab ) ;
[2459]197 void fillMainColumns( Table &tab ) ;
[2393]198 static bool produceChunk(void *ctx) throw(concurrent::PCException);
199 static void consumeChunk(void *ctx) throw(concurrent::PCException);
[2396]200 static void consumeChunkWithClipping(void *ctx) throw(concurrent::PCException);
[2381]201
[2382]202
[2388]203 // user input
204 Int nxUI_ ;
205 Int nyUI_ ;
206 String cellxUI_ ;
207 String cellyUI_ ;
208 String centerUI_ ;
209
[2389]210 Block<String> infileList_ ;
[2390]211 uInt nfile_ ;
[2362]212 Int ifno_ ;
[2396]213 Bool doclip_ ;
[2393]214
[2356]215 Int nx_ ;
216 Int ny_ ;
[2361]217 Int npol_ ;
[2386]218 Int npolOrg_ ;
[2361]219 Int nchan_ ;
[2356]220 Double cellx_ ;
221 Double celly_ ;
222 Vector<Double> center_ ;
223 String convType_ ;
224 Int convSupport_ ;
225 Int userSupport_ ;
226 Int convSampling_ ;
[2360]227 Vector<uInt> pollist_ ;
[2364]228 Vector<uInt> scanlist_ ;
[2361]229 String wtype_ ;
[2393]230 Block<Table> tableList_ ;
231 Vector<uInt> rows_ ;
232 Int nchunk_ ;
[2356]233
[2393]234 /////////////// gridPerRow variable
235 IPosition vshape_;
236 IPosition wshape_;
237 IPosition dshape_;
238 // loop variable
239 Int nrow_ ;
240 Array<Float> data_ ;
241
[2356]242 Table tab_ ;
[2393]243 // per pol
[2382]244 Table ptab_ ;
[2379]245 ROArrayColumn<Float> spectraCol_ ;
246 ROArrayColumn<uChar> flagtraCol_ ;
247 ROArrayColumn<Double> directionCol_ ;
248 ROScalarColumn<uInt> flagRowCol_ ;
249 ROArrayColumn<Float> tsysCol_ ;
250 ROScalarColumn<Double> intervalCol_ ;
[2393]251
[2379]252 Int nprocessed_ ;
[2381]253
254
[2393]255 double eGetData_;
256 double eToPixel_;
257 double eGGridSD_;
[2356]258};
259}
260#endif
Note: See TracBrowser for help on using the repository browser.