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* WVMCalTable::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