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 PolarizationTable_CLASS
00035
#define PolarizationTable_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
#include "CStokesParameter.h"
00083
using namespace StokesParameterMod;
00084
00085
00086
00087
#include "CPolarizationType.h"
00088
using namespace PolarizationTypeMod;
00089
00090
00091
00092
00093
00094
#ifndef WITHOUT_ACS
00095
#include <asdmIDLC.h>
00096
using asdmIDL::PolarizationTableIDL;
00097
#endif
00098
00099
using asdm::Angle;
00100
using asdm::AngularRate;
00101
using asdm::ArrayTime;
00102
using asdm::Complex;
00103
using asdm::Entity;
00104
using asdm::EntityId;
00105
using asdm::EntityRef;
00106
using asdm::Flux;
00107
using asdm::Frequency;
00108
using asdm::Humidity;
00109
using asdm::Interval;
00110
using asdm::Length;
00111
using asdm::PartId;
00112
using asdm::Pressure;
00113
using asdm::Speed;
00114
using asdm::Tag;
00115
using asdm::Temperature;
00116
00117
using asdm::DuplicateKey;
00118
using asdm::ConversionException;
00119
using asdm::NoSuchRow;
00120
using asdm::DuplicateKey;
00121
00122
#include <Representable.h>
00123
00124
namespace asdm {
00125
00126
00127
00128
00129
class ASDM;
00130
class PolarizationRow;
00185 class PolarizationTable :
public Representable {
00186
friend class asdm::ASDM;
00187
00188
public:
00189
00190
00196
static vector<string>
getKeyName();
00197
00198
00199
virtual ~
PolarizationTable();
00200
00206
ASDM &
getContainer()
const;
00207
00213
unsigned int size() ;
00214
00220 string
getName()
const;
00221
00225
Entity getEntity()
const;
00226
00231
void setEntity(
Entity e);
00232
00233
00234
00235
00236
00241
PolarizationRow *
newRow();
00242
00247
PolarizationRow*
newRowEmpty();
00248
00249
00261
PolarizationRow *
newRow(
int numCorr, vector<StokesParameterMod::StokesParameter > corrType, vector<vector<PolarizationTypeMod::PolarizationType > > corrProduct);
00262
00267
PolarizationRow *
newRowFull(
int numCorr, vector<StokesParameterMod::StokesParameter > corrType, vector<vector<PolarizationTypeMod::PolarizationType > > corrProduct);
00268
00269
00282
PolarizationRow *
newRow(
PolarizationRow *row);
00283
00288
PolarizationRow *
newRowCopy(
PolarizationRow *row);
00289
00290
00291
00292
00293
00294
00295
00296
00306
PolarizationRow*
add(
PolarizationRow* x) ;
00307
00308
00309
00310
00311
00312
00313
00319 vector<PolarizationRow *>
get() ;
00320
00321
00322
00323
00324
00334
PolarizationRow*
getRowByKey(
Tag polarizationId);
00335
00336
00337
00338
00339
00353
PolarizationRow*
lookup(
int numCorr, vector<StokesParameterMod::StokesParameter > corrType, vector<vector<PolarizationTypeMod::PolarizationType > > corrProduct);
00354
00355
00356
#ifndef WITHOUT_ACS
00357
00363 PolarizationTableIDL *
toIDL() ;
00364
#endif
00365
00366
#ifndef WITHOUT_ACS
00367
00373
void fromIDL(PolarizationTableIDL x)
throw(
DuplicateKey,
ConversionException);
00374
#endif
00375
00379
char *
toFITS()
const throw(
ConversionException);
00380
00384
void fromFITS(
char *fits)
throw(
ConversionException);
00385
00389 string
toVOTable()
const throw(
ConversionException);
00390
00394
void fromVOTable(string vo)
throw(
ConversionException);
00395
00402 string
toXML()
throw(
ConversionException);
00403
00409
void fromXML(string xmlDoc)
throw(
ConversionException);
00410
00416 string
toMIME();
00417
00424
void setFromMIME(
const string & mimeMsg);
00425
00435
void toFile(string directory);
00436
00445
void setFromFile(
const string& directory);
00446
00447
private:
00448
00457
PolarizationTable (
ASDM & container);
00458
00459
ASDM & container;
00460
00461
bool archiveAsBin;
00462
bool fileAsBin ;
00463
00464
Entity entity;
00465
00466
00467
00468 map<string,int> noAutoIncIds;
00469
void autoIncrement(string key,
PolarizationRow* x);
00470
00471
00475
static string tableName;
00476
00477
00481
static vector<string> key;
00482
00483
00489
PolarizationRow* checkAndAdd(
PolarizationRow* x)
throw (
DuplicateKey,
UniquenessViolationException);
00490
00491
00492
00493
00494
00495
00496 vector<PolarizationRow * > privateRows;
00497
00498
00499
00500 vector<PolarizationRow *> row;
00501
00502
00503
void error()
throw(
ConversionException);
00504
00505 };
00506
00507 }
00508
00509
#endif