astronomia
Version:
An astronomical library
175 lines (163 loc) • 6.85 kB
JavaScript
;
Object.defineProperty(exports, '__esModule', { value: true });
var base = require('./base.cjs');
var globe = require('./globe.cjs');
var sidereal = require('./sidereal.cjs');
var sexagesimal = require('./sexagesimal.cjs');
/**
* @copyright 2013 Sonia Keys
* @copyright 2016 commenthol
* @license MIT
* @module parallax
*/
const horPar = (8.794 / 3600) * Math.PI / 180; // 8".794 arcseconds in radians
/**
* Horizontal returns equatorial horizontal parallax of a body.
*
* @param {number} Δ - distance in AU.
* @return {number} parallax in radians.
*/
function horizontal (Δ) {
// (40.1) p. 279
return Math.asin(Math.sin(horPar) / Δ)
// return horPar / Δ // with sufficient accuracy
}
/**
* Topocentric returns topocentric positions including parallax.
*
* Arguments α, δ are geocentric right ascension and declination in radians.
* Δ is distance to the observed object in AU. ρsφ, ρcφ are parallax
* constants (see package globe.) lon is geographic longitude of the observer,
* jde is time of observation.
*
* @param {Coord} c - geocentric right ascension and declination in radians
* @param {number} ρsφ - parallax constants (see package globe.)
* @param {number} ρcφ - parallax constants (see package globe.)
* @param {number} lon - geographic longitude of the observer (measured positively westwards!)
* @param {number} jde - time of observation
* @return {Coord} observed topocentric ra and dec in radians.
*/
function topocentric (c, ρsφ, ρcφ, lon, jde) {
const [α, δ, Δ] = [c.ra, c.dec, c.range];
const π = horizontal(Δ);
const θ0 = new sexagesimal["default"].Time(sidereal["default"].apparent(jde)).rad();
const H = base["default"].pmod(θ0 - lon - α, 2 * Math.PI);
const sπ = Math.sin(π);
const [sH, cH] = base["default"].sincos(H);
const [sδ, cδ] = base["default"].sincos(δ);
const Δα = Math.atan2(-ρcφ * sπ * sH, cδ - ρcφ * sπ * cH); // (40.2) p. 279
const α_ = α + Δα;
const δ_ = Math.atan2((sδ - ρsφ * sπ) * Math.cos(Δα), cδ - ρcφ * sπ * cH); // (40.3) p. 279
return new base.Coord(α_, δ_)
}
/**
* Topocentric2 returns topocentric corrections including parallax.
*
* This function implements the "non-rigorous" method descripted in the text.
*
* Note that results are corrections, not corrected coordinates.
*
* @param {Coord} c - geocentric right ascension and declination in radians
* @param {number} ρsφ - parallax constants (see package globe.)
* @param {number} ρcφ - parallax constants (see package globe.)
* @param {number} lon - geographic longitude of the observer (measured positively westwards!)
* @param {number} jde - time of observation
* @return {Coord} observed topocentric ra and dec in radians.
*/
function topocentric2 (c, ρsφ, ρcφ, lon, jde) {
const [α, δ, Δ] = [c.ra, c.dec, c.range];
const π = horizontal(Δ);
const θ0 = new sexagesimal["default"].Time(sidereal["default"].apparent(jde)).rad();
const H = base["default"].pmod(θ0 - lon - α, 2 * Math.PI);
const [sH, cH] = base["default"].sincos(H);
const [sδ, cδ] = base["default"].sincos(δ);
const Δα = -π * ρcφ * sH / cδ; // (40.4) p. 280
const Δδ = -π * (ρsφ * cδ - ρcφ * cH * sδ); // (40.5) p. 280
return new base["default"].Coord(Δα, Δδ)
}
/**
* Topocentric3 returns topocentric hour angle and declination including parallax.
*
* This function implements the "alternative" method described in the text.
* The method should be similarly rigorous to that of Topocentric() and results
* should be virtually consistent.
*
* @param {Coord} c - geocentric right ascension and declination in radians
* @param {number} ρsφ - parallax constants (see package globe.)
* @param {number} ρcφ - parallax constants (see package globe.)
* @param {number} lon - geographic longitude of the observer (measured positively westwards!)
* @param {number} jde - time of observation
* @return {Array}
* {number} H_ - topocentric hour angle
* {number} δ_ - topocentric declination
*/
function topocentric3 (c, ρsφ, ρcφ, lon, jde) {
const [α, δ, Δ] = [c.ra, c.dec, c.range];
const π = horizontal(Δ);
const θ0 = new sexagesimal["default"].Time(sidereal["default"].apparent(jde)).rad();
const H = base["default"].pmod(θ0 - lon - α, 2 * Math.PI);
const sπ = Math.sin(π);
const [sH, cH] = base["default"].sincos(H);
const [sδ, cδ] = base["default"].sincos(δ);
const A = cδ * sH;
const B = cδ * cH - ρcφ * sπ;
const C = sδ - ρsφ * sπ;
const q = Math.sqrt(A * A + B * B + C * C);
const H_ = Math.atan2(A, B);
const δ_ = Math.asin(C / q);
return [H_, δ_]
}
/**
* TopocentricEcliptical returns topocentric ecliptical coordinates including parallax.
*
* Arguments `c` are geocentric ecliptical longitude and latitude of a body,
* s is its geocentric semidiameter. φ, h are the observer's latitude and
* and height above the ellipsoid in meters. ε is the obliquity of the
* ecliptic, θ is local sidereal time, π is equatorial horizontal parallax
* of the body (see Horizonal()).
*
* All angular parameters and results are in radians.
*
* @param {Coord} c - geocentric right ascension and declination in radians
* @param {number} s - geocentric semidiameter of `c`
* @param {number} φ - observer's latitude
* @param {number} h - observer's height above the ellipsoid in meters
* @param {number} ε - is the obliquity of the ecliptic
* @param {number} θ - local sidereal time
* @param {number} π - equatorial horizontal parallax of the body
* @return {Array}
* {number} λ_ - observed topocentric longitude
* {number} β_ - observed topocentric latitude
* {number} s_ - observed topocentric semidiameter
*/
function topocentricEcliptical (c, s, φ, h, ε, θ, π) {
const [λ, β] = [c.lon, c.lat];
const [S, C] = globe["default"].Earth76.parallaxConstants(φ, h);
const [sλ, cλ] = base["default"].sincos(λ);
const [sβ, cβ] = base["default"].sincos(β);
const [sε, cε] = base["default"].sincos(ε);
const [sθ, cθ] = base["default"].sincos(θ);
const sπ = Math.sin(π);
const N = cλ * cβ - C * sπ * cθ;
let λ_ = Math.atan2(sλ * cβ - sπ * (S * sε + C * cε * sθ), N);
if (λ_ < 0) {
λ_ += 2 * Math.PI;
}
const cλ_ = Math.cos(λ_);
const β_ = Math.atan(cλ_ * (sβ - sπ * (S * cε - C * sε * sθ)) / N);
const s_ = Math.asin(cλ_ * Math.cos(β_) * Math.sin(s) / N);
return [λ_, β_, s_]
}
var parallax = {
horizontal,
topocentric,
topocentric2,
topocentric3,
topocentricEcliptical
};
exports["default"] = parallax;
exports.horizontal = horizontal;
exports.topocentric = topocentric;
exports.topocentric2 = topocentric2;
exports.topocentric3 = topocentric3;
exports.topocentricEcliptical = topocentricEcliptical;