Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

compute geo distance in elasticsearch

i am using a geo_distance filter with tire in my query and it works fine:

search.filter :geo_distance, :distance => "#{request.distance}km", :location => "#{request.lat},#{request.lng}"

i expected that the result would somehow include the computed distance to the geo-location that i used for my filter.

is there a way to tell elasticsearch to include that in the response, so that i don't have to calculate it in ruby for every result?

== UPDATE ==

i found the answer in a google group:

search.sort do
  by "_geo_distance", "location" => "#{request.lat},#{request.lng}", "unit" => "km" if request.with_location?
end

sorting by the _geo_distance will yield the distance in the raw results.

like image 655
phoet Avatar asked Feb 15 '12 08:02

phoet


2 Answers

Sorting by _geo_distance will return the distance in the results: http://www.elasticsearch.org/guide/reference/api/search/sort.html

like image 139
gjb Avatar answered Nov 16 '22 19:11

gjb


For those that may be wondering, the distance is returned in the sort property of the elastic search results. In order to access it and display it in the view, use the each_with_hit method. For instance:

class Venue
    attr_accessor :distance
end

def index
    @search = Venue.search(params)
    @search.each_with_hit do |result, hit|
        result.distance = hit['sort'][0] # distance from the ES results
    end
    render json: @search.results
end

"each_with_hit" modifies the resulting object and renders the proper json. So far for this to work, you must set load to true when searching:

:load => true
like image 1
chourobin Avatar answered Nov 16 '22 21:11

chourobin