2016-05-12 12:50:10 -04:00
|
|
|
api_version = 1
|
2016-12-01 17:10:56 -05:00
|
|
|
|
2015-05-01 14:06:45 -04:00
|
|
|
-- Bicycle profile
|
|
|
|
local find_access_tag = require("lib/access").find_access_tag
|
2017-02-04 17:05:00 -05:00
|
|
|
local Set = require('lib/set')
|
|
|
|
local Sequence = require('lib/sequence')
|
2017-02-04 17:50:00 -05:00
|
|
|
local Handlers = require("lib/handlers")
|
|
|
|
local next = next -- bind to local for speed
|
2015-05-01 14:06:45 -04:00
|
|
|
local limit = require("lib/maxspeed").limit
|
2012-12-19 09:53:05 -05:00
|
|
|
|
2015-12-18 09:54:33 -05:00
|
|
|
-- these need to be global because they are accesed externaly
|
2016-11-01 17:13:10 -04:00
|
|
|
properties.max_speed_for_map_matching = 110/3.6 -- kmph -> m/s
|
|
|
|
properties.use_turn_restrictions = false
|
2016-04-12 12:47:00 -04:00
|
|
|
properties.continue_straight_at_waypoint = false
|
2016-05-12 12:50:10 -04:00
|
|
|
properties.weight_name = 'duration'
|
|
|
|
--properties.weight_name = 'cyclability'
|
2015-05-16 08:36:32 -04:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
|
|
|
|
local default_speed = 15
|
|
|
|
local walking_speed = 6
|
|
|
|
|
|
|
|
local profile = {
|
2017-02-04 17:50:00 -05:00
|
|
|
default_mode = mode.cycling,
|
|
|
|
default_speed = 15,
|
|
|
|
oneway_handling = true,
|
2017-02-04 17:05:00 -05:00
|
|
|
traffic_light_penalty = 2,
|
|
|
|
u_turn_penalty = 20,
|
|
|
|
turn_penalty = 6,
|
|
|
|
turn_bias = 1.4,
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
-- reduce the driving speed by 30% for unsafe roads
|
|
|
|
-- local safety_penalty = 0.7,
|
|
|
|
safety_penalty = 1.0,
|
|
|
|
use_public_transport = true,
|
|
|
|
|
2017-02-04 17:50:00 -05:00
|
|
|
allowed_start_modes = Set {
|
|
|
|
mode.cycling,
|
|
|
|
mode.pushing_bike
|
|
|
|
},
|
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
barrier_whitelist = Set {
|
|
|
|
'cycle_barrier',
|
|
|
|
'bollard',
|
|
|
|
'entrance',
|
|
|
|
'cattle_grid',
|
|
|
|
'border_control',
|
|
|
|
'toll_booth',
|
|
|
|
'sally_port',
|
|
|
|
'gate',
|
|
|
|
'no',
|
|
|
|
'block'
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
access_tag_whitelist = Set {
|
|
|
|
'yes',
|
|
|
|
'permissive',
|
|
|
|
'designated'
|
|
|
|
},
|
|
|
|
|
|
|
|
access_tag_blacklist = Set {
|
|
|
|
'no',
|
|
|
|
'private',
|
|
|
|
'agricultural',
|
|
|
|
'forestry',
|
|
|
|
'delivery'
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
access_tags_hierarchy = Sequence {
|
|
|
|
'bicycle',
|
|
|
|
'vehicle',
|
|
|
|
'access'
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
restrictions = Set {
|
|
|
|
'bicycle'
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
cycleway_tags = Set {
|
|
|
|
'track',
|
|
|
|
'lane',
|
|
|
|
'opposite',
|
|
|
|
'opposite_lane',
|
|
|
|
'opposite_track',
|
|
|
|
'share_busway',
|
|
|
|
'sharrow',
|
|
|
|
'shared'
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
unsafe_highway_list = Set {
|
|
|
|
'primary',
|
|
|
|
'secondary',
|
|
|
|
'tertiary',
|
|
|
|
'primary_link',
|
|
|
|
'secondary_link',
|
|
|
|
'tertiary_link'
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
bicycle_speeds = {
|
|
|
|
cycleway = default_speed,
|
|
|
|
primary = default_speed,
|
|
|
|
primary_link = default_speed,
|
|
|
|
secondary = default_speed,
|
|
|
|
secondary_link = default_speed,
|
|
|
|
tertiary = default_speed,
|
|
|
|
tertiary_link = default_speed,
|
|
|
|
residential = default_speed,
|
|
|
|
unclassified = default_speed,
|
|
|
|
living_street = default_speed,
|
|
|
|
road = default_speed,
|
|
|
|
service = default_speed,
|
|
|
|
track = 12,
|
|
|
|
path = 12
|
|
|
|
},
|
2017-02-04 17:50:00 -05:00
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
pedestrian_speeds = {
|
|
|
|
footway = walking_speed,
|
|
|
|
pedestrian = walking_speed,
|
|
|
|
steps = 2
|
|
|
|
},
|
|
|
|
|
|
|
|
railway_speeds = {
|
|
|
|
train = 10,
|
|
|
|
railway = 10,
|
|
|
|
subway = 10,
|
|
|
|
light_rail = 10,
|
|
|
|
monorail = 10,
|
|
|
|
tram = 10
|
|
|
|
},
|
|
|
|
|
|
|
|
platform_speeds = {
|
|
|
|
platform = walking_speed
|
|
|
|
},
|
|
|
|
|
|
|
|
amenity_speeds = {
|
|
|
|
parking = 10,
|
|
|
|
parking_entrance = 10
|
|
|
|
},
|
|
|
|
|
|
|
|
man_made_speeds = {
|
|
|
|
pier = walking_speed
|
|
|
|
},
|
|
|
|
|
|
|
|
route_speeds = {
|
|
|
|
ferry = 5
|
|
|
|
},
|
|
|
|
|
|
|
|
bridge_speeds = {
|
|
|
|
movable = 5
|
|
|
|
},
|
|
|
|
|
|
|
|
surface_speeds = {
|
|
|
|
asphalt = default_speed,
|
|
|
|
["cobblestone:flattened"] = 10,
|
|
|
|
paving_stones = 10,
|
|
|
|
compacted = 10,
|
|
|
|
cobblestone = 6,
|
|
|
|
unpaved = 6,
|
|
|
|
fine_gravel = 6,
|
|
|
|
gravel = 6,
|
|
|
|
pebblestone = 6,
|
|
|
|
ground = 6,
|
|
|
|
dirt = 6,
|
|
|
|
earth = 6,
|
|
|
|
grass = 6,
|
|
|
|
mud = 3,
|
|
|
|
sand = 3,
|
|
|
|
sett = 10
|
2017-02-04 17:50:00 -05:00
|
|
|
},
|
|
|
|
|
|
|
|
avoid = Set {
|
|
|
|
'impassable',
|
|
|
|
'construction'
|
2017-02-04 17:05:00 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-09 09:13:04 -04:00
|
|
|
|
2014-03-05 13:16:17 -05:00
|
|
|
local function parse_maxspeed(source)
|
|
|
|
if not source then
|
|
|
|
return 0
|
|
|
|
end
|
|
|
|
local n = tonumber(source:match("%d*"))
|
|
|
|
if not n then
|
|
|
|
n = 0
|
|
|
|
end
|
|
|
|
if string.match(source, "mph") or string.match(source, "mp/h") then
|
2015-09-02 06:23:26 -04:00
|
|
|
n = (n*1609)/1000
|
2014-03-05 13:16:17 -05:00
|
|
|
end
|
|
|
|
return n
|
|
|
|
end
|
|
|
|
|
2016-09-09 06:34:04 -04:00
|
|
|
function get_restrictions(vector)
|
2017-02-04 17:05:00 -05:00
|
|
|
for i,v in ipairs(profile.restrictions) do
|
2014-03-27 16:19:26 -04:00
|
|
|
vector:Add(v)
|
|
|
|
end
|
2013-01-05 11:32:39 -05:00
|
|
|
end
|
2012-10-04 02:36:14 -04:00
|
|
|
|
2014-08-27 12:38:30 -04:00
|
|
|
function node_function (node, result)
|
2015-05-15 08:45:50 -04:00
|
|
|
-- parse access and barrier tags
|
2015-05-30 13:26:56 -04:00
|
|
|
local highway = node:get_value_by_key("highway")
|
|
|
|
local is_crossing = highway and highway == "crossing"
|
|
|
|
|
2017-02-04 17:05:00 -05:00
|
|
|
local access = find_access_tag(node, profile.access_tags_hierarchy)
|
2015-05-15 11:01:21 -04:00
|
|
|
if access and access ~= "" then
|
2015-05-30 13:26:56 -04:00
|
|
|
-- access restrictions on crossing nodes are not relevant for
|
|
|
|
-- the traffic on the road
|
2017-02-04 17:05:00 -05:00
|
|
|
if profile.access_tag_blacklist[access] and not is_crossing then
|
2015-05-15 08:45:50 -04:00
|
|
|
result.barrier = true
|
|
|
|
end
|
|
|
|
else
|
|
|
|
local barrier = node:get_value_by_key("barrier")
|
|
|
|
if barrier and "" ~= barrier then
|
2017-02-04 17:05:00 -05:00
|
|
|
if not profile.barrier_whitelist[barrier] then
|
2015-05-15 08:45:50 -04:00
|
|
|
result.barrier = true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2014-03-05 13:16:17 -05:00
|
|
|
|
2015-05-15 08:45:50 -04:00
|
|
|
-- check if node is a traffic light
|
|
|
|
local tag = node:get_value_by_key("highway")
|
|
|
|
if tag and "traffic_signals" == tag then
|
2015-09-02 06:23:26 -04:00
|
|
|
result.traffic_lights = true
|
2015-05-15 08:45:50 -04:00
|
|
|
end
|
2014-03-05 13:16:17 -05:00
|
|
|
end
|
|
|
|
|
2014-08-27 12:38:30 -04:00
|
|
|
function way_function (way, result)
|
2017-02-04 17:50:00 -05:00
|
|
|
-- the intial filtering of ways based on presence of tags
|
|
|
|
-- affects processing times significantly, because all ways
|
|
|
|
-- have to be checked.
|
|
|
|
-- to increase performance, prefetching and intial tag check
|
|
|
|
-- is done in directly instead of via a handler.
|
|
|
|
|
|
|
|
-- in general we should try to abort as soon as
|
|
|
|
-- possible if the way is not routable, to avoid doing
|
|
|
|
-- unnecessary work. this implies we should check things that
|
|
|
|
-- commonly forbids access early, and handle edge cases later.
|
|
|
|
|
|
|
|
-- data table for storing intermediate values during processing
|
|
|
|
|
|
|
|
local data = {
|
|
|
|
-- prefetch tags
|
|
|
|
highway = way:get_value_by_key('highway'),
|
|
|
|
}
|
|
|
|
|
|
|
|
local handlers = Sequence {
|
|
|
|
-- set the default mode for this profile. if can be changed later
|
|
|
|
-- in case it turns we're e.g. on a ferry
|
|
|
|
'handle_default_mode',
|
|
|
|
|
|
|
|
-- check various tags that could indicate that the way is not
|
|
|
|
-- routable. this includes things like status=impassable,
|
|
|
|
-- toll=yes and oneway=reversible
|
|
|
|
'handle_blocked_ways',
|
|
|
|
}
|
|
|
|
|
|
|
|
if Handlers.run(handlers,way,result,data,profile) == false then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2014-03-27 16:19:26 -04:00
|
|
|
-- initial routability check, filters out buildings, boundaries, etc
|
2014-08-27 12:38:30 -04:00
|
|
|
local highway = way:get_value_by_key("highway")
|
|
|
|
local route = way:get_value_by_key("route")
|
|
|
|
local man_made = way:get_value_by_key("man_made")
|
|
|
|
local railway = way:get_value_by_key("railway")
|
|
|
|
local amenity = way:get_value_by_key("amenity")
|
|
|
|
local public_transport = way:get_value_by_key("public_transport")
|
2015-02-26 11:17:43 -05:00
|
|
|
local bridge = way:get_value_by_key("bridge")
|
2014-03-27 16:19:26 -04:00
|
|
|
if (not highway or highway == '') and
|
2015-09-27 09:45:41 -04:00
|
|
|
(not route or route == '') and
|
2017-02-04 17:05:00 -05:00
|
|
|
(not profile.use_public_transport or not railway or railway=='') and
|
2014-03-27 16:19:26 -04:00
|
|
|
(not amenity or amenity=='') and
|
|
|
|
(not man_made or man_made=='') and
|
2015-02-26 11:17:43 -05:00
|
|
|
(not public_transport or public_transport=='') and
|
|
|
|
(not bridge or bridge=='')
|
2014-03-27 16:19:26 -04:00
|
|
|
then
|
2014-08-20 11:05:39 -04:00
|
|
|
return
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
-- access
|
2017-02-04 17:05:00 -05:00
|
|
|
local access = find_access_tag(way, profile.access_tags_hierarchy)
|
|
|
|
if access and profile.access_tag_blacklist[access] then
|
2014-08-20 11:05:39 -04:00
|
|
|
return
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
-- other tags
|
2014-08-27 12:38:30 -04:00
|
|
|
local junction = way:get_value_by_key("junction")
|
|
|
|
local maxspeed = parse_maxspeed(way:get_value_by_key ( "maxspeed") )
|
|
|
|
local maxspeed_forward = parse_maxspeed(way:get_value_by_key( "maxspeed:forward"))
|
|
|
|
local maxspeed_backward = parse_maxspeed(way:get_value_by_key( "maxspeed:backward"))
|
|
|
|
local barrier = way:get_value_by_key("barrier")
|
|
|
|
local oneway = way:get_value_by_key("oneway")
|
|
|
|
local onewayClass = way:get_value_by_key("oneway:bicycle")
|
|
|
|
local cycleway = way:get_value_by_key("cycleway")
|
|
|
|
local cycleway_left = way:get_value_by_key("cycleway:left")
|
|
|
|
local cycleway_right = way:get_value_by_key("cycleway:right")
|
|
|
|
local duration = way:get_value_by_key("duration")
|
|
|
|
local service = way:get_value_by_key("service")
|
|
|
|
local foot = way:get_value_by_key("foot")
|
2016-05-26 15:04:53 -04:00
|
|
|
local foot_forward = way:get_value_by_key("foot:forward")
|
|
|
|
local foot_backward = way:get_value_by_key("foot:backward")
|
2014-08-27 12:38:30 -04:00
|
|
|
local bicycle = way:get_value_by_key("bicycle")
|
2014-03-27 16:19:26 -04:00
|
|
|
|
|
|
|
|
|
|
|
-- speed
|
2017-02-04 17:05:00 -05:00
|
|
|
local bridge_speed = profile.bridge_speeds[bridge]
|
2015-02-26 10:28:04 -05:00
|
|
|
if (bridge_speed and bridge_speed > 0) then
|
2015-09-02 06:23:26 -04:00
|
|
|
highway = bridge
|
2015-02-26 10:28:04 -05:00
|
|
|
if duration and durationIsValid(duration) then
|
2015-09-02 06:23:26 -04:00
|
|
|
result.duration = math.max( parseDuration(duration), 1 )
|
2015-02-26 10:28:04 -05:00
|
|
|
end
|
|
|
|
result.forward_speed = bridge_speed
|
|
|
|
result.backward_speed = bridge_speed
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif profile.route_speeds[route] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- ferries (doesn't cover routes tagged using relations)
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.ferry
|
|
|
|
result.backward_mode = mode.ferry
|
2014-08-27 12:38:30 -04:00
|
|
|
if duration and durationIsValid(duration) then
|
|
|
|
result.duration = math.max( 1, parseDuration(duration) )
|
2014-03-27 16:19:26 -04:00
|
|
|
else
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.route_speeds[route]
|
|
|
|
result.backward_speed = profile.route_speeds[route]
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
2015-05-15 08:45:50 -04:00
|
|
|
-- public transport
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif profile.use_public_transport and railway and profile.platform_speeds[railway] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- railway platforms (old tagging scheme)
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.platform_speeds[railway]
|
|
|
|
result.backward_speed = profile.platform_speeds[railway]
|
|
|
|
elseif profile.use_public_transport and profile.platform_speeds[public_transport] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- public_transport platforms (new tagging platform)
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.platform_speeds[public_transport]
|
|
|
|
result.backward_speed = profile.platform_speeds[public_transport]
|
|
|
|
elseif profile.use_public_transport and railway and profile.railway_speeds[railway] then
|
2017-01-31 15:54:56 -05:00
|
|
|
result.forward_mode = mode.train
|
|
|
|
result.backward_mode = mode.train
|
|
|
|
-- railways
|
2017-02-04 17:05:00 -05:00
|
|
|
if (not access and highway) or profile.access_tag_whitelist[access] then
|
|
|
|
result.forward_speed = profile.railway_speeds[railway]
|
|
|
|
result.backward_speed = profile.railway_speeds[railway]
|
2013-02-03 07:08:11 -05:00
|
|
|
end
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif amenity and profile.amenity_speeds[amenity] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- parking areas
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.amenity_speeds[amenity]
|
|
|
|
result.backward_speed = profile.amenity_speeds[amenity]
|
|
|
|
elseif profile.bicycle_speeds[highway] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- regular ways
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.bicycle_speeds[highway]
|
|
|
|
result.backward_speed = profile.bicycle_speeds[highway]
|
|
|
|
elseif access and profile.access_tag_whitelist[access] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- unknown way, but valid access tag
|
2014-08-27 12:38:30 -04:00
|
|
|
result.forward_speed = default_speed
|
|
|
|
result.backward_speed = default_speed
|
2014-03-27 16:19:26 -04:00
|
|
|
else
|
|
|
|
-- biking not allowed, maybe we can push our bike?
|
|
|
|
-- essentially requires pedestrian profiling, for example foot=no mean we can't push a bike
|
2016-11-24 07:08:49 -05:00
|
|
|
if foot ~= 'no' and (junction ~= "roundabout" and junction ~= "circular") then
|
2017-02-04 17:05:00 -05:00
|
|
|
if profile.pedestrian_speeds[highway] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- pedestrian-only ways and areas
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.pedestrian_speeds[highway]
|
|
|
|
result.backward_speed = profile.pedestrian_speeds[highway]
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.pushing_bike
|
|
|
|
result.backward_mode = mode.pushing_bike
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif man_made and profile.man_made_speeds[man_made] then
|
2014-03-27 16:19:26 -04:00
|
|
|
-- man made structures
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_speed = profile.man_made_speeds[man_made]
|
|
|
|
result.backward_speed = profile.man_made_speeds[man_made]
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.pushing_bike
|
|
|
|
result.backward_mode = mode.pushing_bike
|
2014-03-27 16:19:26 -04:00
|
|
|
elseif foot == 'yes' then
|
2014-08-27 12:38:30 -04:00
|
|
|
result.forward_speed = walking_speed
|
|
|
|
result.backward_speed = walking_speed
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.pushing_bike
|
|
|
|
result.backward_mode = mode.pushing_bike
|
2014-08-12 08:18:02 -04:00
|
|
|
elseif foot_forward == 'yes' then
|
2014-08-27 12:38:30 -04:00
|
|
|
result.forward_speed = walking_speed
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.pushing_bike
|
|
|
|
result.backward_mode = mode.inaccessible
|
2014-08-12 08:18:02 -04:00
|
|
|
elseif foot_backward == 'yes' then
|
2014-08-27 12:38:30 -04:00
|
|
|
result.forward_speed = walking_speed
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.inaccessible
|
|
|
|
result.backward_mode = mode.pushing_bike
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
2013-02-03 07:08:11 -05:00
|
|
|
end
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
-- direction
|
|
|
|
local impliedOneway = false
|
2016-11-24 07:08:49 -05:00
|
|
|
if junction == "roundabout" or junction == "circular" or highway == "motorway" then
|
2014-03-27 16:19:26 -04:00
|
|
|
impliedOneway = true
|
|
|
|
end
|
|
|
|
|
|
|
|
if onewayClass == "yes" or onewayClass == "1" or onewayClass == "true" then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.backward_mode = mode.inaccessible
|
2014-03-27 16:19:26 -04:00
|
|
|
elseif onewayClass == "no" or onewayClass == "0" or onewayClass == "false" then
|
2014-08-12 08:18:02 -04:00
|
|
|
-- prevent implied oneway
|
2014-03-27 16:19:26 -04:00
|
|
|
elseif onewayClass == "-1" then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.inaccessible
|
2014-03-27 16:19:26 -04:00
|
|
|
elseif oneway == "no" or oneway == "0" or oneway == "false" then
|
2014-08-12 08:18:02 -04:00
|
|
|
-- prevent implied oneway
|
2014-03-27 16:19:26 -04:00
|
|
|
elseif cycleway and string.find(cycleway, "opposite") == 1 then
|
|
|
|
if impliedOneway then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.inaccessible
|
|
|
|
result.backward_mode = mode.cycling
|
2017-02-04 17:05:00 -05:00
|
|
|
result.backward_speed = profile.bicycle_speeds["cycleway"]
|
2013-04-27 11:00:25 -04:00
|
|
|
end
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif cycleway_left and profile.cycleway_tags[cycleway_left] and cycleway_right and profile.cycleway_tags[cycleway_right] then
|
2014-08-12 08:18:02 -04:00
|
|
|
-- prevent implied
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif cycleway_left and profile.cycleway_tags[cycleway_left] then
|
2014-03-27 16:19:26 -04:00
|
|
|
if impliedOneway then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.inaccessible
|
|
|
|
result.backward_mode = mode.cycling
|
2017-02-04 17:05:00 -05:00
|
|
|
result.backward_speed = profile.bicycle_speeds["cycleway"]
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
2017-02-04 17:05:00 -05:00
|
|
|
elseif cycleway_right and profile.cycleway_tags[cycleway_right] then
|
2014-03-27 16:19:26 -04:00
|
|
|
if impliedOneway then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.cycling
|
2017-02-04 17:05:00 -05:00
|
|
|
result.backward_speed = profile.bicycle_speeds["cycleway"]
|
2016-04-01 05:39:47 -04:00
|
|
|
result.backward_mode = mode.inaccessible
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
|
|
|
elseif oneway == "-1" then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.inaccessible
|
2014-08-12 08:18:02 -04:00
|
|
|
elseif oneway == "yes" or oneway == "1" or oneway == "true" or impliedOneway then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.backward_mode = mode.inaccessible
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
2014-08-27 12:38:30 -04:00
|
|
|
|
2014-03-27 16:19:26 -04:00
|
|
|
-- pushing bikes
|
2017-02-04 17:05:00 -05:00
|
|
|
if profile.bicycle_speeds[highway] or profile.pedestrian_speeds[highway] then
|
2016-11-24 07:08:49 -05:00
|
|
|
if foot ~= "no" and junction ~= "roundabout" and junction ~= "circular" then
|
2016-02-25 14:03:49 -05:00
|
|
|
if result.backward_mode == mode.inaccessible then
|
2014-08-27 12:38:30 -04:00
|
|
|
result.backward_speed = walking_speed
|
2016-02-25 14:03:49 -05:00
|
|
|
result.backward_mode = mode.pushing_bike
|
|
|
|
elseif result.forward_mode == mode.inaccessible then
|
2014-08-27 12:38:30 -04:00
|
|
|
result.forward_speed = walking_speed
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.pushing_bike
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
2013-02-04 09:58:35 -05:00
|
|
|
end
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
-- cycleways
|
2017-02-04 17:05:00 -05:00
|
|
|
if cycleway and profile.cycleway_tags[cycleway] then
|
|
|
|
result.forward_speed = profile.bicycle_speeds["cycleway"]
|
|
|
|
result.backward_speed = profile.bicycle_speeds["cycleway"]
|
|
|
|
elseif cycleway_left and profile.cycleway_tags[cycleway_left] then
|
|
|
|
result.forward_speed = profile.bicycle_speeds["cycleway"]
|
|
|
|
result.backward_speed = profile.bicycle_speeds["cycleway"]
|
|
|
|
elseif cycleway_right and profile.cycleway_tags[cycleway_right] then
|
|
|
|
result.forward_speed = profile.bicycle_speeds["cycleway"]
|
|
|
|
result.backward_speed = profile.bicycle_speeds["cycleway"]
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
|
|
|
|
2014-08-12 08:18:02 -04:00
|
|
|
-- dismount
|
|
|
|
if bicycle == "dismount" then
|
2016-02-25 14:03:49 -05:00
|
|
|
result.forward_mode = mode.pushing_bike
|
|
|
|
result.backward_mode = mode.pushing_bike
|
2014-08-27 12:38:30 -04:00
|
|
|
result.forward_speed = walking_speed
|
|
|
|
result.backward_speed = walking_speed
|
2014-08-12 08:18:02 -04:00
|
|
|
end
|
|
|
|
|
2016-06-24 10:06:45 -04:00
|
|
|
|
2014-03-27 16:19:26 -04:00
|
|
|
-- maxspeed
|
2015-05-01 14:06:45 -04:00
|
|
|
limit( result, maxspeed, maxspeed_forward, maxspeed_backward )
|
2016-05-12 12:50:10 -04:00
|
|
|
|
|
|
|
-- convert duration into cyclability
|
2017-02-04 17:05:00 -05:00
|
|
|
local is_unsafe = profile.safety_penalty < 1 and profile.unsafe_highway_list[highway]
|
2016-05-12 12:50:10 -04:00
|
|
|
if result.forward_speed > 0 then
|
|
|
|
-- convert from km/h to m/s
|
|
|
|
result.forward_rate = result.forward_speed / 3.6;
|
|
|
|
if is_unsafe then
|
2017-02-04 17:05:00 -05:00
|
|
|
result.forward_rate = result.forward_rate * profile.safety_penalty
|
2016-05-12 12:50:10 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
if result.backward_speed > 0 then
|
|
|
|
-- convert from km/h to m/s
|
|
|
|
result.backward_rate = result.backward_speed / 3.6;
|
|
|
|
if is_unsafe then
|
2017-02-04 17:05:00 -05:00
|
|
|
result.backward_rate = result.backward_rate * profile.safety_penalty
|
2016-05-12 12:50:10 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
if result.duration > 0 then
|
|
|
|
result.weight = result.duration;
|
|
|
|
if is_unsafe then
|
2017-02-04 17:05:00 -05:00
|
|
|
result.weight = result.weight * (1+profile.safety_penalty)
|
2016-05-12 12:50:10 -04:00
|
|
|
end
|
|
|
|
end
|
2017-02-04 17:50:00 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
local handlers = Sequence {
|
|
|
|
-- compute speed taking into account way type, maxspeed tags, etc.
|
|
|
|
'handle_surface',
|
|
|
|
|
|
|
|
-- handle turn lanes and road classification, used for guidance
|
|
|
|
'handle_classification',
|
|
|
|
|
|
|
|
-- handle various other flags
|
|
|
|
'handle_roundabouts',
|
|
|
|
--'handle_startpoint',
|
|
|
|
|
|
|
|
-- set name, ref and pronunciation
|
|
|
|
'handle_names'
|
|
|
|
}
|
|
|
|
|
|
|
|
Handlers.run(handlers,way,result,data,profile)
|
|
|
|
|
2012-09-19 12:35:45 -04:00
|
|
|
end
|
2013-02-23 02:33:33 -05:00
|
|
|
|
2016-05-12 12:50:10 -04:00
|
|
|
function turn_function(turn)
|
2014-03-27 16:19:26 -04:00
|
|
|
-- compute turn penalty as angle^2, with a left/right bias
|
2016-05-12 12:50:10 -04:00
|
|
|
local normalized_angle = turn.angle / 90.0
|
|
|
|
if normalized_angle >= 0.0 then
|
2017-02-04 17:05:00 -05:00
|
|
|
turn.duration = normalized_angle * normalized_angle * profile.turn_penalty / profile.turn_bias
|
2014-03-27 16:19:26 -04:00
|
|
|
else
|
2017-02-04 17:05:00 -05:00
|
|
|
turn.duration = normalized_angle * normalized_angle * profile.turn_penalty * profile.turn_bias
|
2016-05-12 12:50:10 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
if turn.direction_modifier == direction_modifier.uturn then
|
2017-02-04 17:05:00 -05:00
|
|
|
turn.duration = turn.duration + profile.u_turn_penalty
|
2016-05-12 12:50:10 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
if turn.has_traffic_light then
|
2017-02-04 17:05:00 -05:00
|
|
|
turn.duration = turn.duration + profile.traffic_light_penalty
|
2014-03-27 16:19:26 -04:00
|
|
|
end
|
2013-02-23 02:33:33 -05:00
|
|
|
end
|