]> git.openstreetmap.org Git - nominatim.git/commitdiff
further tweaking of address distance
authorSarah Hoffmann <lonvia@denofr.de>
Fri, 22 Apr 2022 12:32:19 +0000 (14:32 +0200)
committerSarah Hoffmann <lonvia@denofr.de>
Fri, 22 Apr 2022 12:32:19 +0000 (14:32 +0200)
For point features, keep using the distance to centroid.
For area features, add a tie breaker for the case where the
center point falls on the boundary.

lib-sql/functions/partition-functions.sql

index 5eb1aef1e95c535a3160a8252b20c4c1c5c28fb9..e5d356e1e63f5e086f3f476187a23f9e75801770 100644 (file)
@@ -51,7 +51,11 @@ BEGIN
   IF in_partition = {{ partition }} THEN
     FOR r IN
       SELECT place_id, keywords, rank_address, rank_search,
-             min(ST_Distance(feature_centroid, geometry)) as distance,
+             CASE WHEN isguess THEN ST_Distance(feature, centroid)
+                  ELSE min(ST_Distance(feature_centroid, geometry))
+                       -- tie breaker when distance is the same (i.e. way is on boundary)
+                       + 0.00001 * ST_Distance(feature, centroid)
+             END as distance,
              isguess, postcode, centroid
       FROM location_area_large_{{ partition }}
       WHERE geometry && feature