//# MVBaseline.h: A 3D vector on Earth //# Copyright (C) 1998,2000 //# Associated Universities, Inc. Washington DC, USA. //# //# This library is free software; you can redistribute it and/or modify it //# under the terms of the GNU Library General Public License as published by //# the Free Software Foundation; either version 2 of the License, or (at your //# option) any later version. //# //# This library is distributed in the hope that it will be useful, but WITHOUT //# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or //# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public //# License for more details. //# //# You should have received a copy of the GNU Library General Public License //# along with this library; if not, write to the Free Software Foundation, //# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA. //# //# Correspondence concerning AIPS++ should be addressed as follows: //# Internet email: aips2-request@nrao.edu. //# Postal address: AIPS++ Project Office //# National Radio Astronomy Observatory //# 520 Edgemont Road //# Charlottesville, VA 22903-2475 USA //# //# $Id$ #ifndef CASA_MVBASELINE_H #define CASA_MVBASELINE_H //# Includes #include #include namespace casacore { //# NAMESPACE CASACORE - BEGIN //# Forward Declarations // A 3D vector on Earth // // // // //
  • MeasValue // // // // From Measure, Value and Baseline // // // // A MVBaseline is a 3-vector of Baselines in a rectangular frame with // internal units of m.
    // It can be constructed with: //
      //
    • MVBaseline() creates point at origin (0,0,0) //
    • MVBaseline(MVBaseline) creates a copy //
    • MVBaseline(MVPosition) creates (x,y,z) from the given position //
    • MVBaseline(Double, Double, Double) creates (x,y,z) with // specified values (assuming meters) //
    • MVBaseline(Quantity length,Double, Double) creates a MVBaseline assuming // that the two values are (in radians) angle along 'equator' // and towards 'pole'. //
    • MVBaseline(Quantity length, Quantity, Quantity) creates a MVBaseline // assuming angles as in previous, or Baselines //
    • MVBaseline(Quantity, Quantum >) creates a // MVBaseline from angle vector, using first two angles, and // assuming second as zero if not present. //
    • MVBaseline(Quantum > creates from // angles or Baselines, depending on the units in the // quantum vector. In the angle case, // the data derived can be scaled with the readjust() function. If // the unit of the quantum vector is length, Baseline is // assumed. //
    • MVBaseline(Vector creates from angles (less than // or equal to two elements) or x,y,z (3 elements). //
    • MVBaseline(Vector creates from length+angles, // angles, or x,y,z, depending on units. //
    • MVBaseline(MVPosition, MVPosition) creates a baseline // pointing from second to first MVPosition //
    • MVBaseline(MVPosition) creates a baseline as defined by the // position given (e.g. as derived from an offset MPosition) //
    // A void adjust(Double) function normalises the vector to a length of 1; // a get() returns as a // Double 3-vector the length and angles of the Baseline vector; // a getAngle() returns a Quantum 2-vector, (uInt) returns the indicated // element, and getValue returns the vector.
    // Baselines can be added and subtracted.
    // The multiplication of two Baselines produces the in-product.
    //
    // // // See MBaseline class. // // // // To do coordinate transformations // // // //
  • Nothing I know of // class MVBaseline : public MVPosition { public: //# Friends //# Constructors // Default constructor generates a (0,0,0) Baseline MVBaseline(); // Creates from an MVPosition MVBaseline(const MVPosition &other); // Creates a specified vector MVBaseline(Double in0, Double in1, Double in2); // Creates a vector with specified length towards pole // explicit MVBaseline(Double in0); MVBaseline(const Quantity &l); // // Creates the Baseline from specified (azimuth,elevation) angles and length MVBaseline(const Quantity &l, Double angle0, Double angle1); // Creates the Baseline from specified angles and length. or Baselines // //
  • AipsError if quantities not in angle format // // MVBaseline(const Quantity &l, const Quantity &angle0, const Quantity &angle1); // If not enough angles: pole assumed (if none), or elevation =0 (if 1) MVBaseline(const Quantum > &angle); MVBaseline(const Quantity &l, const Quantum > &angle); // // Create from specified length and/or angles and/or Baseline // MVBaseline(const Vector &other); MVBaseline(const Vector &other); // // Baseline as difference between positions (first - second (default(0,0,0)) // MVBaseline(const MVPosition &pos, const MVPosition &base); // //# Operators // Multiplication defined as in-product // Double operator*(const MVBaseline &other) const; // // Equality comparisons // Bool operator== (const MVBaseline &other) const; Bool operator!= (const MVBaseline &other) const; Bool near(const MVBaseline &other, Double tol=1e-13) const; Bool near(const MVBaseline &other, Quantity tol) const; Bool nearAbs(const MVBaseline &other, Double tol=1e-13) const; // // Addition and subtraction // MVBaseline operator-() const; MVBaseline &operator+=(const MVBaseline &right); MVBaseline operator+(const MVBaseline &right) const; MVBaseline &operator-=(const MVBaseline &right); MVBaseline operator-(const MVBaseline &right) const; // //# General Member Functions // Tell me your type // static void assure(const MeasValue &in); // // Normalise direction aspects by adjusting the length to 1 // virtual void adjust(); virtual void adjust(Double &res); virtual void readjust(Double res); // // Get radius of Baseline virtual Double radius(); // Generate a 3-vector of coordinates (length(m), angles(rad)) Vector get() const; // Generate a 3-vector of x,y,z in m const Vector &getValue() const; // Generate angle 2-vector (in rad) Quantum > getAngle() const; // and with specified units Quantum > getAngle(const Unit &unit) const; // Generate the length Quantity getLength() const; // and generate it with the specified units Quantity getLength(const Unit &unit) const; // Get the Baseline angle between the directions. I.e. the angle between // the direction from one to the pole, and from one to the other. // Double BaselineAngle(const MVBaseline &other) const; Quantity BaselineAngle(const MVBaseline &other, const Unit &unit) const; // // Get the angular separation between two directions. // Double separation(const MVBaseline &other) const; Quantity separation(const MVBaseline &other, const Unit &unit) const; // // Produce the cross product MVBaseline crossProduct(const MVBaseline &other) const; // Print data virtual void print(ostream &os) const; // Clone virtual MeasValue *clone() const; // Get the value in internal units virtual Vector getVector() const; // Set the value from internal units (set 0 for empty vector) virtual void putVector(const Vector &in); // Get the internal value as a Vector. Usable in // records. The getXRecordValue() gets additional information for records. // Note that the Vectors could be empty. // virtual Vector > getRecordValue() const; virtual Vector > getXRecordValue() const; virtual Vector > getTMRecordValue() const { return getXRecordValue(); } ; // // Set the internal value if correct values and dimensions virtual Bool putValue(const Vector > &in); }; //# Global functions // Rotate a Baseline vector with rotation matrix and other multiplications // MVBaseline operator*(const RotMatrix &left, const MVBaseline &right); MVBaseline operator*(const MVBaseline &left, const RotMatrix &right); MVBaseline operator*(Double left, const MVBaseline &right); MVBaseline operator*(const MVBaseline &left, Double right); Double operator*(const Vector &left, const MVBaseline &right); Double operator*(const MVBaseline &left, const Vector &right); Double operator*(const MVPosition &left, const MVBaseline &right); Double operator*(const MVBaseline &left, const MVPosition &right); // } //# NAMESPACE CASACORE - END #endif