00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
#ifndef WVMCalTable_CLASS
00035
#define WVMCalTable_CLASS
00036
00037
#include <string>
00038
#include <vector>
00039
#include <map>
00040
#include <set>
00041
using std::string;
00042
using std::vector;
00043
using std::map;
00044
00045
#include <Angle.h>
00046
#include <AngularRate.h>
00047
#include <ArrayTime.h>
00048
#include <ArrayTimeInterval.h>
00049
#include <Complex.h>
00050
#include <Entity.h>
00051
#include <EntityId.h>
00052
#include <EntityRef.h>
00053
#include <Flux.h>
00054
#include <Frequency.h>
00055
#include <Humidity.h>
00056
#include <Interval.h>
00057
#include <Length.h>
00058
#include <PartId.h>
00059
#include <Pressure.h>
00060
#include <Speed.h>
00061
#include <Tag.h>
00062
#include <Temperature.h>
00063
#include <ConversionException.h>
00064
#include <DuplicateKey.h>
00065
#include <UniquenessViolationException.h>
00066
#include <NoSuchRow.h>
00067
#include <DuplicateKey.h>
00068
00069
00070
00071
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
#ifndef WITHOUT_ACS
00093
#include <asdmIDLC.h>
00094
using asdmIDL::WVMCalTableIDL;
00095
#endif
00096
00097
using asdm::Angle;
00098
using asdm::AngularRate;
00099
using asdm::ArrayTime;
00100
using asdm::Complex;
00101
using asdm::Entity;
00102
using asdm::EntityId;
00103
using asdm::EntityRef;
00104
using asdm::Flux;
00105
using asdm::Frequency;
00106
using asdm::Humidity;
00107
using asdm::Interval;
00108
using asdm::Length;
00109
using asdm::PartId;
00110
using asdm::Pressure;
00111
using asdm::Speed;
00112
using asdm::Tag;
00113
using asdm::Temperature;
00114
00115
using asdm::DuplicateKey;
00116
using asdm::ConversionException;
00117
using asdm::NoSuchRow;
00118
using asdm::DuplicateKey;
00119
00120
#include <Representable.h>
00121
00122
namespace asdm {
00123
00124
00125
00126
00127
class ASDM;
00128
class WVMCalRow;
00211 class WVMCalTable :
public Representable {
00212
friend class asdm::ASDM;
00213
00214
public:
00215
00216
00222
static vector<string>
getKeyName();
00223
00224
00225
virtual ~
WVMCalTable();
00226
00232
ASDM &
getContainer()
const;
00233
00239
unsigned int size() ;
00240
00246 string
getName()
const;
00247
00251
Entity getEntity()
const;
00252
00257
void setEntity(
Entity e);
00258
00259
00260
00261
00262
00267
WVMCalRow *
newRow();
00268
00273
WVMCalRow*
newRowEmpty();
00274
00275
00295
WVMCalRow *
newRow(
Tag antennaId,
Tag spectralWindowId,
ArrayTimeInterval timeInterval,
int numPoly,
Frequency freqOrigin, vector<double > pathCoeff, string calibrationMode);
00296
00301
WVMCalRow *
newRowFull(
Tag antennaId,
Tag spectralWindowId,
ArrayTimeInterval timeInterval,
int numPoly,
Frequency freqOrigin, vector<double > pathCoeff, string calibrationMode);
00302
00303
00316
WVMCalRow *
newRow(
WVMCalRow *row);
00317
00322
WVMCalRow *
newRowCopy(
WVMCalRow *row);
00323
00324
00325
00326
00327
00328
00345
WVMCalRow*
add(
WVMCalRow* x) ;
00346
00347
00348
00349
00350
00351
00352
00353
00354
00360 vector<WVMCalRow *>
get() ;
00361
00362
00370 vector <WVMCalRow*> *
getByContext(
Tag antennaId,
Tag spectralWindowId);
00371
00372
00373
00374
00375
00389
WVMCalRow*
getRowByKey(
Tag antennaId,
Tag spectralWindowId,
ArrayTimeInterval timeInterval);
00390
00391
00392
00393
00394
00416
WVMCalRow*
lookup(
Tag antennaId,
Tag spectralWindowId,
ArrayTimeInterval timeInterval,
int numPoly,
Frequency freqOrigin, vector<double > pathCoeff, string calibrationMode);
00417
00418
00419
#ifndef WITHOUT_ACS
00420
00426 WVMCalTableIDL *
toIDL() ;
00427
#endif
00428
00429
#ifndef WITHOUT_ACS
00430
00436
void fromIDL(WVMCalTableIDL x)
throw(
DuplicateKey,
ConversionException);
00437
#endif
00438
00442
char *
toFITS()
const throw(
ConversionException);
00443
00447
void fromFITS(
char *fits)
throw(
ConversionException);
00448
00452 string
toVOTable()
const throw(
ConversionException);
00453
00457
void fromVOTable(string vo)
throw(
ConversionException);
00458
00465 string
toXML()
throw(
ConversionException);
00466
00472
void fromXML(string xmlDoc)
throw(
ConversionException);
00473
00479 string
toMIME();
00480
00487
void setFromMIME(
const string & mimeMsg);
00488
00498
void toFile(string directory);
00499
00508
void setFromFile(
const string& directory);
00509
00510
private:
00511
00520
WVMCalTable (
ASDM & container);
00521
00522
ASDM & container;
00523
00524
bool archiveAsBin;
00525
bool fileAsBin ;
00526
00527
Entity entity;
00528
00529
00530
00534
static string tableName;
00535
00536
00540
static vector<string> key;
00541
00542
00548
WVMCalRow* checkAndAdd(
WVMCalRow* x)
throw (
DuplicateKey);
00549
00550
00551
00552
00560
WVMCalRow * insertByStartTime(
WVMCalRow* x, vector<WVMCalRow* >& row);
00561
00562
00563
00564
00565
00566
00567 vector<WVMCalRow * > privateRows;
00568
00569
00570
00571
00572
00573
00574
00575
00576
typedef vector <WVMCalRow* > TIME_ROWS;
00577 map<string, TIME_ROWS > context;
00578
00583 string Key(
Tag antennaId,
Tag spectralWindowId) ;
00584
00585
00586
00587
00593
void getByKeyNoAutoIncNoTime(vector <WVMCalRow*>& vin, vector <WVMCalRow*>& vout,
Tag antennaId,
Tag spectralWindowId);
00594
00595
00596
00597
void error()
throw(
ConversionException);
00598
00599 };
00600
00601 }
00602
00603
#endif