Compare commits
30 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 28a5fe06bb | |||
| 4c817de697 | |||
| 5133f39d76 | |||
| a29dcfa951 | |||
| e546ddd777 | |||
| c21c9c9106 | |||
| 511f3cff33 | |||
| d5ffbc6a9a | |||
| 60551d209d | |||
| 57be7beb5d | |||
| a8d0c115da | |||
| d9fcf1ecf7 | |||
| 1967701385 | |||
| a2cdc063d4 | |||
| 6e06daff15 | |||
| 2b6bdaf727 | |||
| 2347c0ada7 | |||
| 65034612ff | |||
| bd427e966d | |||
| b777fb1052 | |||
| 11d491e00f | |||
| aa51e8dadd | |||
| 83ca62aa09 | |||
| a26695c04a | |||
| 4787fe30b7 | |||
| fdef3fdfd7 | |||
| f148810a1c | |||
| 9d5a4be2d9 | |||
| 5484118d77 | |||
| 2116cc68ca |
@@ -1,3 +1,29 @@
|
|||||||
|
# 5.14.3
|
||||||
|
- Changes from 5.14.2:
|
||||||
|
- Bugfixes:
|
||||||
|
- FIXED #4754: U-Turn penalties are applied to straight turns.
|
||||||
|
- FIXED #4756: Removed too restrictive road name check in the sliproad handler
|
||||||
|
- FIXED #4731: Use correct weights for edge-based graph duplicated via nodes.
|
||||||
|
- Profile:
|
||||||
|
- CHANGED: added Belarus speed limits
|
||||||
|
- CHANGED: set default urban speed in Ukraine to 50kmh
|
||||||
|
|
||||||
|
# 5.14.2
|
||||||
|
- Changes from 5.14.1:
|
||||||
|
- Bugfixes:
|
||||||
|
- FIXED #4727: Erroring when a old .core file is present.
|
||||||
|
- FIXED #4642: Update checks for EMPTY_NAMEID to check for empty name strings
|
||||||
|
- FIXED #4738: Fix potential segmentation fault
|
||||||
|
- Node.js Bindings:
|
||||||
|
- ADDED: Exposed new `max_radiuses_map_matching` option from `EngingConfig` options
|
||||||
|
- Tools:
|
||||||
|
- ADDED: New osrm-routed `max_radiuses_map_matching` command line flag to optionally set a maximum radius for map matching
|
||||||
|
|
||||||
|
# 5.14.1
|
||||||
|
- Changes from 5.14.0
|
||||||
|
- Bugfixes:
|
||||||
|
- FIXED: don't use removed alternative candidates in `filterPackedPathsByCellSharing`
|
||||||
|
|
||||||
# 5.14.0
|
# 5.14.0
|
||||||
- Changes from 5.13
|
- Changes from 5.13
|
||||||
- API:
|
- API:
|
||||||
|
|||||||
+1
-1
@@ -62,7 +62,7 @@ endif()
|
|||||||
project(OSRM C CXX)
|
project(OSRM C CXX)
|
||||||
set(OSRM_VERSION_MAJOR 5)
|
set(OSRM_VERSION_MAJOR 5)
|
||||||
set(OSRM_VERSION_MINOR 14)
|
set(OSRM_VERSION_MINOR 14)
|
||||||
set(OSRM_VERSION_PATCH 0)
|
set(OSRM_VERSION_PATCH 3)
|
||||||
set(OSRM_VERSION "${OSRM_VERSION_MAJOR}.${OSRM_VERSION_MINOR}.${OSRM_VERSION_PATCH}")
|
set(OSRM_VERSION "${OSRM_VERSION_MAJOR}.${OSRM_VERSION_MINOR}.${OSRM_VERSION_PATCH}")
|
||||||
|
|
||||||
add_definitions(-DOSRM_PROJECT_DIR="${CMAKE_CURRENT_SOURCE_DIR}")
|
add_definitions(-DOSRM_PROJECT_DIR="${CMAKE_CURRENT_SOURCE_DIR}")
|
||||||
|
|||||||
@@ -992,7 +992,6 @@ Feature: Slipways and Dedicated Turn Lanes
|
|||||||
| dbef | primary | dbef | |
|
| dbef | primary | dbef | |
|
||||||
| ae | primary_link | ae | yes |
|
| ae | primary_link | ae | yes |
|
||||||
|
|
||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| waypoints | route | turns | locations |
|
| waypoints | route | turns | locations |
|
||||||
| s,f | sabc,dbef,dbef | depart,turn right,arrive | s,a,f |
|
| s,f | sabc,dbef,dbef | depart,turn right,arrive | s,a,f |
|
||||||
@@ -1019,7 +1018,6 @@ Feature: Slipways and Dedicated Turn Lanes
|
|||||||
| dbcf | primary | dbcf | |
|
| dbcf | primary | dbcf | |
|
||||||
| ac | primary_link | ae | yes |
|
| ac | primary_link | ae | yes |
|
||||||
|
|
||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| waypoints | route | turns | locations |
|
| waypoints | route | turns | locations |
|
||||||
| s,f | sab,dbcf,dbcf | depart,turn right,arrive | s,a,f |
|
| s,f | sab,dbcf,dbcf | depart,turn right,arrive | s,a,f |
|
||||||
@@ -1047,7 +1045,55 @@ Feature: Slipways and Dedicated Turn Lanes
|
|||||||
| ae | primary_link | sab | yes |
|
| ae | primary_link | sab | yes |
|
||||||
| cg | primary | cg | |
|
| cg | primary | cg | |
|
||||||
|
|
||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| waypoints | route | turns | locations |
|
| waypoints | route | turns | locations |
|
||||||
| s,f | sab,dbcef,dbcef | depart,turn right,arrive | s,a,f |
|
| s,f | sab,dbcef,dbcef | depart,turn right,arrive | s,a,f |
|
||||||
|
|
||||||
|
|
||||||
|
@sliproads
|
||||||
|
Scenario: Sliproad converted from a fork
|
||||||
|
Given the node map
|
||||||
|
"""
|
||||||
|
d
|
||||||
|
.
|
||||||
|
b
|
||||||
|
s . a '.
|
||||||
|
`c
|
||||||
|
.
|
||||||
|
f
|
||||||
|
"""
|
||||||
|
|
||||||
|
And the ways
|
||||||
|
| nodes | highway | name | ref | oneway |
|
||||||
|
| sa | tertiary | | D 60A | yes |
|
||||||
|
| ab | tertiary | ab | D 60A | yes |
|
||||||
|
| ac | tertiary | | D 60A | yes |
|
||||||
|
| dbcf | tertiary | dbcf | D 543 | yes |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| waypoints | route | turns | locations |
|
||||||
|
| s,f | ,dbcf,dbcf | depart,turn right,arrive | s,a,f |
|
||||||
|
|
||||||
|
|
||||||
|
@sliproads
|
||||||
|
Scenario: Sliproad to a road with a reference only
|
||||||
|
Given the node map
|
||||||
|
"""
|
||||||
|
s . a . b . d
|
||||||
|
` .
|
||||||
|
' .
|
||||||
|
..
|
||||||
|
c
|
||||||
|
.
|
||||||
|
f
|
||||||
|
"""
|
||||||
|
|
||||||
|
And the ways
|
||||||
|
| nodes | highway | name | ref | oneway |
|
||||||
|
| sabd | primary | road | | |
|
||||||
|
| bcf | primary | | K108 | |
|
||||||
|
| ac | primary_link | | | yes |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| waypoints | route | turns | locations |
|
||||||
|
| s,f | road,, | depart,turn right,arrive | s,a,f |
|
||||||
|
|||||||
@@ -745,12 +745,15 @@ Feature: Basic Roundabout
|
|||||||
|
|
||||||
|
|
||||||
Scenario: Drive through roundabout
|
Scenario: Drive through roundabout
|
||||||
|
Given a grid size of 5 meters
|
||||||
Given the node map
|
Given the node map
|
||||||
"""
|
"""
|
||||||
a
|
. a .
|
||||||
b e d f
|
. .
|
||||||
c
|
b e --- d ---- f
|
||||||
g h
|
. .
|
||||||
|
.c.
|
||||||
|
g h
|
||||||
"""
|
"""
|
||||||
|
|
||||||
And the ways
|
And the ways
|
||||||
@@ -760,12 +763,12 @@ Feature: Basic Roundabout
|
|||||||
| gch | | yes |
|
| gch | | yes |
|
||||||
|
|
||||||
When I route I should get
|
When I route I should get
|
||||||
| waypoints | bearings | route | turns |
|
| waypoints | bearings | route | turns |
|
||||||
| e,f | 90 90 | edf,edf | depart,arrive |
|
| e,f | 90 90 | edf,edf | depart,arrive |
|
||||||
| e,h | 90 135 | edf,gch,gch,gch | depart,roundabout-exit-2,exit roundabout straight,arrive |
|
| e,h | 90 130 | edf,gch,gch,gch | depart,roundabout-exit-2,exit roundabout straight,arrive |
|
||||||
| g,f | 45 90 | gch,edf,edf,edf | depart,roundabout-exit-2,exit roundabout right,arrive |
|
| g,f | 50 90 | gch,edf,edf,edf | depart,roundabout-exit-2,exit roundabout slight right,arrive |
|
||||||
| g,h | 45 135 | gch,gch,gch | depart,exit roundabout right,arrive |
|
| g,h | 50 130 | gch,gch,gch | depart,exit roundabout right,arrive |
|
||||||
| e,e | 90 270 | edf,edf,edf | depart,continue uturn,arrive |
|
| e,e | 90 270 | edf,edf,edf,edf | depart,roundabout-exit-3,exit roundabout sharp left,arrive |
|
||||||
|
|
||||||
Scenario: CCW and CW roundabouts with overlaps
|
Scenario: CCW and CW roundabouts with overlaps
|
||||||
Given the node map
|
Given the node map
|
||||||
|
|||||||
@@ -1372,3 +1372,64 @@ Feature: Simple Turns
|
|||||||
| waypoints | route | turns |
|
| waypoints | route | turns |
|
||||||
| a,d | ab,bcd,bcd | depart,fork slight right,arrive |
|
| a,d | ab,bcd,bcd | depart,fork slight right,arrive |
|
||||||
| a,g | ab,befg,befg | depart,fork slight left,arrive |
|
| a,g | ab,befg,befg | depart,fork slight left,arrive |
|
||||||
|
|
||||||
|
# https://www.openstreetmap.org/#map=18/52.25130/10.42545
|
||||||
|
Scenario: Turn for roads with no name, ref changes
|
||||||
|
Given the node map
|
||||||
|
"""
|
||||||
|
d
|
||||||
|
.
|
||||||
|
.
|
||||||
|
e c . . f
|
||||||
|
.
|
||||||
|
.
|
||||||
|
b
|
||||||
|
.
|
||||||
|
.
|
||||||
|
a
|
||||||
|
"""
|
||||||
|
|
||||||
|
And the ways
|
||||||
|
| nodes | highway | ref | name |
|
||||||
|
| abc | tertiary | K 57 | |
|
||||||
|
| cd | tertiary | K 56 | |
|
||||||
|
| cf | tertiary | K 56 | |
|
||||||
|
| ce | residential | | Heinrichshöhe |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| waypoints | route | turns |
|
||||||
|
| a,f | ,, | depart,turn right,arrive |
|
||||||
|
|
||||||
|
# https://www.openstreetmap.org/#map=18/52.24071/10.29066
|
||||||
|
Scenario: Turn for roads with no name, ref changes
|
||||||
|
Given the node map
|
||||||
|
"""
|
||||||
|
x
|
||||||
|
.
|
||||||
|
.
|
||||||
|
d
|
||||||
|
. .
|
||||||
|
. .
|
||||||
|
. .
|
||||||
|
e. . t . c . p. .f
|
||||||
|
. .
|
||||||
|
. .
|
||||||
|
. .
|
||||||
|
b
|
||||||
|
.
|
||||||
|
.
|
||||||
|
a
|
||||||
|
"""
|
||||||
|
|
||||||
|
And the ways
|
||||||
|
| nodes | highway | ref | name | oneway |
|
||||||
|
| abp | tertiary | K 23 | | yes |
|
||||||
|
| pdx | tertiary | K 23 | | yes |
|
||||||
|
| xdt | tertiary | K 23 | | yes |
|
||||||
|
| tba | tertiary | K 23 | | yes |
|
||||||
|
| etcpf | primary | B 1 | | no |
|
||||||
|
|
||||||
|
When I route I should get
|
||||||
|
| waypoints | route | turns |
|
||||||
|
| e,x | ,,, | depart,turn sharp left,turn right,arrive |
|
||||||
|
| f,a | ,, | depart,turn left,arrive |
|
||||||
|
|||||||
@@ -108,7 +108,7 @@ struct ContractedEdgeContainer
|
|||||||
edges.insert(edges.end(), new_edges.begin(), new_end);
|
edges.insert(edges.end(), new_edges.begin(), new_end);
|
||||||
auto edges_size = edges.size();
|
auto edges_size = edges.size();
|
||||||
auto new_edges_size = std::distance(new_edges.begin(), new_end);
|
auto new_edges_size = std::distance(new_edges.begin(), new_end);
|
||||||
BOOST_ASSERT(edges_size >= new_edges_size);
|
BOOST_ASSERT(static_cast<int>(edges_size) >= new_edges_size);
|
||||||
flags.resize(edges_size);
|
flags.resize(edges_size);
|
||||||
std::fill(flags.begin() + edges_size - new_edges_size, flags.end(), flag);
|
std::fill(flags.begin() + edges_size - new_edges_size, flags.end(), flag);
|
||||||
|
|
||||||
|
|||||||
@@ -77,7 +77,11 @@ struct TurnInstruction
|
|||||||
|
|
||||||
TurnType::Enum type : 5;
|
TurnType::Enum type : 5;
|
||||||
DirectionModifier::Enum direction_modifier : 3;
|
DirectionModifier::Enum direction_modifier : 3;
|
||||||
// the lane tupel that is used for the turn
|
|
||||||
|
bool IsUTurn() const
|
||||||
|
{
|
||||||
|
return type != TurnType::NoTurn && direction_modifier == DirectionModifier::UTurn;
|
||||||
|
}
|
||||||
|
|
||||||
static TurnInstruction INVALID() { return {TurnType::Invalid, DirectionModifier::UTurn}; }
|
static TurnInstruction INVALID() { return {TurnType::Invalid, DirectionModifier::UTurn}; }
|
||||||
|
|
||||||
|
|||||||
@@ -48,14 +48,6 @@ const constexpr char *block_id_to_name[] = {"NAME_CHAR_DATA",
|
|||||||
"HSGR_CHECKSUM",
|
"HSGR_CHECKSUM",
|
||||||
"TIMESTAMP",
|
"TIMESTAMP",
|
||||||
"FILE_INDEX_PATH",
|
"FILE_INDEX_PATH",
|
||||||
"CH_CORE_MARKER_0",
|
|
||||||
"CH_CORE_MARKER_1",
|
|
||||||
"CH_CORE_MARKER_2",
|
|
||||||
"CH_CORE_MARKER_3",
|
|
||||||
"CH_CORE_MARKER_4",
|
|
||||||
"CH_CORE_MARKER_5",
|
|
||||||
"CH_CORE_MARKER_6",
|
|
||||||
"CH_CORE_MARKER_7",
|
|
||||||
"DATASOURCES_NAMES",
|
"DATASOURCES_NAMES",
|
||||||
"PROPERTIES",
|
"PROPERTIES",
|
||||||
"BEARING_CLASSID",
|
"BEARING_CLASSID",
|
||||||
@@ -132,14 +124,6 @@ struct DataLayout
|
|||||||
HSGR_CHECKSUM,
|
HSGR_CHECKSUM,
|
||||||
TIMESTAMP,
|
TIMESTAMP,
|
||||||
FILE_INDEX_PATH,
|
FILE_INDEX_PATH,
|
||||||
CH_CORE_MARKER_0,
|
|
||||||
CH_CORE_MARKER_1,
|
|
||||||
CH_CORE_MARKER_2,
|
|
||||||
CH_CORE_MARKER_3,
|
|
||||||
CH_CORE_MARKER_4,
|
|
||||||
CH_CORE_MARKER_5,
|
|
||||||
CH_CORE_MARKER_6,
|
|
||||||
CH_CORE_MARKER_7,
|
|
||||||
DATASOURCES_NAMES,
|
DATASOURCES_NAMES,
|
||||||
PROPERTIES,
|
PROPERTIES,
|
||||||
BEARING_CLASSID,
|
BEARING_CLASSID,
|
||||||
@@ -200,15 +184,7 @@ struct DataLayout
|
|||||||
|
|
||||||
inline uint64_t GetBlockEntries(BlockID bid) const { return num_entries[bid]; }
|
inline uint64_t GetBlockEntries(BlockID bid) const { return num_entries[bid]; }
|
||||||
|
|
||||||
inline uint64_t GetBlockSize(BlockID bid) const
|
inline uint64_t GetBlockSize(BlockID bid) const { return num_entries[bid] * entry_size[bid]; }
|
||||||
{
|
|
||||||
// special bit encoding
|
|
||||||
if (bid >= CH_CORE_MARKER_0 && bid <= CH_CORE_MARKER_7)
|
|
||||||
{
|
|
||||||
return (num_entries[bid] / 32 + 1) * entry_size[bid];
|
|
||||||
}
|
|
||||||
return num_entries[bid] * entry_size[bid];
|
|
||||||
}
|
|
||||||
|
|
||||||
inline uint64_t GetSizeOfLayout() const
|
inline uint64_t GetSizeOfLayout() const
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -64,7 +64,6 @@ struct StorageConfig final : IOConfig
|
|||||||
{".osrm.hsgr",
|
{".osrm.hsgr",
|
||||||
".osrm.nbg_nodes",
|
".osrm.nbg_nodes",
|
||||||
".osrm.ebg_nodes",
|
".osrm.ebg_nodes",
|
||||||
".osrm.core",
|
|
||||||
".osrm.cells",
|
".osrm.cells",
|
||||||
".osrm.cell_metrics",
|
".osrm.cell_metrics",
|
||||||
".osrm.mldgr",
|
".osrm.mldgr",
|
||||||
|
|||||||
@@ -115,7 +115,7 @@ template <typename EdgeDataT> class DynamicGraph
|
|||||||
|
|
||||||
number_of_nodes = nodes;
|
number_of_nodes = nodes;
|
||||||
number_of_edges = static_cast<EdgeIterator>(graph.size());
|
number_of_edges = static_cast<EdgeIterator>(graph.size());
|
||||||
node_array.resize(number_of_nodes + 1);
|
node_array.resize(number_of_nodes);
|
||||||
EdgeIterator edge = 0;
|
EdgeIterator edge = 0;
|
||||||
EdgeIterator position = 0;
|
EdgeIterator position = 0;
|
||||||
for (const auto node : irange(0u, number_of_nodes))
|
for (const auto node : irange(0u, number_of_nodes))
|
||||||
@@ -129,7 +129,6 @@ template <typename EdgeDataT> class DynamicGraph
|
|||||||
node_array[node].edges = edge - last_edge;
|
node_array[node].edges = edge - last_edge;
|
||||||
position += node_array[node].edges;
|
position += node_array[node].edges;
|
||||||
}
|
}
|
||||||
node_array.back().first_edge = position;
|
|
||||||
edge_list.reserve(static_cast<std::size_t>(edge_list.size() * 1.1));
|
edge_list.reserve(static_cast<std::size_t>(edge_list.size() * 1.1));
|
||||||
edge_list.resize(position);
|
edge_list.resize(position);
|
||||||
edge = 0;
|
edge = 0;
|
||||||
@@ -144,6 +143,8 @@ template <typename EdgeDataT> class DynamicGraph
|
|||||||
++edge;
|
++edge;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_ASSERT(node_array.size() == number_of_nodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy&move for the same data
|
// Copy&move for the same data
|
||||||
@@ -191,6 +192,8 @@ template <typename EdgeDataT> class DynamicGraph
|
|||||||
// Removes all edges to and from nodes for which filter(node_id) returns false
|
// Removes all edges to and from nodes for which filter(node_id) returns false
|
||||||
template <typename Pred> auto Filter(Pred filter) const &
|
template <typename Pred> auto Filter(Pred filter) const &
|
||||||
{
|
{
|
||||||
|
BOOST_ASSERT(node_array.size() == number_of_nodes);
|
||||||
|
|
||||||
DynamicGraph other;
|
DynamicGraph other;
|
||||||
|
|
||||||
other.number_of_nodes = number_of_nodes;
|
other.number_of_nodes = number_of_nodes;
|
||||||
@@ -202,6 +205,8 @@ template <typename EdgeDataT> class DynamicGraph
|
|||||||
std::transform(
|
std::transform(
|
||||||
node_array.begin(), node_array.end(), other.node_array.begin(), [&](const Node &node) {
|
node_array.begin(), node_array.end(), other.node_array.begin(), [&](const Node &node) {
|
||||||
const EdgeIterator first_edge = other.edge_list.size();
|
const EdgeIterator first_edge = other.edge_list.size();
|
||||||
|
|
||||||
|
BOOST_ASSERT(node_id < number_of_nodes);
|
||||||
if (filter(node_id++))
|
if (filter(node_id++))
|
||||||
{
|
{
|
||||||
std::copy_if(edge_list.begin() + node.first_edge,
|
std::copy_if(edge_list.begin() + node.first_edge,
|
||||||
@@ -416,7 +421,7 @@ template <typename EdgeDataT> class DynamicGraph
|
|||||||
void Renumber(const std::vector<NodeID> &old_to_new_node)
|
void Renumber(const std::vector<NodeID> &old_to_new_node)
|
||||||
{
|
{
|
||||||
// permutate everything but the sentinel
|
// permutate everything but the sentinel
|
||||||
util::inplacePermutation(node_array.begin(), std::prev(node_array.end()), old_to_new_node);
|
util::inplacePermutation(node_array.begin(), node_array.end(), old_to_new_node);
|
||||||
|
|
||||||
// Build up edge permutation
|
// Build up edge permutation
|
||||||
auto new_edge_index = 0;
|
auto new_edge_index = 0;
|
||||||
|
|||||||
@@ -26,7 +26,8 @@ namespace guidance
|
|||||||
// Name Change Logic
|
// Name Change Logic
|
||||||
// Used both during Extraction as well as during Post-Processing
|
// Used both during Extraction as well as during Post-Processing
|
||||||
|
|
||||||
inline std::string longest_common_substring(const std::string &lhs, const std::string &rhs)
|
inline util::StringView longest_common_substring(const util::StringView &lhs,
|
||||||
|
const util::StringView &rhs)
|
||||||
{
|
{
|
||||||
if (lhs.empty() || rhs.empty())
|
if (lhs.empty() || rhs.empty())
|
||||||
return "";
|
return "";
|
||||||
@@ -60,15 +61,15 @@ inline std::string longest_common_substring(const std::string &lhs, const std::s
|
|||||||
|
|
||||||
// TODO US-ASCII support only, no UTF-8 support
|
// TODO US-ASCII support only, no UTF-8 support
|
||||||
// While UTF-8 might work in some cases, we do not guarantee full functionality
|
// While UTF-8 might work in some cases, we do not guarantee full functionality
|
||||||
inline auto decompose(const std::string &lhs, const std::string &rhs)
|
template <typename StringView> inline auto decompose(const StringView &lhs, const StringView &rhs)
|
||||||
{
|
{
|
||||||
auto const lcs = longest_common_substring(lhs, rhs);
|
auto const lcs = longest_common_substring(lhs, rhs);
|
||||||
|
|
||||||
// trim spaces, transform to lower
|
// trim spaces, transform to lower
|
||||||
const auto trim = [](auto str) {
|
const auto trim = [](StringView view) {
|
||||||
// we compare suffixes based on this value, it might break UTF chars, but as long as we are
|
// we compare suffixes based on this value, it might break UTF chars, but as long as we are
|
||||||
// consistent in handling, we do not create bad results
|
// consistent in handling, we do not create bad results
|
||||||
boost::to_lower(str);
|
std::string str = boost::to_lower_copy(view.to_string());
|
||||||
auto front = str.find_first_not_of(" ");
|
auto front = str.find_first_not_of(" ");
|
||||||
|
|
||||||
if (front == std::string::npos)
|
if (front == std::string::npos)
|
||||||
@@ -80,8 +81,7 @@ inline auto decompose(const std::string &lhs, const std::string &rhs)
|
|||||||
|
|
||||||
if (lcs.empty())
|
if (lcs.empty())
|
||||||
{
|
{
|
||||||
std::string empty = "";
|
return std::make_tuple(trim(lhs), trim(rhs), std::string(), std::string());
|
||||||
return std::make_tuple(trim(lhs), trim(rhs), empty, empty);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// find the common substring in both
|
// find the common substring in both
|
||||||
@@ -92,32 +92,27 @@ inline auto decompose(const std::string &lhs, const std::string &rhs)
|
|||||||
BOOST_ASSERT(rhs_pos + lcs.size() <= rhs.size());
|
BOOST_ASSERT(rhs_pos + lcs.size() <= rhs.size());
|
||||||
|
|
||||||
// prefixes
|
// prefixes
|
||||||
std::string lhs_prefix = (lhs_pos > 0) ? lhs.substr(0, lhs_pos) : "";
|
auto lhs_prefix = (lhs_pos > 0) ? lhs.substr(0, lhs_pos) : StringView();
|
||||||
std::string rhs_prefix = (rhs_pos > 0) ? rhs.substr(0, rhs_pos) : "";
|
auto rhs_prefix = (rhs_pos > 0) ? rhs.substr(0, rhs_pos) : StringView();
|
||||||
|
|
||||||
// suffices
|
// suffices
|
||||||
std::string lhs_suffix = lhs.substr(lhs_pos + lcs.size());
|
auto lhs_suffix = lhs.substr(lhs_pos + lcs.size());
|
||||||
std::string rhs_suffix = rhs.substr(rhs_pos + lcs.size());
|
auto rhs_suffix = rhs.substr(rhs_pos + lcs.size());
|
||||||
|
|
||||||
lhs_prefix = trim(std::move(lhs_prefix));
|
return std::make_tuple(trim(lhs_prefix), trim(lhs_suffix), trim(rhs_prefix), trim(rhs_suffix));
|
||||||
lhs_suffix = trim(std::move(lhs_suffix));
|
|
||||||
rhs_prefix = trim(std::move(rhs_prefix));
|
|
||||||
rhs_suffix = trim(std::move(rhs_suffix));
|
|
||||||
|
|
||||||
return std::make_tuple(lhs_prefix, lhs_suffix, rhs_prefix, rhs_suffix);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Note: there is an overload without suffix checking below.
|
// Note: there is an overload without suffix checking below.
|
||||||
// (that's the reason we template the suffix table here)
|
// (that's the reason we template the suffix table here)
|
||||||
template <typename SuffixTable>
|
template <typename StringView, typename SuffixTable>
|
||||||
inline bool requiresNameAnnounced(const std::string &from_name,
|
inline bool requiresNameAnnounced(const StringView &from_name,
|
||||||
const std::string &from_ref,
|
const StringView &from_ref,
|
||||||
const std::string &from_pronunciation,
|
const StringView &from_pronunciation,
|
||||||
const std::string &from_exits,
|
const StringView &from_exits,
|
||||||
const std::string &to_name,
|
const StringView &to_name,
|
||||||
const std::string &to_ref,
|
const StringView &to_ref,
|
||||||
const std::string &to_pronunciation,
|
const StringView &to_pronunciation,
|
||||||
const std::string &to_exits,
|
const StringView &to_exits,
|
||||||
const SuffixTable &suffix_table)
|
const SuffixTable &suffix_table)
|
||||||
{
|
{
|
||||||
// first is empty and the second is not
|
// first is empty and the second is not
|
||||||
@@ -134,7 +129,7 @@ inline bool requiresNameAnnounced(const std::string &from_name,
|
|||||||
boost::starts_with(from_name, to_name) || boost::starts_with(to_name, from_name);
|
boost::starts_with(from_name, to_name) || boost::starts_with(to_name, from_name);
|
||||||
|
|
||||||
const auto checkForPrefixOrSuffixChange =
|
const auto checkForPrefixOrSuffixChange =
|
||||||
[](const std::string &first, const std::string &second, const SuffixTable &suffix_table) {
|
[](const StringView &first, const StringView &second, const SuffixTable &suffix_table) {
|
||||||
std::string first_prefix, first_suffix, second_prefix, second_suffix;
|
std::string first_prefix, first_suffix, second_prefix, second_suffix;
|
||||||
std::tie(first_prefix, first_suffix, second_prefix, second_suffix) =
|
std::tie(first_prefix, first_suffix, second_prefix, second_suffix) =
|
||||||
decompose(first, second);
|
decompose(first, second);
|
||||||
@@ -203,17 +198,17 @@ inline bool requiresNameAnnounced(const std::string &from_name,
|
|||||||
struct NopSuffixTable final
|
struct NopSuffixTable final
|
||||||
{
|
{
|
||||||
NopSuffixTable() {}
|
NopSuffixTable() {}
|
||||||
bool isSuffix(const std::string &) const { return false; }
|
bool isSuffix(const StringView &) const { return false; }
|
||||||
} static const table;
|
} static const table;
|
||||||
|
|
||||||
return requiresNameAnnounced(from_name,
|
return requiresNameAnnounced(util::StringView(from_name),
|
||||||
from_ref,
|
util::StringView(from_ref),
|
||||||
from_pronunciation,
|
util::StringView(from_pronunciation),
|
||||||
from_exits,
|
util::StringView(from_exits),
|
||||||
to_name,
|
util::StringView(to_name),
|
||||||
to_ref,
|
util::StringView(to_ref),
|
||||||
to_pronunciation,
|
util::StringView(to_pronunciation),
|
||||||
to_exits,
|
util::StringView(to_exits),
|
||||||
table);
|
table);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -225,37 +220,17 @@ inline bool requiresNameAnnounced(const NameID from_name_id,
|
|||||||
if (from_name_id == to_name_id)
|
if (from_name_id == to_name_id)
|
||||||
return false;
|
return false;
|
||||||
else
|
else
|
||||||
return requiresNameAnnounced(name_table.GetNameForID(from_name_id).to_string(),
|
return requiresNameAnnounced(name_table.GetNameForID(from_name_id),
|
||||||
name_table.GetRefForID(from_name_id).to_string(),
|
name_table.GetRefForID(from_name_id),
|
||||||
name_table.GetPronunciationForID(from_name_id).to_string(),
|
name_table.GetPronunciationForID(from_name_id),
|
||||||
name_table.GetExitsForID(from_name_id).to_string(),
|
name_table.GetExitsForID(from_name_id),
|
||||||
//
|
//
|
||||||
name_table.GetNameForID(to_name_id).to_string(),
|
name_table.GetNameForID(to_name_id),
|
||||||
name_table.GetRefForID(to_name_id).to_string(),
|
name_table.GetRefForID(to_name_id),
|
||||||
name_table.GetPronunciationForID(to_name_id).to_string(),
|
name_table.GetPronunciationForID(to_name_id),
|
||||||
name_table.GetExitsForID(to_name_id).to_string(),
|
name_table.GetExitsForID(to_name_id),
|
||||||
//
|
//
|
||||||
suffix_table);
|
suffix_table);
|
||||||
// FIXME: converts StringViews to strings since the name change heuristics mutates in place
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool requiresNameAnnounced(const NameID from_name_id,
|
|
||||||
const NameID to_name_id,
|
|
||||||
const util::NameTable &name_table)
|
|
||||||
{
|
|
||||||
if (from_name_id == to_name_id)
|
|
||||||
return false;
|
|
||||||
else
|
|
||||||
return requiresNameAnnounced(name_table.GetNameForID(from_name_id).to_string(),
|
|
||||||
name_table.GetRefForID(from_name_id).to_string(),
|
|
||||||
name_table.GetPronunciationForID(from_name_id).to_string(),
|
|
||||||
name_table.GetExitsForID(from_name_id).to_string(),
|
|
||||||
//
|
|
||||||
name_table.GetNameForID(to_name_id).to_string(),
|
|
||||||
name_table.GetRefForID(to_name_id).to_string(),
|
|
||||||
name_table.GetExitsForID(to_name_id).to_string(),
|
|
||||||
name_table.GetPronunciationForID(to_name_id).to_string());
|
|
||||||
// FIXME: converts StringViews to strings since the name change heuristics mutates in place
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace guidance
|
} // namespace guidance
|
||||||
|
|||||||
+1
-1
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "osrm",
|
"name": "osrm",
|
||||||
"version": "5.14.0",
|
"version": "5.14.3",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "The Open Source Routing Machine is a high performance routing engine written in C++14 designed to run on OpenStreetMap data.",
|
"description": "The Open Source Routing Machine is a high performance routing engine written in C++14 designed to run on OpenStreetMap data.",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|||||||
+2
-1
@@ -253,6 +253,8 @@ function setup()
|
|||||||
["at:rural"] = 100,
|
["at:rural"] = 100,
|
||||||
["at:trunk"] = 100,
|
["at:trunk"] = 100,
|
||||||
["be:motorway"] = 120,
|
["be:motorway"] = 120,
|
||||||
|
["by:urban"] = 60,
|
||||||
|
["by:motorway"] = 110,
|
||||||
["ch:rural"] = 80,
|
["ch:rural"] = 80,
|
||||||
["ch:trunk"] = 100,
|
["ch:trunk"] = 100,
|
||||||
["ch:motorway"] = 120,
|
["ch:motorway"] = 120,
|
||||||
@@ -276,7 +278,6 @@ function setup()
|
|||||||
["ru:living_street"] = 20,
|
["ru:living_street"] = 20,
|
||||||
["ru:urban"] = 60,
|
["ru:urban"] = 60,
|
||||||
["ru:motorway"] = 110,
|
["ru:motorway"] = 110,
|
||||||
["ua:urban"] = 60,
|
|
||||||
["uk:nsl_single"] = (60*1609)/1000,
|
["uk:nsl_single"] = (60*1609)/1000,
|
||||||
["uk:nsl_dual"] = (70*1609)/1000,
|
["uk:nsl_dual"] = (70*1609)/1000,
|
||||||
["uk:motorway"] = (70*1609)/1000,
|
["uk:motorway"] = (70*1609)/1000,
|
||||||
|
|||||||
@@ -384,7 +384,7 @@ void RenumberData(std::vector<RemainingNodeData> &remaining_nodes,
|
|||||||
// we need to make a copy here because we are going to modify it
|
// we need to make a copy here because we are going to modify it
|
||||||
auto to_orig = new_to_old_node_id;
|
auto to_orig = new_to_old_node_id;
|
||||||
|
|
||||||
auto new_node_id = 0;
|
auto new_node_id = 0u;
|
||||||
|
|
||||||
// All remaining nodes get the low IDs
|
// All remaining nodes get the low IDs
|
||||||
for (auto &remaining : remaining_nodes)
|
for (auto &remaining : remaining_nodes)
|
||||||
|
|||||||
@@ -41,15 +41,14 @@ bool noIntermediaryIntersections(const RouteStep &step)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Link roads, as far as we are concerned, are short unnamed segments between to named segments.
|
// Link roads, as far as we are concerned, are short unnamed segments between to named segments.
|
||||||
bool isLinkroad(const RouteStep &pre_link_step,
|
bool isLinkRoad(const RouteStep &pre_link_step,
|
||||||
const RouteStep &link_step,
|
const RouteStep &link_step,
|
||||||
const RouteStep &post_link_step)
|
const RouteStep &post_link_step)
|
||||||
{
|
{
|
||||||
const constexpr double MAX_LINK_ROAD_LENGTH = 2 * MAX_COLLAPSE_DISTANCE;
|
const constexpr double MAX_LINK_ROAD_LENGTH = 2 * MAX_COLLAPSE_DISTANCE;
|
||||||
const auto is_short = link_step.distance <= MAX_LINK_ROAD_LENGTH;
|
const auto is_short = link_step.distance <= MAX_LINK_ROAD_LENGTH;
|
||||||
const auto unnamed = link_step.name_id == EMPTY_NAMEID;
|
const auto unnamed = link_step.name.empty();
|
||||||
const auto between_named =
|
const auto between_named = !pre_link_step.name.empty() && !post_link_step.name.empty();
|
||||||
(pre_link_step.name_id != EMPTY_NAMEID) && (post_link_step.name_id != EMPTY_NAMEID);
|
|
||||||
|
|
||||||
return is_short && unnamed && between_named && noIntermediaryIntersections(link_step);
|
return is_short && unnamed && between_named && noIntermediaryIntersections(link_step);
|
||||||
}
|
}
|
||||||
@@ -196,7 +195,7 @@ bool isUTurn(const RouteStepIterator step_prior_to_intersection,
|
|||||||
const auto only_allowed_turn = (numberOfAllowedTurns(*step_leaving_intersection) == 1) &&
|
const auto only_allowed_turn = (numberOfAllowedTurns(*step_leaving_intersection) == 1) &&
|
||||||
noIntermediaryIntersections(*step_entering_intersection);
|
noIntermediaryIntersections(*step_entering_intersection);
|
||||||
|
|
||||||
return collapsable || isLinkroad(*step_prior_to_intersection,
|
return collapsable || isLinkRoad(*step_prior_to_intersection,
|
||||||
*step_entering_intersection,
|
*step_entering_intersection,
|
||||||
*step_leaving_intersection) ||
|
*step_leaving_intersection) ||
|
||||||
only_allowed_turn;
|
only_allowed_turn;
|
||||||
|
|||||||
@@ -784,9 +784,8 @@ InternalManyRoutesResult alternativePathSearch(SearchEngineData<Algorithm> &sear
|
|||||||
begin(weighted_packed_paths) + 1,
|
begin(weighted_packed_paths) + 1,
|
||||||
alternative_paths_last);
|
alternative_paths_last);
|
||||||
|
|
||||||
alternative_paths_last = filterPackedPathsByCellSharing(begin(weighted_packed_paths), //
|
alternative_paths_last = filterPackedPathsByCellSharing(
|
||||||
end(weighted_packed_paths), //
|
begin(weighted_packed_paths), alternative_paths_last, partition);
|
||||||
partition); //
|
|
||||||
|
|
||||||
BOOST_ASSERT(weighted_packed_paths.size() >= 1);
|
BOOST_ASSERT(weighted_packed_paths.size() >= 1);
|
||||||
|
|
||||||
|
|||||||
@@ -375,7 +375,9 @@ EdgeBasedGraphFactory::GenerateEdgeExpandedNodes(const WayRestrictionMap &way_re
|
|||||||
m_edge_based_node_container.nodes[edge_based_node_id].segregated =
|
m_edge_based_node_container.nodes[edge_based_node_id].segregated =
|
||||||
segregated_edges.count(eid) > 0;
|
segregated_edges.count(eid) > 0;
|
||||||
|
|
||||||
m_edge_based_node_weights.push_back(m_edge_based_node_weights[eid]);
|
const auto ebn_weight = m_edge_based_node_weights[nbe_to_ebn_mapping[eid]];
|
||||||
|
BOOST_ASSERT(ebn_weight == INVALID_EDGE_WEIGHT || ebn_weight == edge_data.weight);
|
||||||
|
m_edge_based_node_weights.push_back(ebn_weight);
|
||||||
|
|
||||||
edge_based_node_id++;
|
edge_based_node_id++;
|
||||||
progress.PrintStatus(progress_counter++);
|
progress.PrintStatus(progress_counter++);
|
||||||
@@ -580,7 +582,7 @@ void EdgeBasedGraphFactory::GenerateEdgeExpandedEdges(
|
|||||||
ExtractionTurn extracted_turn(
|
ExtractionTurn extracted_turn(
|
||||||
turn.angle,
|
turn.angle,
|
||||||
m_node_based_graph.GetOutDegree(node_at_center_of_intersection),
|
m_node_based_graph.GetOutDegree(node_at_center_of_intersection),
|
||||||
turn.instruction.direction_modifier == guidance::DirectionModifier::UTurn,
|
turn.instruction.IsUTurn(),
|
||||||
is_traffic_light,
|
is_traffic_light,
|
||||||
edge_data1.flags.restricted,
|
edge_data1.flags.restricted,
|
||||||
edge_data2.flags.restricted,
|
edge_data2.flags.restricted,
|
||||||
|
|||||||
@@ -71,17 +71,19 @@ TurnType::Enum IntersectionHandler::findBasicTurnType(const EdgeID via_edge,
|
|||||||
if (!on_ramp && onto_ramp)
|
if (!on_ramp && onto_ramp)
|
||||||
return TurnType::OnRamp;
|
return TurnType::OnRamp;
|
||||||
|
|
||||||
const auto &in_name =
|
const auto &in_name_id =
|
||||||
node_data_container.GetAnnotation(node_based_graph.GetEdgeData(via_edge).annotation_data)
|
node_data_container.GetAnnotation(node_based_graph.GetEdgeData(via_edge).annotation_data)
|
||||||
.name_id;
|
.name_id;
|
||||||
const auto &out_name =
|
const auto &out_name_id =
|
||||||
node_data_container.GetAnnotation(node_based_graph.GetEdgeData(road.eid).annotation_data)
|
node_data_container.GetAnnotation(node_based_graph.GetEdgeData(road.eid).annotation_data)
|
||||||
.name_id;
|
.name_id;
|
||||||
|
const auto &in_name_empty = name_table.GetNameForID(in_name_id).empty();
|
||||||
|
const auto &out_name_empty = name_table.GetNameForID(out_name_id).empty();
|
||||||
|
|
||||||
const auto same_name = !util::guidance::requiresNameAnnounced(
|
const auto same_name = !util::guidance::requiresNameAnnounced(
|
||||||
in_name, out_name, name_table, street_name_suffix_table);
|
in_name_id, out_name_id, name_table, street_name_suffix_table);
|
||||||
|
|
||||||
if (in_name != EMPTY_NAMEID && out_name != EMPTY_NAMEID && same_name)
|
if (!in_name_empty && !out_name_empty && same_name)
|
||||||
{
|
{
|
||||||
return TurnType::Continue;
|
return TurnType::Continue;
|
||||||
}
|
}
|
||||||
@@ -488,8 +490,8 @@ bool IntersectionHandler::isSameName(const EdgeID source_edge_id, const EdgeID t
|
|||||||
const auto &target_edge_data = node_data_container.GetAnnotation(
|
const auto &target_edge_data = node_data_container.GetAnnotation(
|
||||||
node_based_graph.GetEdgeData(target_edge_id).annotation_data);
|
node_based_graph.GetEdgeData(target_edge_id).annotation_data);
|
||||||
|
|
||||||
return source_edge_data.name_id != EMPTY_NAMEID && //
|
return !name_table.GetNameForID(source_edge_data.name_id).empty() && //
|
||||||
target_edge_data.name_id != EMPTY_NAMEID && //
|
!name_table.GetNameForID(target_edge_data.name_id).empty() && //
|
||||||
!util::guidance::requiresNameAnnounced(source_edge_data.name_id,
|
!util::guidance::requiresNameAnnounced(source_edge_data.name_id,
|
||||||
target_edge_data.name_id,
|
target_edge_data.name_id,
|
||||||
name_table,
|
name_table,
|
||||||
|
|||||||
@@ -23,6 +23,8 @@ namespace guidance
|
|||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
// check a connected road for equality of a name
|
// check a connected road for equality of a name
|
||||||
|
// returns 'true' if no equality because this is used as a filter elsewhere, i.e. filter if fn
|
||||||
|
// returns 'true'
|
||||||
inline auto makeCheckRoadForName(const NameID name_id,
|
inline auto makeCheckRoadForName(const NameID name_id,
|
||||||
const util::NodeBasedDynamicGraph &node_based_graph,
|
const util::NodeBasedDynamicGraph &node_based_graph,
|
||||||
const EdgeBasedNodeDataContainer &node_data_container,
|
const EdgeBasedNodeDataContainer &node_data_container,
|
||||||
@@ -32,15 +34,18 @@ inline auto makeCheckRoadForName(const NameID name_id,
|
|||||||
return [name_id, &node_based_graph, &node_data_container, &name_table, &suffix_table](
|
return [name_id, &node_based_graph, &node_data_container, &name_table, &suffix_table](
|
||||||
const MergableRoadDetector::MergableRoadData &road) {
|
const MergableRoadDetector::MergableRoadData &road) {
|
||||||
// since we filter here, we don't want any other name than the one we are looking for
|
// since we filter here, we don't want any other name than the one we are looking for
|
||||||
const auto road_name =
|
const auto road_name_id =
|
||||||
node_data_container
|
node_data_container
|
||||||
.GetAnnotation(node_based_graph.GetEdgeData(road.eid).annotation_data)
|
.GetAnnotation(node_based_graph.GetEdgeData(road.eid).annotation_data)
|
||||||
.name_id;
|
.name_id;
|
||||||
if (name_id == EMPTY_NAMEID || road_name == EMPTY_NAMEID)
|
const auto road_name_empty = name_table.GetNameForID(road_name_id).empty();
|
||||||
|
const auto in_name_empty = name_table.GetNameForID(name_id).empty();
|
||||||
|
if (in_name_empty || road_name_empty)
|
||||||
return true;
|
return true;
|
||||||
const auto requires_announcement =
|
const auto requires_announcement =
|
||||||
util::guidance::requiresNameAnnounced(name_id, road_name, name_table, suffix_table) ||
|
util::guidance::requiresNameAnnounced(
|
||||||
util::guidance::requiresNameAnnounced(road_name, name_id, name_table, suffix_table);
|
name_id, road_name_id, name_table, suffix_table) ||
|
||||||
|
util::guidance::requiresNameAnnounced(road_name_id, name_id, name_table, suffix_table);
|
||||||
|
|
||||||
return requires_announcement;
|
return requires_announcement;
|
||||||
};
|
};
|
||||||
@@ -465,16 +470,18 @@ bool MergableRoadDetector::IsTrafficIsland(const NodeID intersection_node,
|
|||||||
.name_id;
|
.name_id;
|
||||||
|
|
||||||
const auto has_required_name = [this, required_name_id](const auto edge_id) {
|
const auto has_required_name = [this, required_name_id](const auto edge_id) {
|
||||||
const auto road_name =
|
const auto road_name_id =
|
||||||
node_data_container
|
node_data_container
|
||||||
.GetAnnotation(node_based_graph.GetEdgeData(edge_id).annotation_data)
|
.GetAnnotation(node_based_graph.GetEdgeData(edge_id).annotation_data)
|
||||||
.name_id;
|
.name_id;
|
||||||
if (required_name_id == EMPTY_NAMEID || road_name == EMPTY_NAMEID)
|
const auto &road_name_empty = name_table.GetNameForID(road_name_id).empty();
|
||||||
|
const auto &required_name_empty = name_table.GetNameForID(required_name_id).empty();
|
||||||
|
if (required_name_empty && road_name_empty)
|
||||||
return false;
|
return false;
|
||||||
return !util::guidance::requiresNameAnnounced(
|
return !util::guidance::requiresNameAnnounced(
|
||||||
required_name_id, road_name, name_table, street_name_suffix_table) ||
|
required_name_id, road_name_id, name_table, street_name_suffix_table) ||
|
||||||
!util::guidance::requiresNameAnnounced(
|
!util::guidance::requiresNameAnnounced(
|
||||||
road_name, required_name_id, name_table, street_name_suffix_table);
|
road_name_id, required_name_id, name_table, street_name_suffix_table);
|
||||||
};
|
};
|
||||||
|
|
||||||
/* the beautiful way would be:
|
/* the beautiful way would be:
|
||||||
|
|||||||
@@ -379,11 +379,15 @@ Intersection MotorwayHandler::fromRamp(const EdgeID via_eid, Intersection inters
|
|||||||
//
|
//
|
||||||
// 7 1
|
// 7 1
|
||||||
// 0
|
// 0
|
||||||
|
const auto &first_intersection_name_empty =
|
||||||
|
name_table.GetNameForID(first_intersection_data.name_id).empty();
|
||||||
|
const auto &second_intersection_name_empty =
|
||||||
|
name_table.GetNameForID(second_intersection_data.name_id).empty();
|
||||||
if (intersection[1].entry_allowed)
|
if (intersection[1].entry_allowed)
|
||||||
{
|
{
|
||||||
if (isMotorwayClass(intersection[1].eid, node_based_graph) &&
|
if (isMotorwayClass(intersection[1].eid, node_based_graph) &&
|
||||||
second_intersection_data.name_id != EMPTY_NAMEID &&
|
!second_intersection_name_empty && !first_intersection_name_empty &&
|
||||||
first_intersection_data.name_id != EMPTY_NAMEID && first_second_same_name)
|
first_second_same_name)
|
||||||
{
|
{
|
||||||
// circular order indicates a merge to the left (0-3 onto 4
|
// circular order indicates a merge to the left (0-3 onto 4
|
||||||
if (angularDeviation(intersection[1].angle, STRAIGHT_ANGLE) <
|
if (angularDeviation(intersection[1].angle, STRAIGHT_ANGLE) <
|
||||||
@@ -407,8 +411,8 @@ Intersection MotorwayHandler::fromRamp(const EdgeID via_eid, Intersection inters
|
|||||||
{
|
{
|
||||||
BOOST_ASSERT(intersection[2].entry_allowed);
|
BOOST_ASSERT(intersection[2].entry_allowed);
|
||||||
if (isMotorwayClass(intersection[2].eid, node_based_graph) &&
|
if (isMotorwayClass(intersection[2].eid, node_based_graph) &&
|
||||||
second_intersection_data.name_id != EMPTY_NAMEID &&
|
!second_intersection_name_empty && !first_intersection_name_empty &&
|
||||||
first_intersection_data.name_id != EMPTY_NAMEID && first_second_same_name)
|
first_second_same_name)
|
||||||
{
|
{
|
||||||
// circular order (5-0) onto 4
|
// circular order (5-0) onto 4
|
||||||
if (angularDeviation(intersection[2].angle, STRAIGHT_ANGLE) <
|
if (angularDeviation(intersection[2].angle, STRAIGHT_ANGLE) <
|
||||||
|
|||||||
@@ -295,7 +295,8 @@ RoundaboutType RoundaboutHandler::getRoundaboutType(const NodeID nid) const
|
|||||||
return SPECIAL_EDGEID;
|
return SPECIAL_EDGEID;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (EMPTY_NAMEID != edge_data.name_id)
|
const auto &edge_name_empty = name_table.GetNameForID(edge_data.name_id).empty();
|
||||||
|
if (!edge_name_empty)
|
||||||
{
|
{
|
||||||
|
|
||||||
const auto announce = [&](unsigned id) {
|
const auto announce = [&](unsigned id) {
|
||||||
@@ -306,7 +307,6 @@ RoundaboutType RoundaboutHandler::getRoundaboutType(const NodeID nid) const
|
|||||||
if (std::all_of(begin(roundabout_name_ids), end(roundabout_name_ids), announce))
|
if (std::all_of(begin(roundabout_name_ids), end(roundabout_name_ids), announce))
|
||||||
roundabout_name_ids.insert(edge_data.name_id);
|
roundabout_name_ids.insert(edge_data.name_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
continue_edge = edge_id;
|
continue_edge = edge_id;
|
||||||
}
|
}
|
||||||
else if (!edge.flags.roundabout && !edge.flags.circular)
|
else if (!edge.flags.roundabout && !edge.flags.circular)
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
#include "extractor/guidance/sliproad_handler.hpp"
|
#include "extractor/guidance/sliproad_handler.hpp"
|
||||||
#include "extractor/guidance/constants.hpp"
|
#include "extractor/guidance/constants.hpp"
|
||||||
|
#include "util/assert.hpp"
|
||||||
#include "util/bearing.hpp"
|
#include "util/bearing.hpp"
|
||||||
#include "util/coordinate_calculation.hpp"
|
#include "util/coordinate_calculation.hpp"
|
||||||
#include "util/guidance/name_announcements.hpp"
|
#include "util/guidance/name_announcements.hpp"
|
||||||
@@ -474,10 +475,7 @@ operator()(const NodeID /*nid*/, const EdgeID source_edge_id, Intersection inter
|
|||||||
|
|
||||||
// Name mismatch: check roads at `c` and `d` for same name
|
// Name mismatch: check roads at `c` and `d` for same name
|
||||||
const auto name_mismatch = [&](const NameID road_name_id) {
|
const auto name_mismatch = [&](const NameID road_name_id) {
|
||||||
const auto unnamed = road_name_id == EMPTY_NAMEID;
|
return util::guidance::requiresNameAnnounced(road_name_id, //
|
||||||
|
|
||||||
return unnamed ||
|
|
||||||
util::guidance::requiresNameAnnounced(road_name_id, //
|
|
||||||
candidate_data.name_id, //
|
candidate_data.name_id, //
|
||||||
name_table, //
|
name_table, //
|
||||||
street_name_suffix_table); //
|
street_name_suffix_table); //
|
||||||
@@ -499,11 +497,15 @@ operator()(const NodeID /*nid*/, const EdgeID source_edge_id, Intersection inter
|
|||||||
node_data_container
|
node_data_container
|
||||||
.GetAnnotation(node_based_graph.GetEdgeData(main_road.eid).annotation_data)
|
.GetAnnotation(node_based_graph.GetEdgeData(main_road.eid).annotation_data)
|
||||||
.name_id;
|
.name_id;
|
||||||
|
const auto main_road_name_empty = name_table.GetNameForID(main_road_name_id).empty();
|
||||||
const auto &sliproad_annotation =
|
const auto &sliproad_annotation =
|
||||||
node_data_container.GetAnnotation(sliproad_edge_data.annotation_data);
|
node_data_container.GetAnnotation(sliproad_edge_data.annotation_data);
|
||||||
|
const auto sliproad_name_empty =
|
||||||
|
name_table.GetNameForID(sliproad_annotation.name_id).empty();
|
||||||
|
const auto candidate_road_name_empty =
|
||||||
|
name_table.GetNameForID(candidate_data.name_id).empty();
|
||||||
if (!sliproad_edge_data.flags.road_classification.IsLinkClass() &&
|
if (!sliproad_edge_data.flags.road_classification.IsLinkClass() &&
|
||||||
sliproad_annotation.name_id != EMPTY_NAMEID && main_road_name_id != EMPTY_NAMEID &&
|
!sliproad_name_empty && !main_road_name_empty && !candidate_road_name_empty &&
|
||||||
candidate_data.name_id != EMPTY_NAMEID &&
|
|
||||||
util::guidance::requiresNameAnnounced(main_road_name_id,
|
util::guidance::requiresNameAnnounced(main_road_name_id,
|
||||||
sliproad_annotation.name_id,
|
sliproad_annotation.name_id,
|
||||||
name_table,
|
name_table,
|
||||||
@@ -575,7 +577,7 @@ operator()(const NodeID /*nid*/, const EdgeID source_edge_id, Intersection inter
|
|||||||
intersection[*obvious].instruction.direction_modifier =
|
intersection[*obvious].instruction.direction_modifier =
|
||||||
getTurnDirection(intersection[*obvious].angle);
|
getTurnDirection(intersection[*obvious].angle);
|
||||||
}
|
}
|
||||||
else if (main_annotation.name_id != EMPTY_NAMEID)
|
else if (!name_table.GetNameForID(main_annotation.name_id).empty())
|
||||||
{
|
{
|
||||||
intersection[*obvious].instruction.type = TurnType::NewName;
|
intersection[*obvious].instruction.type = TurnType::NewName;
|
||||||
intersection[*obvious].instruction.direction_modifier =
|
intersection[*obvious].instruction.direction_modifier =
|
||||||
|
|||||||
@@ -199,7 +199,8 @@ bool TurnHandler::isObviousOfTwo(const EdgeID via_edge,
|
|||||||
|
|
||||||
const bool turn_is_perfectly_straight =
|
const bool turn_is_perfectly_straight =
|
||||||
angularDeviation(road.angle, STRAIGHT_ANGLE) < std::numeric_limits<double>::epsilon();
|
angularDeviation(road.angle, STRAIGHT_ANGLE) < std::numeric_limits<double>::epsilon();
|
||||||
if (via_data.name_id != EMPTY_NAMEID)
|
const auto &via_name_empty = name_table.GetNameForID(via_data.name_id).empty();
|
||||||
|
if (!via_name_empty)
|
||||||
{
|
{
|
||||||
const auto same_name = !util::guidance::requiresNameAnnounced(
|
const auto same_name = !util::guidance::requiresNameAnnounced(
|
||||||
via_data.name_id, road_data.name_id, name_table, street_name_suffix_table);
|
via_data.name_id, road_data.name_id, name_table, street_name_suffix_table);
|
||||||
|
|||||||
@@ -331,43 +331,6 @@ void Storage::PopulateLayout(DataLayout &layout)
|
|||||||
layout.SetBlockSize<char>(DataLayout::TIMESTAMP, timestamp_size);
|
layout.SetBlockSize<char>(DataLayout::TIMESTAMP, timestamp_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
// load core marker size
|
|
||||||
if (boost::filesystem::exists(config.GetPath(".osrm.core")))
|
|
||||||
{
|
|
||||||
io::FileReader core_marker_file(config.GetPath(".osrm.core"),
|
|
||||||
io::FileReader::VerifyFingerprint);
|
|
||||||
const auto num_metrics = core_marker_file.ReadElementCount64();
|
|
||||||
if (num_metrics > NUM_METRICS)
|
|
||||||
{
|
|
||||||
throw util::exception("Only " + std::to_string(NUM_METRICS) +
|
|
||||||
" metrics are supported at the same time.");
|
|
||||||
}
|
|
||||||
|
|
||||||
const auto number_of_core_markers = core_marker_file.ReadElementCount64();
|
|
||||||
for (const auto index : util::irange<std::size_t>(0, num_metrics))
|
|
||||||
{
|
|
||||||
layout.SetBlockSize<unsigned>(
|
|
||||||
static_cast<DataLayout::BlockID>(DataLayout::CH_CORE_MARKER_0 + index),
|
|
||||||
number_of_core_markers);
|
|
||||||
}
|
|
||||||
for (const auto index : util::irange<std::size_t>(num_metrics, NUM_METRICS))
|
|
||||||
{
|
|
||||||
layout.SetBlockSize<unsigned>(
|
|
||||||
static_cast<DataLayout::BlockID>(DataLayout::CH_CORE_MARKER_0 + index), 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_0, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_1, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_2, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_3, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_4, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_5, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_6, 0);
|
|
||||||
layout.SetBlockSize<unsigned>(DataLayout::CH_CORE_MARKER_7, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
// load turn weight penalties
|
// load turn weight penalties
|
||||||
{
|
{
|
||||||
io::FileReader turn_weight_penalties_file(config.GetPath(".osrm.turn_weight_penalties"),
|
io::FileReader turn_weight_penalties_file(config.GetPath(".osrm.turn_weight_penalties"),
|
||||||
|
|||||||
+2
-1
@@ -147,6 +147,8 @@
|
|||||||
{"key": "maxspeed", "value": "AT:rural"},
|
{"key": "maxspeed", "value": "AT:rural"},
|
||||||
{"key": "maxspeed", "value": "AT:trunk"},
|
{"key": "maxspeed", "value": "AT:trunk"},
|
||||||
{"key": "maxspeed", "value": "BE:motorway"},
|
{"key": "maxspeed", "value": "BE:motorway"},
|
||||||
|
{"key": "maxspeed", "value": "BY:urban"},
|
||||||
|
{"key": "maxspeed", "value": "BY:motorway"},
|
||||||
{"key": "maxspeed", "value": "CH:rural"},
|
{"key": "maxspeed", "value": "CH:rural"},
|
||||||
{"key": "maxspeed", "value": "CH:trunk"},
|
{"key": "maxspeed", "value": "CH:trunk"},
|
||||||
{"key": "maxspeed", "value": "CH:motorway"},
|
{"key": "maxspeed", "value": "CH:motorway"},
|
||||||
@@ -170,7 +172,6 @@
|
|||||||
{"key": "maxspeed", "value": "RU:living_street"},
|
{"key": "maxspeed", "value": "RU:living_street"},
|
||||||
{"key": "maxspeed", "value": "RU:urban"},
|
{"key": "maxspeed", "value": "RU:urban"},
|
||||||
{"key": "maxspeed", "value": "RU:motorway"},
|
{"key": "maxspeed", "value": "RU:motorway"},
|
||||||
{"key": "maxspeed", "value": "UA:urban"},
|
|
||||||
{"key": "maxspeed", "value": "UK:nsl_single"},
|
{"key": "maxspeed", "value": "UK:nsl_single"},
|
||||||
{"key": "maxspeed", "value": "UK:nsl_dual"},
|
{"key": "maxspeed", "value": "UK:nsl_dual"},
|
||||||
{"key": "maxspeed", "value": "UK:motorway"},
|
{"key": "maxspeed", "value": "UK:motorway"},
|
||||||
|
|||||||
Reference in New Issue
Block a user