source: branches/newfiller/external-alma/atnf/PKSIO/NRODataset.cc@ 2306

Last change on this file since 2306 was 1757, checked in by Kana Sugimoto, 14 years ago

New Development: Yes

JIRA Issue: Yes (CAS-2211)

Ready for Test: Yes

Interface Changes: Yes

What Interface Changed: ASAP 3.0.0 interface changes

Test Programs:

Put in Release Notes: Yes

Module(s): all the CASA sd tools and tasks are affected.

Description: Merged ATNF-ASAP 3.0.0 developments to CASA (alma) branch.

Note you also need to update casa/code/atnf.


File size: 21.5 KB
Line 
1//#---------------------------------------------------------------------------
2//# NRODataset.cc: Base class for NRO dataset.
3//#---------------------------------------------------------------------------
4//# Copyright (C) 2000-2006
5//# Associated Universities, Inc. Washington DC, USA.
6//#
7//# This library is free software; you can redistribute it and/or modify it
8//# under the terms of the GNU Library General Public License as published by
9//# the Free Software Foundation; either version 2 of the License, or (at your
10//# option) any later version.
11//#
12//# This library is distributed in the hope that it will be useful, but WITHOUT
13//# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14//# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
15//# License for more details.
16//#
17//# You should have received a copy of the GNU Library General Public License
18//# along with this library; if not, write to the Free Software Foundation,
19//# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA.
20//#
21//# Correspondence concerning AIPS++ should be addressed as follows:
22//# Internet email: aips2-request@nrao.edu.
23//# Postal address: AIPS++ Project Office
24//# National Radio Astronomy Observatory
25//# 520 Edgemont Road
26//# Charlottesville, VA 22903-2475 USA
27//#
28//# $Id$
29//#---------------------------------------------------------------------------
30//# Original: 2009/02/27, Takeshi Nakazato, NAOJ
31//#---------------------------------------------------------------------------
32
33#include <atnf/PKSIO/NRODataset.h>
34#include <casa/OS/Time.h>
35#include <scimath/Mathematics/InterpolateArray1D.h>
36
37#include <math.h>
38#include <fstream>
39
40//#include <casa/namespace.h>
41
42using namespace std ;
43
44//
45// NRODataset
46//
47// Base class for NRO dataset.
48//
49
50// constructor
51NRODataset::NRODataset( string name )
52{
53 LogIO os( LogOrigin( "NRODataset", "NRODataset()", WHERE ) ) ;
54
55 // memory allocation
56 initialize() ;
57
58 filename_ = name ;
59 fp_ = NULL ;
60 scanNum_ = 0 ;
61 rowNum_ = 0 ;
62 scanLen_ = 0 ;
63 dataLen_ = 0 ;
64 dataid_ = -1 ;
65
66 // OS endian
67 int i = 1 ;
68 endian_ = -1 ;
69 if ( *reinterpret_cast<char *>(&i) == 1 ) {
70 endian_ = LITTLE_ENDIAN ;
71 os << LogIO::NORMAL << "LITTLE_ENDIAN " << LogIO::POST ;
72 }
73 else {
74 endian_ = BIG_ENDIAN ;
75 os << LogIO::NORMAL << "BIG_ENDIAN " << LogIO::POST ;
76 }
77 same_ = -1 ;
78}
79
80// destructor
81NRODataset::~NRODataset()
82{
83 // release memory
84 releaseRecord() ;
85
86 // close file
87 close() ;
88}
89
90// data initialization
91void NRODataset::initialize()
92{
93 datasize_ = sizeof( char ) * 8 // LOFIL
94 + sizeof( char ) * 8 // VER
95 + sizeof( char ) * 16 // GROUP
96 + sizeof( char ) * 16 // PROJ
97 + sizeof( char ) * 24 // SCHED
98 + sizeof( char ) * 40 // OBSVR
99 + sizeof( char ) * 16 // LOSTM
100 + sizeof( char ) * 16 // LOETM
101 + sizeof( int ) * 2 // ARYNM, NSCAN
102 + sizeof( char ) * 120 // TITLE
103 + sizeof( char ) * 16 // OBJ
104 + sizeof( char ) * 8 // EPOCH
105 + sizeof( double ) * 4 // RA0, DEC0, GLNG0, GLAT0
106 + sizeof( int ) * 2 // NCALB, SCNCD
107 + sizeof( char ) * 120 // SCMOD
108 + sizeof( double ) // URVEL
109 + sizeof( char ) * 4 // VREF
110 + sizeof( char ) * 4 // VDEF
111 + sizeof( char ) * 8 // SWMOD
112 + sizeof( double ) * 8 // FRQSW, DBEAM, MLTOF, CMTQ, CMTE, CMTSOM, CMTNODE, CMTI
113 + sizeof( char ) * 24 // CMTTM
114 + sizeof( double ) * 6 // SBDX, SBDY, SBDZ1, SBDZ2, DAZP, DELP
115 + sizeof( int ) * 4 // CHBIND, NUMCH, CHMIN, CHMAX
116 + sizeof( double ) * 3 // ALCTM, IPTIM, PA
117 + sizeof( int ) * 3 // SCNLEN, SBIND, IBIT
118 + sizeof( char ) * 8 ; // SITE
119
120 // NRODataRecord
121 record_ = new NRODataRecord() ;
122 record_->LDATA = NULL ;
123}
124
125void NRODataset::convertEndian( int &value )
126{
127 char volatile *first = reinterpret_cast<char volatile *>( &value ) ;
128 char volatile *last = first + sizeof( int ) ;
129 std::reverse( first, last ) ;
130}
131
132void NRODataset::convertEndian( float &value )
133{
134 char volatile *first = reinterpret_cast<char volatile *>( &value ) ;
135 char volatile *last = first + sizeof( float ) ;
136 std::reverse( first, last ) ;
137}
138
139void NRODataset::convertEndian( double &value )
140{
141 char volatile *first = reinterpret_cast<char volatile *>( &value ) ;
142 char volatile *last = first + sizeof( double ) ;
143 std::reverse( first, last ) ;
144}
145
146int NRODataset::readHeader( char *v, int size )
147{
148 if ( (int)( fread( v, 1, size, fp_ ) ) != size ) {
149 return -1 ;
150 }
151 return 0 ;
152}
153
154int NRODataset::readHeader( int &v, int b )
155{
156 if ( fread( &v, 1, sizeof(int), fp_ ) != sizeof(int) ) {
157 return -1 ;
158 }
159
160 if ( b == 0 )
161 convertEndian( v ) ;
162
163 return 0 ;
164}
165
166int NRODataset::readHeader( float &v, int b )
167{
168 if ( fread( &v, 1, sizeof(float), fp_ ) != sizeof(float) ) {
169 return -1 ;
170 }
171
172 if ( b == 0 )
173 convertEndian( v ) ;
174
175 return 0 ;
176}
177
178int NRODataset::readHeader( double &v, int b )
179{
180 if ( fread( &v, 1, sizeof(double), fp_ ) != sizeof(double) ) {
181 return -1 ;
182 }
183
184 if ( b == 0 )
185 convertEndian( v ) ;
186
187 return 0 ;
188}
189
190void NRODataset::convertEndian( NRODataRecord *r )
191{
192 convertEndian( r->ISCAN ) ;
193 convertEndian( r->DSCX ) ;
194 convertEndian( r->DSCY ) ;
195 convertEndian( r->SCX ) ;
196 convertEndian( r->SCY ) ;
197 convertEndian( r->PAZ ) ;
198 convertEndian( r->PEL ) ;
199 convertEndian( r->RAZ ) ;
200 convertEndian( r->REL ) ;
201 convertEndian( r->XX ) ;
202 convertEndian( r->YY ) ;
203 convertEndian( r->TEMP ) ;
204 convertEndian( r->PATM ) ;
205 convertEndian( r->PH2O ) ;
206 convertEndian( r->VWIND ) ;
207 convertEndian( r->DWIND ) ;
208 convertEndian( r->TAU ) ;
209 convertEndian( r->TSYS ) ;
210 convertEndian( r->BATM ) ;
211 convertEndian( r->LINE ) ;
212 for ( int i = 0 ; i < 4 ; i++ )
213 convertEndian( r->IDMY1[i] ) ;
214 convertEndian( r->VRAD ) ;
215 convertEndian( r->FREQ0 ) ;
216 convertEndian( r->FQTRK ) ;
217 convertEndian( r->FQIF1 ) ;
218 convertEndian( r->ALCV ) ;
219 for ( int i = 0 ; i < 2 ; i++ )
220 for ( int j = 0 ; j < 2 ; j++ )
221 convertEndian( r->OFFCD[i][j] ) ;
222 convertEndian( r->IDMY0 ) ;
223 convertEndian( r->IDMY2 ) ;
224 convertEndian( r->DPFRQ ) ;
225 convertEndian( r->SFCTR ) ;
226 convertEndian( r->ADOFF ) ;
227}
228
229void NRODataset::releaseRecord()
230{
231 if ( record_ ) {
232 if ( record_->LDATA != NULL ) {
233 delete record_->LDATA ;
234 record_->LDATA = NULL ;
235 }
236 delete record_ ;
237 record_ = NULL ;
238 }
239 dataid_ = -1 ;
240}
241
242// Get specified scan
243NRODataRecord *NRODataset::getRecord( int i )
244{
245 LogIO os( LogOrigin( "NRODataset", "getRecord()", WHERE ) ) ;
246
247 // DEBUG
248 //cout << "NRODataset::getRecord() Start " << i << endl ;
249 //
250 if ( i < 0 || i >= rowNum_ ) {
251 //cerr << "NRODataset::getRecord() data index out of range." << endl ;
252 os << LogIO::SEVERE << "data index " << i << " out of range. return NULL." << LogIO::POST ;
253 return NULL ;
254 }
255
256 if ( i == dataid_ ) {
257 return record_ ;
258 }
259
260 // DEBUG
261 //cout << "NRODataset::getData() Get new dataset" << endl ;
262 //
263 // read data
264 int status = fillRecord( i ) ;
265 if ( status == 0 ) {
266 dataid_ = i ;
267 }
268 else {
269 //cerr << "NRODataset::getRecord() error while reading data " << i << endl ;
270 os << LogIO::SEVERE << "error while reading data " << i << ". return NULL." << LogIO::POST ;
271 dataid_ = -1 ;
272 return NULL ;
273 }
274
275 return record_ ;
276}
277
278int NRODataset::fillRecord( int i )
279{
280 LogIO os( LogOrigin( "NRODataset", "fillRecord()", WHERE ) ) ;
281
282 int status = 0 ;
283
284 status = open() ;
285 if ( status != 0 )
286 return status ;
287
288
289 // fill NRODataset
290 int offset = getDataSize() + scanLen_ * i ;
291 // DEBUG
292 //cout << "NRODataset::fillRecord() offset (header) = " << offset << endl ;
293 //cout << "NRODataset::fillRecord() sizeof(NRODataRecord) = " << sizeof( NRODataRecord ) << " byte" << endl ;
294 fseek( fp_, offset, SEEK_SET ) ;
295 if ( (int)fread( record_, 1, SCAN_HEADER_SIZE, fp_ ) != SCAN_HEADER_SIZE ) {
296 //cerr << "Failed to read scan header: " << i << endl ;
297 os << LogIO::SEVERE << "Failed to read scan header for " << i << "th row." << LogIO::POST ;
298 return -1 ;
299 }
300 if ( (int)fread( record_->LDATA, 1, dataLen_, fp_ ) != dataLen_ ) {
301 //cerr << "Failed to read spectral data: " << i << endl ;
302 os << LogIO::SEVERE << "Failed to read spectral data for " << i << "th row." << LogIO::POST ;
303 return -1 ;
304 }
305
306 if ( same_ == 0 ) {
307 convertEndian( record_ ) ;
308 }
309
310 // DWIND unit conversion (deg -> rad)
311 record_->DWIND = record_->DWIND * M_PI / 180.0 ;
312
313 return status ;
314}
315
316// open
317int NRODataset::open()
318{
319 int status = 0 ;
320
321 if ( fp_ == NULL ) {
322 if ( (fp_ = fopen( filename_.c_str(), "rb" )) == NULL )
323 status = -1 ;
324 else
325 status = 0 ;
326 }
327
328 return status ;
329}
330
331// close
332void NRODataset::close()
333{
334 // DEBUG
335 //cout << "NRODataset::close() close file" << endl ;
336 //
337 if ( fp_ != NULL )
338 fclose( fp_ ) ;
339 fp_ = NULL ;
340}
341
342// get spectrum
343vector< vector<double> > NRODataset::getSpectrum()
344{
345 vector< vector<double> > spec;
346
347 for ( int i = 0 ; i < rowNum_ ; i++ ) {
348 spec.push_back( getSpectrum( i ) ) ;
349 }
350
351 return spec ;
352}
353
354vector<double> NRODataset::getSpectrum( int i )
355{
356 LogIO os( LogOrigin( "NRODataset", "getSpectrum", WHERE ) ) ;
357
358 // DEBUG
359 //cout << "NRODataset::getSpectrum() start process (" << i << ")" << endl ;
360 //
361 // size of spectrum is not chmax_ but dataset_->getNCH() after binding
362 int nchan = NUMCH ;
363 vector<double> spec( chmax_, 0.0 ) ; // spectrum "before" binding
364 vector<double> bspec( nchan, 0.0 ) ; // spectrum "after" binding
365 // DEBUG
366 //cout << "NRODataset::getSpectrum() nchan = " << nchan << " chmax_ = " << chmax_ << endl ;
367 //
368
369 NRODataRecord *record = getRecord( i ) ;
370
371 int bit = IBIT ; // fixed to 12 bit
372 double scale = record->SFCTR ;
373 // DEBUG
374 //cout << "NRODataset::getSpectrum() scale = " << scale << endl ;
375 //
376 double offset = record->ADOFF ;
377 // DEBUG
378 //cout << "NRODataset::getSpectrum() offset = " << offset << endl ;
379 //
380 if ( ( scale == 0.0 ) && ( offset == 0.0 ) ) {
381 //cerr << "NRODataset::getSpectrum() zero spectrum (" << i << ")" << endl ;
382 return bspec ;
383 }
384 char *cdata = record->LDATA ;
385 vector<double> mscale = MLTSCF ;
386 double dscale = mscale[getIndex( i )] ;
387 int cbind = CHBIND ;
388 int chmin = CHMIN ;
389
390 // char -> int
391 vector<int> ispec( chmax_, 0 ) ;
392 union SharedMemory {
393 int ivalue ;
394 unsigned char cbuf[4] ;
395 } ;
396 SharedMemory u ;
397 int j = 0 ;
398 char ctmp = 0x00 ;
399 int sw = 0 ;
400 for ( int i = 0 ; i < chmax_ ; i++ ) {
401 if ( bit == 12 ) { // 12 bit qunatization
402 u.ivalue = 0 ;
403
404 if ( endian_ == BIG_ENDIAN ) {
405 // big endian
406 if ( sw == 0 ) {
407 char c0 = (cdata[j] >> 4) & 0x0f ;
408 char c1 = ((cdata[j] << 4) & 0xf0) | ((cdata[j+1] >> 4) & 0x0f) ;
409 ctmp = cdata[j+1] & 0x0f ;
410 u.cbuf[2] = c0 ;
411 u.cbuf[3] = c1 ;
412 j += 2 ;
413 sw = 1 ;
414 }
415 else if ( sw == 1 ) {
416 u.cbuf[2] = ctmp ;
417 u.cbuf[3] = cdata[j] ;
418 j++ ;
419 sw = 0 ;
420 }
421 }
422 else if ( endian_ == LITTLE_ENDIAN ) {
423 // little endian
424 if ( sw == 0 ) {
425 char c0 = (cdata[j] >> 4) & 0x0f ;
426 char c1 = ((cdata[j] << 4) & 0xf0) | ((cdata[j+1] >> 4) & 0x0f) ;
427 ctmp = cdata[j+1] & 0x0f ;
428 u.cbuf[1] = c0 ;
429 u.cbuf[0] = c1 ;
430 j += 2 ;
431 sw = 1 ;
432 }
433 else if ( sw == 1 ) {
434 u.cbuf[1] = ctmp ;
435 u.cbuf[0] = cdata[j] ;
436 j++ ;
437 sw = 0 ;
438 }
439 }
440 }
441
442 ispec[i] = u.ivalue ;
443 if ( ( ispec[i] < 0 ) || ( ispec[i] > 4096 ) ) {
444 //cerr << "NRODataset::getSpectrum() ispec[" << i << "] is out of range" << endl ;
445 os << LogIO::SEVERE << "ispec[" << i << "] is out of range" << LogIO::EXCEPTION ;
446 return bspec ;
447 }
448 // DEBUG
449 //cout << "NRODataset::getSpectrum() ispec[" << i << "] = " << ispec[i] << endl ;
450 //
451 }
452
453 // int -> double
454 for ( int i = 0 ; i < chmax_ ; i++ ) {
455 spec[i] = (double)( ispec[i] * scale + offset ) * dscale ;
456 // DEBUG
457 //cout << "NRODataset::getSpectrum() spec[" << i << "] = " << spec[i] << endl ;
458 //
459 }
460
461 // channel binding
462 if ( cbind != 1 ) {
463 int k = chmin ;
464 double sum0 = 0 ;
465 double sum1 = 0 ;
466 for ( int i = 0 ; i < nchan ; i++ ) {
467 for ( int j = k ; j < k + cbind ; j++ ) {
468 sum0 += spec[k] ;
469 sum1++ ;
470 }
471 bspec[i] = sum0 / sum1 ;
472 k += cbind ;
473 // DEBUG
474 //cout << "NRODataset::getSpectrum() bspec[" << i << "] = " << bspec[i] << endl ;
475 //
476 }
477 }
478 else {
479 for ( int i = 0 ; i < nchan ; i++ )
480 bspec[i] = spec[i] ;
481 }
482
483 // DEBUG
484 //cout << "NRODataset::getSpectrum() end process" << endl ;
485 //
486
487 return bspec ;
488}
489
490int NRODataset::getIndex( int irow )
491{
492 // DEBUG
493 //cout << "NRODataset::getIndex() start" << endl ;
494 //
495 NRODataRecord *record = getRecord( irow ) ;
496 string str = record->ARRYT ;
497 // DEBUG
498 //cout << "NRODataset::getIndex() str = " << str << endl ;
499 //
500 string substr = str.substr( 1, 2 ) ;
501 unsigned int index = (unsigned int)(atoi( substr.c_str() ) - 1) ;
502 // DEBUG
503 //cout << "NRODataset::getIndex() irow = " << irow << " index = " << index << endl ;
504 //
505
506 // DEBUG
507 //cout << "NRODataset::getIndex() end" << endl ;
508 //
509 return index ;
510}
511
512int NRODataset::getPolarizationNum()
513{
514 // DEBUG
515 //cout << "NRODataset::getPolarizationNum() start process" << endl ;
516 //
517 int npol = 0 ;
518
519 vector<string> type( 2 ) ;
520 type[0] = "CIRC" ;
521 type[1] = "LINR" ;
522 vector<double> crot ;
523 vector<double> lagl ;
524 //vector<int> ntype( 2, 0 ) ;
525
526 unsigned int imax = rowNum_ ;
527 for ( unsigned int i = 0 ; i < imax ; i++ ) {
528 int index = getIndex( i ) ;
529 // DEBUG
530 //cout <<"NRODataset::getPolarizationNum() index = " << index << endl ;
531 //
532 if ( POLTP[index] == type[0] ) {
533 if( count( crot.begin(), crot.end(), POLDR[index] ) != 0 ) {
534 crot.push_back( POLDR[index] ) ;
535 npol++ ;
536 }
537 //ntype[0] = 1 ;
538 }
539 else if ( POLTP[index] == type[1] ) {
540 if ( count( lagl.begin(), lagl.end(), POLAN[index] ) != 0 ) {
541 lagl.push_back( POLAN[index] ) ;
542 npol++ ;
543 }
544 //ntype[1] = 1 ;
545 }
546 }
547
548 if ( npol == 0 )
549 npol = 1 ;
550
551 // DEBUG
552 //cout << "NRODataset::getPolarizationNum() end process" << endl ;
553 //
554
555 return npol ;
556}
557
558vector<double> NRODataset::getStartIntTime()
559{
560 vector<double> times ;
561 for ( int i = 0 ; i < rowNum_ ; i++ ) {
562 times.push_back( getStartIntTime( i ) ) ;
563 }
564 return times ;
565}
566
567double NRODataset::getStartIntTime( int i )
568{
569 NRODataRecord *record = getRecord( i ) ;
570
571 char *t = record->LAVST ;
572 return getMJD( t ) ;
573}
574
575double NRODataset::getMJD( char *time )
576{
577 // TODO: should be checked which time zone the time depends on
578 // 2008/11/14 Takeshi Nakazato
579 string strStartTime( time ) ;
580 string strYear = strStartTime.substr( 0, 4 ) ;
581 string strMonth = strStartTime.substr( 4, 2 ) ;
582 string strDay = strStartTime.substr( 6, 2 ) ;
583 string strHour = strStartTime.substr( 8, 2 ) ;
584 string strMinute = strStartTime.substr( 10, 2 ) ;
585 string strSecond = strStartTime.substr( 12, strStartTime.size() - 12 ) ;
586 unsigned int year = atoi( strYear.c_str() ) ;
587 unsigned int month = atoi( strMonth.c_str() ) ;
588 unsigned int day = atoi( strDay.c_str() ) ;
589 unsigned int hour = atoi( strHour.c_str() ) ;
590 unsigned int minute = atoi( strMinute.c_str() ) ;
591 double second = atof( strSecond.c_str() ) ;
592 Time t( year, month, day, hour, minute, second ) ;
593
594 return t.modifiedJulianDay() ;
595}
596
597vector<bool> NRODataset::getIFs()
598{
599 vector<bool> v ;
600 vector< vector<double> > fref ;
601 vector< vector<double> > chcal = CHCAL ;
602 vector<double> f0cal = F0CAL ;
603 vector<double> beres = BERES ;
604 for ( int i = 0 ; i < rowNum_ ; i++ ) {
605 vector<double> f( 4, 0 ) ;
606 uInt index = getIndex( i ) ;
607 f[0] = chcal[index][0] ;
608 f[1] = f0cal[index] ;
609 f[2] = beres[index] ;
610 if ( f[0] != 0. ) {
611 f[1] = f[1] - f[0] * f[2] ;
612 }
613 NRODataRecord *record = getRecord( i ) ;
614 f[3] = record->FREQ0 ;
615 if ( v.size() == 0 ) {
616 v.push_back( True ) ;
617 fref.push_back( f ) ;
618 }
619 else {
620 bool b = true ;
621 int fsize = fref.size() ;
622 for ( int j = 0 ; j < fsize ; j++ ) {
623 if ( fref[j][1] == f[1] && fref[j][2] == f[2] && fref[j][3] == f[3] ) {
624 b = false ;
625 }
626 }
627 if ( b ) {
628 v.push_back( True ) ;
629 fref.push_back( f ) ;
630 }
631 }
632 }
633
634
635 // DEBUG
636 //cout << "NRODataset::getIFs() number of IF is " << v.size() << endl ;
637 //
638
639 return v ;
640}
641
642vector<double> NRODataset::getFrequencies( int i )
643{
644 // return value
645 // v[0] reference channel
646 // v[1] reference frequency
647 // v[2] frequency increment
648 vector<double> v( 3, 0.0 ) ;
649
650 NRODataRecord *record = getRecord( i ) ;
651 string arryt = string( record->ARRYT ) ;
652 //string sbeamno = arryt.substr( 1, arryt.size()-1 ) ;
653 //uInt ib = atoi( sbeamno.c_str() ) - 1 ;
654 uInt ib = getArrayId( arryt ) ;
655
656 int ia = -1 ;
657 bool isAOS = false ;
658 //cout << "NRODataset::getFrequencies() record->ARRYT=" << record->ARRYT << endl ;
659 //cout << "NRODataset::getFrequencies() ib = " << ib << endl ;
660
661 if ( strncmp( record->ARRYT, "X", 1 ) == 0 ) {
662 // FX
663 if ( strncmp( (record->ARRYT)+1, "1", 1 ) == 0
664 || strncmp( (record->ARRYT)+1, "3", 1 ) ) {
665 // FX1, 3
666 ia = 2 ;
667 }
668 else {
669 // FX2, 4
670 ia = 1 ;
671 }
672 }
673 else if ( strncmp( record->ARRYT, "A", 1 ) == 0 )
674 ia = 2 ; // AC
675 else if ( strncmp( record->ARRYT, "W", 1 ) == 0 ) {
676 // AOS-W
677 ia = 2 ;
678 isAOS = true ;
679 }
680 else if ( strncmp( record->ARRYT, "U", 1 ) == 0 ) {
681 // AOS-U
682 ia = 2 ;
683 isAOS = true ;
684 }
685 else if ( strncmp( record->ARRYT, "H", 1 ) == 0 ) {
686 // AOS-H
687 isAOS = true ;
688 //cout << record->ARRYT << " " << strlen(record->ARRYT) << endl ;
689 //cout << (record->ARRYT)+1 << endl ;
690 if ( strncmp( (record->ARRYT)+2, " ", 1 ) == 0 ) {
691 // H1-9
692 if ( strncmp( (record->ARRYT)+1, "9", 1 ) == 0 ) {
693 // H9
694 ia = 2 ;
695 }
696 else {
697 // H1-8
698 ia = 1 ;
699 }
700 }
701 else {
702 // H10-16
703 ia = 2 ;
704 }
705 }
706
707 int iu ;
708 if ( record->FQIF1 > 0 )
709 iu = 1 ; // USB
710 else
711 iu = 2 ; // LSB
712
713 int ivdef = -1 ;
714 //if ( strncmp( (dataset_->getVDEF()).c_str(), "RAD", 3 ) == 0 )
715 if ( (getVDEF()).compare( 0, 3, "RAD" ) == 0 )
716 ivdef = 0 ;
717 //else if ( strncmp( dataset_->getVDEF(), "OPT", 3 ) == 0 )
718 else if ( (getVDEF()).compare( 0, 3, "OPT" ) == 0 )
719 ivdef = 1 ;
720 // DEBUG
721 //cout << "NRODataset::getFrequencies() ivdef = " << ivdef << endl ;
722 //
723 double vel = getURVEL() + record->VRAD ;
724 double cvel = 2.99792458e8 ; // speed of light [m/s]
725 double fq0 = record->FREQ0 ;
726 //double fq0 = record->FQTRK ;
727
728 int ncal = getNFCAL()[ib] ;
729 vector<double> freqs( ncal ) ;
730 double cw = 0.0 ;
731 vector<double> fqcal = getFQCAL()[ib] ;
732 vector<double> chcal = getCHCAL()[ib] ;
733
734 for ( int ii = 0 ; ii < ncal ; ii++ ) {
735 freqs[ii] = fqcal[ii] ;
736 freqs[ii] -= getF0CAL()[ib] ;
737 if ( ia == 1 ) {
738 if ( iu == 1 ) {
739 freqs[ii] = fq0 + freqs[ii] ;
740 }
741 else if ( iu == 2 ) {
742 freqs[ii] = fq0 - freqs[ii] ;
743 }
744 }
745 else if ( ia == 2 ) {
746 if ( iu == 1 ) {
747 freqs[ii] = fq0 - freqs[ii] ;
748 }
749 else if ( iu == 2 ) {
750 freqs[ii] = fq0 + freqs[ii] ;
751 }
752 }
753// if ( ivdef == 0 ) {
754// double factor = 1.0 / ( 1.0 - vel / cvel ) ;
755// freqs[ii] = freqs[ii] * factor - record->FQTRK * ( factor - 1.0 ) ;
756// }
757// else if ( ivdef == 1 ) {
758// double factor = vel / cvel ;
759// freqs[ii] = freqs[ii] * ( 1.0 + factor ) - record->FQTRK * factor ;
760// }
761 }
762
763 if ( isAOS ) {
764 // regridding
765 while ( ncal < (int)chcal.size() ) {
766 chcal.pop_back() ;
767 }
768 Vector<Double> xin( chcal ) ;
769 Vector<Double> yin( freqs ) ;
770 int nchan = getNUMCH() ;
771 Vector<Double> xout( nchan ) ;
772 indgen( xout ) ;
773 Vector<Double> yout ;
774 InterpolateArray1D<Double, Double>::interpolate( yout, xout, xin, yin, InterpolateArray1D<Double,Double>::cubic ) ;
775 Double bw = abs( yout[nchan-1] - yout[0] ) ;
776 bw += 0.5 * abs( yout[nchan-1] - yout[nchan-2] + yout[1] - yout[0] ) ;
777 Double dz = bw / (Double) nchan ;
778 if ( yout[0] > yout[1] )
779 dz = - dz ;
780 v[0] = 0 ;
781 v[1] = yout[0] ;
782 v[2] = dz ;
783 }
784 else {
785 cw = getBERES()[ib] ;
786
787 if ( cw == 0.0 ) {
788 cw = ( freqs[1] - freqs[0] )
789 / ( chcal[1] - chcal[0] ) ;
790// if ( cw < 0.0 )
791// cw = - cw ;
792 }
793 v[0] = chcal[0] - 1 ; // 0-base
794 v[1] = freqs[0] ;
795 v[2] = cw ;
796 }
797
798 return v ;
799}
800
801uInt NRODataset::getArrayId( string type )
802{
803 string sbeamno = type.substr( 1, type.size()-1 ) ;
804 uInt ib = atoi( sbeamno.c_str() ) - 1 ;
805 return ib ;
806}
807
808void NRODataset::show()
809{
810 LogIO os( LogOrigin( "NRODataset", "show()", WHERE ) ) ;
811
812 os << LogIO::NORMAL << "------------------------------------------------------------" << endl ;
813 os << LogIO::NORMAL << "Number of scan = " << scanNum_ << endl ;
814 os << LogIO::NORMAL << "Number of data record = " << rowNum_ << endl ;
815 os << LogIO::NORMAL << "Length of data record = " << scanLen_ << " bytes" << endl ;
816 os << LogIO::NORMAL << "Allocated memory for spectral data = " << dataLen_ << " bytes" << endl ;
817 os << LogIO::NORMAL << "Max number of channel = " << chmax_ << endl ;
818 os << LogIO::NORMAL << "------------------------------------------------------------" << endl ;
819 os.post() ;
820
821}
Note: See TracBrowser for help on using the repository browser.