Humidity.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027 #ifndef Humidity_CLASS
00028 #define Humidity_CLASS
00029 #include <vector>
00030 #include <iostream>
00031 #include <string>
00032 using namespace std;
00033 #ifndef WITHOUT_ACS
00034 #include <asdmIDLTypesC.h>
00035 using asdmIDLTypes::IDLHumidity;
00036 #endif
00037 #include <StringTokenizer.h>
00038 #include <NumberFormatException.h>
00039 using asdm::StringTokenizer;
00040 using asdm::NumberFormatException;
00041 #include "EndianStream.h"
00042 using asdm::EndianOSStream;
00043 using asdm::EndianIStream;
00044 namespace asdm {
00045 class Humidity;
00046 Humidity operator * ( double , const Humidity & );
00047 ostream & operator << ( ostream &, const Humidity & );
00048 istream & operator >> ( istream &, Humidity &);
00059 class Humidity {
00066 friend Humidity operator * ( double d, const Humidity & x );
00072 friend ostream & operator << ( ostream & os, const Humidity & x);
00076 friend istream & operator >> ( istream & is, Humidity & x);
00077 public:
00081 Humidity();
00085 Humidity(const Humidity &);
00093 Humidity(const string &s);
00094 #ifndef WITHOUT_ACS
00095
00101 Humidity(const IDLHumidity & idlHumidity);
00102 #endif
00103
00107 Humidity(double value);
00111 virtual ~Humidity();
00116 static double fromString(const string& s);
00123 static string toString(double);
00129 static Humidity getHumidity(StringTokenizer &st) throw(NumberFormatException);
00130
00135 void toBin(EndianOSStream& eoss);
00141 static void toBin(const vector<Humidity>& angle, EndianOSStream& eoss);
00142
00148 static void toBin(const vector<vector<Humidity> >& angle, EndianOSStream& eoss);
00149
00155 static void toBin(const vector<vector<vector<Humidity> > >& angle, EndianOSStream& eoss);
00162 static Humidity fromBin(EndianIStream& eis);
00163
00170 static vector<Humidity> from1DBin(EndianIStream & eis);
00171
00178 static vector<vector<Humidity> > from2DBin(EndianIStream & eis);
00179
00186 static vector<vector<vector<Humidity> > > from3DBin(EndianIStream & eis);
00187
00192 Humidity & operator = (const Humidity & x);
00193
00198 Humidity & operator = (const double d);
00203 Humidity & operator += (const Humidity & x);
00208 Humidity & operator -= (const Humidity & x);
00213 Humidity & operator *= (const double x);
00218 Humidity & operator /= (const double x);
00223 Humidity operator + (const Humidity & x) const;
00228 Humidity operator - (const Humidity & x) const;
00233 Humidity operator * (const double x) const;
00238 Humidity operator / (const double x) const;
00243 bool operator < (const Humidity & x) const;
00248 bool operator > (const Humidity & x) const;
00253 bool operator <= (const Humidity & x) const;
00258 bool operator >= (const Humidity & x) const;
00263 bool operator == (const Humidity & x) const;
00268 bool equals(const Humidity & x) const;
00273 bool operator != (const Humidity & x) const;
00278 bool isZero() const;
00282 Humidity operator - () const;
00286 Humidity operator + () const;
00291 string toString() const;
00295 string toStringI() const;
00300 operator string () const;
00305 double get() const;
00306 #ifndef WITHOUT_ACS
00307
00311 IDLHumidity toIDLHumidity() const;
00312 #endif
00313
00317 static string unit();
00318 private:
00319 double value;
00320 };
00321
00322 inline Humidity::Humidity() : value(0.0) {
00323 }
00324 inline Humidity::Humidity(const Humidity &t) : value(t.value) {
00325 }
00326 #ifndef WITHOUT_ACS
00327 inline Humidity::Humidity(const IDLHumidity &l) : value(l.value) {
00328 }
00329 #endif
00330 inline Humidity::Humidity(const string &s) : value(fromString(s)) {
00331 }
00332 inline Humidity::Humidity(double v) : value(v) {
00333 }
00334
00335 inline Humidity::~Humidity() { }
00336
00337 inline Humidity & Humidity::operator = ( const Humidity &t ) {
00338 value = t.value;
00339 return *this;
00340 }
00341
00342 inline Humidity & Humidity::operator = ( const double v ) {
00343 value = v;
00344 return *this;
00345 }
00346
00347 inline Humidity & Humidity::operator += ( const Humidity & t) {
00348 value += t.value;
00349 return *this;
00350 }
00351 inline Humidity & Humidity::operator -= ( const Humidity & t) {
00352 value -= t.value;
00353 return *this;
00354 }
00355 inline Humidity & Humidity::operator *= ( const double n) {
00356 value *= n;
00357 return *this;
00358 }
00359 inline Humidity & Humidity::operator /= ( const double n) {
00360 value /= n;
00361 return *this;
00362 }
00363
00364 inline Humidity Humidity::operator + ( const Humidity &t2 ) const {
00365 Humidity tmp;
00366 tmp.value = value + t2.value;
00367 return tmp;
00368 }
00369 inline Humidity Humidity::operator - ( const Humidity &t2 ) const {
00370 Humidity tmp;
00371 tmp.value = value - t2.value;
00372 return tmp;
00373 }
00374 inline Humidity Humidity::operator * ( const double n) const {
00375 Humidity tmp;
00376 tmp.value = value * n;
00377 return tmp;
00378 }
00379 inline Humidity Humidity::operator / ( const double n) const {
00380 Humidity tmp;
00381 tmp.value = value / n;
00382 return tmp;
00383 }
00384
00385 inline bool Humidity::operator < (const Humidity & x) const {
00386 return (value < x.value);
00387 }
00388 inline bool Humidity::operator > (const Humidity & x) const {
00389 return (value > x.value);
00390 }
00391 inline bool Humidity::operator <= (const Humidity & x) const {
00392 return (value <= x.value);
00393 }
00394 inline bool Humidity::operator >= (const Humidity & x) const {
00395 return (value >= x.value);
00396 }
00397 inline bool Humidity::equals(const Humidity & x) const {
00398 return (value == x.value);
00399 }
00400 inline bool Humidity::operator == (const Humidity & x) const {
00401 return (value == x.value);
00402 }
00403 inline bool Humidity::operator != (const Humidity & x) const {
00404 return (value != x.value);
00405 }
00406
00407 inline Humidity Humidity::operator - () const {
00408 Humidity tmp;
00409 tmp.value = -value;
00410 return tmp;
00411 }
00412 inline Humidity Humidity::operator + () const {
00413 Humidity tmp;
00414 tmp.value = value;
00415 return tmp;
00416 }
00417
00418 inline Humidity::operator string () const {
00419 return toString();
00420 }
00421 inline string Humidity::toString() const {
00422 return toString(value);
00423 }
00424 inline string Humidity::toStringI() const {
00425 return toString(value);
00426 }
00427 inline double Humidity::get() const {
00428 return value;
00429 }
00430 #ifndef WITHOUT_ACS
00431 inline IDLHumidity Humidity::toIDLHumidity() const {
00432 IDLHumidity tmp;
00433 tmp.value = value;
00434 return tmp;
00435 }
00436 #endif
00437
00438 inline Humidity operator * ( double n, const Humidity &x) {
00439 Humidity tmp;
00440 tmp.value = x.value * n;
00441 return tmp;
00442 }
00443 inline ostream & operator << ( ostream &o, const Humidity &x ) {
00444 o << x.value;
00445 return o;
00446 }
00447 inline istream & operator >> ( istream &i, Humidity &x ) {
00448 i >> x.value;
00449 return i;
00450 }
00451 inline string Humidity::unit() {
00452 return string ("%");
00453 }
00454 }
00455 #endif