Forums / Extensions / eZ Find / Geographical search

Geographical search

Author Message

Fredrik Ardmar

Saturday 21 February 2009 9:08:21 am

Hi

We have been doing a custom google maps site for a larger Scandinavian client.
We are currently using eZ FInd for standard search functions but our client has now requested geographical search functions such as proximity searches etc..

As an example: Show me all petrol stations within 25 km from the following lat/long.
Then rate the results based on the closest geographical match.

I have been looking into the local solr and it looks like it can provide the needed functions.

Anyone has experience with geographical searches and eZ Find?

Fredrik

http://www.areadigital.org

Custom google maps with eZ Publish

http://www.meresverige.dk
http://dsbfirst.meresverige.dk

Andreas Kaiser

Tuesday 24 February 2009 3:57:44 am

I have no experience with such a situation, but if I'm not wrong in partner day ez system said that ez find 2 could handle such situations...

eZ Partner in Madrid (Spain)
Web: http://www.atela.net/

Fredrik Ardmar

Friday 06 March 2009 1:50:14 am

Hi

Unfortunately I was not there then.
You would not have access to a presentation or document that mentions this?

Fredrik

http://www.areadigital.org

Custom google maps with eZ Publish

http://www.meresverige.dk
http://dsbfirst.meresverige.dk

Andreas Kaiser

Monday 09 March 2009 5:33:41 am

I'm sorry, but there is no presentation about this feature (the ezfind presentation was about indexing external data.)

But a partner asked if it would be possible to do such a geographical search and the answer was yes.

I've been looking the ezfind documentation and perhaps this example (page 16) can help you:

Example:
fetch( ezfind, search, hash( query, 'eZ Systems', filter,
array( 'or', array( 'and', 'article/body:hello','article/rating:[1 TO 10]' ),
array( 'and', 'article/body:goodbye', 'article/rating:[10 TO 20]' ) ) )
Returns:
Result with articles containing the words “ez” and “systems”, either having both 'hello' present in the body and a rating comprized between 1 and 10, either both 'goodbye' in the body and a rating comprized between 10 and 20.

Using this kind of range filter could do the job...

eZ Partner in Madrid (Spain)
Web: http://www.atela.net/

anne martinet

Monday 06 April 2009 12:31:51 am

Hi,

I see these sites :
http://www.meresverige.dk/
http://dsbfirst.meresverige.dk/

And it interest me to use geographical searches (Google Maps) and eZ Find 2.0.0....!
But I don't know how...
Are you found out?

Thanks,

Norman Leutner

Monday 06 April 2009 7:42:44 am

Hi Anne, Fredrik,

I implemented a range search within the GIS operators,
its based on latitude and longitude.

It's a template operator which provides the needed functions.
http://svn.projects.ez.no/gisoperators/

We use the google geocoder to get the lat and long.

The range search is done with a more or less complex SQL statement based on the GRS80-Ellipsoid Modell ( http://en.wikipedia.org/wiki/GRS80 ) which is also the standard for GPS systems:

$query=SELECT street, zip, city, state, country, ".$radius."*ACOS(cos(RADIANS(latitude))*cos(".$theta.")*(sin(RADIANS(longitude))*sin(".$phi.")+cos(RADIANS(longitude))*cos(".$phi."))+sin(RADIANS(latitude))*sin(".$theta.")) AS Distance FROM ezgis_position WHERE ".$radius."*ACOS(cos(RADIANS(latitude))*cos(".$theta.")*(sin(RADIANS(longitude))*sin(".$phi.")+cos(RADIANS(longitude))*cos(".$phi."))+sin(RADIANS(latitude))*sin(".$theta.")) <= ".$range." ORDER BY Distance";

In fact working with the GRS80 modell is very fast and accurate compared to other even when using large databases.

The whole work is done directly within the MySQL Database with a single fast query.

So if you have the geodata available this should be easy...

Mit freundlichen Grüßen
Best regards

Norman Leutner

____________________________________________________________
eZ Publish Platinum Partner - http://www.all2e.com
http://ez.no/partners/worldwide_partners/all2e_gmbh

anne martinet

Tuesday 05 May 2009 7:22:20 am

Thanks Normann for your operator.

For the moment I explore the solution to use eZ Find 2.0.0 with the extension googlemaps : http://projects.ez.no/googlemaps.

I indexed with ez Find more camping and I do:

{def 	$environ=fetch(ezfind, search, 
                       hash(query,'',
                            filter,array(
                              'geolocalisation_temp/latitude:[40 TO 45]'
)))}

When attribute is a float the search doesn't work! Why?
When attribute is a text_line the search work but the result isn't relevant.

Any idea?

Norman Leutner

Monday 11 May 2009 11:17:22 pm

Hi anne,

due to a longitude can something between 111km (equator) or 1km (north pole) this is not a good general solution...

We're in need of getting this also working with eZ Find within the next weeks,
so I'll have a closer look into the solr raw query documenation to see if solr is able to handle the formula also.

Mit freundlichen Grüßen
Best regards

Norman Leutner

____________________________________________________________
eZ Publish Platinum Partner - http://www.all2e.com
http://ez.no/partners/worldwide_partners/all2e_gmbh

Nicolas Pastorino

Tuesday 12 May 2009 2:35:40 am

Hi !

eZ Find 2.0 supports range searches on attributes, as Andreas pointed out. Plus, storing the coordinates of a place is possible, either using the http://projects.ez.no/googlemaps extension ( and probably extending it to have the correct subattributes structures in Solr's index ), or, simpler approach, using 2 ezfloat attributes.
The very issue here is that float attributes are not indexable ( issue coming from the datatype itself, self-described as not indexable ). This is something we are planning on circumventing in eZ Find 2.1. This would allow the coordinates to be pushed in Solr.

You will then need a nice black box, taking as input the search distance ( 2 km ), the original coordinates ( 45, 77 ), and the search-surface type : square, circle, and outputting, for instance, the boundaries of the search surface, as coordinates ( this is a simplisitic assumption, i am sure that the ones who already tackled the subject can give some valuable input on this ). You can then use the built-in ezfind/search fetch function, or directly the PHP API, indifferently, to gather all restaurants located within 2km walking distance around your current geographical location.

This would take the following form :

fetch( 'ezfind', 'search', 
          hash( 'query', '', 
                'filter',
                         array(  'and', 
                                'restaurant/latitude:[44 TO 46]',
                                'restaurant/longitude:[76 TO 78]', 
                               ) 
               )

Any input on this ?
Cheers,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

Norman Leutner

Tuesday 12 May 2009 3:34:35 am

Hi Nicolas,

as far as i understood you're trying search for latitude and longitude whithin a given lat and long range (rectangle).

Due tue the surface distance on 0° latitude is 111.320 km per 1° longitude,
on 90° latitude it is 0 km per 1° longitude.
Due to the used rectangle does not include any sphere information,
this would be very inaccurate.

Here's what I want to achieve:

Let's say where're in a helicoter with our Iphone and need to know the next gas station within 30km. We browse to our site http://www.helikopter-tankstellen.de, enter our lat on long (or address) and submit the form.

The result displays the list on gas stations available within 30km with the actual distance sorted by distance.

I've build this before within a single MySQL Query (shown above) so the only question from my side is if we can use mathematical functions like radians, sin, cos, acos in some way within a solr raw query and build a new attribute 'actual_distance' for the serach result.

Mit freundlichen Grüßen
Best regards

Norman Leutner

____________________________________________________________
eZ Publish Platinum Partner - http://www.all2e.com
http://ez.no/partners/worldwide_partners/all2e_gmbh

Norman Leutner

Tuesday 12 May 2009 5:17:25 am

Grant Ingersoll from Solr is currently working on spatial search:

https://issues.apache.org/jira/browse/SOLR-773

Mit freundlichen Grüßen
Best regards

Norman Leutner

____________________________________________________________
eZ Publish Platinum Partner - http://www.all2e.com
http://ez.no/partners/worldwide_partners/all2e_gmbh

Nicolas Pastorino

Tuesday 12 May 2009 11:41:07 pm

Hi,

Thanks for the Solr issue link. I had seen this pass by on the Solr mailing list yesterday.
We'll closely follow up on this. Here is the enhancement request :
http://issues.ez.no/IssueView.php?Id=14901&ProjectId=8. You may want to add input to it.

Best Regards,

--
Nicolas Pastorino
Director Community - eZ
Member of the Community Project Board

eZ Publish Community on twitter: http://twitter.com/ezcommunity

t : http://twitter.com/jeanvoye
G+ : http://plus.tl/jeanvoye

eZ debug

Timing: Jan 18 2025 02:06:18
Script start
Timing: Jan 18 2025 02:06:18
Module start 'content'
Timing: Jan 18 2025 02:06:18
Module end 'content'
Timing: Jan 18 2025 02:06:18
Script end

Main resources:

Total runtime0.1487 sec
Peak memory usage4,096.0000 KB
Database Queries141

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0087 587.7344180.7891
Module start 'content' 0.00870.0056 768.5234119.0547
Module end 'content' 0.01430.1344 887.5781548.2969
Script end 0.1487  1,435.8750 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00362.4221200.0002
Check MTime0.00140.9582200.0001
Mysql Total
Database connection0.00090.600510.0009
Mysqli_queries0.105370.79291410.0007
Looping result0.00120.78101390.0000
Template Total0.134090.110.1340
Template load0.00090.638010.0009
Template processing0.133089.446310.1330
Override
Cache load0.00060.409410.0006
Sytem overhead
Fetch class attribute can translate value0.00070.447710.0007
XML
Image XML parsing0.00030.177510.0003
General
dbfile0.00332.1876200.0002
String conversion0.00000.004630.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs