Class: Astronoby::Aberration
- Inherits:
-
Object
- Object
- Astronoby::Aberration
- Defined in:
- lib/astronoby/aberration.rb
Constant Summary collapse
- MAXIMUM_SHIFT =
Angle.from_degrees(20.5)
Class Method Summary collapse
Instance Method Summary collapse
-
#apply ⇒ Object
Source: Title: Practical Astronomy with your Calculator or Spreadsheet Authors: Peter Duffett-Smith and Jonathan Zwart Edition: Cambridge University Press Chapter: 36 - Aberration.
-
#initialize(coordinates, epoch) ⇒ Aberration
constructor
A new instance of Aberration.
- #sun_longitude ⇒ Object
Constructor Details
#initialize(coordinates, epoch) ⇒ Aberration
Returns a new instance of Aberration.
11 12 13 14 |
# File 'lib/astronoby/aberration.rb', line 11 def initialize(coordinates, epoch) @coordinates = coordinates @epoch = epoch end |
Class Method Details
.for_ecliptic_coordinates(coordinates:, epoch:) ⇒ Object
7 8 9 |
# File 'lib/astronoby/aberration.rb', line 7 def self.for_ecliptic_coordinates(coordinates:, epoch:) new(coordinates, epoch).apply end |
Instance Method Details
#apply ⇒ Object
Source:
Title: Practical Astronomy with your Calculator or Spreadsheet
Authors: Peter Duffett-Smith and Jonathan Zwart
Edition: Cambridge University Press
Chapter: 36 - Aberration
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
# File 'lib/astronoby/aberration.rb', line 21 def apply delta_longitude = Angle.from_degrees( -MAXIMUM_SHIFT.degrees * ( sun_longitude - @coordinates.longitude ).cos / @coordinates.latitude.cos / Constants::SECONDS_PER_DEGREE ) delta_latitude = Angle.from_degrees( -MAXIMUM_SHIFT.degrees * (sun_longitude - @coordinates.longitude).sin * @coordinates.latitude.sin / Constants::SECONDS_PER_DEGREE ) Coordinates::Ecliptic.new( latitude: @coordinates.latitude + delta_latitude, longitude: @coordinates.longitude + delta_longitude ) end |