oracular (3) Astro::Coord.3pm.gz

Provided by: libastro-perl_0.78-2_all bug

NAME

       Astro::Coord - Astronomical coordinate transformations

SYNOPSIS

           use Astro::Coord;

           ($l, $b) = fk4gal($ra, $dec);
           ($az, $el) = eqazel($ha, $dec, $latitude);

DESCRIPTION

       Astro::Coord contains an assorted set Perl routines for coordinate conversions, such as
       hour angle to elevation and J2000 to B1950.

AUTHOR

       Chris Phillips  Chris.Phillips@csiro.au

FUNCTIONS

       pol2r
             ($x, $y, $z) = pol2r($polar1, $polar2);

            Converts a position in polar coordinates into rectangular coordinates
              $polar1, $polar2   The polar coordinates to convert (turns)
              $x, $y, $z         The rectangular coordinates

       r2pol
             ($polar1, $polar2) = r2pol($x, $y, $z);

            Converts a position in rectangular coordinates into polar coordinates
              $x, $y, $y         The rectangular coordinates to convert
              $polar1, $polar2   The polar coordinates (turns);
            Returns undef if too few or too many arguments are passed.

       xy2azel
             ($az, $el) = xy2azel($x, $y);

            Converts a telescope position in X,Y coordinates into Az,El coordinates
              $x, $y     The X and Y coordinates (turns)
              $az, $el    The azimuth and elevation (turns)

       azel2xy
             ($x, $y) = azel2xy($az, $el);

            Converts a position in Az,El coordinates into X,Y coordinates
              $az, $el    The azimuth and elevation (turns)
              $x, $y      The X and Y coordinate (turns)

       eqazel
             ($ha, $dec) = eqazel($az, $el, $latitude);
             ($az, $el) = eqazel($ha, $dec, $latitude);
             ($ha, $dec) = eqazel($az, $el, $latitude, $allownegative);

            Converts HA/Dec coordinates to Az/El and vice versa.
              $ha, $dec     Hour angle and declination of source (turns)
              $az, $el      Azimuth and elevation of source (turns)
              $latitude     Latitude of the observatory (turns)
              $allownegative  If true, allow negative $ha or $az on return (Optional)
            Note:
             The ha,dec and az,el conversion is symmetrical

       fk4fk5
            ($JRA, $JDec) = fk4fk5($BRA, $BDec);
                 (@fk5) = fk4fk5(@fk4);

            Converts an FK4 (B1950) position to the equivalent FK5 (J2000)
            position.
              $BRA,$BDec     fk4/B1950 position (turns)
              $JRA,$Dec      fk5/J2000 position (turns)
              @fk4           fk4/B1950 position (as a 3-vector)
              @fk5           fk5/J2000 position (as a 3-vector)
            Note:
             This code is based on similar routines from the Fortran SLALIB
             package, so are quite accurate, but subject to a restrictive
             license (see README).

       fk4fk5r
            @fk5 = fk4fk5r(@fk4);

            Converts an FK4 (B1950) position to the equivalent FK5 (J2000) position.
            Note: Convert equitoral positions to/from 3-vectors using pol2r and r2pol.
              @fk4       fk4 position (as a 3-vector, turns)
              @fk5       fk5 position (as a 3-vector, turns)
            Note:
             Just a wrapper to fk4fk5 which now handler polar and rectangular
             arguments

       fk5fk4
            ($JRA, $JDec) = fk4fk5($BRA, $BDec);
                  ($@fk5) = fk4fk5(@fk4);

            Converts an FK5 (J2000) position to the equivalent FK4 (B1950) position.
              $JRA,$Dec      fk5/J2000 position (turns)
              $BRA,$BDec     fk4/B1950 position (turns)
              @fk5           fk5/J2000 position (as a 3-vector)
              @fk4           fk4/B1950 position (as a 3-vector)
            Note:
             This code is based on similar routines from the Fortran SLALIB
             package, so are quite accurate, but subject to a restrictive
             license (see README).

       fk5fk4r
            @fk4 = fk5fk4r(@fk5);

            Converts an FK5 (J2000) position to the equivalent FK4 (B1950) position.
            Note: Convert equitoral positions to/from 3-vectors using pol2r and r2pol.
              @fk4       fk4 position (as a 3-vector, turns)
              @fk5       fk5 position (as a 3-vector, turns)
            Note:
             Just a wrapper to fk5fk4 which now handler polar and rectangular
             arguments

       fk4galr
             @gal = fk4galr(@fk4)

            Converts an FK4 position (B1950.0) to the IAU 1958 Galactic
            coordinate system
            Note: convert equitoral positions to/from 3-vectors using pol2r and r2pol.
              @fk4     fk4 position to convert (as a 3-vector, turns)
              @gal     Galactic position (as a 3-vector, turns)
            Returns undef if too few or two many arguments are passed.
            Reference : Blaauw et al., 1960, MNRAS, 121, 123.

       galfk4
             ($bRA, $bDec) = galfk4($l, $b);
             @fk4 = galfk4(@gal);

            Converts an IAU 1958 Galactic position to the FK4 coordinate system (B1950)
            Notes: Converts equitoral positions to/from 3-vectors using pol2r and r2pol.
              $BRA,$BDec  fk4/B1950 position (turns)
              $l, $b      Galactic longitude and latitude
              @gal        Galactic position (as a 3-vector, turns)
              @fk4        fk4 position (as a  3-vector, turns)
            Reference : Blaauw et al., 1960, MNRAS, 121, 123.

       fk4gal
             ($l, $b) = fk4gal($ra, $dec);

            Converts an FK4 position (B1950) to the IAU 1958 Galactic
            coordinate system
              ($ra, $dec)  fk4 position to convert (turns)
              ($l, $b)     Galactic position (turns)
            Reference : Blaauw et al., 1960, MNRAS, 121, 123.

       ephem_vars
             ($omega, $rma, $mlanom, $F, $D, $eps0) = ephem_vars($jd)

             Given the Julian day ($jd) this routine calculates the ephemeris
             values required by the prcmat and nutate routines

             The returned values are :
               $omega  - Longitude of the ascending node of the Moons mean orbit on
                         the ecliptic, measured from the mean equinox of date.
               $rma    - Mean anomaly of the Sun.
               $mlanom - Mean anomaly of the Moon.
               $F      - L - omega, where L is the mean longitude of the Moon.
               $D      - Mean elongation of the Moon from the Sun.
               $eps0   - Mean obilquity of the ecliptic.

       J2000todate
            ($DRA, $DDec) = J2000todate($JRA, $JDec, $mjd);
            @date = J2000todate(@J2000, $mjd);

            Converts an J2000 position date coordinate

              $DRA,$DDec     Date coordinate (turns)
              $JRA,$Dec      J2000 position (turns)
              @date          Date coordinate (as a 3-vector)
              @J2000         J2000 position (as a 3-vector)

       nutate
             ($deps, $dpsi, @nu) = nutate($omega, $F, $D, $rma, $mlanom, $eps0);

             To calculate the nutation in longitude and obliquity according to
             the 1980 IAU Theory of Nutation including terms with amplitudes
             greater than 0.01 arcsecond.  The nutation matrix is used to
             compute true place from mean place: true vector = N x mean place
             vector where the three components of each vector are the direction
             cosines wrt the mean equinox and equator.

                  /   1          -dpsi.cos(eps)    -dpsi.sin(eps)  \
                 |                                                  |
             N = |  dpsi.cos(eps)      1               -deps        |
                 |                                                  |
                  \ dpsi.sin(eps)    deps                 1        /

             The required inputs are : (NOTE: these are the values returned by ephem_vars)
               $omega  - Longitude of the ascending node of the Moons mean orbit on
                         the ecliptic, measured from the mean equinox of date.
               $rma    - Mean anomaly of the Sun.
               $mlanom - Mean anomaly of the Moon.
               $F      - L - omega, where L is the mean longitude of the Moon.
               $D      - Mean elongation of the Moon from the Sun.
               $eps0   - Mean obilquity of the ecliptic.

             The returned values are :
               $deps - nutation in obliquity
               $dpsi - nutation in longitude (scalar)
               @nu   - nutation matrix (array [3][3])

       precsn
             @gp = precsn($jd_start, $jd_stop);

             To calculate the precession matrix P for dates AFTER 1984.0 (JD =
             2445700.5) Given the position of an object referred to the equator
             and equinox of the epoch $jd_start its position referred to the
             equator and equinox of epoch $jd_stop can be calculated as follows :

             1) Express the position as a direction cosine 3-vector (V1)
                (use pol2r to do this).
             2) The corresponding vector V2 for epoch jd_end is V2 = P.V1

             The required inputs are :
               $jd_start - The Julian day of the current epoch of the coordinates.
               $jd_end   - The Julian day at the required epoch for the conversion.

             The returned values are :
               @gp - The required precession matrix (array [3][3])

       coord_convert
             ($output_left, $output_right) = coord_convert($input_left, $input_right,
                                                           $input_mode, $output_mode,
                                                           $mjd, $longitude, $latitude,
                                                           $ref0);

             A routine for converting between any of the following coordinate systems :
                   Coordinate system                               input/output mode
                   -----------------                               -----------------
               X, Y (East-West mounted)                                    0
               Azimuth, Elevation                                          1
               Hour Angle, Declination                                     2
               Right Ascension, Declination (date, J2000 or B1950)       3,4,5
               Galactic (B1950)                                            6

             The last four parameters in the call ($mjd, $longitude, $latitude
             and $ref0) are not always required for the coordinate conversion.
             In particular if the conversion is between two coordinate systems
             which are fixed with respect to the celestial sphere (RA/Dec J2000,
             B1950 or Galactic), or two coordinate systems which are fixed with
             respect to the antenna (X/Y and Az/El) then these parameters are not
             used (NOTE: they must always be passed, even if they only hold 0 or
             undef as the routine will return undef if it is not passed 8
             parameters).  The RA/Dec date system is defined with respect to the
             celestial sphere, but varies with time.  The table below shows which
             of $mjd, $longitude, $latitude and $ref0 are used for a given
             conversion.  If in doubt you should determing the correct values for
             all input parameters, no checking is done in the routine that the
             passed values are sensible.

                           Conversion                 $mjd $longitude $latitude $ref0
             ------------------------------------------------------------------------
             Galactic,             Galactic,
             RA/Dec J2000,B1950 <->RA/Dec J2000, B1950  N       N         N       N

             Galactic,
             RA/Dec J2000,B1950 <->RA/Dec date          Y       N         N       N

             Galactic,
             RA/Dec J2000,B1950,<->HA/Dec               Y       Y         N       N
             date

             Galactic,
             RA/Dec J2000,B1950,<->X/Y, Az/El           Y       Y         Y       Y
             date

             X/Y, Az/El         <->X/Y, Az/El           N       N         N       N

             X/Y, Az/El         <->HA/Dec               N       N         Y       Y

             NOTE :  The method used for refraction correction is asymptotic at
                     an elevation of 0 degrees.

             The required inputs are :
               $input_left   - The left/longitude input coordinate (turns)
               $input_right  - The right/latitude input coordinate (turns)
               $input_mode   - The mode of the input coordinates (0-6)
               $output_mode  - The mode to convert the coordinates to.
               $mjd          - The time as modified Julian day (if necessary) at
                               which to perform the conversion
               $longitude    - The longitude of the location/observatory (if necessary)
                               at which to perform the conversion (turns)
               $latitude     - The latitude of the location/observatory (if necessary)
                               at which to perform the conversion (turns)
               $ref0         - The refraction constant (if in doubt use 0.00005).

             The returned values are :
               $output_left  - The left/longitude output coordinate (turns)
               $output_right - The right/latitude output coordinate (turns)

       haset_ewxy
             $haset = haset_ewxy($declination, $latitude, %limits);

              This routine takes the $declination of the source, and the $latitude of the
              EWXY mounted antenna and calculates the hour angle at which the source
              will set.  It is then trivial to calculate the time until the source
              sets, simply by subtracting the current hour angle of the source from
              the hour angle at which it sets.

             The required inputs are :
               $declination - The declination of the source (turns)
               $latitude    - The latitude of the observatory (turns)
               %limits     - A reference to a hash holding the EWXY antenna limits
                              The following keys must be defined XLOW, XLOW_KEYHOLE,
                              XHIGH, XHIGH_KEYHOLE, YLOW, YLOW_KEYHOLE, YHIGH,
                              YHIGH_KEYHOLE (all values shoule be in turns)

             The returned value is :
               $haset       - The hour angle (turns) at which a source at this
                              declination sets for an EWXY mounted antenna with the
                              given limits at the given latitude

             NOTE: returns undef if %limits hash is missing any of the required keys

       ewxy_tlos
             $tlos = ewxy_tlos($hour_angle, $declination, $latitude, %limits);

             This routine calculates the time left on-source (tlos) for a source
             at $hour_angle, $declination for an EWXY mount antenna at $latitude.

             The required inputs are :
               $hour_angle  - The current hour angle of the source (turns)
               $declination - The declination of the source (turns)
               $latitude    - The latitude of the observatory (turns)
               \%limits     - A reference to a hash holding the EWXY antenna limits
                              The following keys must be defined XLOW, XLOW_KEYHOLE,
                              XHIGH, XHIGH_KEYHOLE, YLOW, YLOW_KEYHOLE, YHIGH,
                              YHIGH_KEYHOLE (all values should be in turns)

             The returned value is :
               $tlos        - The time left on-source (turns)

       haset_azel
             $haset = haset_azel($declination, $latitude, %limits);

              This routine takes the $declination of the source, and the
              $latitude of the Az/El mounted antenna and calculates the hour
              angle at which the source will set.  It is then trivial to
              calculate the time until the source sets, simply by subtracting the
              current hour angle of the source from the hour angle at which it
              sets.  This routine assumes that the antenna is able to rotate
              through 360 degrees in azimuth.

             The required inputs are :
               $declination - The declination of the source (turns)
               $latitude    - The latitude of the observatory (turns)
               \%limits     - A reference to a hash holding the Az/El antenna limits
                              The following keys must be defined ELLOW (all values should
                              be in turns)

             The returned value is :
               $haset       - The hour angle (turns) at which a source at this
                              declination sets for an Az/El mounted antenna with the
                              given limits at the given latitude

             NOTE: returns undef if the %limits hash is missing any of the required keys

       azel_tlos
             $tlos = azel_tlos($hour_angle, $declination, $latitude, \%limits);

             This routine calculates the time left on-source (tlos) for a source
             at $hour_angle, $declination for an Az/El mount antenna at $latitude.

             The required inputs are :
               $hour_angle  - The current hour angle of the source (turns)
               $declination - The declination of the source (turns)
               $latitude    - The latitude of the observatory (turns)
               %limits     - A reference to a hash holding the Az/El antenna limits
                              The following keys must be defined ELLOW (all values
                              should be in turns)

             The returned value is :
               $tlos        - The time left on-source (turns)

       antenna_rise
             $ha_set = antenna_rise($declination, $latitude, $mount, \%limits);

              Given the $declination of the source, the $latitude of the antenna,
              the type of the antenna $mount and a reference to a hash holding
              information on the antenna limits, this routine calculates the hour
              angle at which the source sets for the antenna.  The hour angle at
              which it rises is simply the negative of that at which it sets.
              These values in turn can be used to calculate the LMST at which the
              source rises/sets and from that the UT at which the source
              rises/sets on a given day, or to calculate the native coordinates
              at which the source rises/sets.

              If you want to calculate source rise times above arbitrary elevation,
              use the routine rise.

             The required inputs are :
               $declination - The declination of the source (turns)
               $latitude    - The latitude of the observatory (turns)
               $mount       - The type of antenna mount, 0 => EWXY mount, 1 => Az/El,
                              any other number will cause the routine to return
                              undef
               %limits     - A reference to a hash holding the antenna limits
                              For an EWXY antenna there must be keys for all the
                              limits (i.e.  XLOW, XLOW_KEYHOLE, XHIGH, XHIGH_KEYHOLE,
                              YLOW, YLOW_KEYHOLE, YHIGH, YHIGH_KEYHOLE).  For an Az/El
                              antenna there must be a key for ELLOW (all values should
                              be in turns).

             The returned values are :
               $ha_set  - The hour angle at which the source sets (turns).  The hour
                          angle at which the source rises is simply the negative of this
                          value.