LCOV - code coverage report
Current view: top level - alma/ASDM - EphemerisRow.cc (source / functions) Hit Total Coverage
Test: casa_coverage.info Lines: 130 386 33.7 %
Date: 2023-10-25 08:47:59 Functions: 31 67 46.3 %

          Line data    Source code
       1             : 
       2             : /*
       3             :  * ALMA - Atacama Large Millimeter Array
       4             :  * (c) European Southern Observatory, 2002
       5             :  * (c) Associated Universities Inc., 2002
       6             :  * Copyright by ESO (in the framework of the ALMA collaboration),
       7             :  * Copyright by AUI (in the framework of the ALMA collaboration),
       8             :  * All rights reserved.
       9             :  * 
      10             :  * This library is free software; you can redistribute it and/or
      11             :  * modify it under the terms of the GNU Lesser General Public
      12             :  * License as published by the Free software Foundation; either
      13             :  * version 2.1 of the License, or (at your option) any later version.
      14             :  * 
      15             :  * This library is distributed in the hope that it will be useful,
      16             :  * but WITHOUT ANY WARRANTY, without even the implied warranty of
      17             :  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
      18             :  * Lesser General Public License for more details.
      19             :  * 
      20             :  * You should have received a copy of the GNU Lesser General Public
      21             :  * License along with this library; if not, write to the Free Software
      22             :  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
      23             :  * MA 02111-1307  USA
      24             :  *
      25             :  * Warning!
      26             :  *  -------------------------------------------------------------------- 
      27             :  * | This is generated code!  Do not modify this file.                  |
      28             :  * | If you do, all changes will be lost when the file is re-generated. |
      29             :  *  --------------------------------------------------------------------
      30             :  *
      31             :  * File EphemerisRow.cpp
      32             :  */
      33             :  
      34             : #include <vector>
      35             : #include <set>
      36             : 
      37             : #include <alma/ASDM/ASDM.h>
      38             : #include <alma/ASDM/EphemerisRow.h>
      39             : #include <alma/ASDM/EphemerisTable.h>
      40             :         
      41             : 
      42             : using asdm::ASDM;
      43             : using asdm::EphemerisRow;
      44             : using asdm::EphemerisTable;
      45             : 
      46             : 
      47             : #include <alma/ASDM/Parser.h>
      48             : 
      49             : #include <alma/ASDM/EnumerationParser.h>
      50             : #include <alma/ASDM/ASDMValuesParser.h>
      51             :  
      52             : #include <alma/ASDM/InvalidArgumentException.h>
      53             : 
      54             : using namespace std;
      55             : 
      56             : namespace asdm {
      57         578 :         EphemerisRow::~EphemerisRow() {
      58         578 :         }
      59             : 
      60             :         /**
      61             :          * Return the table to which this row belongs.
      62             :          */
      63           0 :         EphemerisTable &EphemerisRow::getTable() const {
      64           0 :                 return table;
      65             :         }
      66             : 
      67           0 :         bool EphemerisRow::isAdded() const {
      68           0 :                 return hasBeenAdded;
      69             :         }       
      70             : 
      71         289 :         void EphemerisRow::isAdded(bool added) {
      72         289 :                 hasBeenAdded = added;
      73         289 :         }
      74             :         
      75             : #ifndef WITHOUT_ACS
      76             :         using asdmIDL::EphemerisRowIDL;
      77             : #endif
      78             :         
      79             : #ifndef WITHOUT_ACS
      80             :         /**
      81             :          * Return this row in the form of an IDL struct.
      82             :          * @return The values of this row as a EphemerisRowIDL struct.
      83             :          */
      84             :         EphemerisRowIDL *EphemerisRow::toIDL() const {
      85             :                 EphemerisRowIDL *x = new EphemerisRowIDL ();
      86             :                 
      87             :                 // Fill the IDL structure.
      88             :         
      89             :                 
      90             :         
      91             :                 
      92             :                 
      93             :                 
      94             :                         
      95             :                 x->timeInterval = timeInterval.toIDLArrayTimeInterval();
      96             :                         
      97             :                 
      98             :         
      99             : 
     100             :         
     101             :                 
     102             :                 
     103             :                 
     104             :                         
     105             :                                 
     106             :                 x->ephemerisId = ephemerisId;
     107             :                                 
     108             :                         
     109             :                 
     110             :         
     111             : 
     112             :         
     113             :                 
     114             :                 
     115             :                 
     116             :                         
     117             :                 x->observerLocation.length(observerLocation.size());
     118             :                 for (unsigned int i = 0; i < observerLocation.size(); ++i) {
     119             :                         
     120             :                                 
     121             :                         x->observerLocation[i] = observerLocation.at(i);
     122             :                                 
     123             :                         
     124             :                 }
     125             :                         
     126             :                 
     127             :         
     128             : 
     129             :         
     130             :                 
     131             :                 
     132             :                 
     133             :                         
     134             :                                 
     135             :                 x->equinoxEquator = equinoxEquator;
     136             :                                 
     137             :                         
     138             :                 
     139             :         
     140             : 
     141             :         
     142             :                 
     143             :                 
     144             :                 
     145             :                         
     146             :                                 
     147             :                 x->numPolyDir = numPolyDir;
     148             :                                 
     149             :                         
     150             :                 
     151             :         
     152             : 
     153             :         
     154             :                 
     155             :                 
     156             :                 
     157             :                         
     158             :                 x->dir.length(dir.size());
     159             :                 for (unsigned int i = 0; i < dir.size(); i++) {
     160             :                         x->dir[i].length(dir.at(i).size());                                  
     161             :                 }
     162             :                 
     163             :                 for (unsigned int i = 0; i < dir.size() ; i++)
     164             :                         for (unsigned int j = 0; j < dir.at(i).size(); j++)
     165             :                                         
     166             :                                                 
     167             :                                 x->dir[i][j] = dir.at(i).at(j);
     168             :                                                 
     169             :                                                                         
     170             :                 
     171             :                         
     172             :                 
     173             :         
     174             : 
     175             :         
     176             :                 
     177             :                 
     178             :                 
     179             :                         
     180             :                                 
     181             :                 x->numPolyDist = numPolyDist;
     182             :                                 
     183             :                         
     184             :                 
     185             :         
     186             : 
     187             :         
     188             :                 
     189             :                 
     190             :                 
     191             :                         
     192             :                 x->distance.length(distance.size());
     193             :                 for (unsigned int i = 0; i < distance.size(); ++i) {
     194             :                         
     195             :                                 
     196             :                         x->distance[i] = distance.at(i);
     197             :                                 
     198             :                         
     199             :                 }
     200             :                         
     201             :                 
     202             :         
     203             : 
     204             :         
     205             :                 
     206             :                 
     207             :                 
     208             :                         
     209             :                 x->timeOrigin = timeOrigin.toIDLArrayTime();
     210             :                         
     211             :                 
     212             :         
     213             : 
     214             :         
     215             :                 
     216             :                 
     217             :                 
     218             :                         
     219             :                                 
     220             :                 x->origin = CORBA::string_dup(origin.c_str());
     221             :                                 
     222             :                         
     223             :                 
     224             :         
     225             : 
     226             :         
     227             :                 
     228             :                 
     229             :                 x->numPolyRadVelExists = numPolyRadVelExists;
     230             :                 
     231             :                 
     232             :                         
     233             :                                 
     234             :                 x->numPolyRadVel = numPolyRadVel;
     235             :                                 
     236             :                         
     237             :                 
     238             :         
     239             : 
     240             :         
     241             :                 
     242             :                 
     243             :                 x->radVelExists = radVelExists;
     244             :                 
     245             :                 
     246             :                         
     247             :                 x->radVel.length(radVel.size());
     248             :                 for (unsigned int i = 0; i < radVel.size(); ++i) {
     249             :                         
     250             :                                 
     251             :                         x->radVel[i] = radVel.at(i);
     252             :                                 
     253             :                         
     254             :                 }
     255             :                         
     256             :                 
     257             :         
     258             : 
     259             :         
     260             :         
     261             :                 
     262             :                 
     263             :                 return x;
     264             :         
     265             :         }
     266             :         
     267             :         void EphemerisRow::toIDL(asdmIDL::EphemerisRowIDL& x) const {
     268             :                 // Set the x's fields.
     269             :         
     270             :                 
     271             :         
     272             :                 
     273             :                 
     274             :                 
     275             :                         
     276             :                 x.timeInterval = timeInterval.toIDLArrayTimeInterval();
     277             :                         
     278             :                 
     279             :         
     280             : 
     281             :         
     282             :                 
     283             :                 
     284             :                 
     285             :                         
     286             :                                 
     287             :                 x.ephemerisId = ephemerisId;
     288             :                                 
     289             :                         
     290             :                 
     291             :         
     292             : 
     293             :         
     294             :                 
     295             :                 
     296             :                 
     297             :                         
     298             :                 x.observerLocation.length(observerLocation.size());
     299             :                 for (unsigned int i = 0; i < observerLocation.size(); ++i) {
     300             :                         
     301             :                                 
     302             :                         x.observerLocation[i] = observerLocation.at(i);
     303             :                                 
     304             :                         
     305             :                 }
     306             :                         
     307             :                 
     308             :         
     309             : 
     310             :         
     311             :                 
     312             :                 
     313             :                 
     314             :                         
     315             :                                 
     316             :                 x.equinoxEquator = equinoxEquator;
     317             :                                 
     318             :                         
     319             :                 
     320             :         
     321             : 
     322             :         
     323             :                 
     324             :                 
     325             :                 
     326             :                         
     327             :                                 
     328             :                 x.numPolyDir = numPolyDir;
     329             :                                 
     330             :                         
     331             :                 
     332             :         
     333             : 
     334             :         
     335             :                 
     336             :                 
     337             :                 
     338             :                         
     339             :                 x.dir.length(dir.size());
     340             :                 for (unsigned int i = 0; i < dir.size(); i++) {
     341             :                         x.dir[i].length(dir.at(i).size());                                      
     342             :                 }
     343             :                 
     344             :                 for (unsigned int i = 0; i < dir.size() ; i++)
     345             :                         for (unsigned int j = 0; j < dir.at(i).size(); j++)
     346             :                                         
     347             :                                                 
     348             :                                 x.dir[i][j] = dir.at(i).at(j);
     349             :                                                 
     350             :                                                                         
     351             :                 
     352             :                         
     353             :                 
     354             :         
     355             : 
     356             :         
     357             :                 
     358             :                 
     359             :                 
     360             :                         
     361             :                                 
     362             :                 x.numPolyDist = numPolyDist;
     363             :                                 
     364             :                         
     365             :                 
     366             :         
     367             : 
     368             :         
     369             :                 
     370             :                 
     371             :                 
     372             :                         
     373             :                 x.distance.length(distance.size());
     374             :                 for (unsigned int i = 0; i < distance.size(); ++i) {
     375             :                         
     376             :                                 
     377             :                         x.distance[i] = distance.at(i);
     378             :                                 
     379             :                         
     380             :                 }
     381             :                         
     382             :                 
     383             :         
     384             : 
     385             :         
     386             :                 
     387             :                 
     388             :                 
     389             :                         
     390             :                 x.timeOrigin = timeOrigin.toIDLArrayTime();
     391             :                         
     392             :                 
     393             :         
     394             : 
     395             :         
     396             :                 
     397             :                 
     398             :                 
     399             :                         
     400             :                                 
     401             :                 x.origin = CORBA::string_dup(origin.c_str());
     402             :                                 
     403             :                         
     404             :                 
     405             :         
     406             : 
     407             :         
     408             :                 
     409             :                 
     410             :                 x.numPolyRadVelExists = numPolyRadVelExists;
     411             :                 
     412             :                 
     413             :                         
     414             :                                 
     415             :                 x.numPolyRadVel = numPolyRadVel;
     416             :                                 
     417             :                         
     418             :                 
     419             :         
     420             : 
     421             :         
     422             :                 
     423             :                 
     424             :                 x.radVelExists = radVelExists;
     425             :                 
     426             :                 
     427             :                         
     428             :                 x.radVel.length(radVel.size());
     429             :                 for (unsigned int i = 0; i < radVel.size(); ++i) {
     430             :                         
     431             :                                 
     432             :                         x.radVel[i] = radVel.at(i);
     433             :                                 
     434             :                         
     435             :                 }
     436             :                         
     437             :                 
     438             :         
     439             : 
     440             :         
     441             :         
     442             :                 
     443             :         
     444             :         }
     445             : #endif
     446             :         
     447             : 
     448             : #ifndef WITHOUT_ACS
     449             :         /**
     450             :          * Fill the values of this row from the IDL struct EphemerisRowIDL.
     451             :          * @param x The IDL struct containing the values used to fill this row.
     452             :          */
     453             :         void EphemerisRow::setFromIDL (EphemerisRowIDL x){
     454             :                 try {
     455             :                 // Fill the values from x.
     456             :         
     457             :                 
     458             :         
     459             :                 
     460             :                 
     461             :                         
     462             :                 setTimeInterval(ArrayTimeInterval (x.timeInterval));
     463             :                         
     464             :                 
     465             :                 
     466             :         
     467             : 
     468             :         
     469             :                 
     470             :                 
     471             :                         
     472             :                 setEphemerisId(x.ephemerisId);
     473             :                         
     474             :                 
     475             :                 
     476             :         
     477             : 
     478             :         
     479             :                 
     480             :                 
     481             :                         
     482             :                 observerLocation .clear();
     483             :                 for (unsigned int i = 0; i <x.observerLocation.length(); ++i) {
     484             :                         
     485             :                         observerLocation.push_back(x.observerLocation[i]);
     486             :                         
     487             :                 }
     488             :                         
     489             :                 
     490             :                 
     491             :         
     492             : 
     493             :         
     494             :                 
     495             :                 
     496             :                         
     497             :                 setEquinoxEquator(x.equinoxEquator);
     498             :                         
     499             :                 
     500             :                 
     501             :         
     502             : 
     503             :         
     504             :                 
     505             :                 
     506             :                         
     507             :                 setNumPolyDir(x.numPolyDir);
     508             :                         
     509             :                 
     510             :                 
     511             :         
     512             : 
     513             :         
     514             :                 
     515             :                 
     516             :                         
     517             :                 dir .clear();
     518             :         
     519             :         vector<double> v_aux_dir;
     520             :         
     521             :                 for (unsigned int i = 0; i < x.dir.length(); ++i) {
     522             :                         v_aux_dir.clear();
     523             :                         for (unsigned int j = 0; j < x.dir[0].length(); ++j) {
     524             :                                 
     525             :                                 v_aux_dir.push_back(x.dir[i][j]);
     526             :                                 
     527             :                         }
     528             :                         dir.push_back(v_aux_dir);                       
     529             :                 }
     530             :                         
     531             :                 
     532             :                 
     533             :         
     534             : 
     535             :         
     536             :                 
     537             :                 
     538             :                         
     539             :                 setNumPolyDist(x.numPolyDist);
     540             :                         
     541             :                 
     542             :                 
     543             :         
     544             : 
     545             :         
     546             :                 
     547             :                 
     548             :                         
     549             :                 distance .clear();
     550             :                 for (unsigned int i = 0; i <x.distance.length(); ++i) {
     551             :                         
     552             :                         distance.push_back(x.distance[i]);
     553             :                         
     554             :                 }
     555             :                         
     556             :                 
     557             :                 
     558             :         
     559             : 
     560             :         
     561             :                 
     562             :                 
     563             :                         
     564             :                 setTimeOrigin(ArrayTime (x.timeOrigin));
     565             :                         
     566             :                 
     567             :                 
     568             :         
     569             : 
     570             :         
     571             :                 
     572             :                 
     573             :                         
     574             :                 setOrigin(string (x.origin));
     575             :                         
     576             :                 
     577             :                 
     578             :         
     579             : 
     580             :         
     581             :                 
     582             :                 numPolyRadVelExists = x.numPolyRadVelExists;
     583             :                 if (x.numPolyRadVelExists) {
     584             :                 
     585             :                 
     586             :                         
     587             :                 setNumPolyRadVel(x.numPolyRadVel);
     588             :                         
     589             :                 
     590             :                 
     591             :                 }
     592             :                 
     593             :         
     594             : 
     595             :         
     596             :                 
     597             :                 radVelExists = x.radVelExists;
     598             :                 if (x.radVelExists) {
     599             :                 
     600             :                 
     601             :                         
     602             :                 radVel .clear();
     603             :                 for (unsigned int i = 0; i <x.radVel.length(); ++i) {
     604             :                         
     605             :                         radVel.push_back(x.radVel[i]);
     606             :                         
     607             :                 }
     608             :                         
     609             :                 
     610             :                 
     611             :                 }
     612             :                 
     613             :         
     614             : 
     615             :         
     616             :         
     617             :                 
     618             :                 } catch (const IllegalAccessException &err) {
     619             :                         throw ConversionException (err.getMessage(),"Ephemeris");
     620             :                 }
     621             :         }
     622             : #endif
     623             :         
     624             :         /**
     625             :          * Return this row in the form of an XML string.
     626             :          * @return The values of this row as an XML string.
     627             :          */
     628           0 :         string EphemerisRow::toXML() const {
     629           0 :                 string buf;
     630           0 :                 buf.append("<row> \n");
     631             :                 
     632             :         
     633             :                 
     634             :         
     635             :                 
     636             :                 
     637           0 :                 Parser::toXML(timeInterval, "timeInterval", buf);
     638             :                 
     639             :                 
     640             :         
     641             : 
     642             :         
     643             :                 
     644             :                 
     645           0 :                 Parser::toXML(ephemerisId, "ephemerisId", buf);
     646             :                 
     647             :                 
     648             :         
     649             : 
     650             :         
     651             :                 
     652             :                 
     653           0 :                 Parser::toXML(observerLocation, "observerLocation", buf);
     654             :                 
     655             :                 
     656             :         
     657             : 
     658             :         
     659             :                 
     660             :                 
     661           0 :                 Parser::toXML(equinoxEquator, "equinoxEquator", buf);
     662             :                 
     663             :                 
     664             :         
     665             : 
     666             :         
     667             :                 
     668             :                 
     669           0 :                 Parser::toXML(numPolyDir, "numPolyDir", buf);
     670             :                 
     671             :                 
     672             :         
     673             : 
     674             :         
     675             :                 
     676             :                 
     677           0 :                 Parser::toXML(dir, "dir", buf);
     678             :                 
     679             :                 
     680             :         
     681             : 
     682             :         
     683             :                 
     684             :                 
     685           0 :                 Parser::toXML(numPolyDist, "numPolyDist", buf);
     686             :                 
     687             :                 
     688             :         
     689             : 
     690             :         
     691             :                 
     692             :                 
     693           0 :                 Parser::toXML(distance, "distance", buf);
     694             :                 
     695             :                 
     696             :         
     697             : 
     698             :         
     699             :                 
     700             :                 
     701           0 :                 Parser::toXML(timeOrigin, "timeOrigin", buf);
     702             :                 
     703             :                 
     704             :         
     705             : 
     706             :         
     707             :                 
     708             :                 
     709           0 :                 Parser::toXML(origin, "origin", buf);
     710             :                 
     711             :                 
     712             :         
     713             : 
     714             :         
     715             :                 
     716           0 :                 if (numPolyRadVelExists) {
     717             :                 
     718             :                 
     719           0 :                 Parser::toXML(numPolyRadVel, "numPolyRadVel", buf);
     720             :                 
     721             :                 
     722             :                 }
     723             :                 
     724             :         
     725             : 
     726             :         
     727             :                 
     728           0 :                 if (radVelExists) {
     729             :                 
     730             :                 
     731           0 :                 Parser::toXML(radVel, "radVel", buf);
     732             :                 
     733             :                 
     734             :                 }
     735             :                 
     736             :         
     737             : 
     738             :         
     739             :         
     740             :                 
     741             :                 
     742           0 :                 buf.append("</row>\n");
     743           0 :                 return buf;
     744             :         }
     745             : 
     746             :         /**
     747             :          * Fill the values of this row from an XML string 
     748             :          * that was produced by the toXML() method.
     749             :          * @param x The XML string being used to set the values of this row.
     750             :          */
     751         289 :         void EphemerisRow::setFromXML (string rowDoc) {
     752         578 :                 Parser row(rowDoc);
     753         578 :                 string s = "";
     754             :                 try {
     755             :         
     756             :                 
     757             :         
     758             :                 
     759             :                         
     760         289 :                 setTimeInterval(Parser::getArrayTimeInterval("timeInterval","Ephemeris",rowDoc));
     761             :                         
     762             :                 
     763             :         
     764             : 
     765             :         
     766             :                 
     767             :                         
     768         289 :                 setEphemerisId(Parser::getInteger("ephemerisId","Ephemeris",rowDoc));
     769             :                         
     770             :                 
     771             :         
     772             : 
     773             :         
     774             :                 
     775             :                         
     776             :                                         
     777         289 :                 setObserverLocation(Parser::get1DDouble("observerLocation","Ephemeris",rowDoc));
     778             :                                 
     779             :                         
     780             :                 
     781             :         
     782             : 
     783             :         
     784             :                 
     785             :                         
     786         289 :                 setEquinoxEquator(Parser::getDouble("equinoxEquator","Ephemeris",rowDoc));
     787             :                         
     788             :                 
     789             :         
     790             : 
     791             :         
     792             :                 
     793             :                         
     794         289 :                 setNumPolyDir(Parser::getInteger("numPolyDir","Ephemeris",rowDoc));
     795             :                         
     796             :                 
     797             :         
     798             : 
     799             :         
     800             :                 
     801             :                         
     802             :                                         
     803         289 :                 setDir(Parser::get2DDouble("dir","Ephemeris",rowDoc));
     804             :                                 
     805             :                         
     806             :                 
     807             :         
     808             : 
     809             :         
     810             :                 
     811             :                         
     812         289 :                 setNumPolyDist(Parser::getInteger("numPolyDist","Ephemeris",rowDoc));
     813             :                         
     814             :                 
     815             :         
     816             : 
     817             :         
     818             :                 
     819             :                         
     820             :                                         
     821         289 :                 setDistance(Parser::get1DDouble("distance","Ephemeris",rowDoc));
     822             :                                 
     823             :                         
     824             :                 
     825             :         
     826             : 
     827             :         
     828             :                 
     829             :                         
     830         289 :                 setTimeOrigin(Parser::getArrayTime("timeOrigin","Ephemeris",rowDoc));
     831             :                         
     832             :                 
     833             :         
     834             : 
     835             :         
     836             :                 
     837             :                         
     838         289 :                 setOrigin(Parser::getString("origin","Ephemeris",rowDoc));
     839             :                         
     840             :                 
     841             :         
     842             : 
     843             :         
     844             :                 
     845         289 :         if (row.isStr("<numPolyRadVel>")) {
     846             :                         
     847         288 :                         setNumPolyRadVel(Parser::getInteger("numPolyRadVel","Ephemeris",rowDoc));
     848             :                         
     849             :                 }
     850             :                 
     851             :         
     852             : 
     853             :         
     854             :                 
     855         289 :         if (row.isStr("<radVel>")) {
     856             :                         
     857             :                                                                 
     858         288 :                         setRadVel(Parser::get1DDouble("radVel","Ephemeris",rowDoc));
     859             :                                 
     860             :                         
     861             :                 }
     862             :                 
     863             :         
     864             : 
     865             :         
     866             :         
     867             :                 
     868           0 :                 } catch (const IllegalAccessException &err) {
     869           0 :                         throw ConversionException (err.getMessage(),"Ephemeris");
     870             :                 }
     871         289 :         }
     872             :         
     873           0 :         void EphemerisRow::toBin(EndianOSStream& eoss) {
     874             :         
     875             :         
     876             :         
     877             :         
     878             :                 
     879           0 :         timeInterval.toBin(eoss);
     880             :                 
     881             :         
     882             : 
     883             :         
     884             :         
     885             :                 
     886             :                                                 
     887           0 :                         eoss.writeInt(ephemerisId);
     888             :                                 
     889             :                 
     890             :         
     891             : 
     892             :         
     893             :         
     894             :                 
     895             :                 
     896             :                         
     897           0 :                 eoss.writeInt((int) observerLocation.size());
     898           0 :                 for (unsigned int i = 0; i < observerLocation.size(); i++)
     899             :                                 
     900           0 :                         eoss.writeDouble(observerLocation.at(i));
     901             :                                 
     902             :                                 
     903             :                                                 
     904             :                 
     905             :         
     906             : 
     907             :         
     908             :         
     909             :                 
     910             :                                                 
     911           0 :                         eoss.writeDouble(equinoxEquator);
     912             :                                 
     913             :                 
     914             :         
     915             : 
     916             :         
     917             :         
     918             :                 
     919             :                                                 
     920           0 :                         eoss.writeInt(numPolyDir);
     921             :                                 
     922             :                 
     923             :         
     924             : 
     925             :         
     926             :         
     927             :                 
     928             :                 
     929             :                         
     930           0 :                 eoss.writeInt((int) dir.size());
     931           0 :                 eoss.writeInt((int) dir.at(0).size());
     932           0 :                 for (unsigned int i = 0; i < dir.size(); i++) 
     933           0 :                         for (unsigned int j = 0;  j < dir.at(0).size(); j++) 
     934             :                                                          
     935           0 :                                 eoss.writeDouble(dir.at(i).at(j));
     936             :                                 
     937             :         
     938             :                                                 
     939             :                 
     940             :         
     941             : 
     942             :         
     943             :         
     944             :                 
     945             :                                                 
     946           0 :                         eoss.writeInt(numPolyDist);
     947             :                                 
     948             :                 
     949             :         
     950             : 
     951             :         
     952             :         
     953             :                 
     954             :                 
     955             :                         
     956           0 :                 eoss.writeInt((int) distance.size());
     957           0 :                 for (unsigned int i = 0; i < distance.size(); i++)
     958             :                                 
     959           0 :                         eoss.writeDouble(distance.at(i));
     960             :                                 
     961             :                                 
     962             :                                                 
     963             :                 
     964             :         
     965             : 
     966             :         
     967             :         
     968             :                 
     969           0 :         timeOrigin.toBin(eoss);
     970             :                 
     971             :         
     972             : 
     973             :         
     974             :         
     975             :                 
     976             :                                                 
     977           0 :                         eoss.writeString(origin);
     978             :                                 
     979             :                 
     980             :         
     981             : 
     982             : 
     983             :         
     984             :         
     985           0 :         eoss.writeBoolean(numPolyRadVelExists);
     986           0 :         if (numPolyRadVelExists) {
     987             :         
     988             :         
     989             :         
     990             :                 
     991             :                                                 
     992           0 :                         eoss.writeInt(numPolyRadVel);
     993             :                                 
     994             :                 
     995             :         
     996             : 
     997             :         }
     998             : 
     999           0 :         eoss.writeBoolean(radVelExists);
    1000           0 :         if (radVelExists) {
    1001             :         
    1002             :         
    1003             :         
    1004             :                 
    1005             :                 
    1006             :                         
    1007           0 :                 eoss.writeInt((int) radVel.size());
    1008           0 :                 for (unsigned int i = 0; i < radVel.size(); i++)
    1009             :                                 
    1010           0 :                         eoss.writeDouble(radVel.at(i));
    1011             :                                 
    1012             :                                 
    1013             :                                                 
    1014             :                 
    1015             :         
    1016             : 
    1017             :         }
    1018             : 
    1019           0 :         }
    1020             :         
    1021           0 : void EphemerisRow::timeIntervalFromBin(EndianIStream& eis) {
    1022             :                 
    1023             :         
    1024             :                 
    1025             :                 
    1026           0 :                 timeInterval =  ArrayTimeInterval::fromBin(eis);
    1027             :                 
    1028             :         
    1029             :         
    1030           0 : }
    1031           0 : void EphemerisRow::ephemerisIdFromBin(EndianIStream& eis) {
    1032             :                 
    1033             :         
    1034             :         
    1035             :                 
    1036             :                         
    1037           0 :                 ephemerisId =  eis.readInt();
    1038             :                         
    1039             :                 
    1040             :         
    1041             :         
    1042           0 : }
    1043           0 : void EphemerisRow::observerLocationFromBin(EndianIStream& eis) {
    1044             :                 
    1045             :         
    1046             :         
    1047             :                 
    1048             :                         
    1049             :         
    1050           0 :                 observerLocation.clear();
    1051             :                 
    1052           0 :                 unsigned int observerLocationDim1 = eis.readInt();
    1053           0 :                 for (unsigned int  i = 0 ; i < observerLocationDim1; i++)
    1054             :                         
    1055           0 :                         observerLocation.push_back(eis.readDouble());
    1056             :                         
    1057             :         
    1058             : 
    1059             :                 
    1060             :         
    1061             :         
    1062           0 : }
    1063           0 : void EphemerisRow::equinoxEquatorFromBin(EndianIStream& eis) {
    1064             :                 
    1065             :         
    1066             :         
    1067             :                 
    1068             :                         
    1069           0 :                 equinoxEquator =  eis.readDouble();
    1070             :                         
    1071             :                 
    1072             :         
    1073             :         
    1074           0 : }
    1075           0 : void EphemerisRow::numPolyDirFromBin(EndianIStream& eis) {
    1076             :                 
    1077             :         
    1078             :         
    1079             :                 
    1080             :                         
    1081           0 :                 numPolyDir =  eis.readInt();
    1082             :                         
    1083             :                 
    1084             :         
    1085             :         
    1086           0 : }
    1087           0 : void EphemerisRow::dirFromBin(EndianIStream& eis) {
    1088             :                 
    1089             :         
    1090             :         
    1091             :                 
    1092             :                         
    1093             :         
    1094           0 :                 dir.clear();
    1095             :                 
    1096           0 :                 unsigned int dirDim1 = eis.readInt();
    1097           0 :                 unsigned int dirDim2 = eis.readInt();
    1098             :         
    1099           0 :                 vector <double> dirAux1;
    1100             :         
    1101           0 :                 for (unsigned int i = 0; i < dirDim1; i++) {
    1102           0 :                         dirAux1.clear();
    1103           0 :                         for (unsigned int j = 0; j < dirDim2 ; j++)                  
    1104             :                         
    1105           0 :                         dirAux1.push_back(eis.readDouble());
    1106             :                         
    1107           0 :                         dir.push_back(dirAux1);
    1108             :                 }
    1109             :         
    1110             :         
    1111             : 
    1112             :                 
    1113             :         
    1114             :         
    1115           0 : }
    1116           0 : void EphemerisRow::numPolyDistFromBin(EndianIStream& eis) {
    1117             :                 
    1118             :         
    1119             :         
    1120             :                 
    1121             :                         
    1122           0 :                 numPolyDist =  eis.readInt();
    1123             :                         
    1124             :                 
    1125             :         
    1126             :         
    1127           0 : }
    1128           0 : void EphemerisRow::distanceFromBin(EndianIStream& eis) {
    1129             :                 
    1130             :         
    1131             :         
    1132             :                 
    1133             :                         
    1134             :         
    1135           0 :                 distance.clear();
    1136             :                 
    1137           0 :                 unsigned int distanceDim1 = eis.readInt();
    1138           0 :                 for (unsigned int  i = 0 ; i < distanceDim1; i++)
    1139             :                         
    1140           0 :                         distance.push_back(eis.readDouble());
    1141             :                         
    1142             :         
    1143             : 
    1144             :                 
    1145             :         
    1146             :         
    1147           0 : }
    1148           0 : void EphemerisRow::timeOriginFromBin(EndianIStream& eis) {
    1149             :                 
    1150             :         
    1151             :                 
    1152             :                 
    1153           0 :                 timeOrigin =  ArrayTime::fromBin(eis);
    1154             :                 
    1155             :         
    1156             :         
    1157           0 : }
    1158           0 : void EphemerisRow::originFromBin(EndianIStream& eis) {
    1159             :                 
    1160             :         
    1161             :         
    1162             :                 
    1163             :                         
    1164           0 :                 origin =  eis.readString();
    1165             :                         
    1166             :                 
    1167             :         
    1168             :         
    1169           0 : }
    1170             : 
    1171           0 : void EphemerisRow::numPolyRadVelFromBin(EndianIStream& eis) {
    1172             :                 
    1173           0 :         numPolyRadVelExists = eis.readBoolean();
    1174           0 :         if (numPolyRadVelExists) {
    1175             :                 
    1176             :         
    1177             :         
    1178             :                 
    1179             :                         
    1180           0 :                 numPolyRadVel =  eis.readInt();
    1181             :                         
    1182             :                 
    1183             :         
    1184             : 
    1185             :         }
    1186             :         
    1187           0 : }
    1188           0 : void EphemerisRow::radVelFromBin(EndianIStream& eis) {
    1189             :                 
    1190           0 :         radVelExists = eis.readBoolean();
    1191           0 :         if (radVelExists) {
    1192             :                 
    1193             :         
    1194             :         
    1195             :                 
    1196             :                         
    1197             :         
    1198           0 :                 radVel.clear();
    1199             :                 
    1200           0 :                 unsigned int radVelDim1 = eis.readInt();
    1201           0 :                 for (unsigned int  i = 0 ; i < radVelDim1; i++)
    1202             :                         
    1203           0 :                         radVel.push_back(eis.readDouble());
    1204             :                         
    1205             :         
    1206             : 
    1207             :                 
    1208             :         
    1209             : 
    1210             :         }
    1211             :         
    1212           0 : }
    1213             :         
    1214             :         
    1215           0 :         EphemerisRow* EphemerisRow::fromBin(EndianIStream& eis, EphemerisTable& table, const vector<string>& attributesSeq) {
    1216           0 :                 EphemerisRow* row = new  EphemerisRow(table);
    1217             :                 
    1218           0 :                 map<string, EphemerisAttributeFromBin>::iterator iter ;
    1219           0 :                 for (unsigned int i = 0; i < attributesSeq.size(); i++) {
    1220           0 :                         iter = row->fromBinMethods.find(attributesSeq.at(i));
    1221           0 :                         if (iter != row->fromBinMethods.end()) {
    1222           0 :                                 (row->*(row->fromBinMethods[ attributesSeq.at(i) ] ))(eis);                       
    1223             :                         }
    1224             :                         else {
    1225           0 :                                 BinaryAttributeReaderFunctor* functorP = table.getUnknownAttributeBinaryReader(attributesSeq.at(i));
    1226           0 :                                 if (functorP)
    1227           0 :                                         (*functorP)(eis);
    1228             :                                 else
    1229           0 :                                         throw ConversionException("There is not method to read an attribute '"+attributesSeq.at(i)+"'.", "EphemerisTable");
    1230             :                         }
    1231             :                                 
    1232             :                 }                               
    1233           0 :                 return row;
    1234             :         }
    1235             : 
    1236             :         //
    1237             :         // A collection of methods to set the value of the attributes from their textual value in the XML representation
    1238             :         // of one row.
    1239             :         //
    1240             :         
    1241             :         // Convert a string into an ArrayTimeInterval 
    1242           0 :         void EphemerisRow::timeIntervalFromText(const string & s) {
    1243             :                  
    1244             :           
    1245           0 :                 timeInterval = ASDMValuesParser::parse<ArrayTimeInterval>(s);
    1246             :           
    1247             :                 
    1248           0 :         }
    1249             :         
    1250             :         
    1251             :         // Convert a string into an int 
    1252           0 :         void EphemerisRow::ephemerisIdFromText(const string & s) {
    1253             :                  
    1254             :           
    1255           0 :                 ephemerisId = ASDMValuesParser::parse<int>(s);
    1256             :           
    1257             :                 
    1258           0 :         }
    1259             :         
    1260             :         
    1261             :         // Convert a string into an double 
    1262           0 :         void EphemerisRow::observerLocationFromText(const string & s) {
    1263             :                  
    1264             :           
    1265           0 :                 observerLocation = ASDMValuesParser::parse1D<double>(s);
    1266             :           
    1267             :                 
    1268           0 :         }
    1269             :         
    1270             :         
    1271             :         // Convert a string into an double 
    1272           0 :         void EphemerisRow::equinoxEquatorFromText(const string & s) {
    1273             :                  
    1274             :           
    1275           0 :                 equinoxEquator = ASDMValuesParser::parse<double>(s);
    1276             :           
    1277             :                 
    1278           0 :         }
    1279             :         
    1280             :         
    1281             :         // Convert a string into an int 
    1282           0 :         void EphemerisRow::numPolyDirFromText(const string & s) {
    1283             :                  
    1284             :           
    1285           0 :                 numPolyDir = ASDMValuesParser::parse<int>(s);
    1286             :           
    1287             :                 
    1288           0 :         }
    1289             :         
    1290             :         
    1291             :         // Convert a string into an double 
    1292           0 :         void EphemerisRow::dirFromText(const string & s) {
    1293             :                  
    1294             :           
    1295           0 :                 dir = ASDMValuesParser::parse2D<double>(s);
    1296             :           
    1297             :                 
    1298           0 :         }
    1299             :         
    1300             :         
    1301             :         // Convert a string into an int 
    1302           0 :         void EphemerisRow::numPolyDistFromText(const string & s) {
    1303             :                  
    1304             :           
    1305           0 :                 numPolyDist = ASDMValuesParser::parse<int>(s);
    1306             :           
    1307             :                 
    1308           0 :         }
    1309             :         
    1310             :         
    1311             :         // Convert a string into an double 
    1312           0 :         void EphemerisRow::distanceFromText(const string & s) {
    1313             :                  
    1314             :           
    1315           0 :                 distance = ASDMValuesParser::parse1D<double>(s);
    1316             :           
    1317             :                 
    1318           0 :         }
    1319             :         
    1320             :         
    1321             :         // Convert a string into an ArrayTime 
    1322           0 :         void EphemerisRow::timeOriginFromText(const string & s) {
    1323             :                  
    1324             :           
    1325           0 :                 timeOrigin = ASDMValuesParser::parse<ArrayTime>(s);
    1326             :           
    1327             :                 
    1328           0 :         }
    1329             :         
    1330             :         
    1331             :         // Convert a string into an String 
    1332           0 :         void EphemerisRow::originFromText(const string & s) {
    1333             :                  
    1334             :           
    1335           0 :                 origin = ASDMValuesParser::parse<string>(s);
    1336             :           
    1337             :                 
    1338           0 :         }
    1339             :         
    1340             : 
    1341             :         
    1342             :         // Convert a string into an int 
    1343           0 :         void EphemerisRow::numPolyRadVelFromText(const string & s) {
    1344           0 :                 numPolyRadVelExists = true;
    1345             :                  
    1346             :           
    1347           0 :                 numPolyRadVel = ASDMValuesParser::parse<int>(s);
    1348             :           
    1349             :                 
    1350           0 :         }
    1351             :         
    1352             :         
    1353             :         // Convert a string into an double 
    1354           0 :         void EphemerisRow::radVelFromText(const string & s) {
    1355           0 :                 radVelExists = true;
    1356             :                  
    1357             :           
    1358           0 :                 radVel = ASDMValuesParser::parse1D<double>(s);
    1359             :           
    1360             :                 
    1361           0 :         }
    1362             :         
    1363             :         
    1364             :         
    1365           0 :         void EphemerisRow::fromText(const std::string& attributeName, const std::string&  t) {
    1366           0 :                 map<string, EphemerisAttributeFromText>::iterator iter;
    1367           0 :                 if ((iter = fromTextMethods.find(attributeName)) == fromTextMethods.end())
    1368           0 :                         throw ConversionException("I do not know what to do with '"+attributeName+"' and its content '"+t+"' (while parsing an XML document)", "EphemerisTable");
    1369           0 :                 (this->*(iter->second))(t);
    1370           0 :         }
    1371             :                         
    1372             :         ////////////////////////////////////////////////
    1373             :         // Intrinsic Table Attributes getters/setters //
    1374             :         ////////////////////////////////////////////////
    1375             :         
    1376             :         
    1377             : 
    1378             :         
    1379             :         /**
    1380             :          * Get timeInterval.
    1381             :          * @return timeInterval as ArrayTimeInterval
    1382             :          */
    1383         308 :         ArrayTimeInterval EphemerisRow::getTimeInterval() const {
    1384             :         
    1385         308 :                 return timeInterval;
    1386             :         }
    1387             : 
    1388             :         /**
    1389             :          * Set timeInterval with the specified ArrayTimeInterval.
    1390             :          * @param timeInterval The ArrayTimeInterval value to which timeInterval is to be set.
    1391             :          
    1392             :         
    1393             :                 
    1394             :          * @throw IllegalAccessException If an attempt is made to change this field after is has been added to the table.
    1395             :                 
    1396             :          */
    1397         289 :         void EphemerisRow::setTimeInterval (ArrayTimeInterval timeInterval)  {
    1398             :         
    1399             :         
    1400         289 :                 if (hasBeenAdded) {
    1401             :                 
    1402           0 :                         throw IllegalAccessException("timeInterval", "Ephemeris");
    1403             :                 
    1404             :                 }
    1405             :         
    1406         289 :                 this->timeInterval = timeInterval;
    1407             :         
    1408         289 :         }
    1409             :         
    1410             :         
    1411             : 
    1412             :         
    1413             : 
    1414             :         
    1415             :         /**
    1416             :          * Get ephemerisId.
    1417             :          * @return ephemerisId as int
    1418             :          */
    1419         578 :         int EphemerisRow::getEphemerisId() const {
    1420             :         
    1421         578 :                 return ephemerisId;
    1422             :         }
    1423             : 
    1424             :         /**
    1425             :          * Set ephemerisId with the specified int.
    1426             :          * @param ephemerisId The int value to which ephemerisId is to be set.
    1427             :          
    1428             :         
    1429             :                 
    1430             :          * @throw IllegalAccessException If an attempt is made to change this field after is has been added to the table.
    1431             :                 
    1432             :          */
    1433         289 :         void EphemerisRow::setEphemerisId (int ephemerisId)  {
    1434             :         
    1435             :         
    1436         289 :                 if (hasBeenAdded) {
    1437             :                 
    1438           0 :                         throw IllegalAccessException("ephemerisId", "Ephemeris");
    1439             :                 
    1440             :                 }
    1441             :         
    1442         289 :                 this->ephemerisId = ephemerisId;
    1443             :         
    1444         289 :         }
    1445             :         
    1446             :         
    1447             : 
    1448             :         
    1449             : 
    1450             :         
    1451             :         /**
    1452             :          * Get observerLocation.
    1453             :          * @return observerLocation as std::vector<double >
    1454             :          */
    1455           9 :         std::vector<double > EphemerisRow::getObserverLocation() const {
    1456             :         
    1457           9 :                 return observerLocation;
    1458             :         }
    1459             : 
    1460             :         /**
    1461             :          * Set observerLocation with the specified std::vector<double >.
    1462             :          * @param observerLocation The std::vector<double > value to which observerLocation is to be set.
    1463             :          
    1464             :         
    1465             :                 
    1466             :          */
    1467         289 :         void EphemerisRow::setObserverLocation (std::vector<double > observerLocation)  {
    1468             :         
    1469             :         
    1470         289 :                 if (hasBeenAdded) {
    1471             :                 
    1472             :                 }
    1473             :         
    1474         289 :                 this->observerLocation = observerLocation;
    1475             :         
    1476         289 :         }
    1477             :         
    1478             :         
    1479             : 
    1480             :         
    1481             : 
    1482             :         
    1483             :         /**
    1484             :          * Get equinoxEquator.
    1485             :          * @return equinoxEquator as double
    1486             :          */
    1487           9 :         double EphemerisRow::getEquinoxEquator() const {
    1488             :         
    1489           9 :                 return equinoxEquator;
    1490             :         }
    1491             : 
    1492             :         /**
    1493             :          * Set equinoxEquator with the specified double.
    1494             :          * @param equinoxEquator The double value to which equinoxEquator is to be set.
    1495             :          
    1496             :         
    1497             :                 
    1498             :          */
    1499         289 :         void EphemerisRow::setEquinoxEquator (double equinoxEquator)  {
    1500             :         
    1501             :         
    1502         289 :                 if (hasBeenAdded) {
    1503             :                 
    1504             :                 }
    1505             :         
    1506         289 :                 this->equinoxEquator = equinoxEquator;
    1507             :         
    1508         289 :         }
    1509             :         
    1510             :         
    1511             : 
    1512             :         
    1513             : 
    1514             :         
    1515             :         /**
    1516             :          * Get numPolyDir.
    1517             :          * @return numPolyDir as int
    1518             :          */
    1519         289 :         int EphemerisRow::getNumPolyDir() const {
    1520             :         
    1521         289 :                 return numPolyDir;
    1522             :         }
    1523             : 
    1524             :         /**
    1525             :          * Set numPolyDir with the specified int.
    1526             :          * @param numPolyDir The int value to which numPolyDir is to be set.
    1527             :          
    1528             :         
    1529             :                 
    1530             :          */
    1531         289 :         void EphemerisRow::setNumPolyDir (int numPolyDir)  {
    1532             :         
    1533             :         
    1534         289 :                 if (hasBeenAdded) {
    1535             :                 
    1536             :                 }
    1537             :         
    1538         289 :                 this->numPolyDir = numPolyDir;
    1539             :         
    1540         289 :         }
    1541             :         
    1542             :         
    1543             : 
    1544             :         
    1545             : 
    1546             :         
    1547             :         /**
    1548             :          * Get dir.
    1549             :          * @return dir as std::vector<std::vector<double > >
    1550             :          */
    1551         289 :         std::vector<std::vector<double > > EphemerisRow::getDir() const {
    1552             :         
    1553         289 :                 return dir;
    1554             :         }
    1555             : 
    1556             :         /**
    1557             :          * Set dir with the specified std::vector<std::vector<double > >.
    1558             :          * @param dir The std::vector<std::vector<double > > value to which dir is to be set.
    1559             :          
    1560             :         
    1561             :                 
    1562             :          */
    1563         289 :         void EphemerisRow::setDir (std::vector<std::vector<double > > dir)  {
    1564             :         
    1565             :         
    1566         289 :                 if (hasBeenAdded) {
    1567             :                 
    1568             :                 }
    1569             :         
    1570         289 :                 this->dir = dir;
    1571             :         
    1572         289 :         }
    1573             :         
    1574             :         
    1575             : 
    1576             :         
    1577             : 
    1578             :         
    1579             :         /**
    1580             :          * Get numPolyDist.
    1581             :          * @return numPolyDist as int
    1582             :          */
    1583         289 :         int EphemerisRow::getNumPolyDist() const {
    1584             :         
    1585         289 :                 return numPolyDist;
    1586             :         }
    1587             : 
    1588             :         /**
    1589             :          * Set numPolyDist with the specified int.
    1590             :          * @param numPolyDist The int value to which numPolyDist is to be set.
    1591             :          
    1592             :         
    1593             :                 
    1594             :          */
    1595         289 :         void EphemerisRow::setNumPolyDist (int numPolyDist)  {
    1596             :         
    1597             :         
    1598         289 :                 if (hasBeenAdded) {
    1599             :                 
    1600             :                 }
    1601             :         
    1602         289 :                 this->numPolyDist = numPolyDist;
    1603             :         
    1604         289 :         }
    1605             :         
    1606             :         
    1607             : 
    1608             :         
    1609             : 
    1610             :         
    1611             :         /**
    1612             :          * Get distance.
    1613             :          * @return distance as std::vector<double >
    1614             :          */
    1615         289 :         std::vector<double > EphemerisRow::getDistance() const {
    1616             :         
    1617         289 :                 return distance;
    1618             :         }
    1619             : 
    1620             :         /**
    1621             :          * Set distance with the specified std::vector<double >.
    1622             :          * @param distance The std::vector<double > value to which distance is to be set.
    1623             :          
    1624             :         
    1625             :                 
    1626             :          */
    1627         289 :         void EphemerisRow::setDistance (std::vector<double > distance)  {
    1628             :         
    1629             :         
    1630         289 :                 if (hasBeenAdded) {
    1631             :                 
    1632             :                 }
    1633             :         
    1634         289 :                 this->distance = distance;
    1635             :         
    1636         289 :         }
    1637             :         
    1638             :         
    1639             : 
    1640             :         
    1641             : 
    1642             :         
    1643             :         /**
    1644             :          * Get timeOrigin.
    1645             :          * @return timeOrigin as ArrayTime
    1646             :          */
    1647           1 :         ArrayTime EphemerisRow::getTimeOrigin() const {
    1648             :         
    1649           1 :                 return timeOrigin;
    1650             :         }
    1651             : 
    1652             :         /**
    1653             :          * Set timeOrigin with the specified ArrayTime.
    1654             :          * @param timeOrigin The ArrayTime value to which timeOrigin is to be set.
    1655             :          
    1656             :         
    1657             :                 
    1658             :          */
    1659         289 :         void EphemerisRow::setTimeOrigin (ArrayTime timeOrigin)  {
    1660             :         
    1661             :         
    1662         289 :                 if (hasBeenAdded) {
    1663             :                 
    1664             :                 }
    1665             :         
    1666         289 :                 this->timeOrigin = timeOrigin;
    1667             :         
    1668         289 :         }
    1669             :         
    1670             :         
    1671             : 
    1672             :         
    1673             : 
    1674             :         
    1675             :         /**
    1676             :          * Get origin.
    1677             :          * @return origin as std::string
    1678             :          */
    1679           9 :         std::string EphemerisRow::getOrigin() const {
    1680             :         
    1681           9 :                 return origin;
    1682             :         }
    1683             : 
    1684             :         /**
    1685             :          * Set origin with the specified std::string.
    1686             :          * @param origin The std::string value to which origin is to be set.
    1687             :          
    1688             :         
    1689             :                 
    1690             :          */
    1691         289 :         void EphemerisRow::setOrigin (std::string origin)  {
    1692             :         
    1693             :         
    1694         289 :                 if (hasBeenAdded) {
    1695             :                 
    1696             :                 }
    1697             :         
    1698         289 :                 this->origin = origin;
    1699             :         
    1700         289 :         }
    1701             :         
    1702             :         
    1703             : 
    1704             :         
    1705             :         /**
    1706             :          * The attribute numPolyRadVel is optional. Return true if this attribute exists.
    1707             :          * @return true if and only if the numPolyRadVel attribute exists. 
    1708             :          */
    1709         288 :         bool EphemerisRow::isNumPolyRadVelExists() const {
    1710         288 :                 return numPolyRadVelExists;
    1711             :         }
    1712             :         
    1713             : 
    1714             :         
    1715             :         /**
    1716             :          * Get numPolyRadVel, which is optional.
    1717             :          * @return numPolyRadVel as int
    1718             :          * @throw IllegalAccessException If numPolyRadVel does not exist.
    1719             :          */
    1720         288 :         int EphemerisRow::getNumPolyRadVel() const  {
    1721         288 :                 if (!numPolyRadVelExists) {
    1722           0 :                         throw IllegalAccessException("numPolyRadVel", "Ephemeris");
    1723             :                 }
    1724             :         
    1725         288 :                 return numPolyRadVel;
    1726             :         }
    1727             : 
    1728             :         /**
    1729             :          * Set numPolyRadVel with the specified int.
    1730             :          * @param numPolyRadVel The int value to which numPolyRadVel is to be set.
    1731             :          
    1732             :         
    1733             :          */
    1734         288 :         void EphemerisRow::setNumPolyRadVel (int numPolyRadVel) {
    1735             :         
    1736         288 :                 this->numPolyRadVel = numPolyRadVel;
    1737             :         
    1738         288 :                 numPolyRadVelExists = true;
    1739             :         
    1740         288 :         }
    1741             :         
    1742             :         
    1743             :         /**
    1744             :          * Mark numPolyRadVel, which is an optional field, as non-existent.
    1745             :          */
    1746           0 :         void EphemerisRow::clearNumPolyRadVel () {
    1747           0 :                 numPolyRadVelExists = false;
    1748           0 :         }
    1749             :         
    1750             : 
    1751             :         
    1752             :         /**
    1753             :          * The attribute radVel is optional. Return true if this attribute exists.
    1754             :          * @return true if and only if the radVel attribute exists. 
    1755             :          */
    1756         290 :         bool EphemerisRow::isRadVelExists() const {
    1757         290 :                 return radVelExists;
    1758             :         }
    1759             :         
    1760             : 
    1761             :         
    1762             :         /**
    1763             :          * Get radVel, which is optional.
    1764             :          * @return radVel as std::vector<double >
    1765             :          * @throw IllegalAccessException If radVel does not exist.
    1766             :          */
    1767         288 :         std::vector<double > EphemerisRow::getRadVel() const  {
    1768         288 :                 if (!radVelExists) {
    1769           0 :                         throw IllegalAccessException("radVel", "Ephemeris");
    1770             :                 }
    1771             :         
    1772         288 :                 return radVel;
    1773             :         }
    1774             : 
    1775             :         /**
    1776             :          * Set radVel with the specified std::vector<double >.
    1777             :          * @param radVel The std::vector<double > value to which radVel is to be set.
    1778             :          
    1779             :         
    1780             :          */
    1781         288 :         void EphemerisRow::setRadVel (std::vector<double > radVel) {
    1782             :         
    1783         288 :                 this->radVel = radVel;
    1784             :         
    1785         288 :                 radVelExists = true;
    1786             :         
    1787         288 :         }
    1788             :         
    1789             :         
    1790             :         /**
    1791             :          * Mark radVel, which is an optional field, as non-existent.
    1792             :          */
    1793           0 :         void EphemerisRow::clearRadVel () {
    1794           0 :                 radVelExists = false;
    1795           0 :         }
    1796             :         
    1797             : 
    1798             :         
    1799             :         ///////////////////////////////////////////////
    1800             :         // Extrinsic Table Attributes getters/setters//
    1801             :         ///////////////////////////////////////////////
    1802             :         
    1803             : 
    1804             :         //////////////////////////////////////
    1805             :         // Links Attributes getters/setters //
    1806             :         //////////////////////////////////////
    1807             :         
    1808             :         
    1809             :         /**
    1810             :          * Create a EphemerisRow.
    1811             :          * <p>
    1812             :          * This constructor is private because only the
    1813             :          * table can create rows.  All rows know the table
    1814             :          * to which they belong.
    1815             :          * @param table The table to which this row belongs.
    1816             :          */ 
    1817         289 :         EphemerisRow::EphemerisRow (EphemerisTable &t) : table(t) {
    1818         289 :                 hasBeenAdded = false;
    1819             :                 
    1820             :         
    1821             :         
    1822             : 
    1823             :         
    1824             : 
    1825             :         
    1826             : 
    1827             :         
    1828             : 
    1829             :         
    1830             : 
    1831             :         
    1832             : 
    1833             :         
    1834             : 
    1835             :         
    1836             : 
    1837             :         
    1838             : 
    1839             :         
    1840             : 
    1841             :         
    1842         289 :                 numPolyRadVelExists = false;
    1843             :         
    1844             : 
    1845             :         
    1846         289 :                 radVelExists = false;
    1847             :         
    1848             : 
    1849             :         
    1850             :         
    1851             :         
    1852             :         
    1853             :         
    1854             : 
    1855             :         
    1856             : 
    1857             :         
    1858             : 
    1859             :         
    1860             : 
    1861             :         
    1862             : 
    1863             :         
    1864             : 
    1865             :         
    1866             : 
    1867             :         
    1868             : 
    1869             :         
    1870             : 
    1871             :         
    1872             : 
    1873             :         
    1874             : 
    1875             :         
    1876             : 
    1877             :         
    1878             :         
    1879         289 :          fromBinMethods["timeInterval"] = &EphemerisRow::timeIntervalFromBin; 
    1880         289 :          fromBinMethods["ephemerisId"] = &EphemerisRow::ephemerisIdFromBin; 
    1881         289 :          fromBinMethods["observerLocation"] = &EphemerisRow::observerLocationFromBin; 
    1882         289 :          fromBinMethods["equinoxEquator"] = &EphemerisRow::equinoxEquatorFromBin; 
    1883         289 :          fromBinMethods["numPolyDir"] = &EphemerisRow::numPolyDirFromBin; 
    1884         289 :          fromBinMethods["dir"] = &EphemerisRow::dirFromBin; 
    1885         289 :          fromBinMethods["numPolyDist"] = &EphemerisRow::numPolyDistFromBin; 
    1886         289 :          fromBinMethods["distance"] = &EphemerisRow::distanceFromBin; 
    1887         289 :          fromBinMethods["timeOrigin"] = &EphemerisRow::timeOriginFromBin; 
    1888         289 :          fromBinMethods["origin"] = &EphemerisRow::originFromBin; 
    1889             :                 
    1890             :         
    1891         289 :          fromBinMethods["numPolyRadVel"] = &EphemerisRow::numPolyRadVelFromBin; 
    1892         289 :          fromBinMethods["radVel"] = &EphemerisRow::radVelFromBin; 
    1893             :         
    1894             :         
    1895             :         
    1896             :         
    1897             :                                  
    1898         289 :         fromTextMethods["timeInterval"] = &EphemerisRow::timeIntervalFromText;
    1899             :                  
    1900             :         
    1901             :                                  
    1902         289 :         fromTextMethods["ephemerisId"] = &EphemerisRow::ephemerisIdFromText;
    1903             :                  
    1904             :         
    1905             :                                  
    1906         289 :         fromTextMethods["observerLocation"] = &EphemerisRow::observerLocationFromText;
    1907             :                  
    1908             :         
    1909             :                                  
    1910         289 :         fromTextMethods["equinoxEquator"] = &EphemerisRow::equinoxEquatorFromText;
    1911             :                  
    1912             :         
    1913             :                                  
    1914         289 :         fromTextMethods["numPolyDir"] = &EphemerisRow::numPolyDirFromText;
    1915             :                  
    1916             :         
    1917             :                                  
    1918         289 :         fromTextMethods["dir"] = &EphemerisRow::dirFromText;
    1919             :                  
    1920             :         
    1921             :                                  
    1922         289 :         fromTextMethods["numPolyDist"] = &EphemerisRow::numPolyDistFromText;
    1923             :                  
    1924             :         
    1925             :                                  
    1926         289 :         fromTextMethods["distance"] = &EphemerisRow::distanceFromText;
    1927             :                  
    1928             :         
    1929             :                                  
    1930         289 :         fromTextMethods["timeOrigin"] = &EphemerisRow::timeOriginFromText;
    1931             :                  
    1932             :         
    1933             :                                  
    1934         289 :         fromTextMethods["origin"] = &EphemerisRow::originFromText;
    1935             :                  
    1936             :         
    1937             : 
    1938             :          
    1939             :                                 
    1940         289 :         fromTextMethods["numPolyRadVel"] = &EphemerisRow::numPolyRadVelFromText;
    1941             :                         
    1942             :          
    1943             :                                 
    1944         289 :         fromTextMethods["radVel"] = &EphemerisRow::radVelFromText;
    1945             :                         
    1946             :                 
    1947         289 :         }
    1948             :         
    1949           0 :         EphemerisRow::EphemerisRow (EphemerisTable &t, EphemerisRow *row) : table(t) {
    1950           0 :                 hasBeenAdded = false;
    1951             :                 
    1952           0 :                 if (row == 0) {
    1953             :         
    1954             :         
    1955             :         
    1956             : 
    1957             :         
    1958             : 
    1959             :         
    1960             : 
    1961             :         
    1962             : 
    1963             :         
    1964             : 
    1965             :         
    1966             : 
    1967             :         
    1968             : 
    1969             :         
    1970             : 
    1971             :         
    1972             : 
    1973             :         
    1974             : 
    1975             :         
    1976           0 :                 numPolyRadVelExists = false;
    1977             :         
    1978             : 
    1979             :         
    1980           0 :                 radVelExists = false;
    1981             :         
    1982             : 
    1983             :                         
    1984             :                 }
    1985             :                 else {
    1986             :         
    1987             :                 
    1988           0 :                         timeInterval = row->timeInterval;
    1989             :                 
    1990           0 :                         ephemerisId = row->ephemerisId;
    1991             :                 
    1992             :                 
    1993             :                 
    1994             :                 
    1995           0 :                         observerLocation = row->observerLocation;
    1996             :                 
    1997           0 :                         equinoxEquator = row->equinoxEquator;
    1998             :                 
    1999           0 :                         numPolyDir = row->numPolyDir;
    2000             :                 
    2001           0 :                         dir = row->dir;
    2002             :                 
    2003           0 :                         numPolyDist = row->numPolyDist;
    2004             :                 
    2005           0 :                         distance = row->distance;
    2006             :                 
    2007           0 :                         timeOrigin = row->timeOrigin;
    2008             :                 
    2009           0 :                         origin = row->origin;
    2010             :                 
    2011             :                 
    2012             :                 
    2013             :                 
    2014           0 :                 if (row->numPolyRadVelExists) {
    2015           0 :                         numPolyRadVel = row->numPolyRadVel;          
    2016           0 :                         numPolyRadVelExists = true;
    2017             :                 }
    2018             :                 else
    2019           0 :                         numPolyRadVelExists = false;
    2020             :                 
    2021           0 :                 if (row->radVelExists) {
    2022           0 :                         radVel = row->radVel;                
    2023           0 :                         radVelExists = true;
    2024             :                 }
    2025             :                 else
    2026           0 :                         radVelExists = false;
    2027             :                 
    2028             :                 }
    2029             :                 
    2030           0 :                  fromBinMethods["timeInterval"] = &EphemerisRow::timeIntervalFromBin; 
    2031           0 :                  fromBinMethods["ephemerisId"] = &EphemerisRow::ephemerisIdFromBin; 
    2032           0 :                  fromBinMethods["observerLocation"] = &EphemerisRow::observerLocationFromBin; 
    2033           0 :                  fromBinMethods["equinoxEquator"] = &EphemerisRow::equinoxEquatorFromBin; 
    2034           0 :                  fromBinMethods["numPolyDir"] = &EphemerisRow::numPolyDirFromBin; 
    2035           0 :                  fromBinMethods["dir"] = &EphemerisRow::dirFromBin; 
    2036           0 :                  fromBinMethods["numPolyDist"] = &EphemerisRow::numPolyDistFromBin; 
    2037           0 :                  fromBinMethods["distance"] = &EphemerisRow::distanceFromBin; 
    2038           0 :                  fromBinMethods["timeOrigin"] = &EphemerisRow::timeOriginFromBin; 
    2039           0 :                  fromBinMethods["origin"] = &EphemerisRow::originFromBin; 
    2040             :                         
    2041             :         
    2042           0 :                  fromBinMethods["numPolyRadVel"] = &EphemerisRow::numPolyRadVelFromBin; 
    2043           0 :                  fromBinMethods["radVel"] = &EphemerisRow::radVelFromBin; 
    2044             :                         
    2045           0 :         }
    2046             : 
    2047             :         
    2048           0 :         bool EphemerisRow::compareNoAutoInc(ArrayTimeInterval timeInterval, int ephemerisId, std::vector<double > observerLocation, double equinoxEquator, int numPolyDir, std::vector<std::vector<double > > dir, int numPolyDist, std::vector<double > distance, ArrayTime timeOrigin, std::string origin) {
    2049             :                 bool result;
    2050           0 :                 result = true;
    2051             :                 
    2052             :         
    2053             :                 
    2054           0 :                 result = result && (this->timeInterval.overlaps(timeInterval));
    2055             :                 
    2056           0 :                 if (!result) return false;
    2057             :         
    2058             : 
    2059             :         
    2060             :                 
    2061           0 :                 result = result && (this->ephemerisId == ephemerisId);
    2062             :                 
    2063           0 :                 if (!result) return false;
    2064             :         
    2065             : 
    2066             :         
    2067             :                 
    2068           0 :                 result = result && (this->observerLocation == observerLocation);
    2069             :                 
    2070           0 :                 if (!result) return false;
    2071             :         
    2072             : 
    2073             :         
    2074             :                 
    2075           0 :                 result = result && (this->equinoxEquator == equinoxEquator);
    2076             :                 
    2077           0 :                 if (!result) return false;
    2078             :         
    2079             : 
    2080             :         
    2081             :                 
    2082           0 :                 result = result && (this->numPolyDir == numPolyDir);
    2083             :                 
    2084           0 :                 if (!result) return false;
    2085             :         
    2086             : 
    2087             :         
    2088             :                 
    2089           0 :                 result = result && (this->dir == dir);
    2090             :                 
    2091           0 :                 if (!result) return false;
    2092             :         
    2093             : 
    2094             :         
    2095             :                 
    2096           0 :                 result = result && (this->numPolyDist == numPolyDist);
    2097             :                 
    2098           0 :                 if (!result) return false;
    2099             :         
    2100             : 
    2101             :         
    2102             :                 
    2103           0 :                 result = result && (this->distance == distance);
    2104             :                 
    2105           0 :                 if (!result) return false;
    2106             :         
    2107             : 
    2108             :         
    2109             :                 
    2110           0 :                 result = result && (this->timeOrigin == timeOrigin);
    2111             :                 
    2112           0 :                 if (!result) return false;
    2113             :         
    2114             : 
    2115             :         
    2116             :                 
    2117           0 :                 result = result && (this->origin == origin);
    2118             :                 
    2119           0 :                 if (!result) return false;
    2120             :         
    2121             : 
    2122           0 :                 return result;
    2123             :         }       
    2124             :         
    2125             :         
    2126             :         
    2127           0 :         bool EphemerisRow::compareRequiredValue(std::vector<double > observerLocation, double equinoxEquator, int numPolyDir, std::vector<std::vector<double > > dir, int numPolyDist, std::vector<double > distance, ArrayTime timeOrigin, std::string origin) {
    2128             :                 bool result;
    2129           0 :                 result = true;
    2130             :                 
    2131             :         
    2132           0 :                 if (!(this->observerLocation == observerLocation)) return false;
    2133             :         
    2134             : 
    2135             :         
    2136           0 :                 if (!(this->equinoxEquator == equinoxEquator)) return false;
    2137             :         
    2138             : 
    2139             :         
    2140           0 :                 if (!(this->numPolyDir == numPolyDir)) return false;
    2141             :         
    2142             : 
    2143             :         
    2144           0 :                 if (!(this->dir == dir)) return false;
    2145             :         
    2146             : 
    2147             :         
    2148           0 :                 if (!(this->numPolyDist == numPolyDist)) return false;
    2149             :         
    2150             : 
    2151             :         
    2152           0 :                 if (!(this->distance == distance)) return false;
    2153             :         
    2154             : 
    2155             :         
    2156           0 :                 if (!(this->timeOrigin == timeOrigin)) return false;
    2157             :         
    2158             : 
    2159             :         
    2160           0 :                 if (!(this->origin == origin)) return false;
    2161             :         
    2162             : 
    2163           0 :                 return result;
    2164             :         }
    2165             :         
    2166             :         
    2167             :         /**
    2168             :          * Return true if all required attributes of the value part are equal to their homologues
    2169             :          * in x and false otherwise.
    2170             :          *
    2171             : 
    2172             :          * @param x a pointer on the EphemerisRow whose required attributes of the value part 
    2173             : 
    2174             :          * will be compared with those of this.
    2175             :          * @return a boolean.
    2176             :          */
    2177           0 :         bool EphemerisRow::equalByRequiredValue(EphemerisRow*  x ) {
    2178             :                 
    2179             :                         
    2180           0 :                 if (this->observerLocation != x->observerLocation) return false;
    2181             :                         
    2182           0 :                 if (this->equinoxEquator != x->equinoxEquator) return false;
    2183             :                         
    2184           0 :                 if (this->numPolyDir != x->numPolyDir) return false;
    2185             :                         
    2186           0 :                 if (this->dir != x->dir) return false;
    2187             :                         
    2188           0 :                 if (this->numPolyDist != x->numPolyDist) return false;
    2189             :                         
    2190           0 :                 if (this->distance != x->distance) return false;
    2191             :                         
    2192           0 :                 if (this->timeOrigin != x->timeOrigin) return false;
    2193             :                         
    2194           0 :                 if (this->origin != x->origin) return false;
    2195             :                         
    2196             :                 
    2197           0 :                 return true;
    2198             :         }       
    2199             :         
    2200             : /*
    2201             :          map<string, EphemerisAttributeFromBin> EphemerisRow::initFromBinMethods() {
    2202             :                 map<string, EphemerisAttributeFromBin> result;
    2203             :                 
    2204             :                 result["timeInterval"] = &EphemerisRow::timeIntervalFromBin;
    2205             :                 result["ephemerisId"] = &EphemerisRow::ephemerisIdFromBin;
    2206             :                 result["observerLocation"] = &EphemerisRow::observerLocationFromBin;
    2207             :                 result["equinoxEquator"] = &EphemerisRow::equinoxEquatorFromBin;
    2208             :                 result["numPolyDir"] = &EphemerisRow::numPolyDirFromBin;
    2209             :                 result["dir"] = &EphemerisRow::dirFromBin;
    2210             :                 result["numPolyDist"] = &EphemerisRow::numPolyDistFromBin;
    2211             :                 result["distance"] = &EphemerisRow::distanceFromBin;
    2212             :                 result["timeOrigin"] = &EphemerisRow::timeOriginFromBin;
    2213             :                 result["origin"] = &EphemerisRow::originFromBin;
    2214             :                 
    2215             :                 
    2216             :                 result["numPolyRadVel"] = &EphemerisRow::numPolyRadVelFromBin;
    2217             :                 result["radVel"] = &EphemerisRow::radVelFromBin;
    2218             :                         
    2219             :                 
    2220             :                 return result;  
    2221             :         }
    2222             : */      
    2223             : } // End namespace asdm
    2224             :  

Generated by: LCOV version 1.16