casa  5.7.0-16
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Angle.h
Go to the documentation of this file.
1 //Angle.h generated on 'Thu Feb 04 10:20:05 CET 2010'. Edit at your own risk.
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  * File Angle.h
26  */
27 #ifndef Angle_CLASS
28 #define Angle_CLASS
29 #include <vector>
30 #include <iostream>
31 #include <string>
32 #ifndef WITHOUT_ACS
33 #include <asdmIDLTypesC.h>
34 #endif
37 #include <alma/ASDM/EndianStream.h>
38 namespace asdm {
39 class Angle;
40 Angle operator * ( double , const Angle & );
41 std::ostream & operator << ( std::ostream &, const Angle & );
42 std::istream & operator >> ( std::istream &, Angle &);
53 class Angle {
60  friend Angle operator * ( double d, const Angle & x );
66  friend std::ostream & operator << ( std::ostream & os, const Angle & x);
70  friend std::istream & operator >> ( std::istream & is, Angle & x);
71 public:
75  Angle();
79  Angle(const Angle &);
87  Angle(const std::string &s);
88 #ifndef WITHOUT_ACS
89 
95  Angle(const asdmIDLTypes::IDLAngle & idlAngle);
96 #endif
97 
101  Angle(double value);
105  virtual ~Angle();
110  static double fromString(const std::string& s);
117  static std::string toString(double);
124 
129  void toBin(EndianOSStream& eoss);
135  static void toBin(const std::vector<Angle>& angle, EndianOSStream& eoss);
136 
142  static void toBin(const std::vector<std::vector<Angle> >& angle, EndianOSStream& eoss);
143 
149  static void toBin(const std::vector<std::vector<std::vector<Angle> > >& angle, EndianOSStream& eoss);
156  static Angle fromBin(EndianIStream& eis);
157 
164  static std::vector<Angle> from1DBin(EndianIStream & eis);
165 
172  static std::vector<std::vector<Angle> > from2DBin(EndianIStream & eis);
173 
180  static std::vector<std::vector<std::vector<Angle> > > from3DBin(EndianIStream & eis);
181 
186  Angle & operator = (const Angle & x);
187 
192  Angle & operator = (const double d);
197  Angle & operator += (const Angle & x);
202  Angle & operator -= (const Angle & x);
207  Angle & operator *= (const double x);
212  Angle & operator /= (const double x);
217  Angle operator + (const Angle & x) const;
222  Angle operator - (const Angle & x) const;
227  Angle operator * (const double x) const;
232  Angle operator / (const double x) const;
237  bool operator < (const Angle & x) const;
242  bool operator > (const Angle & x) const;
247  bool operator <= (const Angle & x) const;
252  bool operator >= (const Angle & x) const;
257  bool operator == (const Angle & x) const;
262  bool equals(const Angle & x) const;
267  bool operator != (const Angle & x) const;
272  bool isZero() const;
276  Angle operator - () const;
280  Angle operator + () const;
285  std::string toString() const;
289  std::string toStringI() const;
294  operator std::string () const;
299  double get() const;
300 #ifndef WITHOUT_ACS
301 
305  asdmIDLTypes::IDLAngle toIDLAngle() const;
306 #endif
307 
311  static std::string unit();
312 private:
313  double value;
314 };
315 // Angle constructors
316 inline Angle::Angle() : value(0.0) {
317 }
318 inline Angle::Angle(const Angle &t) : value(t.value) {
319 }
320 #ifndef WITHOUT_ACS
321 inline Angle::Angle(const asdmIDLTypes::IDLAngle &l) : value(l.value) {
322 }
323 #endif
324 inline Angle::Angle(const std::string &s) : value(fromString(s)) {
325 }
326 inline Angle::Angle(double v) : value(v) {
327 }
328 // Angle destructor
329 inline Angle::~Angle() { }
330 // assignment operator
331 inline Angle & Angle::operator = ( const Angle &t ) {
332  value = t.value;
333  return *this;
334 }
335 // assignment operator
336 inline Angle & Angle::operator = ( const double v ) {
337  value = v;
338  return *this;
339 }
340 // assignment with arithmetic operators
341 inline Angle & Angle::operator += ( const Angle & t) {
342  value += t.value;
343  return *this;
344 }
345 inline Angle & Angle::operator -= ( const Angle & t) {
346  value -= t.value;
347  return *this;
348 }
349 inline Angle & Angle::operator *= ( const double n) {
350  value *= n;
351  return *this;
352 }
353 inline Angle & Angle::operator /= ( const double n) {
354  value /= n;
355  return *this;
356 }
357 // arithmetic functions
358 inline Angle Angle::operator + ( const Angle &t2 ) const {
359  Angle tmp;
360  tmp.value = value + t2.value;
361  return tmp;
362 }
363 inline Angle Angle::operator - ( const Angle &t2 ) const {
364  Angle tmp;
365  tmp.value = value - t2.value;
366  return tmp;
367 }
368 inline Angle Angle::operator * ( const double n) const {
369  Angle tmp;
370  tmp.value = value * n;
371  return tmp;
372 }
373 inline Angle Angle::operator / ( const double n) const {
374  Angle tmp;
375  tmp.value = value / n;
376  return tmp;
377 }
378 // comparison operators
379 inline bool Angle::operator < (const Angle & x) const {
380  return (value < x.value);
381 }
382 inline bool Angle::operator > (const Angle & x) const {
383  return (value > x.value);
384 }
385 inline bool Angle::operator <= (const Angle & x) const {
386  return (value <= x.value);
387 }
388 inline bool Angle::operator >= (const Angle & x) const {
389  return (value >= x.value);
390 }
391 inline bool Angle::equals(const Angle & x) const {
392  return (value == x.value);
393 }
394 inline bool Angle::operator == (const Angle & x) const {
395  return (value == x.value);
396 }
397 inline bool Angle::operator != (const Angle & x) const {
398  return (value != x.value);
399 }
400 // unary - and + operators
401 inline Angle Angle::operator - () const {
402  Angle tmp;
403  tmp.value = -value;
404  return tmp;
405 }
406 inline Angle Angle::operator + () const {
407  Angle tmp;
408  tmp.value = value;
409  return tmp;
410 }
411 // Conversion functions
412 inline Angle::operator std::string () const {
413  return toString();
414 }
415 inline std::string Angle::toString() const {
416  return toString(value);
417 }
418 inline std::string Angle::toStringI() const {
419  return toString(value);
420 }
421 inline double Angle::get() const {
422  return value;
423 }
424 #ifndef WITHOUT_ACS
425 inline asdmIDLTypes::IDLAngle Angle::toIDLAngle() const {
426  asdmIDLTypes::IDLAngle tmp;
427  tmp.value = value;
428  return tmp;
429 }
430 #endif
431 // Friend functions
432 inline Angle operator * ( double n, const Angle &x) {
433  Angle tmp;
434  tmp.value = x.value * n;
435  return tmp;
436 }
437 inline std::ostream & operator << ( std::ostream &o, const Angle &x ) {
438  o << x.value;
439  return o;
440 }
441 inline std::istream & operator >> ( std::istream &i, Angle &x ) {
442  i >> x.value;
443  return i;
444 }
445 inline std::string Angle::unit() {
446  return std::string ("rad");
447 }
448 } // End namespace asdm
449 #endif /* Angle_CLASS */
static std::string unit()
Returns the abbreviated name of the unit implicitely associated to any Angle.
Definition: Angle.h:445
virtual ~Angle()
The destructor.
Definition: Angle.h:329
static std::vector< std::vector< Angle > > from2DBin(EndianIStream &eis)
Read the binary representation of a vector of vector of Angle from an EndianIStream and use the read ...
bool operator!=(const Angle &x) const
Comparison operator.
Definition: Angle.h:397
Angle operator/(const double x) const
Division operator.
Definition: Angle.h:373
bool operator>=(const Angle &x) const
Comparison operator.
Definition: Angle.h:388
double value
Definition: Angle.h:313
std::istream & operator>>(std::istream &, EntityId &)
Definition: EntityId.h:164
static std::vector< Angle > from1DBin(EndianIStream &eis)
Read the binary representation of a vector of Angle from an EndianIStream and use the read value to s...
The StringTokenizer class is a translation into C++ of the Java class of the same name in Java&#39;s util...
friend std::istream & operator>>(std::istream &is, Angle &x)
Overloading of &gt;&gt; to read an Angle from an istream.
std::string toString() const
Converts into a string.
Definition: Angle.h:415
static Angle getAngle(StringTokenizer &st)
Parse the next (string) token of a StringTokenizer into an angle.
static Angle fromBin(EndianIStream &eis)
Read the binary representation of an Angle from a EndianIStream and use the read value to set an Angl...
Angle & operator-=(const Angle &x)
Operator decrement and assign.
Definition: Angle.h:345
static std::vector< std::vector< std::vector< Angle > > > from3DBin(EndianIStream &eis)
Read the binary representation of a vector of vector of vector of Angle from an EndianIStream and use...
bool operator==(const Angle &x) const
Comparision operator.
Definition: Angle.h:394
The NumberFormatException class represents an exception when an error occurs in converting a numeric ...
Length operator*(double, const Length &)
Friend functions.
Definition: Length.h:432
double get() const
Return the double precision value of the Angle.
Definition: Angle.h:421
Angle operator-() const
Unary operator.
Definition: Angle.h:401
std::string toStringI() const
Idem toString.
Definition: Angle.h:418
The Angle class implements a quantity of angle in radians.
Definition: Angle.h:53
Angle & operator/=(const double x)
Operator divide and assign.
Definition: Angle.h:353
std::ostream & operator<<(std::ostream &, const EntityId &)
Friend functions.
Definition: EntityId.h:159
casacore::String toString(VisibilityProcessor::ProcessingType p)
Angle & operator*=(const double x)
Operator multiply and assign.
Definition: Angle.h:349
void toBin(EndianOSStream &eoss)
Write the binary representation of this to an EndianOSStream .
Angle operator+() const
Unary operator.
Definition: Angle.h:406
bool operator>(const Angle &x) const
Comparison operator.
Definition: Angle.h:382
Angle & operator=(const Angle &x)
An assignment operator Angle = Angle.
Definition: Angle.h:331
Angle()
The nullary constructor (default).
Definition: Angle.h:316
friend Angle operator*(double d, const Angle &x)
Overloading of multiplication operator.
Angle & operator+=(const Angle &x)
Operator increment and assign.
Definition: Angle.h:341
bool equals(const Angle &x) const
Comparison method.
Definition: Angle.h:391
bool isZero() const
Comparison method.
Defines a Class for those parameters being angles.
Definition: ATMAngle.h:44
asdmIDLTypes::IDLAngle toIDLAngle() const
Return the IDLAngle representation of the Angle.
Definition: Angle.h:425
static double fromString(const std::string &s)
A static method equivalent to the constructor from a string.
bool operator<=(const Angle &x) const
Comparison operator.
Definition: Angle.h:385
LatticeExprNode value(const LatticeExprNode &expr)
This function returns the value of the expression without a mask.
friend std::ostream & operator<<(std::ostream &os, const Angle &x)
Overloading of &lt;&lt; to output the value an Angle on an ostream.
bool operator<(const Angle &x) const
Comparison operator.
Definition: Angle.h:379