Parking Areas#
Areas for parking outside the road network (either road-side parking or
car parks) can be defined using the <parkingArea>
element. This accomplishes the
following purposes:
- arbitrary parking positions and angles can be defined to visualize fishbone or parallel parking
- parking space outside the road network can be limited to a set capacity
- automatic rerouting to an alternative parking area can be triggered whenever a parking area becomes full
Definition#
A road-side parkingArea is defined as in the following:
<parkingArea id="ParkAreaA" lane="a_0" startPos="200" endPos="250" roadsideCapacity="5" angle="45" length="30"/>
Additionally, individual parking spaces can be defined:
<parkingArea id="ParkAreaB" lane="b_0" startPos="240" endPos="260" roadsideCapacity="0" width="5" length="10" angle="30">
<space x="853" y="623"/>
<space x="863" y="618"/>
<space x="873" y="613"/>
<space x="883" y="608"/>
<space x="893" y="603"/>
<space x="848" y="611" width="4" length="8" angle="120"/>
<space x="858" y="606" width="4" length="8" angle="120"/>
<space x="868" y="601" width="4" length="8" angle="120"/>
<space x="878" y="596" width="4" length="8" angle="120"/>
<space x="888" y="591" width="4" length="8" angle="120"/>
</parkingArea>
The total capacity of a parking area is given by the sum of its
roadsideCapacity and the number of its <space>
elements.
The parkingArea supports the following attributes:
Attribute Name | Value Type | Value Range | Default | Description |
---|---|---|---|---|
id | string | id | The name of the parking area; must be unique | |
lane | string | valid lane id | The name of the lane the parking area shall be located at | |
startPos | float | -lane.length < x < lane.length (negative values count backwards from the end of the lane) | 0 | The begin position on the lane (the lower position on the lane) in meters |
endPos | float | -lane.length < x < lane.length (negative values count backwards from the end of the lane) | lane.length | The end position on the lane (the higher position on the lane) in meters, must be larger than startPos by more than 0.1m |
friendlyPos | bool | true,false | false | whether invalid stop positions should be corrected automatically (default false) |
name | string | simple String | Arbitrary text to describe the parking area. This is only used for visualization purposes. | |
roadsideCapacity | int | non-negative | 0 | The number of parking spaces for road-side parking |
onRoad | bool | false | Whether vehicles remain on the road while parking. Note: If set to true, only roadsideCapacity is used and no <space> -definitions are permitted. |
|
width | float | positive | 3.2 | The width of the road-side parking spaces |
length | float | positive | (endPos - startPos) / roadsideCapacity | The length of the road-side parking spaces |
angle | float (degree) | 0 | The angle of the road-side parking spaces relative to the lane angle, positive means clockwise |
Custom parking spaces#
The space element supports the following attributes:
Attribute Name | Value Type | Value Range | Default | Description |
---|---|---|---|---|
x | float | The x-position in meters of the parking vehicle | ||
y | float | The y-position in meters of the parking vehicle | ||
z | float | 0 | The z-position in meters of the parking vehicle | |
width | float | width value of the parent parking area | The width of the parking space | |
length | float | length value of the parent parking area | The length of the parking space | |
angle | float (degree) | absolute angle of the parent parking area (lane angle + angle attribute) | Absolute angle of the parking space | |
slope | float (degree) | 0 | Slope angle of the parking space |
Caution
Please note that parking areas must be added to a config via the --additional-files parameter (see additional-file).
Letting Vehicles stop at a parking area#
To declare a vehicle that stops at a parkingPlace, a <stop>
-definition must
be part of the vehicle or it's route:
<vehicle id="0" depart="0">
<route edges="e1 e2 e3"/>
<stop parkingArea="pa0" duration="20"/>
</vehicle>
What is defined here is a vehicle named "0" that stops as at parkingArea "pa0". Note, that the lane of that parking area must belong to one of the edges "e1, e2, e3" of the vehicles route.
For a complete list of attributes for the "stop"-element of a vehicle see Definition_of_Vehicles,_Vehicle_Types,_and_Routes#Stops.
Modelling Maneuvering Times when Entering and Leaving the Parking Space#
When setting the (boolean) option --parking.maneuver, vehicles will spend extra time on the road when leaving and entering a parkingArea. This time depends on the angle of the parking lot relative to the road lane and can be configured with the vType attribute maneuverAngleTimes. This is a comma-separated list of number-triplets of the form ANGLE ENTERINGTIME LEAVINGTIME:
<vType id="example" maneuverAngleTimes="10 3.0 4.0,80 1.6 11.0,110 11.0 2.0,170 8.1 3.0,181 3.0 4.0"/>
The value corresponding to the closest angle is used. The value of maneuverAngleTimes is initialized to a vClass-specific value:
- default:
maneuverAngleTimes="10 3 4,80 1 11,110 11 2,170 8 3,181 3 4"
- truck, trailer, coach, delivery: all times doubled compared to default
- bicycle, moped:
maneuverAngleTimes="181 1 1"
Rerouting when the current parkingArea is full#
If a vehicle reaches a parkingArea that is filled to capacity it must wait on the road until a space becomes available or reroute to a new parking area.
TraCI#
Some information regarding parking areas can be accessed directly using traci.simulation.getParameter() calls.
- parkingArea.capacity: total number of parking spaces
(roadsideCapacity + number of
<space>
elements) - parkingArea.occupancy: number of vehicles parking at this parking area