]> git.openstreetmap.org Git - nominatim.git/commitdiff
use different area estimates for large countries
authorSarah Hoffmann <lonvia@denofr.de>
Mon, 2 Nov 2020 10:41:53 +0000 (11:41 +0100)
committerSarah Hoffmann <lonvia@denofr.de>
Mon, 2 Nov 2020 13:21:30 +0000 (14:21 +0100)
sql/functions/placex_triggers.sql
sql/functions/ranking.sql

index 433ceb92e9e21c3b9a9c748066c7d62df39f9461..6848140ad44e249fcacf41eb6768abfbb9b347c8 100644 (file)
@@ -909,7 +909,7 @@ BEGIN
   END IF;
 
   IF NEW.rank_address = 0 THEN
   END IF;
 
   IF NEW.rank_address = 0 THEN
-    max_rank := geometry_to_rank(NEW.rank_search, NEW.geometry);
+    max_rank := geometry_to_rank(NEW.rank_search, NEW.geometry, NEW.country_code);
   ELSEIF NEW.rank_address > 25 THEN
     max_rank := 25;
   ELSE
   ELSEIF NEW.rank_address > 25 THEN
     max_rank := 25;
   ELSE
index e918f924d9e0771537c01ac9baaf0520d88409d7..a84269fe6730669b6c805a0bb632b645c87f1199 100644 (file)
@@ -60,7 +60,7 @@ LANGUAGE plpgsql IMMUTABLE;
 -- This is all simple guess work. We don't need particularly good estimates
 -- here. This just avoids to have very high ranked address parts in features
 -- that span very large areas (or vice versa).
 -- This is all simple guess work. We don't need particularly good estimates
 -- here. This just avoids to have very high ranked address parts in features
 -- that span very large areas (or vice versa).
-CREATE OR REPLACE FUNCTION geometry_to_rank(search_rank SMALLINT, geometry GEOMETRY)
+CREATE OR REPLACE FUNCTION geometry_to_rank(search_rank SMALLINT, geometry GEOMETRY, country_code TEXT)
   RETURNS SMALLINT
   AS $$
 DECLARE
   RETURNS SMALLINT
   AS $$
 DECLARE
@@ -74,6 +74,15 @@ BEGIN
     RETURN search_rank;
   END IF;
 
     RETURN search_rank;
   END IF;
 
+  -- adjust for the fact that countries come in different sizes
+  IF country_code IN ('ca', 'au', 'ru') THEN
+    area := area / 5;
+  ELSIF country_code IN ('br', 'kz', 'cn', 'us', 'ne', 'gb', 'za', 'sa', 'id', 'eh', 'ml', 'tm') THEN
+    area := area / 3;
+  ELSIF country_code IN ('bo', 'ar', 'sd', 'mn', 'in', 'et', 'cd', 'mz', 'ly', 'cl', 'zm') THEN
+    area := area / 2;
+  END IF;
+
   IF area > 1 THEN
     RETURN 7;
   ELSIF area > 0.1 THEN
   IF area > 1 THEN
     RETURN 7;
   ELSIF area > 0.1 THEN