Class: Suntrack
- Inherits:
-
Object
- Object
- Suntrack
- Defined in:
- lib/suntrack.rb
Overview
Main methods for Ruby version of calculations in “Astronomy on the Personal Computer”, by Montenbruck and Pfleger (1991).
Defined Under Namespace
Constant Summary collapse
- @@attributes =
{}
Class Method Summary collapse
-
.method_missing(name, *args) ⇒ Object
allow user to create new star location functions User must define declination and right ascension.
-
.sirius_location(date_time, latitude, longitude) ⇒ Object
Return Sirius location, in altitude(y) and azimuth(z), given DateTime, latitude and longitude.
-
.sun_location(date_time, latitude, longitude) ⇒ Object
Return Sun location, in altitude(y) and azimuth(z), given DateTime, latitude and longitude.
Class Method Details
.method_missing(name, *args) ⇒ Object
allow user to create new star location functions User must define declination and right ascension
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
# File 'lib/suntrack.rb', line 34 def self.method_missing name, *args attribute = name.to_s if attribute =~ /=$/ @@attributes[attribute.chop] = args[0] elsif attribute =~ /location/ @@star = attribute.match(/(\w+)_location/)[1] begin dt = DateTime.now mjd = Suntrack::RAstro.to_mjd(args[0]) tau = 15 * (Suntrack::RAstro.lmst(mjd,args[2]) - @@attributes["#{@@star}_ra"]) z_in = Suntrack::Point3D.new(@@attributes["#{@@star}_declination"],tau,args[1]) z = z_in.equatorial_to_horizon z rescue Exception => ex p "Suntrack ERROR: Please define declination and right ascension for #{@@star}" end end end |
.sirius_location(date_time, latitude, longitude) ⇒ Object
Return Sirius location, in altitude(y) and azimuth(z), given DateTime, latitude and longitude
24 25 26 27 28 29 30 |
# File 'lib/suntrack.rb', line 24 def self.sirius_location(date_time,latitude,longitude) mjd = Suntrack::RAstro.to_mjd(date_time) tau = 15 * (Suntrack::RAstro.lmst(mjd,longitude) - Suntrack::RAstro::SIRIUS_RA) z_in = Suntrack::Point3D.new(Suntrack::RAstro::SIRIUS_DECLINATION,tau,latitude) z = z_in.equatorial_to_horizon z end |
.sun_location(date_time, latitude, longitude) ⇒ Object
Return Sun location, in altitude(y) and azimuth(z), given DateTime, latitude and longitude
10 11 12 13 14 15 16 17 18 19 20 |
# File 'lib/suntrack.rb', line 10 def self.sun_location(date_time,latitude,longitude) mjd = Suntrack::RAstro.to_mjd(date_time) jd = Suntrack::RAstro.jd(mjd) tm = Suntrack::RAstro.get_time(jd) dec = Suntrack::RAstro.sun_position(tm) tau = 15 * (Suntrack::RAstro.lmst(mjd,longitude) - dec.z) z_in = Suntrack::Point3D.new(dec.y,tau,latitude) z = z_in.equatorial_to_horizon z end |