LCOV - code coverage report
Current view: top level - alma/ASDM - PointingModelRow.cc (source / functions) Hit Total Coverage
Test: casa_coverage.info Lines: 115 317 36.3 %
Date: 2023-10-25 08:47:59 Functions: 23 59 39.0 %

          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 PointingModelRow.cpp
      32             :  */
      33             :  
      34             : #include <vector>
      35             : #include <set>
      36             : 
      37             : #include <alma/ASDM/ASDM.h>
      38             : #include <alma/ASDM/PointingModelRow.h>
      39             : #include <alma/ASDM/PointingModelTable.h>
      40             : 
      41             : #include <alma/ASDM/PointingModelTable.h>
      42             : #include <alma/ASDM/PointingModelRow.h>
      43             : 
      44             : #include <alma/ASDM/AntennaTable.h>
      45             : #include <alma/ASDM/AntennaRow.h>
      46             :         
      47             : 
      48             : using asdm::ASDM;
      49             : using asdm::PointingModelRow;
      50             : using asdm::PointingModelTable;
      51             : 
      52             : using asdm::PointingModelTable;
      53             : using asdm::PointingModelRow;
      54             : 
      55             : using asdm::AntennaTable;
      56             : using asdm::AntennaRow;
      57             : 
      58             : 
      59             : #include <alma/ASDM/Parser.h>
      60             : 
      61             : #include <alma/ASDM/EnumerationParser.h>
      62             : #include <alma/ASDM/ASDMValuesParser.h>
      63             :  
      64             : #include <alma/ASDM/InvalidArgumentException.h>
      65             : 
      66             : using namespace std;
      67             : 
      68             : namespace asdm {
      69        1004 :         PointingModelRow::~PointingModelRow() {
      70        1004 :         }
      71             : 
      72             :         /**
      73             :          * Return the table to which this row belongs.
      74             :          */
      75           0 :         PointingModelTable &PointingModelRow::getTable() const {
      76           0 :                 return table;
      77             :         }
      78             : 
      79           0 :         bool PointingModelRow::isAdded() const {
      80           0 :                 return hasBeenAdded;
      81             :         }       
      82             : 
      83         502 :         void PointingModelRow::isAdded(bool added) {
      84         502 :                 hasBeenAdded = added;
      85         502 :         }
      86             :         
      87             : #ifndef WITHOUT_ACS
      88             :         using asdmIDL::PointingModelRowIDL;
      89             : #endif
      90             :         
      91             : #ifndef WITHOUT_ACS
      92             :         /**
      93             :          * Return this row in the form of an IDL struct.
      94             :          * @return The values of this row as a PointingModelRowIDL struct.
      95             :          */
      96             :         PointingModelRowIDL *PointingModelRow::toIDL() const {
      97             :                 PointingModelRowIDL *x = new PointingModelRowIDL ();
      98             :                 
      99             :                 // Fill the IDL structure.
     100             :         
     101             :                 
     102             :         
     103             :                 
     104             :                 
     105             :                 
     106             :                         
     107             :                                 
     108             :                 x->pointingModelId = pointingModelId;
     109             :                                 
     110             :                         
     111             :                 
     112             :         
     113             : 
     114             :         
     115             :                 
     116             :                 
     117             :                 
     118             :                         
     119             :                                 
     120             :                 x->numCoeff = numCoeff;
     121             :                                 
     122             :                         
     123             :                 
     124             :         
     125             : 
     126             :         
     127             :                 
     128             :                 
     129             :                 
     130             :                         
     131             :                 x->coeffName.length(coeffName.size());
     132             :                 for (unsigned int i = 0; i < coeffName.size(); ++i) {
     133             :                         
     134             :                                 
     135             :                         x->coeffName[i] = CORBA::string_dup(coeffName.at(i).c_str());
     136             :                                 
     137             :                         
     138             :                 }
     139             :                         
     140             :                 
     141             :         
     142             : 
     143             :         
     144             :                 
     145             :                 
     146             :                 
     147             :                         
     148             :                 x->coeffVal.length(coeffVal.size());
     149             :                 for (unsigned int i = 0; i < coeffVal.size(); ++i) {
     150             :                         
     151             :                                 
     152             :                         x->coeffVal[i] = coeffVal.at(i);
     153             :                                 
     154             :                         
     155             :                 }
     156             :                         
     157             :                 
     158             :         
     159             : 
     160             :         
     161             :                 
     162             :                 
     163             :                 
     164             :                         
     165             :                                 
     166             :                 x->polarizationType = polarizationType;
     167             :                                 
     168             :                         
     169             :                 
     170             :         
     171             : 
     172             :         
     173             :                 
     174             :                 
     175             :                 
     176             :                         
     177             :                                 
     178             :                 x->receiverBand = receiverBand;
     179             :                                 
     180             :                         
     181             :                 
     182             :         
     183             : 
     184             :         
     185             :                 
     186             :                 
     187             :                 
     188             :                         
     189             :                                 
     190             :                 x->assocNature = CORBA::string_dup(assocNature.c_str());
     191             :                                 
     192             :                         
     193             :                 
     194             :         
     195             : 
     196             :         
     197             :                 
     198             :                 
     199             :                 x->coeffFormulaExists = coeffFormulaExists;
     200             :                 
     201             :                 
     202             :                         
     203             :                 x->coeffFormula.length(coeffFormula.size());
     204             :                 for (unsigned int i = 0; i < coeffFormula.size(); ++i) {
     205             :                         
     206             :                                 
     207             :                         x->coeffFormula[i] = CORBA::string_dup(coeffFormula.at(i).c_str());
     208             :                                 
     209             :                         
     210             :                 }
     211             :                         
     212             :                 
     213             :         
     214             : 
     215             :         
     216             :         
     217             :                 
     218             :         
     219             :         
     220             :                 
     221             :                 
     222             :                 
     223             :                         
     224             :                 x->antennaId = antennaId.toIDLTag();
     225             :                         
     226             :                                 
     227             :         
     228             : 
     229             :         
     230             :         
     231             :                 
     232             :                 
     233             :                 
     234             :                         
     235             :                                 
     236             :                 x->assocPointingModelId = assocPointingModelId;
     237             :                                 
     238             :                         
     239             :                                 
     240             :         
     241             : 
     242             :         
     243             :                 
     244             :         
     245             : 
     246             :         
     247             : 
     248             :                 
     249             :                 return x;
     250             :         
     251             :         }
     252             :         
     253             :         void PointingModelRow::toIDL(asdmIDL::PointingModelRowIDL& x) const {
     254             :                 // Set the x's fields.
     255             :         
     256             :                 
     257             :         
     258             :                 
     259             :                 
     260             :                 
     261             :                         
     262             :                                 
     263             :                 x.pointingModelId = pointingModelId;
     264             :                                 
     265             :                         
     266             :                 
     267             :         
     268             : 
     269             :         
     270             :                 
     271             :                 
     272             :                 
     273             :                         
     274             :                                 
     275             :                 x.numCoeff = numCoeff;
     276             :                                 
     277             :                         
     278             :                 
     279             :         
     280             : 
     281             :         
     282             :                 
     283             :                 
     284             :                 
     285             :                         
     286             :                 x.coeffName.length(coeffName.size());
     287             :                 for (unsigned int i = 0; i < coeffName.size(); ++i) {
     288             :                         
     289             :                                 
     290             :                         x.coeffName[i] = CORBA::string_dup(coeffName.at(i).c_str());
     291             :                                 
     292             :                         
     293             :                 }
     294             :                         
     295             :                 
     296             :         
     297             : 
     298             :         
     299             :                 
     300             :                 
     301             :                 
     302             :                         
     303             :                 x.coeffVal.length(coeffVal.size());
     304             :                 for (unsigned int i = 0; i < coeffVal.size(); ++i) {
     305             :                         
     306             :                                 
     307             :                         x.coeffVal[i] = coeffVal.at(i);
     308             :                                 
     309             :                         
     310             :                 }
     311             :                         
     312             :                 
     313             :         
     314             : 
     315             :         
     316             :                 
     317             :                 
     318             :                 
     319             :                         
     320             :                                 
     321             :                 x.polarizationType = polarizationType;
     322             :                                 
     323             :                         
     324             :                 
     325             :         
     326             : 
     327             :         
     328             :                 
     329             :                 
     330             :                 
     331             :                         
     332             :                                 
     333             :                 x.receiverBand = receiverBand;
     334             :                                 
     335             :                         
     336             :                 
     337             :         
     338             : 
     339             :         
     340             :                 
     341             :                 
     342             :                 
     343             :                         
     344             :                                 
     345             :                 x.assocNature = CORBA::string_dup(assocNature.c_str());
     346             :                                 
     347             :                         
     348             :                 
     349             :         
     350             : 
     351             :         
     352             :                 
     353             :                 
     354             :                 x.coeffFormulaExists = coeffFormulaExists;
     355             :                 
     356             :                 
     357             :                         
     358             :                 x.coeffFormula.length(coeffFormula.size());
     359             :                 for (unsigned int i = 0; i < coeffFormula.size(); ++i) {
     360             :                         
     361             :                                 
     362             :                         x.coeffFormula[i] = CORBA::string_dup(coeffFormula.at(i).c_str());
     363             :                                 
     364             :                         
     365             :                 }
     366             :                         
     367             :                 
     368             :         
     369             : 
     370             :         
     371             :         
     372             :                 
     373             :         
     374             :         
     375             :                 
     376             :                 
     377             :                 
     378             :                         
     379             :                 x.antennaId = antennaId.toIDLTag();
     380             :                         
     381             :                                 
     382             :         
     383             : 
     384             :         
     385             :         
     386             :                 
     387             :                 
     388             :                 
     389             :                         
     390             :                                 
     391             :                 x.assocPointingModelId = assocPointingModelId;
     392             :                                 
     393             :                         
     394             :                                 
     395             :         
     396             : 
     397             :         
     398             :                 
     399             :         
     400             : 
     401             :         
     402             : 
     403             :         
     404             :         }
     405             : #endif
     406             :         
     407             : 
     408             : #ifndef WITHOUT_ACS
     409             :         /**
     410             :          * Fill the values of this row from the IDL struct PointingModelRowIDL.
     411             :          * @param x The IDL struct containing the values used to fill this row.
     412             :          */
     413             :         void PointingModelRow::setFromIDL (PointingModelRowIDL x){
     414             :                 try {
     415             :                 // Fill the values from x.
     416             :         
     417             :                 
     418             :         
     419             :                 
     420             :                 
     421             :                         
     422             :                 setPointingModelId(x.pointingModelId);
     423             :                         
     424             :                 
     425             :                 
     426             :         
     427             : 
     428             :         
     429             :                 
     430             :                 
     431             :                         
     432             :                 setNumCoeff(x.numCoeff);
     433             :                         
     434             :                 
     435             :                 
     436             :         
     437             : 
     438             :         
     439             :                 
     440             :                 
     441             :                         
     442             :                 coeffName .clear();
     443             :                 for (unsigned int i = 0; i <x.coeffName.length(); ++i) {
     444             :                         
     445             :                         coeffName.push_back(string (x.coeffName[i]));
     446             :                         
     447             :                 }
     448             :                         
     449             :                 
     450             :                 
     451             :         
     452             : 
     453             :         
     454             :                 
     455             :                 
     456             :                         
     457             :                 coeffVal .clear();
     458             :                 for (unsigned int i = 0; i <x.coeffVal.length(); ++i) {
     459             :                         
     460             :                         coeffVal.push_back(x.coeffVal[i]);
     461             :                         
     462             :                 }
     463             :                         
     464             :                 
     465             :                 
     466             :         
     467             : 
     468             :         
     469             :                 
     470             :                 
     471             :                         
     472             :                 setPolarizationType(x.polarizationType);
     473             :                         
     474             :                 
     475             :                 
     476             :         
     477             : 
     478             :         
     479             :                 
     480             :                 
     481             :                         
     482             :                 setReceiverBand(x.receiverBand);
     483             :                         
     484             :                 
     485             :                 
     486             :         
     487             : 
     488             :         
     489             :                 
     490             :                 
     491             :                         
     492             :                 setAssocNature(string (x.assocNature));
     493             :                         
     494             :                 
     495             :                 
     496             :         
     497             : 
     498             :         
     499             :                 
     500             :                 coeffFormulaExists = x.coeffFormulaExists;
     501             :                 if (x.coeffFormulaExists) {
     502             :                 
     503             :                 
     504             :                         
     505             :                 coeffFormula .clear();
     506             :                 for (unsigned int i = 0; i <x.coeffFormula.length(); ++i) {
     507             :                         
     508             :                         coeffFormula.push_back(string (x.coeffFormula[i]));
     509             :                         
     510             :                 }
     511             :                         
     512             :                 
     513             :                 
     514             :                 }
     515             :                 
     516             :         
     517             : 
     518             :         
     519             :         
     520             :                 
     521             :         
     522             :                 
     523             :                 
     524             :                         
     525             :                 setAntennaId(Tag (x.antennaId));
     526             :                         
     527             :                 
     528             :                 
     529             :         
     530             : 
     531             :         
     532             :                 
     533             :                 
     534             :                         
     535             :                 setAssocPointingModelId(x.assocPointingModelId);
     536             :                         
     537             :                 
     538             :                 
     539             :         
     540             : 
     541             :         
     542             :                 
     543             :         
     544             : 
     545             :         
     546             : 
     547             :                 } catch (const IllegalAccessException &err) {
     548             :                         throw ConversionException (err.getMessage(),"PointingModel");
     549             :                 }
     550             :         }
     551             : #endif
     552             :         
     553             :         /**
     554             :          * Return this row in the form of an XML string.
     555             :          * @return The values of this row as an XML string.
     556             :          */
     557         502 :         string PointingModelRow::toXML() const {
     558         502 :                 string buf;
     559         502 :                 buf.append("<row> \n");
     560             :                 
     561             :         
     562             :                 
     563             :         
     564             :                 
     565             :                 
     566         502 :                 Parser::toXML(pointingModelId, "pointingModelId", buf);
     567             :                 
     568             :                 
     569             :         
     570             : 
     571             :         
     572             :                 
     573             :                 
     574         502 :                 Parser::toXML(numCoeff, "numCoeff", buf);
     575             :                 
     576             :                 
     577             :         
     578             : 
     579             :         
     580             :                 
     581             :                 
     582         502 :                 Parser::toXML(coeffName, "coeffName", buf);
     583             :                 
     584             :                 
     585             :         
     586             : 
     587             :         
     588             :                 
     589             :                 
     590         502 :                 Parser::toXML(coeffVal, "coeffVal", buf);
     591             :                 
     592             :                 
     593             :         
     594             : 
     595             :         
     596             :                 
     597             :                 
     598         502 :                         buf.append(EnumerationParser::toXML("polarizationType", polarizationType));
     599             :                 
     600             :                 
     601             :         
     602             : 
     603             :         
     604             :                 
     605             :                 
     606         502 :                         buf.append(EnumerationParser::toXML("receiverBand", receiverBand));
     607             :                 
     608             :                 
     609             :         
     610             : 
     611             :         
     612             :                 
     613             :                 
     614         502 :                 Parser::toXML(assocNature, "assocNature", buf);
     615             :                 
     616             :                 
     617             :         
     618             : 
     619             :         
     620             :                 
     621         502 :                 if (coeffFormulaExists) {
     622             :                 
     623             :                 
     624           0 :                 Parser::toXML(coeffFormula, "coeffFormula", buf);
     625             :                 
     626             :                 
     627             :                 }
     628             :                 
     629             :         
     630             : 
     631             :         
     632             :         
     633             :                 
     634             :         
     635             :                 
     636             :                 
     637         502 :                 Parser::toXML(antennaId, "antennaId", buf);
     638             :                 
     639             :                 
     640             :         
     641             : 
     642             :         
     643             :                 
     644             :                 
     645         502 :                 Parser::toXML(assocPointingModelId, "assocPointingModelId", buf);
     646             :                 
     647             :                 
     648             :         
     649             : 
     650             :         
     651             :                 
     652             :         
     653             : 
     654             :         
     655             : 
     656             :                 
     657         502 :                 buf.append("</row>\n");
     658         502 :                 return buf;
     659             :         }
     660             : 
     661             :         /**
     662             :          * Fill the values of this row from an XML string 
     663             :          * that was produced by the toXML() method.
     664             :          * @param x The XML string being used to set the values of this row.
     665             :          */
     666           0 :         void PointingModelRow::setFromXML (string rowDoc) {
     667           0 :                 Parser row(rowDoc);
     668           0 :                 string s = "";
     669             :                 try {
     670             :         
     671             :                 
     672             :         
     673             :                 
     674             :                         
     675           0 :                 setPointingModelId(Parser::getInteger("pointingModelId","PointingModel",rowDoc));
     676             :                         
     677             :                 
     678             :         
     679             : 
     680             :         
     681             :                 
     682             :                         
     683           0 :                 setNumCoeff(Parser::getInteger("numCoeff","PointingModel",rowDoc));
     684             :                         
     685             :                 
     686             :         
     687             : 
     688             :         
     689             :                 
     690             :                         
     691             :                                         
     692           0 :                 setCoeffName(Parser::get1DString("coeffName","PointingModel",rowDoc));
     693             :                                 
     694             :                         
     695             :                 
     696             :         
     697             : 
     698             :         
     699             :                 
     700             :                         
     701             :                                         
     702           0 :                 setCoeffVal(Parser::get1DFloat("coeffVal","PointingModel",rowDoc));
     703             :                                 
     704             :                         
     705             :                 
     706             :         
     707             : 
     708             :         
     709             :                 
     710             :                 
     711             :                 
     712           0 :                 polarizationType = EnumerationParser::getPolarizationType("polarizationType","PointingModel",rowDoc);
     713             :                 
     714             :                 
     715             :                 
     716             :         
     717             : 
     718             :         
     719             :                 
     720             :                 
     721             :                 
     722           0 :                 receiverBand = EnumerationParser::getReceiverBand("receiverBand","PointingModel",rowDoc);
     723             :                 
     724             :                 
     725             :                 
     726             :         
     727             : 
     728             :         
     729             :                 
     730             :                         
     731           0 :                 setAssocNature(Parser::getString("assocNature","PointingModel",rowDoc));
     732             :                         
     733             :                 
     734             :         
     735             : 
     736             :         
     737             :                 
     738           0 :         if (row.isStr("<coeffFormula>")) {
     739             :                         
     740             :                                                                 
     741           0 :                         setCoeffFormula(Parser::get1DString("coeffFormula","PointingModel",rowDoc));
     742             :                                 
     743             :                         
     744             :                 }
     745             :                 
     746             :         
     747             : 
     748             :         
     749             :         
     750             :                 
     751             :         
     752             :                 
     753             :                         
     754           0 :                 setAntennaId(Parser::getTag("antennaId","Antenna",rowDoc));
     755             :                         
     756             :                 
     757             :         
     758             : 
     759             :         
     760             :                 
     761             :                         
     762           0 :                 setAssocPointingModelId(Parser::getInteger("assocPointingModelId","PointingModel",rowDoc));
     763             :                         
     764             :                 
     765             :         
     766             : 
     767             :         
     768             :                 
     769             :         
     770             : 
     771             :         
     772             : 
     773           0 :                 } catch (const IllegalAccessException &err) {
     774           0 :                         throw ConversionException (err.getMessage(),"PointingModel");
     775             :                 }
     776           0 :         }
     777             :         
     778           0 :         void PointingModelRow::toBin(EndianOSStream& eoss) {
     779             :         
     780             :         
     781             :         
     782             :         
     783             :                 
     784           0 :         antennaId.toBin(eoss);
     785             :                 
     786             :         
     787             : 
     788             :         
     789             :         
     790             :                 
     791             :                                                 
     792           0 :                         eoss.writeInt(pointingModelId);
     793             :                                 
     794             :                 
     795             :         
     796             : 
     797             :         
     798             :         
     799             :                 
     800             :                                                 
     801           0 :                         eoss.writeInt(numCoeff);
     802             :                                 
     803             :                 
     804             :         
     805             : 
     806             :         
     807             :         
     808             :                 
     809             :                 
     810             :                         
     811           0 :                 eoss.writeInt((int) coeffName.size());
     812           0 :                 for (unsigned int i = 0; i < coeffName.size(); i++)
     813             :                                 
     814           0 :                         eoss.writeString(coeffName.at(i));
     815             :                                 
     816             :                                 
     817             :                                                 
     818             :                 
     819             :         
     820             : 
     821             :         
     822             :         
     823             :                 
     824             :                 
     825             :                         
     826           0 :                 eoss.writeInt((int) coeffVal.size());
     827           0 :                 for (unsigned int i = 0; i < coeffVal.size(); i++)
     828             :                                 
     829           0 :                         eoss.writeFloat(coeffVal.at(i));
     830             :                                 
     831             :                                 
     832             :                                                 
     833             :                 
     834             :         
     835             : 
     836             :         
     837             :         
     838             :                 
     839             :                                         
     840           0 :                 eoss.writeString(CPolarizationType::name(polarizationType));
     841             :                         /* eoss.writeInt(polarizationType); */
     842             :                                 
     843             :                 
     844             :         
     845             : 
     846             :         
     847             :         
     848             :                 
     849             :                                         
     850           0 :                 eoss.writeString(CReceiverBand::name(receiverBand));
     851             :                         /* eoss.writeInt(receiverBand); */
     852             :                                 
     853             :                 
     854             :         
     855             : 
     856             :         
     857             :         
     858             :                 
     859             :                                                 
     860           0 :                         eoss.writeString(assocNature);
     861             :                                 
     862             :                 
     863             :         
     864             : 
     865             :         
     866             :         
     867             :                 
     868             :                                                 
     869           0 :                         eoss.writeInt(assocPointingModelId);
     870             :                                 
     871             :                 
     872             :         
     873             : 
     874             : 
     875             :         
     876             :         
     877           0 :         eoss.writeBoolean(coeffFormulaExists);
     878           0 :         if (coeffFormulaExists) {
     879             :         
     880             :         
     881             :         
     882             :                 
     883             :                 
     884             :                         
     885           0 :                 eoss.writeInt((int) coeffFormula.size());
     886           0 :                 for (unsigned int i = 0; i < coeffFormula.size(); i++)
     887             :                                 
     888           0 :                         eoss.writeString(coeffFormula.at(i));
     889             :                                 
     890             :                                 
     891             :                                                 
     892             :                 
     893             :         
     894             : 
     895             :         }
     896             : 
     897           0 :         }
     898             :         
     899           0 : void PointingModelRow::antennaIdFromBin(EndianIStream& eis) {
     900             :                 
     901             :         
     902             :                 
     903             :                 
     904           0 :                 antennaId =  Tag::fromBin(eis);
     905             :                 
     906             :         
     907             :         
     908           0 : }
     909           0 : void PointingModelRow::pointingModelIdFromBin(EndianIStream& eis) {
     910             :                 
     911             :         
     912             :         
     913             :                 
     914             :                         
     915           0 :                 pointingModelId =  eis.readInt();
     916             :                         
     917             :                 
     918             :         
     919             :         
     920           0 : }
     921           0 : void PointingModelRow::numCoeffFromBin(EndianIStream& eis) {
     922             :                 
     923             :         
     924             :         
     925             :                 
     926             :                         
     927           0 :                 numCoeff =  eis.readInt();
     928             :                         
     929             :                 
     930             :         
     931             :         
     932           0 : }
     933           0 : void PointingModelRow::coeffNameFromBin(EndianIStream& eis) {
     934             :                 
     935             :         
     936             :         
     937             :                 
     938             :                         
     939             :         
     940           0 :                 coeffName.clear();
     941             :                 
     942           0 :                 unsigned int coeffNameDim1 = eis.readInt();
     943           0 :                 for (unsigned int  i = 0 ; i < coeffNameDim1; i++)
     944             :                         
     945           0 :                         coeffName.push_back(eis.readString());
     946             :                         
     947             :         
     948             : 
     949             :                 
     950             :         
     951             :         
     952           0 : }
     953           0 : void PointingModelRow::coeffValFromBin(EndianIStream& eis) {
     954             :                 
     955             :         
     956             :         
     957             :                 
     958             :                         
     959             :         
     960           0 :                 coeffVal.clear();
     961             :                 
     962           0 :                 unsigned int coeffValDim1 = eis.readInt();
     963           0 :                 for (unsigned int  i = 0 ; i < coeffValDim1; i++)
     964             :                         
     965           0 :                         coeffVal.push_back(eis.readFloat());
     966             :                         
     967             :         
     968             : 
     969             :                 
     970             :         
     971             :         
     972           0 : }
     973           0 : void PointingModelRow::polarizationTypeFromBin(EndianIStream& eis) {
     974             :                 
     975             :         
     976             :         
     977             :                 
     978             :                         
     979           0 :                 polarizationType = CPolarizationType::literal(eis.readString());
     980             :                         
     981             :                 
     982             :         
     983             :         
     984           0 : }
     985           0 : void PointingModelRow::receiverBandFromBin(EndianIStream& eis) {
     986             :                 
     987             :         
     988             :         
     989             :                 
     990             :                         
     991           0 :                 receiverBand = CReceiverBand::literal(eis.readString());
     992             :                         
     993             :                 
     994             :         
     995             :         
     996           0 : }
     997           0 : void PointingModelRow::assocNatureFromBin(EndianIStream& eis) {
     998             :                 
     999             :         
    1000             :         
    1001             :                 
    1002             :                         
    1003           0 :                 assocNature =  eis.readString();
    1004             :                         
    1005             :                 
    1006             :         
    1007             :         
    1008           0 : }
    1009           0 : void PointingModelRow::assocPointingModelIdFromBin(EndianIStream& eis) {
    1010             :                 
    1011             :         
    1012             :         
    1013             :                 
    1014             :                         
    1015           0 :                 assocPointingModelId =  eis.readInt();
    1016             :                         
    1017             :                 
    1018             :         
    1019             :         
    1020           0 : }
    1021             : 
    1022           0 : void PointingModelRow::coeffFormulaFromBin(EndianIStream& eis) {
    1023             :                 
    1024           0 :         coeffFormulaExists = eis.readBoolean();
    1025           0 :         if (coeffFormulaExists) {
    1026             :                 
    1027             :         
    1028             :         
    1029             :                 
    1030             :                         
    1031             :         
    1032           0 :                 coeffFormula.clear();
    1033             :                 
    1034           0 :                 unsigned int coeffFormulaDim1 = eis.readInt();
    1035           0 :                 for (unsigned int  i = 0 ; i < coeffFormulaDim1; i++)
    1036             :                         
    1037           0 :                         coeffFormula.push_back(eis.readString());
    1038             :                         
    1039             :         
    1040             : 
    1041             :                 
    1042             :         
    1043             : 
    1044             :         }
    1045             :         
    1046           0 : }
    1047             :         
    1048             :         
    1049           0 :         PointingModelRow* PointingModelRow::fromBin(EndianIStream& eis, PointingModelTable& table, const vector<string>& attributesSeq) {
    1050           0 :                 PointingModelRow* row = new  PointingModelRow(table);
    1051             :                 
    1052           0 :                 map<string, PointingModelAttributeFromBin>::iterator iter ;
    1053           0 :                 for (unsigned int i = 0; i < attributesSeq.size(); i++) {
    1054           0 :                         iter = row->fromBinMethods.find(attributesSeq.at(i));
    1055           0 :                         if (iter != row->fromBinMethods.end()) {
    1056           0 :                                 (row->*(row->fromBinMethods[ attributesSeq.at(i) ] ))(eis);                       
    1057             :                         }
    1058             :                         else {
    1059           0 :                                 BinaryAttributeReaderFunctor* functorP = table.getUnknownAttributeBinaryReader(attributesSeq.at(i));
    1060           0 :                                 if (functorP)
    1061           0 :                                         (*functorP)(eis);
    1062             :                                 else
    1063           0 :                                         throw ConversionException("There is not method to read an attribute '"+attributesSeq.at(i)+"'.", "PointingModelTable");
    1064             :                         }
    1065             :                                 
    1066             :                 }                               
    1067           0 :                 return row;
    1068             :         }
    1069             : 
    1070             :         //
    1071             :         // A collection of methods to set the value of the attributes from their textual value in the XML representation
    1072             :         // of one row.
    1073             :         //
    1074             :         
    1075             :         // Convert a string into an Tag 
    1076           0 :         void PointingModelRow::antennaIdFromText(const string & s) {
    1077             :                  
    1078             :           
    1079           0 :                 antennaId = ASDMValuesParser::parse<Tag>(s);
    1080             :           
    1081             :                 
    1082           0 :         }
    1083             :         
    1084             :         
    1085             :         // Convert a string into an int 
    1086           0 :         void PointingModelRow::pointingModelIdFromText(const string & s) {
    1087             :                  
    1088             :           
    1089           0 :                 pointingModelId = ASDMValuesParser::parse<int>(s);
    1090             :           
    1091             :                 
    1092           0 :         }
    1093             :         
    1094             :         
    1095             :         // Convert a string into an int 
    1096           0 :         void PointingModelRow::numCoeffFromText(const string & s) {
    1097             :                  
    1098             :           
    1099           0 :                 numCoeff = ASDMValuesParser::parse<int>(s);
    1100             :           
    1101             :                 
    1102           0 :         }
    1103             :         
    1104             :         
    1105             :         // Convert a string into an String 
    1106           0 :         void PointingModelRow::coeffNameFromText(const string & s) {
    1107             :                  
    1108             :           
    1109           0 :                 coeffName = ASDMValuesParser::parse1D<string>(s);
    1110             :           
    1111             :                 
    1112           0 :         }
    1113             :         
    1114             :         
    1115             :         // Convert a string into an float 
    1116           0 :         void PointingModelRow::coeffValFromText(const string & s) {
    1117             :                  
    1118             :           
    1119           0 :                 coeffVal = ASDMValuesParser::parse1D<float>(s);
    1120             :           
    1121             :                 
    1122           0 :         }
    1123             :         
    1124             :         
    1125             :         // Convert a string into an PolarizationType 
    1126           0 :         void PointingModelRow::polarizationTypeFromText(const string & s) {
    1127             :                  
    1128             :           
    1129           0 :                 polarizationType = ASDMValuesParser::parse<PolarizationTypeMod::PolarizationType>(s);
    1130             :           
    1131             :                 
    1132           0 :         }
    1133             :         
    1134             :         
    1135             :         // Convert a string into an ReceiverBand 
    1136           0 :         void PointingModelRow::receiverBandFromText(const string & s) {
    1137             :                  
    1138             :           
    1139           0 :                 receiverBand = ASDMValuesParser::parse<ReceiverBandMod::ReceiverBand>(s);
    1140             :           
    1141             :                 
    1142           0 :         }
    1143             :         
    1144             :         
    1145             :         // Convert a string into an String 
    1146           0 :         void PointingModelRow::assocNatureFromText(const string & s) {
    1147             :                  
    1148             :           
    1149           0 :                 assocNature = ASDMValuesParser::parse<string>(s);
    1150             :           
    1151             :                 
    1152           0 :         }
    1153             :         
    1154             :         
    1155             :         // Convert a string into an int 
    1156           0 :         void PointingModelRow::assocPointingModelIdFromText(const string & s) {
    1157             :                  
    1158             :           
    1159           0 :                 assocPointingModelId = ASDMValuesParser::parse<int>(s);
    1160             :           
    1161             :                 
    1162           0 :         }
    1163             :         
    1164             : 
    1165             :         
    1166             :         // Convert a string into an String 
    1167           0 :         void PointingModelRow::coeffFormulaFromText(const string & s) {
    1168           0 :                 coeffFormulaExists = true;
    1169             :                  
    1170             :           
    1171           0 :                 coeffFormula = ASDMValuesParser::parse1D<string>(s);
    1172             :           
    1173             :                 
    1174           0 :         }
    1175             :         
    1176             :         
    1177             :         
    1178           0 :         void PointingModelRow::fromText(const std::string& attributeName, const std::string&  t) {
    1179           0 :                 map<string, PointingModelAttributeFromText>::iterator iter;
    1180           0 :                 if ((iter = fromTextMethods.find(attributeName)) == fromTextMethods.end())
    1181           0 :                         throw ConversionException("I do not know what to do with '"+attributeName+"' and its content '"+t+"' (while parsing an XML document)", "PointingModelTable");
    1182           0 :                 (this->*(iter->second))(t);
    1183           0 :         }
    1184             :                         
    1185             :         ////////////////////////////////////////////////
    1186             :         // Intrinsic Table Attributes getters/setters //
    1187             :         ////////////////////////////////////////////////
    1188             :         
    1189             :         
    1190             : 
    1191             :         
    1192             :         /**
    1193             :          * Get pointingModelId.
    1194             :          * @return pointingModelId as int
    1195             :          */
    1196         251 :         int PointingModelRow::getPointingModelId() const {
    1197             :         
    1198         251 :                 return pointingModelId;
    1199             :         }
    1200             : 
    1201             :         /**
    1202             :          * Set pointingModelId with the specified int.
    1203             :          * @param pointingModelId The int value to which pointingModelId is to be set.
    1204             :          
    1205             :         
    1206             :                 
    1207             :          * @throw IllegalAccessException If an attempt is made to change this field after is has been added to the table.
    1208             :                 
    1209             :          */
    1210           0 :         void PointingModelRow::setPointingModelId (int pointingModelId)  {
    1211             :         
    1212             :         
    1213           0 :                 if (hasBeenAdded) {
    1214             :                 
    1215           0 :                         throw IllegalAccessException("pointingModelId", "PointingModel");
    1216             :                 
    1217             :                 }
    1218             :         
    1219           0 :                 this->pointingModelId = pointingModelId;
    1220             :         
    1221           0 :         }
    1222             :         
    1223             :         
    1224             : 
    1225             :         
    1226             : 
    1227             :         
    1228             :         /**
    1229             :          * Get numCoeff.
    1230             :          * @return numCoeff as int
    1231             :          */
    1232        1792 :         int PointingModelRow::getNumCoeff() const {
    1233             :         
    1234        1792 :                 return numCoeff;
    1235             :         }
    1236             : 
    1237             :         /**
    1238             :          * Set numCoeff with the specified int.
    1239             :          * @param numCoeff The int value to which numCoeff is to be set.
    1240             :          
    1241             :         
    1242             :                 
    1243             :          */
    1244        1792 :         void PointingModelRow::setNumCoeff (int numCoeff)  {
    1245             :         
    1246             :         
    1247        1792 :                 if (hasBeenAdded) {
    1248             :                 
    1249             :                 }
    1250             :         
    1251        1792 :                 this->numCoeff = numCoeff;
    1252             :         
    1253        1792 :         }
    1254             :         
    1255             :         
    1256             : 
    1257             :         
    1258             : 
    1259             :         
    1260             :         /**
    1261             :          * Get coeffName.
    1262             :          * @return coeffName as std::vector<std::string >
    1263             :          */
    1264        1792 :         std::vector<std::string > PointingModelRow::getCoeffName() const {
    1265             :         
    1266        1792 :                 return coeffName;
    1267             :         }
    1268             : 
    1269             :         /**
    1270             :          * Set coeffName with the specified std::vector<std::string >.
    1271             :          * @param coeffName The std::vector<std::string > value to which coeffName is to be set.
    1272             :          
    1273             :         
    1274             :                 
    1275             :          */
    1276        1792 :         void PointingModelRow::setCoeffName (std::vector<std::string > coeffName)  {
    1277             :         
    1278             :         
    1279        1792 :                 if (hasBeenAdded) {
    1280             :                 
    1281             :                 }
    1282             :         
    1283        1792 :                 this->coeffName = coeffName;
    1284             :         
    1285        1792 :         }
    1286             :         
    1287             :         
    1288             : 
    1289             :         
    1290             : 
    1291             :         
    1292             :         /**
    1293             :          * Get coeffVal.
    1294             :          * @return coeffVal as std::vector<float >
    1295             :          */
    1296        1792 :         std::vector<float > PointingModelRow::getCoeffVal() const {
    1297             :         
    1298        1792 :                 return coeffVal;
    1299             :         }
    1300             : 
    1301             :         /**
    1302             :          * Set coeffVal with the specified std::vector<float >.
    1303             :          * @param coeffVal The std::vector<float > value to which coeffVal is to be set.
    1304             :          
    1305             :         
    1306             :                 
    1307             :          */
    1308        1792 :         void PointingModelRow::setCoeffVal (std::vector<float > coeffVal)  {
    1309             :         
    1310             :         
    1311        1792 :                 if (hasBeenAdded) {
    1312             :                 
    1313             :                 }
    1314             :         
    1315        1792 :                 this->coeffVal = coeffVal;
    1316             :         
    1317        1792 :         }
    1318             :         
    1319             :         
    1320             : 
    1321             :         
    1322             : 
    1323             :         
    1324             :         /**
    1325             :          * Get polarizationType.
    1326             :          * @return polarizationType as PolarizationTypeMod::PolarizationType
    1327             :          */
    1328        1792 :         PolarizationTypeMod::PolarizationType PointingModelRow::getPolarizationType() const {
    1329             :         
    1330        1792 :                 return polarizationType;
    1331             :         }
    1332             : 
    1333             :         /**
    1334             :          * Set polarizationType with the specified PolarizationTypeMod::PolarizationType.
    1335             :          * @param polarizationType The PolarizationTypeMod::PolarizationType value to which polarizationType is to be set.
    1336             :          
    1337             :         
    1338             :                 
    1339             :          */
    1340        1792 :         void PointingModelRow::setPolarizationType (PolarizationTypeMod::PolarizationType polarizationType)  {
    1341             :         
    1342             :         
    1343        1792 :                 if (hasBeenAdded) {
    1344             :                 
    1345             :                 }
    1346             :         
    1347        1792 :                 this->polarizationType = polarizationType;
    1348             :         
    1349        1792 :         }
    1350             :         
    1351             :         
    1352             : 
    1353             :         
    1354             : 
    1355             :         
    1356             :         /**
    1357             :          * Get receiverBand.
    1358             :          * @return receiverBand as ReceiverBandMod::ReceiverBand
    1359             :          */
    1360        1792 :         ReceiverBandMod::ReceiverBand PointingModelRow::getReceiverBand() const {
    1361             :         
    1362        1792 :                 return receiverBand;
    1363             :         }
    1364             : 
    1365             :         /**
    1366             :          * Set receiverBand with the specified ReceiverBandMod::ReceiverBand.
    1367             :          * @param receiverBand The ReceiverBandMod::ReceiverBand value to which receiverBand is to be set.
    1368             :          
    1369             :         
    1370             :                 
    1371             :          */
    1372        1792 :         void PointingModelRow::setReceiverBand (ReceiverBandMod::ReceiverBand receiverBand)  {
    1373             :         
    1374             :         
    1375        1792 :                 if (hasBeenAdded) {
    1376             :                 
    1377             :                 }
    1378             :         
    1379        1792 :                 this->receiverBand = receiverBand;
    1380             :         
    1381        1792 :         }
    1382             :         
    1383             :         
    1384             : 
    1385             :         
    1386             : 
    1387             :         
    1388             :         /**
    1389             :          * Get assocNature.
    1390             :          * @return assocNature as std::string
    1391             :          */
    1392        1792 :         std::string PointingModelRow::getAssocNature() const {
    1393             :         
    1394        1792 :                 return assocNature;
    1395             :         }
    1396             : 
    1397             :         /**
    1398             :          * Set assocNature with the specified std::string.
    1399             :          * @param assocNature The std::string value to which assocNature is to be set.
    1400             :          
    1401             :         
    1402             :                 
    1403             :          */
    1404        1792 :         void PointingModelRow::setAssocNature (std::string assocNature)  {
    1405             :         
    1406             :         
    1407        1792 :                 if (hasBeenAdded) {
    1408             :                 
    1409             :                 }
    1410             :         
    1411        1792 :                 this->assocNature = assocNature;
    1412             :         
    1413        1792 :         }
    1414             :         
    1415             :         
    1416             : 
    1417             :         
    1418             :         /**
    1419             :          * The attribute coeffFormula is optional. Return true if this attribute exists.
    1420             :          * @return true if and only if the coeffFormula attribute exists. 
    1421             :          */
    1422           0 :         bool PointingModelRow::isCoeffFormulaExists() const {
    1423           0 :                 return coeffFormulaExists;
    1424             :         }
    1425             :         
    1426             : 
    1427             :         
    1428             :         /**
    1429             :          * Get coeffFormula, which is optional.
    1430             :          * @return coeffFormula as std::vector<std::string >
    1431             :          * @throw IllegalAccessException If coeffFormula does not exist.
    1432             :          */
    1433           0 :         std::vector<std::string > PointingModelRow::getCoeffFormula() const  {
    1434           0 :                 if (!coeffFormulaExists) {
    1435           0 :                         throw IllegalAccessException("coeffFormula", "PointingModel");
    1436             :                 }
    1437             :         
    1438           0 :                 return coeffFormula;
    1439             :         }
    1440             : 
    1441             :         /**
    1442             :          * Set coeffFormula with the specified std::vector<std::string >.
    1443             :          * @param coeffFormula The std::vector<std::string > value to which coeffFormula is to be set.
    1444             :          
    1445             :         
    1446             :          */
    1447           0 :         void PointingModelRow::setCoeffFormula (std::vector<std::string > coeffFormula) {
    1448             :         
    1449           0 :                 this->coeffFormula = coeffFormula;
    1450             :         
    1451           0 :                 coeffFormulaExists = true;
    1452             :         
    1453           0 :         }
    1454             :         
    1455             :         
    1456             :         /**
    1457             :          * Mark coeffFormula, which is an optional field, as non-existent.
    1458             :          */
    1459           0 :         void PointingModelRow::clearCoeffFormula () {
    1460           0 :                 coeffFormulaExists = false;
    1461           0 :         }
    1462             :         
    1463             : 
    1464             :         
    1465             :         ///////////////////////////////////////////////
    1466             :         // Extrinsic Table Attributes getters/setters//
    1467             :         ///////////////////////////////////////////////
    1468             :         
    1469             :         
    1470             : 
    1471             :         
    1472             :         /**
    1473             :          * Get antennaId.
    1474             :          * @return antennaId as Tag
    1475             :          */
    1476        1792 :         Tag PointingModelRow::getAntennaId() const {
    1477             :         
    1478        1792 :                 return antennaId;
    1479             :         }
    1480             : 
    1481             :         /**
    1482             :          * Set antennaId with the specified Tag.
    1483             :          * @param antennaId The Tag value to which antennaId is to be set.
    1484             :          
    1485             :         
    1486             :                 
    1487             :          * @throw IllegalAccessException If an attempt is made to change this field after is has been added to the table.
    1488             :                 
    1489             :          */
    1490        1792 :         void PointingModelRow::setAntennaId (Tag antennaId)  {
    1491             :         
    1492             :         
    1493        1792 :                 if (hasBeenAdded) {
    1494             :                 
    1495           0 :                         throw IllegalAccessException("antennaId", "PointingModel");
    1496             :                 
    1497             :                 }
    1498             :         
    1499        1792 :                 this->antennaId = antennaId;
    1500             :         
    1501        1792 :         }
    1502             :         
    1503             :         
    1504             : 
    1505             :         
    1506             : 
    1507             :         
    1508             :         /**
    1509             :          * Get assocPointingModelId.
    1510             :          * @return assocPointingModelId as int
    1511             :          */
    1512        1792 :         int PointingModelRow::getAssocPointingModelId() const {
    1513             :         
    1514        1792 :                 return assocPointingModelId;
    1515             :         }
    1516             : 
    1517             :         /**
    1518             :          * Set assocPointingModelId with the specified int.
    1519             :          * @param assocPointingModelId The int value to which assocPointingModelId is to be set.
    1520             :          
    1521             :         
    1522             :                 
    1523             :          */
    1524        1792 :         void PointingModelRow::setAssocPointingModelId (int assocPointingModelId)  {
    1525             :         
    1526             :         
    1527        1792 :                 if (hasBeenAdded) {
    1528             :                 
    1529             :                 }
    1530             :         
    1531        1792 :                 this->assocPointingModelId = assocPointingModelId;
    1532             :         
    1533        1792 :         }
    1534             :         
    1535             :         
    1536             : 
    1537             : 
    1538             :         //////////////////////////////////////
    1539             :         // Links Attributes getters/setters //
    1540             :         //////////////////////////////////////
    1541             :         
    1542             :         
    1543             :         
    1544             :         
    1545             :                 
    1546             : 
    1547             :         // ===> Slice link from a row of PointingModel table to a collection of row of PointingModel table.
    1548             :         
    1549             :         /**
    1550             :          * Get the collection of row in the PointingModel table having their attribut pointingModelId == this->pointingModelId
    1551             :          */
    1552           0 :         vector <PointingModelRow *> PointingModelRow::getPointingModels() {
    1553             :                 
    1554           0 :                         return table.getContainer().getPointingModel().getRowByPointingModelId(pointingModelId);
    1555             :                 
    1556             :         }
    1557             :         
    1558             : 
    1559             :         
    1560             : 
    1561             :         
    1562             :         
    1563             :         
    1564             :                 
    1565             : 
    1566             :         /**
    1567             :          * Returns the pointer to the row in the Antenna table having Antenna.antennaId == antennaId
    1568             :          * @return a AntennaRow*
    1569             :          * 
    1570             :          
    1571             :          */
    1572           0 :          AntennaRow* PointingModelRow::getAntennaUsingAntennaId() {
    1573             :          
    1574           0 :                 return table.getContainer().getAntenna().getRowByKey(antennaId);
    1575             :          }
    1576             :          
    1577             : 
    1578             :         
    1579             : 
    1580             :         
    1581             :         /**
    1582             :          * Create a PointingModelRow.
    1583             :          * <p>
    1584             :          * This constructor is private because only the
    1585             :          * table can create rows.  All rows know the table
    1586             :          * to which they belong.
    1587             :          * @param table The table to which this row belongs.
    1588             :          */ 
    1589        1792 :         PointingModelRow::PointingModelRow (PointingModelTable &t) : table(t) {
    1590        1792 :                 hasBeenAdded = false;
    1591             :                 
    1592             :         
    1593             :         
    1594             : 
    1595             :         
    1596             : 
    1597             :         
    1598             : 
    1599             :         
    1600             : 
    1601             :         
    1602             : 
    1603             :         
    1604             : 
    1605             :         
    1606             : 
    1607             :         
    1608        1792 :                 coeffFormulaExists = false;
    1609             :         
    1610             : 
    1611             :         
    1612             :         
    1613             : 
    1614             :         
    1615             : 
    1616             :         
    1617             :         
    1618             :         
    1619             :         
    1620             : 
    1621             :         
    1622             : 
    1623             :         
    1624             : 
    1625             :         
    1626             : 
    1627             :         
    1628             : // This attribute is scalar and has an enumeration type. Let's initialize it to some valid value (the 1st of the enumeration).          
    1629        1792 : polarizationType = CPolarizationType::from_int(0);
    1630             :         
    1631             : 
    1632             :         
    1633             : // This attribute is scalar and has an enumeration type. Let's initialize it to some valid value (the 1st of the enumeration).          
    1634        1792 : receiverBand = CReceiverBand::from_int(0);
    1635             :         
    1636             : 
    1637             :         
    1638             : 
    1639             :         
    1640             : 
    1641             :         
    1642             :         
    1643        1792 :          fromBinMethods["antennaId"] = &PointingModelRow::antennaIdFromBin; 
    1644        1792 :          fromBinMethods["pointingModelId"] = &PointingModelRow::pointingModelIdFromBin; 
    1645        1792 :          fromBinMethods["numCoeff"] = &PointingModelRow::numCoeffFromBin; 
    1646        1792 :          fromBinMethods["coeffName"] = &PointingModelRow::coeffNameFromBin; 
    1647        1792 :          fromBinMethods["coeffVal"] = &PointingModelRow::coeffValFromBin; 
    1648        1792 :          fromBinMethods["polarizationType"] = &PointingModelRow::polarizationTypeFromBin; 
    1649        1792 :          fromBinMethods["receiverBand"] = &PointingModelRow::receiverBandFromBin; 
    1650        1792 :          fromBinMethods["assocNature"] = &PointingModelRow::assocNatureFromBin; 
    1651        1792 :          fromBinMethods["assocPointingModelId"] = &PointingModelRow::assocPointingModelIdFromBin; 
    1652             :                 
    1653             :         
    1654        1792 :          fromBinMethods["coeffFormula"] = &PointingModelRow::coeffFormulaFromBin; 
    1655             :         
    1656             :         
    1657             :         
    1658             :         
    1659             :                                  
    1660        1792 :         fromTextMethods["antennaId"] = &PointingModelRow::antennaIdFromText;
    1661             :                  
    1662             :         
    1663             :                                  
    1664        1792 :         fromTextMethods["pointingModelId"] = &PointingModelRow::pointingModelIdFromText;
    1665             :                  
    1666             :         
    1667             :                                  
    1668        1792 :         fromTextMethods["numCoeff"] = &PointingModelRow::numCoeffFromText;
    1669             :                  
    1670             :         
    1671             :                                  
    1672        1792 :         fromTextMethods["coeffName"] = &PointingModelRow::coeffNameFromText;
    1673             :                  
    1674             :         
    1675             :                                  
    1676        1792 :         fromTextMethods["coeffVal"] = &PointingModelRow::coeffValFromText;
    1677             :                  
    1678             :         
    1679             :                                  
    1680        1792 :         fromTextMethods["polarizationType"] = &PointingModelRow::polarizationTypeFromText;
    1681             :                  
    1682             :         
    1683             :                                  
    1684        1792 :         fromTextMethods["receiverBand"] = &PointingModelRow::receiverBandFromText;
    1685             :                  
    1686             :         
    1687             :                                  
    1688        1792 :         fromTextMethods["assocNature"] = &PointingModelRow::assocNatureFromText;
    1689             :                  
    1690             :         
    1691             :                                  
    1692        1792 :         fromTextMethods["assocPointingModelId"] = &PointingModelRow::assocPointingModelIdFromText;
    1693             :                  
    1694             :         
    1695             : 
    1696             :          
    1697             :                                 
    1698        1792 :         fromTextMethods["coeffFormula"] = &PointingModelRow::coeffFormulaFromText;
    1699             :                         
    1700             :                 
    1701        1792 :         }
    1702             :         
    1703           0 :         PointingModelRow::PointingModelRow (PointingModelTable &t, PointingModelRow *row) : table(t) {
    1704           0 :                 hasBeenAdded = false;
    1705             :                 
    1706           0 :                 if (row == 0) {
    1707             :         
    1708             :         
    1709             :         
    1710             : 
    1711             :         
    1712             : 
    1713             :         
    1714             : 
    1715             :         
    1716             : 
    1717             :         
    1718             : 
    1719             :         
    1720             : 
    1721             :         
    1722             : 
    1723             :         
    1724           0 :                 coeffFormulaExists = false;
    1725             :         
    1726             : 
    1727             :         
    1728             :         
    1729             : 
    1730             :         
    1731             :                 
    1732             :                 }
    1733             :                 else {
    1734             :         
    1735             :                 
    1736           0 :                         antennaId = row->antennaId;
    1737             :                 
    1738           0 :                         pointingModelId = row->pointingModelId;
    1739             :                 
    1740             :                 
    1741             :                 
    1742             :                 
    1743           0 :                         numCoeff = row->numCoeff;
    1744             :                 
    1745           0 :                         coeffName = row->coeffName;
    1746             :                 
    1747           0 :                         coeffVal = row->coeffVal;
    1748             :                 
    1749           0 :                         polarizationType = row->polarizationType;
    1750             :                 
    1751           0 :                         receiverBand = row->receiverBand;
    1752             :                 
    1753           0 :                         assocNature = row->assocNature;
    1754             :                 
    1755           0 :                         assocPointingModelId = row->assocPointingModelId;
    1756             :                 
    1757             :                 
    1758             :                 
    1759             :                 
    1760           0 :                 if (row->coeffFormulaExists) {
    1761           0 :                         coeffFormula = row->coeffFormula;            
    1762           0 :                         coeffFormulaExists = true;
    1763             :                 }
    1764             :                 else
    1765           0 :                         coeffFormulaExists = false;
    1766             :                 
    1767             :                 }
    1768             :                 
    1769           0 :                  fromBinMethods["antennaId"] = &PointingModelRow::antennaIdFromBin; 
    1770           0 :                  fromBinMethods["pointingModelId"] = &PointingModelRow::pointingModelIdFromBin; 
    1771           0 :                  fromBinMethods["numCoeff"] = &PointingModelRow::numCoeffFromBin; 
    1772           0 :                  fromBinMethods["coeffName"] = &PointingModelRow::coeffNameFromBin; 
    1773           0 :                  fromBinMethods["coeffVal"] = &PointingModelRow::coeffValFromBin; 
    1774           0 :                  fromBinMethods["polarizationType"] = &PointingModelRow::polarizationTypeFromBin; 
    1775           0 :                  fromBinMethods["receiverBand"] = &PointingModelRow::receiverBandFromBin; 
    1776           0 :                  fromBinMethods["assocNature"] = &PointingModelRow::assocNatureFromBin; 
    1777           0 :                  fromBinMethods["assocPointingModelId"] = &PointingModelRow::assocPointingModelIdFromBin; 
    1778             :                         
    1779             :         
    1780           0 :                  fromBinMethods["coeffFormula"] = &PointingModelRow::coeffFormulaFromBin; 
    1781             :                         
    1782           0 :         }
    1783             : 
    1784             :         
    1785       27274 :         bool PointingModelRow::compareNoAutoInc(Tag antennaId, int numCoeff, std::vector<std::string > coeffName, std::vector<float > coeffVal, PolarizationTypeMod::PolarizationType polarizationType, ReceiverBandMod::ReceiverBand receiverBand, std::string assocNature, int assocPointingModelId) {
    1786             :                 bool result;
    1787       27274 :                 result = true;
    1788             :                 
    1789             :         
    1790             :                 
    1791       27274 :                 result = result && (this->antennaId == antennaId);
    1792             :                 
    1793       27274 :                 if (!result) return false;
    1794             :         
    1795             : 
    1796             :         
    1797             :                 
    1798        2186 :                 result = result && (this->numCoeff == numCoeff);
    1799             :                 
    1800        2186 :                 if (!result) return false;
    1801             :         
    1802             : 
    1803             :         
    1804             :                 
    1805        2186 :                 result = result && (this->coeffName == coeffName);
    1806             :                 
    1807        2186 :                 if (!result) return false;
    1808             :         
    1809             : 
    1810             :         
    1811             :                 
    1812        2186 :                 result = result && (this->coeffVal == coeffVal);
    1813             :                 
    1814        2186 :                 if (!result) return false;
    1815             :         
    1816             : 
    1817             :         
    1818             :                 
    1819        2186 :                 result = result && (this->polarizationType == polarizationType);
    1820             :                 
    1821        2186 :                 if (!result) return false;
    1822             :         
    1823             : 
    1824             :         
    1825             :                 
    1826        1290 :                 result = result && (this->receiverBand == receiverBand);
    1827             :                 
    1828        1290 :                 if (!result) return false;
    1829             :         
    1830             : 
    1831             :         
    1832             :                 
    1833        1290 :                 result = result && (this->assocNature == assocNature);
    1834             :                 
    1835        1290 :                 if (!result) return false;
    1836             :         
    1837             : 
    1838             :         
    1839             :                 
    1840        1290 :                 result = result && (this->assocPointingModelId == assocPointingModelId);
    1841             :                 
    1842        1290 :                 if (!result) return false;
    1843             :         
    1844             : 
    1845        1290 :                 return result;
    1846             :         }       
    1847             :         
    1848             :         
    1849             :         
    1850           0 :         bool PointingModelRow::compareRequiredValue(int numCoeff, std::vector<std::string > coeffName, std::vector<float > coeffVal, PolarizationTypeMod::PolarizationType polarizationType, ReceiverBandMod::ReceiverBand receiverBand, std::string assocNature, int assocPointingModelId) {
    1851             :                 bool result;
    1852           0 :                 result = true;
    1853             :                 
    1854             :         
    1855           0 :                 if (!(this->numCoeff == numCoeff)) return false;
    1856             :         
    1857             : 
    1858             :         
    1859           0 :                 if (!(this->coeffName == coeffName)) return false;
    1860             :         
    1861             : 
    1862             :         
    1863           0 :                 if (!(this->coeffVal == coeffVal)) return false;
    1864             :         
    1865             : 
    1866             :         
    1867           0 :                 if (!(this->polarizationType == polarizationType)) return false;
    1868             :         
    1869             : 
    1870             :         
    1871           0 :                 if (!(this->receiverBand == receiverBand)) return false;
    1872             :         
    1873             : 
    1874             :         
    1875           0 :                 if (!(this->assocNature == assocNature)) return false;
    1876             :         
    1877             : 
    1878             :         
    1879           0 :                 if (!(this->assocPointingModelId == assocPointingModelId)) return false;
    1880             :         
    1881             : 
    1882           0 :                 return result;
    1883             :         }
    1884             :         
    1885             :         
    1886             :         /**
    1887             :          * Return true if all required attributes of the value part are equal to their homologues
    1888             :          * in x and false otherwise.
    1889             :          *
    1890             : 
    1891             :          * @param x a pointer on the PointingModelRow whose required attributes of the value part 
    1892             : 
    1893             :          * will be compared with those of this.
    1894             :          * @return a boolean.
    1895             :          */
    1896           0 :         bool PointingModelRow::equalByRequiredValue(PointingModelRow*  x ) {
    1897             :                 
    1898             :                         
    1899           0 :                 if (this->numCoeff != x->numCoeff) return false;
    1900             :                         
    1901           0 :                 if (this->coeffName != x->coeffName) return false;
    1902             :                         
    1903           0 :                 if (this->coeffVal != x->coeffVal) return false;
    1904             :                         
    1905           0 :                 if (this->polarizationType != x->polarizationType) return false;
    1906             :                         
    1907           0 :                 if (this->receiverBand != x->receiverBand) return false;
    1908             :                         
    1909           0 :                 if (this->assocNature != x->assocNature) return false;
    1910             :                         
    1911           0 :                 if (this->assocPointingModelId != x->assocPointingModelId) return false;
    1912             :                         
    1913             :                 
    1914           0 :                 return true;
    1915             :         }       
    1916             :         
    1917             : /*
    1918             :          map<string, PointingModelAttributeFromBin> PointingModelRow::initFromBinMethods() {
    1919             :                 map<string, PointingModelAttributeFromBin> result;
    1920             :                 
    1921             :                 result["antennaId"] = &PointingModelRow::antennaIdFromBin;
    1922             :                 result["pointingModelId"] = &PointingModelRow::pointingModelIdFromBin;
    1923             :                 result["numCoeff"] = &PointingModelRow::numCoeffFromBin;
    1924             :                 result["coeffName"] = &PointingModelRow::coeffNameFromBin;
    1925             :                 result["coeffVal"] = &PointingModelRow::coeffValFromBin;
    1926             :                 result["polarizationType"] = &PointingModelRow::polarizationTypeFromBin;
    1927             :                 result["receiverBand"] = &PointingModelRow::receiverBandFromBin;
    1928             :                 result["assocNature"] = &PointingModelRow::assocNatureFromBin;
    1929             :                 result["assocPointingModelId"] = &PointingModelRow::assocPointingModelIdFromBin;
    1930             :                 
    1931             :                 
    1932             :                 result["coeffFormula"] = &PointingModelRow::coeffFormulaFromBin;
    1933             :                         
    1934             :                 
    1935             :                 return result;  
    1936             :         }
    1937             : */      
    1938             : } // End namespace asdm
    1939             :  

Generated by: LCOV version 1.16