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 |