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 SeeingTable_CLASS
00035
#define SeeingTable_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
#ifndef WITHOUT_ACS
00091
#include <asdmIDLC.h>
00092
using asdmIDL::SeeingTableIDL;
00093
#endif
00094
00095
using asdm::Angle;
00096
using asdm::AngularRate;
00097
using asdm::ArrayTime;
00098
using asdm::Complex;
00099
using asdm::Entity;
00100
using asdm::EntityId;
00101
using asdm::EntityRef;
00102
using asdm::Flux;
00103
using asdm::Frequency;
00104
using asdm::Humidity;
00105
using asdm::Interval;
00106
using asdm::Length;
00107
using asdm::PartId;
00108
using asdm::Pressure;
00109
using asdm::Speed;
00110
using asdm::Tag;
00111
using asdm::Temperature;
00112
00113
using asdm::DuplicateKey;
00114
using asdm::ConversionException;
00115
using asdm::NoSuchRow;
00116
using asdm::DuplicateKey;
00117
00118
#include <Representable.h>
00119
00120
namespace asdm {
00121
00122
00123
00124
00125
class ASDM;
00126
class SeeingRow;
00184 class SeeingTable :
public Representable {
00185
friend class asdm::ASDM;
00186
00187
public:
00188
00189
00195
static vector<string>
getKeyName();
00196
00197
00198
virtual ~
SeeingTable();
00199
00205
ASDM &
getContainer()
const;
00206
00212
unsigned int size() ;
00213
00219 string
getName()
const;
00220
00224
Entity getEntity()
const;
00225
00230
void setEntity(
Entity e);
00231
00232
00233
00234
00235
00240
SeeingRow *
newRow();
00241
00246
SeeingRow*
newRowEmpty();
00247
00248
00266
SeeingRow *
newRow(
ArrayTimeInterval timeInterval,
int numBaseLength, vector<Length > baseLength, vector<Angle > phaseRms,
float seeing,
float exponent);
00267
00272
SeeingRow *
newRowFull(
ArrayTimeInterval timeInterval,
int numBaseLength, vector<Length > baseLength, vector<Angle > phaseRms,
float seeing,
float exponent);
00273
00274
00287
SeeingRow *
newRow(
SeeingRow *row);
00288
00293
SeeingRow *
newRowCopy(
SeeingRow *row);
00294
00295
00296
00297
00298
00299
00316
SeeingRow*
add(
SeeingRow* x) ;
00317
00318
00319
00320
00321
00322
00323
00324
00325
00331 vector<SeeingRow *>
get() ;
00332
00333
00341 vector <SeeingRow*> *
getByContext();
00342
00343
00344
00345
00346
00356
SeeingRow*
getRowByKey(
ArrayTimeInterval timeInterval);
00357
00358
00359
00360
00361
00381
SeeingRow*
lookup(
ArrayTimeInterval timeInterval,
int numBaseLength, vector<Length > baseLength, vector<Angle > phaseRms,
float seeing,
float exponent);
00382
00383
00384
#ifndef WITHOUT_ACS
00385
00391 SeeingTableIDL *
toIDL() ;
00392
#endif
00393
00394
#ifndef WITHOUT_ACS
00395
00401
void fromIDL(SeeingTableIDL x)
throw(
DuplicateKey,
ConversionException);
00402
#endif
00403
00407
char *
toFITS()
const throw(
ConversionException);
00408
00412
void fromFITS(
char *fits)
throw(
ConversionException);
00413
00417 string
toVOTable()
const throw(
ConversionException);
00418
00422
void fromVOTable(string vo)
throw(
ConversionException);
00423
00430 string
toXML()
throw(
ConversionException);
00431
00437
void fromXML(string xmlDoc)
throw(
ConversionException);
00438
00444 string
toMIME();
00445
00452
void setFromMIME(
const string & mimeMsg);
00453
00463
void toFile(string directory);
00464
00473
void setFromFile(
const string& directory);
00474
00475
private:
00476
00485
SeeingTable (
ASDM & container);
00486
00487
ASDM & container;
00488
00489
bool archiveAsBin;
00490
bool fileAsBin ;
00491
00492
Entity entity;
00493
00494
00495
00499
static string tableName;
00500
00501
00505
static vector<string> key;
00506
00507
00513
SeeingRow* checkAndAdd(
SeeingRow* x)
throw (
DuplicateKey);
00514
00515
00516
00517
00525
SeeingRow * insertByStartTime(
SeeingRow* x, vector<SeeingRow* >& row);
00526
00527
00528
00529
00530
00531
00532 vector<SeeingRow * > privateRows;
00533
00534
00535
00536
00537
00538
00539
00540
00541 vector <SeeingRow *> row;
00542
00543
00544
00545
00546
00547
00548
void error()
throw(
ConversionException);
00549
00550 };
00551
00552 }
00553
00554
#endif