mirror of
https://github.com/osm-search/Nominatim.git
synced 2026-03-06 18:14:16 +00:00
Merge branch 'tigerlines' of https://github.com/markigail/Nominatim
This commit is contained in:
161
lib/Geocode.php
161
lib/Geocode.php
@@ -358,7 +358,7 @@
|
|||||||
$this->loadStructuredAddressElement($sPostalCode, 'postalcode' , 5, 11, array(5, 11));
|
$this->loadStructuredAddressElement($sPostalCode, 'postalcode' , 5, 11, array(5, 11));
|
||||||
$this->loadStructuredAddressElement($sCountry, 'country', 4, 4, false);
|
$this->loadStructuredAddressElement($sCountry, 'country', 4, 4, false);
|
||||||
|
|
||||||
if (sizeof($this->aStructuredQuery) > 0)
|
if (sizeof($this->aStructuredQuery) > 0)
|
||||||
{
|
{
|
||||||
$this->sQuery = join(', ', $this->aStructuredQuery);
|
$this->sQuery = join(', ', $this->aStructuredQuery);
|
||||||
if ($this->iMaxAddressRank < 30)
|
if ($this->iMaxAddressRank < 30)
|
||||||
@@ -393,19 +393,20 @@
|
|||||||
|
|
||||||
function getDetails($aPlaceIDs)
|
function getDetails($aPlaceIDs)
|
||||||
{
|
{
|
||||||
|
//$aPlaceIDs is an array with key: placeID and value: tiger-housenumber, if found, else -1
|
||||||
if (sizeof($aPlaceIDs) == 0) return array();
|
if (sizeof($aPlaceIDs) == 0) return array();
|
||||||
|
|
||||||
$sLanguagePrefArraySQL = "ARRAY[".join(',',array_map("getDBQuoted",$this->aLangPrefOrder))."]";
|
$sLanguagePrefArraySQL = "ARRAY[".join(',',array_map("getDBQuoted",$this->aLangPrefOrder))."]";
|
||||||
|
|
||||||
// Get the details for display (is this a redundant extra step?)
|
// Get the details for display (is this a redundant extra step?)
|
||||||
$sPlaceIDs = join(',',$aPlaceIDs);
|
$sPlaceIDs = join(',', array_keys($aPlaceIDs));
|
||||||
|
|
||||||
$sImportanceSQL = '';
|
$sImportanceSQL = '';
|
||||||
if ($this->sViewboxSmallSQL) $sImportanceSQL .= " case when ST_Contains($this->sViewboxSmallSQL, ST_Collect(centroid)) THEN 1 ELSE 0.75 END * ";
|
if ($this->sViewboxSmallSQL) $sImportanceSQL .= " case when ST_Contains($this->sViewboxSmallSQL, ST_Collect(centroid)) THEN 1 ELSE 0.75 END * ";
|
||||||
if ($this->sViewboxLargeSQL) $sImportanceSQL .= " case when ST_Contains($this->sViewboxLargeSQL, ST_Collect(centroid)) THEN 1 ELSE 0.75 END * ";
|
if ($this->sViewboxLargeSQL) $sImportanceSQL .= " case when ST_Contains($this->sViewboxLargeSQL, ST_Collect(centroid)) THEN 1 ELSE 0.75 END * ";
|
||||||
|
|
||||||
$sSQL = "select osm_type,osm_id,class,type,admin_level,rank_search,rank_address,min(place_id) as place_id, min(parent_place_id) as parent_place_id, calculated_country_code as country_code,";
|
$sSQL = "select osm_type,osm_id,class,type,admin_level,rank_search,rank_address,min(place_id) as place_id, min(parent_place_id) as parent_place_id, calculated_country_code as country_code,";
|
||||||
$sSQL .= "get_address_by_language(place_id, $sLanguagePrefArraySQL) as langaddress,";
|
$sSQL .= "get_address_by_language(place_id, -1, $sLanguagePrefArraySQL) as langaddress,";
|
||||||
$sSQL .= "get_name_by_language(name, $sLanguagePrefArraySQL) as placename,";
|
$sSQL .= "get_name_by_language(name, $sLanguagePrefArraySQL) as placename,";
|
||||||
$sSQL .= "get_name_by_language(name, ARRAY['ref']) as ref,";
|
$sSQL .= "get_name_by_language(name, ARRAY['ref']) as ref,";
|
||||||
if ($this->bIncludeExtraTags) $sSQL .= "hstore_to_json(extratags)::text as extra,";
|
if ($this->bIncludeExtraTags) $sSQL .= "hstore_to_json(extratags)::text as extra,";
|
||||||
@@ -432,37 +433,56 @@
|
|||||||
|
|
||||||
if (30 >= $this->iMinAddressRank && 30 <= $this->iMaxAddressRank)
|
if (30 >= $this->iMinAddressRank && 30 <= $this->iMaxAddressRank)
|
||||||
{
|
{
|
||||||
|
//query also location_property_tiger and location_property_aux
|
||||||
|
//Tiger search only if a housenumber was searched and if it was found (i.e. aPlaceIDs[placeID] = housenumber != -1) (realized through a join)
|
||||||
|
//only Tiger housenumbers need to be interpolated, because they are saved as lines with start- and endnumber, the common osm housenumbers are usually saved as points
|
||||||
|
$sHousenumbers = "";
|
||||||
|
$i = 0;
|
||||||
|
$length = count($aPlaceIDs);
|
||||||
|
foreach($aPlaceIDs as $placeID => $housenumber)
|
||||||
|
{
|
||||||
|
$i++;
|
||||||
|
$sHousenumbers .= "(".$placeID.", ".$housenumber.")";
|
||||||
|
if($i<$length)
|
||||||
|
$sHousenumbers .= ", ";
|
||||||
|
}
|
||||||
|
|
||||||
|
$sSQL .= "union ";
|
||||||
|
$sSQL .= "select 'T' as osm_type, place_id as osm_id, 'place' as class, 'house' as type, null as admin_level, 30 as rank_search, 30 as rank_address, min(place_id) as place_id, min(parent_place_id) as parent_place_id, 'us' as country_code";
|
||||||
|
$sSQL .= ", get_address_by_language(place_id, housenumber_for_place, $sLanguagePrefArraySQL) as langaddress ";
|
||||||
|
$sSQL .= ", null as placename";
|
||||||
|
$sSQL .= ", null as ref";
|
||||||
|
if ($this->bIncludeExtraTags) $sSQL .= ", null as extra";
|
||||||
|
if ($this->bIncludeNameDetails) $sSQL .= ", null as names";
|
||||||
|
$sSQL .= ", avg(st_x(point)) as lon, avg(st_y(point)) as lat";
|
||||||
|
$sSQL .= $sImportanceSQL.", -1.15 as importance ";
|
||||||
|
$sSQL .= ", (select max(p.importance*(p.rank_address+2)) from place_addressline s, placex p where s.place_id = min(blub.parent_place_id) and p.place_id = s.address_place_id and s.isaddress and p.importance is not null) as addressimportance ";
|
||||||
|
$sSQL .= ", null as extra_place ";
|
||||||
|
$sSQL .= " from (select place_id";
|
||||||
|
//interpolate the Tiger housenumbers here
|
||||||
|
$sSQL .= ", ST_LineInterpolatePoint(linegeo, (housenumber_for_place-startnumber::float)/(endnumber-startnumber)::float) as point, parent_place_id, housenumber_for_place ";
|
||||||
|
$sSQL .= "from (location_property_tiger ";
|
||||||
|
$sSQL .= " join (values ".$sHousenumbers.") as housenumbers(place_id, housenumber_for_place) using(place_id)) ";
|
||||||
|
$sSQL .= " where housenumber_for_place>=0 and 30 between $this->iMinAddressRank and $this->iMaxAddressRank) as blub"; //postgres wants an alias here
|
||||||
|
$sSQL .= " group by place_id, housenumber_for_place"; //is this group by really needed?, place_id + housenumber (in combination) are unique
|
||||||
|
if (!$this->bDeDupe) $sSQL .= ", place_id ";
|
||||||
|
|
||||||
$sSQL .= " union ";
|
$sSQL .= " union ";
|
||||||
$sSQL .= "select 'T' as osm_type,place_id as osm_id,'place' as class,'house' as type,null as admin_level,30 as rank_search,30 as rank_address,min(place_id) as place_id, min(parent_place_id) as parent_place_id,'us' as country_code,";
|
$sSQL .= "select 'L' as osm_type, place_id as osm_id, 'place' as class, 'house' as type, null as admin_level, 0 as rank_search, 0 as rank_address, min(place_id) as place_id, min(parent_place_id) as parent_place_id, 'us' as country_code, ";
|
||||||
$sSQL .= "get_address_by_language(place_id, $sLanguagePrefArraySQL) as langaddress,";
|
$sSQL .= "get_address_by_language(place_id, -1, $sLanguagePrefArraySQL) as langaddress, ";
|
||||||
$sSQL .= "null as placename,";
|
$sSQL .= "null as placename, ";
|
||||||
$sSQL .= "null as ref,";
|
$sSQL .= "null as ref, ";
|
||||||
if ($this->bIncludeExtraTags) $sSQL .= "null as extra,";
|
if ($this->bIncludeExtraTags) $sSQL .= "null as extra, ";
|
||||||
if ($this->bIncludeNameDetails) $sSQL .= "null as names,";
|
if ($this->bIncludeNameDetails) $sSQL .= "null as names, ";
|
||||||
$sSQL .= "avg(ST_X(centroid)) as lon,avg(ST_Y(centroid)) as lat, ";
|
$sSQL .= "avg(ST_X(centroid)) as lon, avg(ST_Y(centroid)) as lat, ";
|
||||||
$sSQL .= $sImportanceSQL."-1.15 as importance, ";
|
|
||||||
$sSQL .= "(select max(p.importance*(p.rank_address+2)) from place_addressline s, placex p where s.place_id = min(location_property_tiger.parent_place_id) and p.place_id = s.address_place_id and s.isaddress and p.importance is not null) as addressimportance, ";
|
|
||||||
$sSQL .= "null as extra_place ";
|
|
||||||
$sSQL .= "from location_property_tiger where place_id in ($sPlaceIDs) ";
|
|
||||||
$sSQL .= "and 30 between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
|
||||||
$sSQL .= "group by place_id";
|
|
||||||
if (!$this->bDeDupe) $sSQL .= ",place_id ";
|
|
||||||
$sSQL .= " union ";
|
|
||||||
$sSQL .= "select 'L' as osm_type,place_id as osm_id,'place' as class,'house' as type,null as admin_level,30 as rank_search,30 as rank_address,min(place_id) as place_id, min(parent_place_id) as parent_place_id,'us' as country_code,";
|
|
||||||
$sSQL .= "get_address_by_language(place_id, $sLanguagePrefArraySQL) as langaddress,";
|
|
||||||
$sSQL .= "null as placename,";
|
|
||||||
$sSQL .= "null as ref,";
|
|
||||||
if ($this->bIncludeExtraTags) $sSQL .= "null as extra,";
|
|
||||||
if ($this->bIncludeNameDetails) $sSQL .= "null as names,";
|
|
||||||
$sSQL .= "avg(ST_X(centroid)) as lon,avg(ST_Y(centroid)) as lat, ";
|
|
||||||
$sSQL .= $sImportanceSQL."-1.10 as importance, ";
|
$sSQL .= $sImportanceSQL."-1.10 as importance, ";
|
||||||
$sSQL .= "(select max(p.importance*(p.rank_address+2)) from place_addressline s, placex p where s.place_id = min(location_property_aux.parent_place_id) and p.place_id = s.address_place_id and s.isaddress and p.importance is not null) as addressimportance, ";
|
$sSQL .= "(select max(p.importance*(p.rank_address+2)) from place_addressline s, placex p where s.place_id = min(location_property_aux.parent_place_id) and p.place_id = s.address_place_id and s.isaddress and p.importance is not null) as addressimportance, ";
|
||||||
$sSQL .= "null as extra_place ";
|
$sSQL .= "null as extra_place ";
|
||||||
$sSQL .= "from location_property_aux where place_id in ($sPlaceIDs) ";
|
$sSQL .= "from location_property_aux where place_id in ($sPlaceIDs) ";
|
||||||
$sSQL .= "and 30 between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
$sSQL .= "and 30 between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
||||||
$sSQL .= "group by place_id";
|
$sSQL .= "group by place_id";
|
||||||
if (!$this->bDeDupe) $sSQL .= ",place_id";
|
if (!$this->bDeDupe) $sSQL .= ", place_id";
|
||||||
$sSQL .= ",get_address_by_language(place_id, $sLanguagePrefArraySQL) ";
|
$sSQL .= ", get_address_by_language(place_id, -1, $sLanguagePrefArraySQL) ";
|
||||||
}
|
}
|
||||||
|
|
||||||
$sSQL .= " order by importance desc";
|
$sSQL .= " order by importance desc";
|
||||||
@@ -780,7 +800,7 @@
|
|||||||
addressimportance: cumulated importance of address elements
|
addressimportance: cumulated importance of address elements
|
||||||
extra_place: type of place (for admin boundaries, if there is a place tag)
|
extra_place: type of place (for admin boundaries, if there is a place tag)
|
||||||
aBoundingBox: bounding Box
|
aBoundingBox: bounding Box
|
||||||
label: short description of the object class/type (English only)
|
label: short description of the object class/type (English only)
|
||||||
name: full name (currently the same as langaddress)
|
name: full name (currently the same as langaddress)
|
||||||
foundorder: secondary ordering for places with same importance
|
foundorder: secondary ordering for places with same importance
|
||||||
*/
|
*/
|
||||||
@@ -854,9 +874,10 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Do we have anything that looks like a lat/lon pair?
|
// Do we have anything that looks like a lat/lon pair?
|
||||||
if ( $aLooksLike = looksLikeLatLonPair($sQuery) ){
|
if ( $aLooksLike = looksLikeLatLonPair($sQuery) )
|
||||||
|
{
|
||||||
$this->setNearPoint(array($aLooksLike['lat'], $aLooksLike['lon']));
|
$this->setNearPoint(array($aLooksLike['lat'], $aLooksLike['lon']));
|
||||||
$sQuery = $aLooksLike['query'];
|
$sQuery = $aLooksLike['query'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$aSearchResults = array();
|
$aSearchResults = array();
|
||||||
@@ -864,21 +885,21 @@
|
|||||||
{
|
{
|
||||||
// Start with a blank search
|
// Start with a blank search
|
||||||
$aSearches = array(
|
$aSearches = array(
|
||||||
array('iSearchRank' => 0,
|
array('iSearchRank' => 0,
|
||||||
'iNamePhrase' => -1,
|
'iNamePhrase' => -1,
|
||||||
'sCountryCode' => false,
|
'sCountryCode' => false,
|
||||||
'aName' => array(),
|
'aName' => array(),
|
||||||
'aAddress' => array(),
|
'aAddress' => array(),
|
||||||
'aFullNameAddress' => array(),
|
'aFullNameAddress' => array(),
|
||||||
'aNameNonSearch' => array(),
|
'aNameNonSearch' => array(),
|
||||||
'aAddressNonSearch' => array(),
|
'aAddressNonSearch' => array(),
|
||||||
'sOperator' => '',
|
'sOperator' => '',
|
||||||
'aFeatureName' => array(),
|
'aFeatureName' => array(),
|
||||||
'sClass' => '',
|
'sClass' => '',
|
||||||
'sType' => '',
|
'sType' => '',
|
||||||
'sHouseNumber' => '',
|
'sHouseNumber' => '',
|
||||||
'fLat' => '',
|
'fLat' => '',
|
||||||
'fLon' => '',
|
'fLon' => '',
|
||||||
'fRadius' => ''
|
'fRadius' => ''
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
@@ -1079,6 +1100,7 @@
|
|||||||
// TODO: suggestions
|
// TODO: suggestions
|
||||||
|
|
||||||
// Start the search process
|
// Start the search process
|
||||||
|
// array with: placeid => -1 | tiger-housenumber
|
||||||
$aResultPlaceIDs = array();
|
$aResultPlaceIDs = array();
|
||||||
|
|
||||||
$aGroupedSearches = $this->getGroupedSearches($aSearches, $aPhraseTypes, $aPhrases, $aValidTokens, $aWordFrequencyScores, $bStructuredPhrases);
|
$aGroupedSearches = $this->getGroupedSearches($aSearches, $aPhraseTypes, $aPhrases, $aValidTokens, $aWordFrequencyScores, $bStructuredPhrases);
|
||||||
@@ -1196,6 +1218,7 @@
|
|||||||
foreach($aSearches as $aSearch)
|
foreach($aSearches as $aSearch)
|
||||||
{
|
{
|
||||||
$iQueryLoop++;
|
$iQueryLoop++;
|
||||||
|
$searchedHousenumber = -1;
|
||||||
|
|
||||||
if (CONST_Debug) { echo "<hr><b>Search Loop, group $iGroupLoop, loop $iQueryLoop</b>"; }
|
if (CONST_Debug) { echo "<hr><b>Search Loop, group $iGroupLoop, loop $iQueryLoop</b>"; }
|
||||||
if (CONST_Debug) _debugDumpGroupedSearches(array($iGroupedRank => array($aSearch)), $aValidTokens);
|
if (CONST_Debug) _debugDumpGroupedSearches(array($iGroupedRank => array($aSearch)), $aValidTokens);
|
||||||
@@ -1392,6 +1415,7 @@
|
|||||||
//var_Dump($aPlaceIDs);
|
//var_Dump($aPlaceIDs);
|
||||||
//exit;
|
//exit;
|
||||||
|
|
||||||
|
//now search for housenumber, if housenumber provided
|
||||||
if ($aSearch['sHouseNumber'] && sizeof($aPlaceIDs))
|
if ($aSearch['sHouseNumber'] && sizeof($aPlaceIDs))
|
||||||
{
|
{
|
||||||
$aRoadPlaceIDs = $aPlaceIDs;
|
$aRoadPlaceIDs = $aPlaceIDs;
|
||||||
@@ -1408,7 +1432,7 @@
|
|||||||
if (CONST_Debug) var_dump($sSQL);
|
if (CONST_Debug) var_dump($sSQL);
|
||||||
$aPlaceIDs = $this->oDB->getCol($sSQL);
|
$aPlaceIDs = $this->oDB->getCol($sSQL);
|
||||||
|
|
||||||
// If not try the aux fallback table
|
// If nothing found try the aux fallback table
|
||||||
if (!sizeof($aPlaceIDs))
|
if (!sizeof($aPlaceIDs))
|
||||||
{
|
{
|
||||||
$sSQL = "select place_id from location_property_aux where parent_place_id in (".$sPlaceIDs.") and housenumber = '".pg_escape_string($aSearch['sHouseNumber'])."'";
|
$sSQL = "select place_id from location_property_aux where parent_place_id in (".$sPlaceIDs.") and housenumber = '".pg_escape_string($aSearch['sHouseNumber'])."'";
|
||||||
@@ -1420,30 +1444,43 @@
|
|||||||
if (CONST_Debug) var_dump($sSQL);
|
if (CONST_Debug) var_dump($sSQL);
|
||||||
$aPlaceIDs = $this->oDB->getCol($sSQL);
|
$aPlaceIDs = $this->oDB->getCol($sSQL);
|
||||||
}
|
}
|
||||||
|
//if nothing was found in placex or location_property_aux, then search in Tiger data for this housenumber(location_property_tiger)
|
||||||
|
$searchedHousenumber = intval($aSearch['sHouseNumber']);
|
||||||
if (!sizeof($aPlaceIDs))
|
if (!sizeof($aPlaceIDs))
|
||||||
{
|
{
|
||||||
$sSQL = "select place_id from location_property_tiger where parent_place_id in (".$sPlaceIDs.") and housenumber = '".pg_escape_string($aSearch['sHouseNumber'])."'";
|
//new query for lines, not housenumbers anymore
|
||||||
|
if($searchedHousenumber%2 == 0){
|
||||||
|
//if housenumber is even, look for housenumber in streets with interpolationtype even or all
|
||||||
|
$sSQL = "select distinct place_id from location_property_tiger where parent_place_id in (".$sPlaceIDs.") and (interpolationtype='even' or interpolationtype='all') and ".$searchedHousenumber.">=startnumber and ".$searchedHousenumber."<=endnumber";
|
||||||
|
}else{
|
||||||
|
//look for housenumber in streets with interpolationtype odd or all
|
||||||
|
$sSQL = "select distinct place_id from location_property_tiger where parent_place_id in (".$sPlaceIDs.") and (interpolationtype='odd' or interpolationtype='all') and ".$searchedHousenumber.">=startnumber and ".$searchedHousenumber."<=endnumber";
|
||||||
|
}
|
||||||
|
|
||||||
if (sizeof($this->aExcludePlaceIDs))
|
if (sizeof($this->aExcludePlaceIDs))
|
||||||
{
|
{
|
||||||
$sSQL .= " and place_id not in (".join(',',$this->aExcludePlaceIDs).")";
|
$sSQL .= " and place_id not in (".join(',', $this->aExcludePlaceIDs).")";
|
||||||
}
|
}
|
||||||
//$sSQL .= " limit $this->iLimit";
|
//$sSQL .= " limit $this->iLimit";
|
||||||
if (CONST_Debug) var_dump($sSQL);
|
if (CONST_Debug) var_dump($sSQL);
|
||||||
$aPlaceIDs = $this->oDB->getCol($sSQL);
|
//get place IDs
|
||||||
|
$aPlaceIDs = $this->oDB->getCol($sSQL, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fallback to the road
|
// Fallback to the road (if no housenumber was found)
|
||||||
if (!sizeof($aPlaceIDs) && preg_match('/[0-9]+/', $aSearch['sHouseNumber']))
|
if (!sizeof($aPlaceIDs) && preg_match('/[0-9]+/', $aSearch['sHouseNumber']))
|
||||||
{
|
{
|
||||||
$aPlaceIDs = $aRoadPlaceIDs;
|
$aPlaceIDs = $aRoadPlaceIDs;
|
||||||
|
//set to -1, if no housenumbers were found
|
||||||
|
$searchedHousenumber = -1;
|
||||||
}
|
}
|
||||||
|
//else: housenumber was found, remains saved in searchedHousenumber
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if ($aSearch['sClass'] && sizeof($aPlaceIDs))
|
if ($aSearch['sClass'] && sizeof($aPlaceIDs))
|
||||||
{
|
{
|
||||||
$sPlaceIDs = join(',',$aPlaceIDs);
|
$sPlaceIDs = join(',', $aPlaceIDs);
|
||||||
$aClassPlaceIDs = array();
|
$aClassPlaceIDs = array();
|
||||||
|
|
||||||
if (!$aSearch['sOperator'] || $aSearch['sOperator'] == 'name')
|
if (!$aSearch['sOperator'] || $aSearch['sOperator'] == 'name')
|
||||||
@@ -1567,7 +1604,8 @@
|
|||||||
|
|
||||||
foreach($aPlaceIDs as $iPlaceID)
|
foreach($aPlaceIDs as $iPlaceID)
|
||||||
{
|
{
|
||||||
$aResultPlaceIDs[$iPlaceID] = $iPlaceID;
|
// array for placeID => -1 | Tiger housenumber
|
||||||
|
$aResultPlaceIDs[$iPlaceID] = $searchedHousenumber;
|
||||||
}
|
}
|
||||||
if ($iQueryLoop > 20) break;
|
if ($iQueryLoop > 20) break;
|
||||||
}
|
}
|
||||||
@@ -1575,16 +1613,23 @@
|
|||||||
if (isset($aResultPlaceIDs) && sizeof($aResultPlaceIDs) && ($this->iMinAddressRank != 0 || $this->iMaxAddressRank != 30))
|
if (isset($aResultPlaceIDs) && sizeof($aResultPlaceIDs) && ($this->iMinAddressRank != 0 || $this->iMaxAddressRank != 30))
|
||||||
{
|
{
|
||||||
// Need to verify passes rank limits before dropping out of the loop (yuk!)
|
// Need to verify passes rank limits before dropping out of the loop (yuk!)
|
||||||
$sSQL = "select place_id from placex where place_id in (".join(',',$aResultPlaceIDs).") ";
|
// reduces the number of place ids, like a filter
|
||||||
|
$sSQL = "select place_id from placex where place_id in (".join(',',array_keys($aResultPlaceIDs)).") ";
|
||||||
$sSQL .= "and (placex.rank_address between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
$sSQL .= "and (placex.rank_address between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
||||||
if (14 >= $this->iMinAddressRank && 14 <= $this->iMaxAddressRank) $sSQL .= " OR (extratags->'place') = 'city'";
|
if (14 >= $this->iMinAddressRank && 14 <= $this->iMaxAddressRank) $sSQL .= " OR (extratags->'place') = 'city'";
|
||||||
if ($this->aAddressRankList) $sSQL .= " OR placex.rank_address in (".join(',',$this->aAddressRankList).")";
|
if ($this->aAddressRankList) $sSQL .= " OR placex.rank_address in (".join(',',$this->aAddressRankList).")";
|
||||||
$sSQL .= ") UNION select place_id from location_property_tiger where place_id in (".join(',',$aResultPlaceIDs).") ";
|
$sSQL .= ") UNION select place_id from location_property_tiger where place_id in (".join(',',array_keys($aResultPlaceIDs)).") ";
|
||||||
$sSQL .= "and (30 between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
$sSQL .= "and (30 between $this->iMinAddressRank and $this->iMaxAddressRank ";
|
||||||
if ($this->aAddressRankList) $sSQL .= " OR 30 in (".join(',',$this->aAddressRankList).")";
|
if ($this->aAddressRankList) $sSQL .= " OR 30 in (".join(',',$this->aAddressRankList).")";
|
||||||
$sSQL .= ")";
|
$sSQL .= ")";
|
||||||
if (CONST_Debug) var_dump($sSQL);
|
if (CONST_Debug) var_dump($sSQL);
|
||||||
$aResultPlaceIDs = $this->oDB->getCol($sSQL);
|
$aFilteredPlaceIDs = $this->oDB->getCol($sSQL);
|
||||||
|
$tempIDs = array();
|
||||||
|
foreach($aFilteredPlaceIDs as $placeID)
|
||||||
|
{
|
||||||
|
$tempIDs[$placeID] = $aResultPlaceIDs[$placeID]; //assign housenumber to placeID
|
||||||
|
}
|
||||||
|
$aResultPlaceIDs = $tempIDs;
|
||||||
}
|
}
|
||||||
|
|
||||||
//exit;
|
//exit;
|
||||||
@@ -1676,16 +1721,16 @@
|
|||||||
{
|
{
|
||||||
$aResult['label'] = $aClassType[$aResult['class'].':'.$aResult['type']]['label'];
|
$aResult['label'] = $aClassType[$aResult['class'].':'.$aResult['type']]['label'];
|
||||||
}
|
}
|
||||||
|
// if tag '&addressdetails=1' is set in query
|
||||||
if ($this->bIncludeAddressDetails)
|
if ($this->bIncludeAddressDetails)
|
||||||
{
|
{
|
||||||
$aResult['address'] = getAddressDetails($this->oDB, $sLanguagePrefArraySQL, $aResult['place_id'], $aResult['country_code']);
|
// getAddressDetails() is defined in lib.php and uses the SQL function get_addressdata in functions.sql
|
||||||
|
$aResult['address'] = getAddressDetails($this->oDB, $sLanguagePrefArraySQL, $aResult['place_id'], $aResult['country_code'], $aResultPlaceIDs[$aResult['place_id']]);
|
||||||
if ($aResult['extra_place'] == 'city' && !isset($aResult['address']['city']))
|
if ($aResult['extra_place'] == 'city' && !isset($aResult['address']['city']))
|
||||||
{
|
{
|
||||||
$aResult['address'] = array_merge(array('city' => array_shift(array_values($aResult['address']))), $aResult['address']);
|
$aResult['address'] = array_merge(array('city' => array_shift(array_values($aResult['address']))), $aResult['address']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($this->bIncludeExtraTags)
|
if ($this->bIncludeExtraTags)
|
||||||
{
|
{
|
||||||
if ($aResult['extra'])
|
if ($aResult['extra'])
|
||||||
|
|||||||
@@ -7,6 +7,8 @@
|
|||||||
|
|
||||||
protected $sType = false;
|
protected $sType = false;
|
||||||
|
|
||||||
|
protected $fTigerFraction = -1;
|
||||||
|
|
||||||
protected $aLangPrefOrder = array();
|
protected $aLangPrefOrder = array();
|
||||||
|
|
||||||
protected $bAddressDetails = false;
|
protected $bAddressDetails = false;
|
||||||
@@ -115,6 +117,7 @@
|
|||||||
{
|
{
|
||||||
$this->setOSMID($details['osm_type'], $details['osm_id']);
|
$this->setOSMID($details['osm_type'], $details['osm_id']);
|
||||||
}
|
}
|
||||||
|
if (isset($details['fraction'])) $this->fTigerFraction = $details['fraction'];
|
||||||
|
|
||||||
return $this->lookup();
|
return $this->lookup();
|
||||||
}
|
}
|
||||||
@@ -130,20 +133,24 @@
|
|||||||
$sSQL = "select place_id,partition, 'T' as osm_type, place_id as osm_id, 'place' as class, 'house' as type, null as admin_level, housenumber, null as street, null as isin, postcode,";
|
$sSQL = "select place_id,partition, 'T' as osm_type, place_id as osm_id, 'place' as class, 'house' as type, null as admin_level, housenumber, null as street, null as isin, postcode,";
|
||||||
$sSQL .= " 'us' as country_code, parent_place_id, null as linked_place_id, 30 as rank_address, 30 as rank_search,";
|
$sSQL .= " 'us' as country_code, parent_place_id, null as linked_place_id, 30 as rank_address, 30 as rank_search,";
|
||||||
$sSQL .= " coalesce(null,0.75-(30::float/40)) as importance, null as indexed_status, null as indexed_date, null as wikipedia, 'us' as calculated_country_code, ";
|
$sSQL .= " coalesce(null,0.75-(30::float/40)) as importance, null as indexed_status, null as indexed_date, null as wikipedia, 'us' as calculated_country_code, ";
|
||||||
$sSQL .= " get_address_by_language(place_id, $sLanguagePrefArraySQL) as langaddress,";
|
$sSQL .= " get_address_by_language(place_id, housenumber, $sLanguagePrefArraySQL) as langaddress,";
|
||||||
$sSQL .= " null as placename,";
|
$sSQL .= " null as placename,";
|
||||||
$sSQL .= " null as ref,";
|
$sSQL .= " null as ref,";
|
||||||
if ($this->bExtraTags) $sSQL .= " null as extra,";
|
if ($this->bExtraTags) $sSQL .= " null as extra,";
|
||||||
if ($this->bNameDetails) $sSQL .= " null as names,";
|
if ($this->bNameDetails) $sSQL .= " null as names,";
|
||||||
$sSQL .= " st_y(centroid) as lat,";
|
$sSQL .= " ST_X(point) as lon, ST_Y(point) as lat from (select *, ST_LineInterpolatePoint(linegeo, (housenumber-startnumber::float)/(endnumber-startnumber)::float) as point from ";
|
||||||
$sSQL .= " st_x(centroid) as lon";
|
$sSQL .= " (select *, ";
|
||||||
$sSQL .= " from location_property_tiger where place_id = ".(int)$this->iPlaceID;
|
$sSQL .= " CASE WHEN interpolationtype='odd' THEN floor((".$this->fTigerFraction."*(endnumber-startnumber)+startnumber)/2)::int*2+1";
|
||||||
|
$sSQL .= " WHEN interpolationtype='even' THEN ((".$this->fTigerFraction."*(endnumber-startnumber)+startnumber+1)/2)::int*2";
|
||||||
|
$sSQL .= " WHEN interpolationtype='all' THEN (".$this->fTigerFraction."*(endnumber-startnumber)+startnumber)::int";
|
||||||
|
$sSQL .= " END as housenumber";
|
||||||
|
$sSQL .= " from location_property_tiger where place_id = ".(int)$this->iPlaceID.") as blub1) as blub2";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$sSQL = "select placex.place_id, partition, osm_type, osm_id, class, type, admin_level, housenumber, street, isin, postcode, country_code, parent_place_id, linked_place_id, rank_address, rank_search, ";
|
$sSQL = "select placex.place_id, partition, osm_type, osm_id, class, type, admin_level, housenumber, street, isin, postcode, country_code, parent_place_id, linked_place_id, rank_address, rank_search, ";
|
||||||
$sSQL .= " coalesce(importance,0.75-(rank_search::float/40)) as importance, indexed_status, indexed_date, wikipedia, calculated_country_code, ";
|
$sSQL .= " coalesce(importance,0.75-(rank_search::float/40)) as importance, indexed_status, indexed_date, wikipedia, calculated_country_code, ";
|
||||||
$sSQL .= " get_address_by_language(place_id, $sLanguagePrefArraySQL) as langaddress,";
|
$sSQL .= " get_address_by_language(place_id, -1, $sLanguagePrefArraySQL) as langaddress,";
|
||||||
$sSQL .= " get_name_by_language(name, $sLanguagePrefArraySQL) as placename,";
|
$sSQL .= " get_name_by_language(name, $sLanguagePrefArraySQL) as placename,";
|
||||||
$sSQL .= " get_name_by_language(name, ARRAY['ref']) as ref,";
|
$sSQL .= " get_name_by_language(name, ARRAY['ref']) as ref,";
|
||||||
if ($this->bExtraTags) $sSQL .= " hstore_to_json(extratags) as extra,";
|
if ($this->bExtraTags) $sSQL .= " hstore_to_json(extratags) as extra,";
|
||||||
@@ -165,7 +172,10 @@
|
|||||||
|
|
||||||
if ($this->bAddressDetails)
|
if ($this->bAddressDetails)
|
||||||
{
|
{
|
||||||
$aAddress = $this->getAddressNames();
|
if($this->sType == 'tiger') // to get addressdetails for tiger data, the housenumber is needed
|
||||||
|
$aAddress = $this->getAddressNames($aPlace['housenumber']);
|
||||||
|
else
|
||||||
|
$aAddress = $this->getAddressNames();
|
||||||
$aPlace['aAddress'] = $aAddress;
|
$aPlace['aAddress'] = $aAddress;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -213,13 +223,13 @@
|
|||||||
return $aPlace;
|
return $aPlace;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getAddressDetails($bAll = false)
|
function getAddressDetails($bAll = false, $housenumber = -1)
|
||||||
{
|
{
|
||||||
if (!$this->iPlaceID) return null;
|
if (!$this->iPlaceID) return null;
|
||||||
|
|
||||||
$sLanguagePrefArraySQL = "ARRAY[".join(',',array_map("getDBQuoted", $this->aLangPrefOrder))."]";
|
$sLanguagePrefArraySQL = "ARRAY[".join(',',array_map("getDBQuoted", $this->aLangPrefOrder))."]";
|
||||||
|
|
||||||
$sSQL = "select *,get_name_by_language(name,$sLanguagePrefArraySQL) as localname from get_addressdata(".$this->iPlaceID.")";
|
$sSQL = "select *,get_name_by_language(name,$sLanguagePrefArraySQL) as localname from get_addressdata(".$this->iPlaceID.",".$housenumber.")";
|
||||||
if (!$bAll) $sSQL .= " WHERE isaddress OR type = 'country_code'";
|
if (!$bAll) $sSQL .= " WHERE isaddress OR type = 'country_code'";
|
||||||
$sSQL .= " order by rank_address desc,isaddress desc";
|
$sSQL .= " order by rank_address desc,isaddress desc";
|
||||||
|
|
||||||
@@ -232,9 +242,9 @@
|
|||||||
return $aAddressLines;
|
return $aAddressLines;
|
||||||
}
|
}
|
||||||
|
|
||||||
function getAddressNames()
|
function getAddressNames($housenumber = -1)
|
||||||
{
|
{
|
||||||
$aAddressLines = $this->getAddressDetails(false);
|
$aAddressLines = $this->getAddressDetails(false, $housenumber);
|
||||||
|
|
||||||
$aAddress = array();
|
$aAddress = array();
|
||||||
$aFallback = array();
|
$aFallback = array();
|
||||||
|
|||||||
@@ -158,17 +158,15 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Only street found? If it's in the US we can check TIGER data for nearest housenumber
|
// Only street found? If it's in the US we can check TIGER data for nearest housenumber
|
||||||
if ($bIsInUnitedStates && $iMaxRank_orig >= 28 && $iPlaceID && ($aPlace['rank_search'] == 26 || $aPlace['rank_search'] == 27 ))
|
if ($bIsInUnitedStates && $iMaxRank_orig >= 28 && $iPlaceID && ($aPlace['rank_search'] == 26 || $aPlace['rank_search'] == 27 ))
|
||||||
{
|
{
|
||||||
$fSearchDiam = 0.001;
|
$fSearchDiam = 0.001;
|
||||||
$sSQL = 'SELECT place_id,parent_place_id,30 as rank_search ';
|
$sSQL = 'SELECT place_id,parent_place_id,30 as rank_search, ST_line_locate_point(linegeo,'.$sPointSQL.') as fraction';
|
||||||
if (CONST_Debug) { $sSQL .= ', housenumber, ST_distance('.$sPointSQL.', centroid) as distance, st_y(centroid) as lat, st_x(centroid) as lon'; }
|
//if (CONST_Debug) { $sSQL .= ', housenumber, ST_distance('.$sPointSQL.', centroid) as distance, st_y(centroid) as lat, st_x(centroid) as lon'; }
|
||||||
$sSQL .= ' FROM location_property_tiger WHERE parent_place_id = '.$iPlaceID;
|
$sSQL .= ' FROM location_property_tiger WHERE parent_place_id = '.$iPlaceID;
|
||||||
$sSQL .= ' AND ST_DWithin('.$sPointSQL.', centroid, '.$fSearchDiam.')';
|
$sSQL .= ' AND ST_DWithin('.$sPointSQL.', linegeo, '.$fSearchDiam.')'; //no centroid anymore in Tiger data, now we have lines
|
||||||
$sSQL .= ' ORDER BY ST_distance('.$sPointSQL.', centroid) ASC limit 1';
|
$sSQL .= ' ORDER BY ST_distance('.$sPointSQL.', linegeo) ASC limit 1';
|
||||||
|
|
||||||
|
|
||||||
// print all house numbers in the parent (street)
|
|
||||||
if (CONST_Debug)
|
if (CONST_Debug)
|
||||||
{
|
{
|
||||||
$sSQL = preg_replace('/limit 1/', 'limit 100', $sSQL);
|
$sSQL = preg_replace('/limit 1/', 'limit 100', $sSQL);
|
||||||
@@ -193,6 +191,7 @@
|
|||||||
$aPlace = $aPlaceTiger;
|
$aPlace = $aPlaceTiger;
|
||||||
$iPlaceID = $aPlaceTiger['place_id'];
|
$iPlaceID = $aPlaceTiger['place_id'];
|
||||||
$iParentPlaceID = $aPlaceTiger['parent_place_id']; // the street
|
$iParentPlaceID = $aPlaceTiger['parent_place_id']; // the street
|
||||||
|
$iFraction = $aPlaceTiger['fraction'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -220,7 +219,8 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
return array('place_id' => $iPlaceID,
|
return array('place_id' => $iPlaceID,
|
||||||
'type' => $bPlaceIsTiger ? 'tiger' : 'osm');
|
'type' => $bPlaceIsTiger ? 'tiger' : 'osm',
|
||||||
|
'fraction' => $bPlaceIsTiger ? $iFraction : -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
10
lib/lib.php
10
lib/lib.php
@@ -77,7 +77,7 @@
|
|||||||
function getProcessorCount()
|
function getProcessorCount()
|
||||||
{
|
{
|
||||||
$sCPU = file_get_contents('/proc/cpuinfo');
|
$sCPU = file_get_contents('/proc/cpuinfo');
|
||||||
preg_match_all('#processor : [0-9]+#', $sCPU, $aMatches);
|
preg_match_all('#processor : [0-9]+#', $sCPU, $aMatches);
|
||||||
return sizeof($aMatches[0]);
|
return sizeof($aMatches[0]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -115,8 +115,8 @@
|
|||||||
return ($a['aPointPolygon']['numfeatures'] > $b['aPointPolygon']['numfeatures']?-1:1);
|
return ($a['aPointPolygon']['numfeatures'] > $b['aPointPolygon']['numfeatures']?-1:1);
|
||||||
if ($a['aPointPolygon']['area'] != $b['aPointPolygon']['area'])
|
if ($a['aPointPolygon']['area'] != $b['aPointPolygon']['area'])
|
||||||
return ($a['aPointPolygon']['area'] > $b['aPointPolygon']['area']?-1:1);
|
return ($a['aPointPolygon']['area'] > $b['aPointPolygon']['area']?-1:1);
|
||||||
// if ($a['levenshtein'] != $b['levenshtein'])
|
// if ($a['levenshtein'] != $b['levenshtein'])
|
||||||
// return ($a['levenshtein'] < $b['levenshtein']?-1:1);
|
// return ($a['levenshtein'] < $b['levenshtein']?-1:1);
|
||||||
if ($a['rank_search'] != $b['rank_search'])
|
if ($a['rank_search'] != $b['rank_search'])
|
||||||
return ($a['rank_search'] < $b['rank_search']?-1:1);
|
return ($a['rank_search'] < $b['rank_search']?-1:1);
|
||||||
*/
|
*/
|
||||||
@@ -805,9 +805,9 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function getAddressDetails(&$oDB, $sLanguagePrefArraySQL, $iPlaceID, $sCountryCode = false, $bRaw = false)
|
function getAddressDetails(&$oDB, $sLanguagePrefArraySQL, $iPlaceID, $sCountryCode = false, $housenumber = -1, $bRaw = false)
|
||||||
{
|
{
|
||||||
$sSQL = "select *,get_name_by_language(name,$sLanguagePrefArraySQL) as localname from get_addressdata($iPlaceID)";
|
$sSQL = "select *,get_name_by_language(name,$sLanguagePrefArraySQL) as localname from get_addressdata($iPlaceID, $housenumber)";
|
||||||
if (!$bRaw) $sSQL .= " WHERE isaddress OR type = 'country_code'";
|
if (!$bRaw) $sSQL .= " WHERE isaddress OR type = 'country_code'";
|
||||||
$sSQL .= " order by rank_address desc,isaddress desc";
|
$sSQL .= " order by rank_address desc,isaddress desc";
|
||||||
|
|
||||||
|
|||||||
@@ -8,8 +8,8 @@
|
|||||||
'place_id'=>$aPointDetails['place_id'],
|
'place_id'=>$aPointDetails['place_id'],
|
||||||
'licence'=>"Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright",
|
'licence'=>"Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright",
|
||||||
);
|
);
|
||||||
|
|
||||||
$sOSMType = ($aPointDetails['osm_type'] == 'N'?'node':($aPointDetails['osm_type'] == 'W'?'way':($aPointDetails['osm_type'] == 'R'?'relation':'')));
|
$sOSMType = ($aPointDetails['osm_type'] == 'N'?'node':($aPointDetails['osm_type'] == 'W'?'way':($aPointDetails['osm_type'] == 'R'?'relation':($aPointDetails['osm_type'] == 'T'?'tiger':''))));
|
||||||
if ($sOSMType)
|
if ($sOSMType)
|
||||||
{
|
{
|
||||||
$aPlace['osm_type'] = $sOSMType;
|
$aPlace['osm_type'] = $sOSMType;
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
'licence'=>"Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright",
|
'licence'=>"Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright",
|
||||||
);
|
);
|
||||||
|
|
||||||
$sOSMType = ($aPointDetails['osm_type'] == 'N'?'node':($aPointDetails['osm_type'] == 'W'?'way':($aPointDetails['osm_type'] == 'R'?'relation':'')));
|
$sOSMType = ($aPointDetails['osm_type'] == 'N'?'node':($aPointDetails['osm_type'] == 'W'?'way':($aPointDetails['osm_type'] == 'R'?'relation':($aPointDetails['osm_type'] == 'T'?'tiger':''))));
|
||||||
if ($sOSMType)
|
if ($sOSMType)
|
||||||
{
|
{
|
||||||
$aPlace['osm_type'] = $sOSMType;
|
$aPlace['osm_type'] = $sOSMType;
|
||||||
|
|||||||
@@ -25,7 +25,7 @@
|
|||||||
foreach($aSearchResults as $iResNum => $aResult)
|
foreach($aSearchResults as $iResNum => $aResult)
|
||||||
{
|
{
|
||||||
echo "<place place_id='".$aResult['place_id']."'";
|
echo "<place place_id='".$aResult['place_id']."'";
|
||||||
$sOSMType = ($aResult['osm_type'] == 'N'?'node':($aResult['osm_type'] == 'W'?'way':($aResult['osm_type'] == 'R'?'relation':'')));
|
$sOSMType = ($aResult['osm_type'] == 'N'?'node':($aResult['osm_type'] == 'W'?'way':($aResult['osm_type'] == 'R'?'relation':($aResult['osm_type'] == 'T'?'tiger':''))));
|
||||||
if ($sOSMType)
|
if ($sOSMType)
|
||||||
{
|
{
|
||||||
echo " osm_type='$sOSMType'";
|
echo " osm_type='$sOSMType'";
|
||||||
|
|||||||
@@ -2183,7 +2183,8 @@ END;
|
|||||||
$$
|
$$
|
||||||
LANGUAGE plpgsql;
|
LANGUAGE plpgsql;
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION get_address_by_language(for_place_id BIGINT, languagepref TEXT[]) RETURNS TEXT
|
--housenumber only needed for tiger data
|
||||||
|
CREATE OR REPLACE FUNCTION get_address_by_language(for_place_id BIGINT, housenumber INTEGER, languagepref TEXT[]) RETURNS TEXT
|
||||||
AS $$
|
AS $$
|
||||||
DECLARE
|
DECLARE
|
||||||
result TEXT[];
|
result TEXT[];
|
||||||
@@ -2195,7 +2196,7 @@ BEGIN
|
|||||||
result := '{}';
|
result := '{}';
|
||||||
prevresult := '';
|
prevresult := '';
|
||||||
|
|
||||||
FOR location IN select * from get_addressdata(for_place_id) where isaddress order by rank_address desc LOOP
|
FOR location IN select * from get_addressdata(for_place_id, housenumber) where isaddress order by rank_address desc LOOP
|
||||||
currresult := trim(get_name_by_language(location.name, languagepref));
|
currresult := trim(get_name_by_language(location.name, languagepref));
|
||||||
IF currresult != prevresult AND currresult IS NOT NULL AND result[(100 - location.rank_address)] IS NULL THEN
|
IF currresult != prevresult AND currresult IS NOT NULL AND result[(100 - location.rank_address)] IS NULL THEN
|
||||||
result[(100 - location.rank_address)] := trim(get_name_by_language(location.name, languagepref));
|
result[(100 - location.rank_address)] := trim(get_name_by_language(location.name, languagepref));
|
||||||
@@ -2223,10 +2224,10 @@ create type addressline as (
|
|||||||
distance FLOAT
|
distance FLOAT
|
||||||
);
|
);
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION get_addressdata(in_place_id BIGINT) RETURNS setof addressline
|
CREATE OR REPLACE FUNCTION get_addressdata(in_place_id BIGINT, in_housenumber INTEGER) RETURNS setof addressline
|
||||||
AS $$
|
AS $$
|
||||||
DECLARE
|
DECLARE
|
||||||
for_place_id BIGINT;
|
for_place_id BIGINT;--parent_place_id
|
||||||
result TEXT[];
|
result TEXT[];
|
||||||
search TEXT[];
|
search TEXT[];
|
||||||
found INTEGER;
|
found INTEGER;
|
||||||
@@ -2242,11 +2243,14 @@ DECLARE
|
|||||||
countryname HSTORE;
|
countryname HSTORE;
|
||||||
hadcountry BOOLEAN;
|
hadcountry BOOLEAN;
|
||||||
BEGIN
|
BEGIN
|
||||||
|
--first query tiger data
|
||||||
select parent_place_id,'us', housenumber, 30, postcode, null, 'place', 'house' from location_property_tiger
|
select parent_place_id,'us', 30, postcode, null, 'place', 'house' from location_property_tiger
|
||||||
WHERE place_id = in_place_id
|
WHERE place_id = in_place_id AND in_housenumber>=startnumber AND in_housenumber <= endnumber
|
||||||
INTO for_place_id,searchcountrycode, searchhousenumber, searchrankaddress, searchpostcode, searchhousename, searchclass, searchtype;
|
INTO for_place_id,searchcountrycode, searchrankaddress, searchpostcode, searchhousename, searchclass, searchtype;
|
||||||
|
IF for_place_id IS NOT NULL THEN
|
||||||
|
searchhousenumber = in_housenumber::text;
|
||||||
|
END IF;
|
||||||
|
|
||||||
IF for_place_id IS NULL THEN
|
IF for_place_id IS NULL THEN
|
||||||
select parent_place_id,'us', housenumber, 30, postcode, null, 'place', 'house' from location_property_aux
|
select parent_place_id,'us', housenumber, 30, postcode, null, 'place', 'house' from location_property_aux
|
||||||
WHERE place_id = in_place_id
|
WHERE place_id = in_place_id
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
CREATE INDEX idx_location_property_tiger_housenumber_parent_place_id_imp ON location_property_tiger_import (parent_place_id, housenumber) {ts:aux-index};
|
--index only on parent_place_id
|
||||||
|
CREATE INDEX idx_location_property_tiger_parent_place_id_imp ON location_property_tiger_import (parent_place_id) {ts:aux-index};
|
||||||
CREATE UNIQUE INDEX idx_location_property_tiger_place_id_imp ON location_property_tiger_import (place_id) {ts:aux-index};
|
CREATE UNIQUE INDEX idx_location_property_tiger_place_id_imp ON location_property_tiger_import (place_id) {ts:aux-index};
|
||||||
|
|
||||||
GRANT SELECT ON location_property_tiger_import TO "{www-user}";
|
GRANT SELECT ON location_property_tiger_import TO "{www-user}";
|
||||||
@@ -6,7 +7,7 @@ GRANT SELECT ON location_property_tiger_import TO "{www-user}";
|
|||||||
DROP TABLE IF EXISTS location_property_tiger;
|
DROP TABLE IF EXISTS location_property_tiger;
|
||||||
ALTER TABLE location_property_tiger_import RENAME TO location_property_tiger;
|
ALTER TABLE location_property_tiger_import RENAME TO location_property_tiger;
|
||||||
|
|
||||||
ALTER INDEX idx_location_property_tiger_housenumber_parent_place_id_imp RENAME TO idx_location_property_tiger_housenumber_parent_place_id;
|
ALTER INDEX idx_location_property_tiger_parent_place_id_imp RENAME TO idx_location_property_tiger_housenumber_parent_place_id;
|
||||||
ALTER INDEX idx_location_property_tiger_place_id_imp RENAME TO idx_location_property_tiger_place_id;
|
ALTER INDEX idx_location_property_tiger_place_id_imp RENAME TO idx_location_property_tiger_place_id;
|
||||||
|
|
||||||
DROP FUNCTION tigger_create_interpolation (linegeo geometry, in_startnumber integer, in_endnumber integer, interpolationtype text, in_street text, in_isin text, in_postcode text);
|
DROP FUNCTION tiger_line_import (linegeo geometry, in_startnumber integer, in_endnumber integer, interpolationtype text, in_street text, in_isin text, in_postcode text);
|
||||||
|
|||||||
@@ -1,19 +1,15 @@
|
|||||||
DROP TABLE IF EXISTS location_property_tiger_import;
|
DROP TABLE IF EXISTS location_property_tiger_import;
|
||||||
CREATE TABLE location_property_tiger_import () INHERITS (location_property) {ts:aux-data};
|
CREATE TABLE location_property_tiger_import (linegeo GEOMETRY, place_id BIGINT, partition INTEGER, parent_place_id BIGINT, startnumber INTEGER, endnumber INTEGER, interpolationtype TEXT, postcode TEXT);
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION tigger_create_interpolation(linegeo GEOMETRY, in_startnumber INTEGER,
|
CREATE OR REPLACE FUNCTION tiger_line_import(linegeo GEOMETRY, in_startnumber INTEGER,
|
||||||
in_endnumber INTEGER, interpolationtype TEXT,
|
in_endnumber INTEGER, interpolationtype TEXT,
|
||||||
in_street TEXT, in_isin TEXT, in_postcode TEXT) RETURNS INTEGER
|
in_street TEXT, in_isin TEXT, in_postcode TEXT) RETURNS INTEGER
|
||||||
AS $$
|
AS $$
|
||||||
DECLARE
|
DECLARE
|
||||||
|
|
||||||
startnumber INTEGER;
|
startnumber INTEGER;
|
||||||
endnumber INTEGER;
|
endnumber INTEGER;
|
||||||
stepsize INTEGER;
|
stepsize INTEGER;
|
||||||
housenum INTEGER;
|
|
||||||
newpoints INTEGER;
|
|
||||||
numberrange INTEGER;
|
numberrange INTEGER;
|
||||||
rangestartnumber INTEGER;
|
|
||||||
place_centroid GEOMETRY;
|
place_centroid GEOMETRY;
|
||||||
out_partition INTEGER;
|
out_partition INTEGER;
|
||||||
out_parent_place_id BIGINT;
|
out_parent_place_id BIGINT;
|
||||||
@@ -31,7 +27,6 @@ BEGIN
|
|||||||
END IF;
|
END IF;
|
||||||
|
|
||||||
numberrange := endnumber - startnumber;
|
numberrange := endnumber - startnumber;
|
||||||
rangestartnumber := startnumber;
|
|
||||||
|
|
||||||
IF (interpolationtype = 'odd' AND startnumber%2 = 0) OR (interpolationtype = 'even' AND startnumber%2 = 1) THEN
|
IF (interpolationtype = 'odd' AND startnumber%2 = 0) OR (interpolationtype = 'even' AND startnumber%2 = 1) THEN
|
||||||
startnumber := startnumber + 1;
|
startnumber := startnumber + 1;
|
||||||
@@ -75,15 +70,11 @@ BEGIN
|
|||||||
END LOOP;
|
END LOOP;
|
||||||
END IF;
|
END IF;
|
||||||
|
|
||||||
newpoints := 0;
|
--insert street(line) into import table
|
||||||
FOR housenum IN startnumber..endnumber BY stepsize LOOP
|
insert into location_property_tiger_import (linegeo, place_id, partition, parent_place_id, startnumber, endnumber, interpolationtype, postcode)
|
||||||
insert into location_property_tiger_import (place_id, partition, parent_place_id, housenumber, postcode, centroid)
|
values (linegeo, nextval('seq_place'), out_partition, out_parent_place_id, startnumber, endnumber, interpolationtype, in_postcode);
|
||||||
values (nextval('seq_place'), out_partition, out_parent_place_id, housenum, in_postcode,
|
|
||||||
ST_LineInterpolatePoint(linegeo, (housenum::float-rangestartnumber::float)/numberrange::float));
|
|
||||||
newpoints := newpoints + 1;
|
|
||||||
END LOOP;
|
|
||||||
|
|
||||||
RETURN newpoints;
|
RETURN 1;
|
||||||
END;
|
END;
|
||||||
$$
|
$$
|
||||||
LANGUAGE plpgsql;
|
LANGUAGE plpgsql;
|
||||||
|
|||||||
@@ -189,6 +189,68 @@ class NominatimTest extends \PHPUnit_Framework_TestCase
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function test_geometryText2Points()
|
||||||
|
{
|
||||||
|
$fRadius = 1;
|
||||||
|
|
||||||
|
// invalid value
|
||||||
|
$this->assertEquals(
|
||||||
|
NULL,
|
||||||
|
geometryText2Points('', $fRadius)
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
// POINT
|
||||||
|
$aPoints = geometryText2Points('POINT(10 20)', $fRadius);
|
||||||
|
$this->assertEquals(
|
||||||
|
101,
|
||||||
|
count($aPoints)
|
||||||
|
);
|
||||||
|
|
||||||
|
$this->assertEquals(
|
||||||
|
|
||||||
|
array(
|
||||||
|
['', 10, 21],
|
||||||
|
['', 10.062790519529, 20.998026728428],
|
||||||
|
['', 10.125333233564, 20.992114701314]
|
||||||
|
),
|
||||||
|
array_splice($aPoints, 0,3)
|
||||||
|
);
|
||||||
|
|
||||||
|
// POLYGON
|
||||||
|
$this->assertEquals(
|
||||||
|
array(
|
||||||
|
['30 10', '30', '10'],
|
||||||
|
['40 40', '40', '40'],
|
||||||
|
['20 40', '20', '40'],
|
||||||
|
['10 20', '10', '20'],
|
||||||
|
['30 10', '30', '10']
|
||||||
|
),
|
||||||
|
geometryText2Points('POLYGON((30 10, 40 40, 20 40, 10 20, 30 10))', $fRadius)
|
||||||
|
);
|
||||||
|
|
||||||
|
// MULTIPOLYGON
|
||||||
|
// only the first polygon is used
|
||||||
|
$this->assertEquals(
|
||||||
|
array(
|
||||||
|
['30 20', '30', '20'],
|
||||||
|
['45 40', '45', '40'],
|
||||||
|
['10 40', '10', '40'],
|
||||||
|
['30 20', '30', '20'],
|
||||||
|
|
||||||
|
// ['15 5' , '15', '5' ],
|
||||||
|
// ['45 10', '45', '10'],
|
||||||
|
// ['10 20', '10', '20'],
|
||||||
|
// ['5 10' , '5' , '10'],
|
||||||
|
// ['15 5' , '15', '5' ]
|
||||||
|
),
|
||||||
|
geometryText2Points('MULTIPOLYGON(((30 20, 45 40, 10 40, 30 20)),((15 5, 40 10, 10 20, 5 10, 15 5)))', $fRadius)
|
||||||
|
);
|
||||||
|
|
||||||
// you might say we're creating a circle
|
// you might say we're creating a circle
|
||||||
public function test_createPointsAroundCenter()
|
public function test_createPointsAroundCenter()
|
||||||
|
|||||||
@@ -11,4 +11,3 @@ Feature: Object details
|
|||||||
| N158845944
|
| N158845944
|
||||||
| W72493656
|
| W72493656
|
||||||
| R62422
|
| R62422
|
||||||
|
|
||||||
|
|||||||
@@ -3893,8 +3893,8 @@ def addressways(waylist, nodelist, first_id):
|
|||||||
# ret.append( "<tag k=\"source\" v=\"%s_import_v%s_%s\" />" % (iSource, VERSION, import_guid) )
|
# ret.append( "<tag k=\"source\" v=\"%s_import_v%s_%s\" />" % (iSource, VERSION, import_guid) )
|
||||||
# ret.append( "<tag k=\"attribution\" v=\"%s\" />" % (iAttrib) )
|
# ret.append( "<tag k=\"attribution\" v=\"%s\" />" % (iAttrib) )
|
||||||
# ret.append( "</way>" )
|
# ret.append( "</way>" )
|
||||||
|
# call new tiger_line_import function to save the lines in the DB.
|
||||||
ret.append( "select tigger_create_interpolation(ST_GeomFromText('LINESTRING(%s)',4326), '%s', '%s', '%s', '%s', '%s', '%s');" %
|
ret.append( "select tiger_line_import(ST_GeomFromText('LINESTRING(%s)',4326), '%s', '%s', '%s', '%s', '%s', '%s');" %
|
||||||
( ",".join(rlinestring), rfromadd.replace("'", "''"), rtoadd.replace("'", "''"), interpolationtype.replace("'", "''"), name.replace("'", "''"), county.replace("'", "''"), zipr.replace("'", "''") ) )
|
( ",".join(rlinestring), rfromadd.replace("'", "''"), rtoadd.replace("'", "''"), interpolationtype.replace("'", "''"), name.replace("'", "''"), county.replace("'", "''"), zipr.replace("'", "''") ) )
|
||||||
|
|
||||||
if left:
|
if left:
|
||||||
@@ -3919,7 +3919,7 @@ def addressways(waylist, nodelist, first_id):
|
|||||||
interpolationtype = "all";
|
interpolationtype = "all";
|
||||||
else:
|
else:
|
||||||
interpolationtype = "all";
|
interpolationtype = "all";
|
||||||
ret.append( "select tigger_create_interpolation(ST_GeomFromText('LINESTRING(%s)',4326), '%s', '%s', '%s', '%s', '%s', '%s');" %
|
ret.append( "select tiger_line_import(ST_GeomFromText('LINESTRING(%s)',4326), '%s', '%s', '%s', '%s', '%s', '%s');" %
|
||||||
( ",".join(llinestring), lfromadd.replace("'", "''"), ltoadd.replace("'", "''"), interpolationtype.replace("'", "''"), name.replace("'", "''"), county.replace("'", "''"), zipl.replace("'", "''") ) )
|
( ",".join(llinestring), lfromadd.replace("'", "''"), ltoadd.replace("'", "''"), interpolationtype.replace("'", "''"), name.replace("'", "''"), county.replace("'", "''"), zipl.replace("'", "''") ) )
|
||||||
|
|
||||||
return ret
|
return ret
|
||||||
|
|||||||
@@ -103,7 +103,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Address
|
// Address
|
||||||
$aAddressLines = getAddressDetails($oDB, $sLanguagePrefArraySQL, $iPlaceID, $aPointDetails['country_code'], true);
|
$aAddressLines = getAddressDetails($oDB, $sLanguagePrefArraySQL, $iPlaceID, $aPointDetails['country_code'], -1, true);
|
||||||
|
|
||||||
// Linked places
|
// Linked places
|
||||||
$sSQL = "select placex.place_id, osm_type, osm_id, class, type, housenumber, admin_level, rank_address, ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon') as isarea, ST_Distance_Spheroid(geometry, placegeometry, 'SPHEROID[\"WGS 84\",6378137,298.257223563, AUTHORITY[\"EPSG\",\"7030\"]]') as distance, ";
|
$sSQL = "select placex.place_id, osm_type, osm_id, class, type, housenumber, admin_level, rank_address, ST_GeometryType(geometry) in ('ST_Polygon','ST_MultiPolygon') as isarea, ST_Distance_Spheroid(geometry, placegeometry, 'SPHEROID[\"WGS 84\",6378137,298.257223563, AUTHORITY[\"EPSG\",\"7030\"]]') as distance, ";
|
||||||
|
|||||||
Reference in New Issue
Block a user