Bicycle Simulation#
This page describes simulations of bicycles in SUMO. To build an intermodal simulation scenario with bicycles, additional steps have to be take in comparison to a plain vehicular simulation.
Caution
The simulation of bicycles is a developing subject and still carries some difficulties. These are discussed below.
Approaches to bicycle modelling#
Currently, no exclusive movement model for bicycles is implemented. Existing models need to be re-purposed
Bicycles as slow vehicles#
In this case, vehicles are specified as vehicles with the appropriate type:
<vType id="bike" vClass="bicycle"/>
<vehicle type="bike" .../>
Note, that that the guiShape="bicycle" along with sensible default
parameters are
automatically used when specifying vClass="bicycle". By adapting vType-parameters for
acceleration,deceleration,maximumSpeed,etc..
different cyclist types can be modelled.
Useful Model Parameters#
Once the vClass "bicycle" is chosen, the following parameters, which can still be customized, are set for bicycle:
- minGap = 0.5 m
- max. acceleration = 1.2 m/s^2
- max. deceleration = 3 m/s^2
- emergency deceleration = 7 m/s^2
- Length = 1.6 m
- maxSpeed = 50 km/h
- desiredMaxSpeed = 20 km/h
The values of some other parameters for bicycles are different from those for vehicles apparently. If no real data for the respective calibrations is available, some intuitive suggestions are listed below for reference.
- latAlignment = "right" (cyclists ride on the right side of their lane)
- carFollowModel = IDM (if smoothed acceleration is desired)
- lcStrategic = 0.5 (in comparison to the default value (1) this setting makes bicycles to perform strategic lane changing later)
- lcCooperativeRoundabout = 0. (cyclists keep on the right lane in a multi-lane roundabout)
- lcTurnAlignmentDistance = 20. (distance to a location where bicycles start to keeping right/left of their lane for preparing to make turns)
- jmCrossingGap = 4 (Minimum distance to pedestrians that are walking towards the conflict point with a bike - lower than the default of 10 for cars)
- jmSigmaMinor = 0. (no imperfection while passing a minor link)
- jmStoplineGap = 0.5 (Stopping distance in front of prioritary / TL-controlled stop line)
Speed limits#
Bicycles are usually not limited by the road speed limit but rather by individual preferences. This cannot easily be modelled by vType attribute maxSpeed because it is not subject the the randomly chosen personal speedFactor (unless carFollowModel="KraussPS" is set). Instead, bicycle speed is limited by desiredMaxSpeed (multiplied by the individual speedFactor). For this reason, the desiredMaxSpeed < maxSpeed by default.
To model the effect of slopes on bicycle speed (only with carFollowModel="KraussPS"), it is necessary that the desiredMaxSpeed is above the "power limit" (maxSpeed).
The slope-dependent speed is scaled according to maxSpeed * speedFactor which results in the follow behavior:
- vehicles going uphill are slowed down to below maxSpeed * speedFactor
- vehicles on level ground can go up to speed maxSpeed * speedFactor
- vehicles going downhill may exceed maxSpeed * speedFactorand reach a speed up todesiredMaxSpeed * speedFactor
Problems and workarounds#
- No bi-directional movements on bicycle lanes
- No shared space for bicycles and pedestrians by default. This can be fixed by using the Sublane Model and defining lanes that allow bicycles and pedestrians.
- No overtaking by vehicles on a single-lane road. This can be fixed by using the Sublane Model.
- The intersection model has no special adaptations for bicycles. This results in unrealistic (large) safety gaps when bicycles are approaching a large priority intersection from a prioritized road
One way for overcoming most of these problems is to control bicycle movements at intersections with an external control script. This approach is described in Integration of an external bicycle model in SUMO, Heather Twaddle 2016.
Bicycles as fast pedestrians#
In this case, persons walking at high speed are used.
Problems and workarounds#
- No support for proper visualization - Movement model is not validated
Building a network for bicycle simulation#
Automatic import#
The import of bicycle lanes from OpenStreetMap is supported since version 0.24.0. Since version 1.17.0 you can enable them using the option --osm.bike-access. The earlier typemap approach can still be used (also together with the option to modify bike lane widths).
Generating a network with bike lanes#
A bike lane is a lane which only permits the vClass bicycle. There are various different options for generating a network with bike lanes which are explained below. All of these options recognize the presence of an existing bike lane and will not add another lane in that case.
Explicit specification of additional lanes#
Bike lanes may be defined explicitly in plain XML input when describing edges edges (plain.edg.xml). This is done by defining an additional lane which only permits the vClass “bicycle” and setting the appropriate width. In this case it may be useful to disallow bicycles on other lanes. Also, any pre-existing connection definitions must be modified to account for the new bike lane.
Explicit specification of bike lanes#
Alternatively to the above method, the <edge>-attribute bikeLaneWidth may be used. It will cause a bike lane of the specified width to be added to that edge, connections to be remapped and bicycle permissions to be removed from all other lanes.
Note
The heuristic methods described below, also perform automatic connection shifting and removal of bicycle permissions from non-bike lanes
Type-based generation#
When importing edges with defined types, it is also possible to declare that certain types should receive a sidewalk. This can be used to automatically generate bike lanes for residential streets while omitting them for motorways when importing OSM data.
<types>
   <type id="highway.motorway" numLanes="3" speed="44.44" priority="13" oneway="true" disallow="pedestrian bicycle"/>
   <type id="highway.unclassified"   numLanes="1" speed="13.89" priority="5" bikeLaneWidth="1" disallow="bicycle"/>
   <type id="highway.residential"    numLanes="1" speed="13.89" priority="4" bikeLaneWidth="1" disallow="bicycle"/>
   <type id="highway.living_street"  numLanes="1" speed="2.78"  priority="3"/>
   ...
</types>
A special type file that imports bike lanes based on additional OSM attributes can be found in <SUMO_HOME>/data/typemap/osmNetconvertBicycle.typ.xml. This is to be preferred for importing bike lanes from OSM as it uses more accurate data.
Heuristic generation#
A third option which can be used if no edge types are available is a heuristic based on edge speed. It adds a bike lane for all edges within a given speed range. This is controlled by using the following options:
| Option | Description | 
|---|---|
| --bikelanes.guess <BOOL> | Guess bike lanes based on edge speed | 
| --bikelanes.guess.max-speed <FLOAT> | Add bike lanes for edges with a speed equal or below the given limit default:13.89 | 
| --bikelanes.guess.min-speed <FLOAT> | Add bike lanes for edges with a speed above the given limit default:5.8 | 
| --bikelanes.guess.exclude {{ DT_ID }}[, | Specify a list of edges that shall not receive a bike lane | 
Permission-based generation#
Option --bikelanes.guess.from-permissions <BOOL> is suitable for networks which specify their edge permissions (such as DlrNavteq). It adds a bike lane for all edges which allow bicycles on any of their lanes. The option --bikelanes.guess.exclude <ID>[,<ID>]* applies here as well.
Adding bike lanes with netedit#
To add bike lanes to a set of edges in netedit select these and right click on them. From the context-menu select lane operations->add restricted lane->Bikelane.
Notes on Right-of-Way rules#
When using bicycle lanes in a network, right-turning vehicles must yield for straight-going bicycles. The intersection model supports these right-of-way rules and builds internal junctions where appropriate.
Likewise, left-turning bicycles one a bicycle lane (on the right side of the road) must yield to straight-going vehicles.
Indirect left turn#
In reality, left-turning bicycles may move in two stages: 1. move straight across, and then 2. turn 90° left and then move straight across
By default, netconvert generates a wide curve rather than going straight twice as above. To change this behavior, connection attribute indirect="true" may be set by the user.
If fine grained control of the the geometry of the indirect left turn is needed, it is also possible to set custom shapes for these internal lanes. To adjust the waiting position of the bicycle (the point where the first stage ends), connection attribute 'contPos' must be set.
To define a controlled indirect turn where both stages respect the traffic light corresponding to the current movement direction another custom setting is needed. The first part of the left-turn connection will be controlled automatically by the traffic light according to the 'linkIndex' attribute of the connection. The second part can be controlled by setting the optional attribute 'linkIndex2'. The easiest setup is to copy the linkIndex that controls the movement of vehicles (or pedestrians) going straight from right to left. In addition, parallel waiting of bicycles/motorpads in front of an intersection can be achieved by activating the Sublane-Model.
Sometimes, bicycles/motorpads do not wait side by side properly. The following parameters can help to solve/improve this issue.
- latAlignment="nice"
- minGapLat="0.1"
Short overview#
| Input | Desired output | Options to use | 
|---|---|---|
| shapefile or other data without bicycle info | no bicycle infrastructure | none | 
| bicycle lanes where applicable | --bikelanes.guess | |
| OpenStreetMap | no bicycle infrastructure | none | 
| bicycle lanes as in the input | --osm.bike-access | |
| guessed bicycle lanes (discarding input) | a typemap which gives a bikelane width to all street types which should receive one or --bikelanes.guess | 
The options above only apply to adding further lanes for existing streets or foot paths. Separate bike paths are always imported (if the typemap or other filter options do not prevent it).
Bicycle routing#
When routing bicycles in the simulation the option --device.rerouting.bike-speeds can be used to enable separate tracking of bicycle speeds. This ensure that routing for bicycles which can use a dedicated bicycle lane is not affected by jammed cars.
