|Specifies the maximum legal speed limit on a road, railway or waterway|
|Used on these elements|
|Tools for this tag|
The maxspeed=* tag is used to define the maximum legal speed limit for general traffic on a particular road, railway or waterway. By default, values will be interpreted as kilometres per hour. If the speed limit should be specified in a different unit the unit can be added to the end of the value, separated by a space (see Examples).
|The maximum fixed numeric speed limit, followed by the appropriate unit if not measured in km/h when no units should be included. For example maxspeed=60 for 60 km/h and maxspeed=50 mph for 50 mph.|
||maxspeed=signals|| Indicates that there is a (variable) maximum speed limit displayed on electronic variable signs. Please do not use this tag for railway lines and tag instead the maximum allowed speed there.
||maxspeed=none||Indicates that there is no fixed maximum numeric speed limit for this section of road (on some German autobahns and a very few other places. Not to be used for situations where there is a limit but it is not known. Where the limit is not known do not include a maxspeed tag.|
||maxspeed=walk|| In Austria and Germany the speed limit for living street (german: Wohnstraße bzw. Verkehrsberuhigter Bereich) is defined only as being a walking speed but there is no defined numeric value for this. The maxspeed walk proposal suggests that |
||maxspeed=<countrycode>:<zone type>||In some places, notably Romania and Russia, it is common to find that maxspeed holds a value of the form '<countrycode>:<zone type>' for areas where the speed limit is indicated on the street by use of a symbol or icon rather than a number. The format includes a country code followed by a ':' and a zone identifier (For example 'IT:urban' or 'DE:rural'). In most other places it is more common to place the appropriate numeric value in maxspeed and then identify the type of limit in the '<countrycode>:<zone type>' format using either source:maxspeed=* or maxspeed:type=*. For more information on this, and for a table of common values see Speed limits.|
Where different speed limits are posted for different classes of vehicles these should be specified using maxspeed:<vehicle>=*. The possible values for
<vehicle> correspond to the values for transport modes of the key access=* (see also Examples).
'Note: Where a lower blanket speed limit is applied for certain classes of vehicle across all roads within the jurisdiction then this should not be tagged at the individual road level.
Where different speed limits are specified for each driving direction those can be specified using maxspeed:forward=* resp. maxspeed:backward=*, whereas
forward applies to the speed limit for the same direction as the OSM way and
backward to the speed limit for the opposite direction.
Where different speed limits are specified for each lane of a road those can be specified using maxspeed:lanes=*. Each lane’s maxiumum speed has to be seperated with the “|” character. The first maximum speed is the maximum speed of the leftmost lane (viewed from the direction of the OSM way), the second maximum speed is the speed of the lane right from the leftmost lane and so on until the rightmost lane.
Further if they should be specified for each driving direction separately the key maxspeed:lanes:forward=* resp. maxspeed:lanes:backward=* can be used, whereas
lanes:forward applies to the speed limit of the lanes for the same direction as the OSM way and
lanes:backward to the speed limit of the lanes of the opposite direction. See therefore also the Examples as well as the article about mapping individual lanes.
Time or other conditions
Speed restrictions may be dependent on the time of day or other conditions. Such speed limits can be tagged as shown below:
Example: The maximum speed is 100 km/h between 6am and 7pm but otherwise is 120 km/h:
maxspeed:conditional=100 @ (06:00-19:00)
- For a full description and more examples, please see the conditional restrictions page.
|maxspeed=60 + source:maxspeed=sign||Alternatively maxspeed=60 km/h can be used.|
|maxspeed=50 mph + source:maxspeed=sign||The speed limit is specified in the unit is is legally defined and will not be converted to km/h.|
| maxspeed=50 + source:maxspeed=DE:urban or maxspeed=DE:urban + source:maxspeed=implicit
||On all roads in Germany, where no explicit speed limit is defined, the corresponding implicit values can be specified.|
|10 knots||maxspeed=10 knots||The speed limit is specified in the unit is is legally defined and will not be converted to km/h.|
|maxspeed=signals||The (variable) speed limit is announced on speed limit signs.|
|maxspeed=60 mph + maxspeed:type=GB:nsl_single + source:maxspeed=sign||A speed limit of 60 miles per hour on a road in the UK based on a "national speed limit" sign.|
|maxspeed:lanes=100|100|80||A speed limit of 80 kilometres per hour on the rightmost lane on a road with an assumed general speed limit of 100 kilometres per hour.|
|A speed limit of 60 kilometres per hour valid only for heavy good vehicles - 80 kilometres per hour otherwise.|
- ITO Map offers global speed limits updated daily
- Other services:
Regular expression for numeric values only:
Regular expression which catches numeric values and implicit values, e.g. like
^([^ ]+?)(?:[ ]?(?:kmh|km/h|mph|kph))?$
One mile per hour corresponds to 1.609 km/h and one knot to 1.852 kilometres per hour.
- minspeed=* for the minimum speed
- access=* for other restrictions
- source:maxspeed=* for the source of the speed limit
- traffic_sign=* for single traffic signs of the restriction
- highway=speed_camera for an enforced maxspeed
- Max Speed via Overpass - Map showing speed limits. Wait for lines to show then click and edit.
- Average speed per way - an attempt to collect/derive useful average speed information for routing
- Overview of possible units
- Transport modes of the key access=*
- Detailed overview of implicit speed limits
- Description of the
:lanesextension for mapping individual lanes
- Proposal for maxspeed=walk
- Proposal for implicit traffic laws
- General article about speed limits
- Alternative to