Sha256: 75d2c31ee8a10b71a6cba62c63c872bfaa594785e1970c08b52f67dcf71e741b

Contents?: true

Size: 1.71 KB

Versions: 15

Compression:

Stored size: 1.71 KB

Contents

module Graticule
  module Distance

    #
    # The Spherical Law of Cosines is the simplist though least accurate distance
    # formula (earth isn't a perfect sphere).
    #
    class Spherical < DistanceFormula

      # Calculate the distance between two Locations using the Spherical formula
      #
      #   Graticule::Distance::Spherical.distance(
      #     Graticule::Location.new(:latitude => 42.7654, :longitude => -86.1085),
      #     Graticule::Location.new(:latitude => 41.849838, :longitude => -87.648193)
      #   )
      #   #=> 101.061720831853
      #
      def self.distance(from, to, units = :miles)
        from_longitude  = from.longitude.to_radians
        from_latitude   = from.latitude.to_radians
        to_longitude    = to.longitude.to_radians
        to_latitude     = to.latitude.to_radians

        Math.acos(
            Math.sin(from_latitude) *
            Math.sin(to_latitude) +

            Math.cos(from_latitude) * 
            Math.cos(to_latitude) *
            Math.cos(to_longitude - from_longitude)
        ) * EARTH_RADIUS[units.to_sym]
      end

      def self.to_sql(options)
        options = {
          :units => :miles,
          :latitude_column => 'latitude',
          :longitude_column => 'longitude'
        }.merge(options)
        %{(ACOS(
            SIN(RADIANS(#{options[:latitude]})) *
            SIN(RADIANS(#{options[:latitude_column]})) +
            COS(RADIANS(#{options[:latitude]})) *
            COS(RADIANS(#{options[:latitude_column]})) *
            COS(RADIANS(#{options[:longitude_column]}) - RADIANS(#{options[:longitude]}))
          ) * #{Graticule::Distance::EARTH_RADIUS[options[:units].to_sym]})
        }.gsub("\n", '').squeeze(" ")
      end
  
    end
  end
end

Version data entries

15 entries across 15 versions & 5 rubygems

Version Path
CodeMonkeySteve-graticule-0.2.11 lib/graticule/distance/spherical.rb
CodeMonkeySteve-graticule-0.2.12 lib/graticule/distance/spherical.rb
aub-graticule-0.2.11 lib/graticule/distance/spherical.rb
collectiveidea-graticule-0.2.12 lib/graticule/distance/spherical.rb
pepe-graticule-0.2.11 lib/graticule/distance/spherical.rb
aub-graticule-0.3.2 lib/graticule/distance/spherical.rb
graticule-2.0.1 lib/graticule/distance/spherical.rb
graticule-2.0.0 lib/graticule/distance/spherical.rb
aub-graticule-0.3.1 lib/graticule/distance/spherical.rb
aub-graticule-0.3.0 lib/graticule/distance/spherical.rb
graticule-1.0.0.pre2 lib/graticule/distance/spherical.rb
graticule-1.0.0.pre lib/graticule/distance/spherical.rb
graticule-0.2.12 lib/graticule/distance/spherical.rb
graticule-0.2.10 lib/graticule/distance/spherical.rb
graticule-0.2.9 lib/graticule/distance/spherical.rb