Command 0xab: Get Simulation Variable#
| ubyte | string | 
|---|---|
| Variable | Simulation ID (always unused) | 
Asks for the value of a certain simulation variable
The following variable values can be retrieved and subscribed to. The type of the return value is also shown in the table. It is not possible to subscribe to position conversion (0x82), distance request (0x83), find route (0x86), find intermodal route (0x87) and all bus stop functions.
| Variable | ValueType | Description | |
|---|---|---|---|
| current simulation time (0x66) | double | Returns the current simulation time (in s) | |
| current simulation time (0x70) (deprecated) | int | Returns the current simulation time (in ms) | |
| number of loaded vehicles (id 0x71) | int | The number of vehicles which were loaded in this time step. | |
| ids of loaded vehicles (id 0x72) | stringList | A list of ids of vehicles which were loaded in this time step. | |
| number of departed vehicles (id 0x73) | int | The number of vehicles which departed (were inserted into the road network) in this time step. | |
| ids of departed vehicles (id 0x74) | stringList | A list of ids of vehicles which departed (were inserted into the road network) in this time step. | |
| number of vehicles that start to teleport | int | The number of vehicles which started to teleport in this time step. | |
| ids of vehicles that start to teleport (id 0x76) | stringList | A list of ids of vehicles which started to teleport in this time step. | |
| number of vehicles that end being teleported | int | The number of vehicles which ended to be teleported in this time step. | |
| ids of vehicles that end being teleported | stringList | A list of ids of vehicles which ended to be teleported in this time step. | |
| number of arrived vehicles (id 0x79) | int | The number of vehicles which arrived (have reached their destination and are removed from the road network) in this time step. | |
| ids of arrived vehicles (id 0x7a) | stringList | A list of ids of vehicles which arrived (have reached their destination and are removed from the road network) in this time step. | |
| network bounding box (id 0x7c) | 2D polygon | The lower left and the upper right corner of the bounding box of the simulation network. | |
| minimum number of vehicles that are still expected to leave the net (id 0x7d) | int | The number of vehicles which are in the net plus the ones still waiting to start. This number may be smaller than the actual number of vehicles still to come because of delayed route file parsing. | |
| number of vehicles that begin a stop (id 0x68) | int | The number of vehicles that halted on a scheduled stop in this time step. | |
| ids of vehicles that begin a stop (id 0x69) | stringList | A list of ids of vehicles that halted on a scheduled stop in this time step. | |
| number of vehicles that end a stop (id 0x6a) | int | The number of vehicles that begin to continue their journey, leaving a scheduled stop in this time step. | |
| ids of vehicles that end a stop (id 0x6b) | stringList | A list of ids of vehicles that begin to continue their journey, leaving a scheduled stop in this time step. | |
| number of vehicles involved in a collision (id 0x80) | int | The number of vehicles that were involved in a collision in this time step. | |
| ids of vehicles involved in a collision (id 0x81) | stringList | A list of ids of vehicles that were involved in a collision in this time step. | |
| number of vehicles that begin to be parked | int | The number of vehicles that enter a parking position in this time step. | |
| ids of vehicles that begin to be parked | stringList | A list of ids of vehicles that enter a parking position in this time step. | |
| number of vehicles that end to be parked | int | The number of vehicles that begin to continue their journey, leaving a scheduled parking in this time step. | |
| ids of vehicles that end being parked (id 0x6f) | stringList | A list of ids of vehicles that begin to continue their journey, leaving a scheduled parking in this time step. | |
| bus stop waiting (id 0x67) | int | Get the total number of waiting persons at the named bus stop (deprecated, use busstop.getPersonCount instead). | |
| bus stop waiting ids (id 0xef) | stringList | Get the ids of waiting persons at the named bus stop (deprecated, use busstop.getPersonIDs instead). | |
| delta T (id 0x7b) | double | Returns the length of one simulation step in seconds. | |
| parameter (0x7e) | string | Returns the value for the given string parameter. | |
| scale (id 0x8e) | double | Returns the traffic scaling factor. | |
| option (0x3f) | string | Returns the value of one of the global SUMO options. | 
Response 0xbb: Simulation Variable#
| ubyte | string | ubyte | <return_type> | 
|---|---|---|---|
| Variable | <invalid> | Return type of the variable | <VARIABLE_VALUE> | 
The respond to a "Command Get Simulation Variable".
Extended retrieval messages#
Some further messages require additional parameters.
| Variable | Request ValueType | Response ValueType | Description | |
|---|---|---|---|---|
| position conversion (0x82) | compound, see below | Position, as wished | Reads a position information and returns it converted into the given representation. | |
| distance request (0x83) | compound, see below | double | Reads two positions and an indicator whether the air or the driving distance shall be computed. Returns the according distance. | |
| find route (0x86) | compound, see below | compound, see below | Reads origin and destination edge together with some vehicle parameters and computes the currently fastest driving route for the vehicle (for pedestrians / passengers use find intermodal route). | |
| find intermodal route (0x87) | compound, see below | compound, see below | Reads origin and destination position together with usable modes and other person parameters and computes the currently fastest route for the person using the available modes. | |
| get collisions (0x23) | - | compound, see below | Retrieves details on all collision events in the last time step. Collision detection is disabled by default (**--collision.action none**). | 
Command 0x82: Position Conversion#
The request needs the following parameter:
| byte | integer | Position | byte | ubyte | 
|---|---|---|---|---|
| value type compound | item number (always 2) | position to convert | value type ubyte | Type of the Position to return | 
Use this command to convert between the different position types used by TraCI. The specified Position is converted into the requested format given through PositionId. When converting from coordinates to road positions, the result is the closest position that was found to match the given one. In all other cases, the conversion will give an exact match. The return values consists of the converted value only.
To simplify position conversions, a number of convenience functions are provided by many traci client libraries,and libsumo:
- convert2D: convert road,laneIndex,offset to x,y or lon,lat
- convert3D: convert road,laneIndex,offset to x,y,z or lon,lat
- convertGeo: convert x,y to lon,lat or vice versa
- convertRoad: convert x,y or lon,lat to road,laneInex,offset
See TraCI/Protocol#Position Representations for available position formats.
Command 0x83: Distance Request#
The request needs the following parameter:
| byte | integer | Position | Position | ubyte | 
|---|---|---|---|---|
| value type compound | item number (always 3) | start position | end position | Distance Type | 
where
- Distance Type==0: air distance
- Distance Type==1: driving distance
The resulting distance is returned.
Command 0x86: Find Route#
| byte | integer | byte | string | byte | string | byte | string | byte | double | byte | integer | 
|---|---|---|---|---|---|---|---|---|---|---|---|
| value type compound | item number (always 5) | value type string | start edge | value type string | destination edge | value type string | vehicle type | value type double | departure time (s) | value type integer | routing mode (see below) | 
Caution
Routing mode shall be used to specify which data source to use for estimation of edge travel times. This is not yet implemented and the same data sources as for command vehicle.rerouteTraveltime is used.
The following response is returned:
| type + string | type + string | type + stringList | type + double | type + double | 
|---|---|---|---|---|
| type (always "driving") | line (always "") | edges | travel time (s) | travel time (s) | 
Note
The python and C++ client return a namedtuple / struct with field names stageType, line, destStop, edges, travelTime, cost.
Note
The seemingly unused/redundant fields are reserved for route-by-cost and intermodal routing (see below).
Command 0x87: Find Intermodal Route#
| byte | integer | byte | string | byte | string | byte | string | byte | double | byte | integer | byte | double | byte | double | byte | double | byte | double | byte | double | byte | string | byte | string | 
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| value type compound | item number (always 12) | value type string | start edge | value type string | destination edge | value type string | available modes | value type double | departure time (s) | value type integer | routing mode (see above) | value type double | walking speed (m/s) | value type double | walk factor | value type double | depart position (m) | value type double | arrival position (m) | value type double | departPosLat (m) | value type string | vtype of the vehicle | value type string | vtype of the pedestrian | 
The available modes are "car", "public", "bicycle" or space separated combination. Walking is always considered possible and is the default (or used when giving an empty string). When "car" is an available mode the vehicle type can be given using the vtype parameter. If this is empty, the default vehicle type is used.
The response is a list of stages similar to the one returned by findRoute.
Command 0x23: Get Collisions#
The response is a list of Collision objects:
| type + string | type + string | type + string | type + string | type + double | type + double | type + string | type + string | type + double | 
|---|---|---|---|---|---|---|---|---|
| collider id | victim id | collider type | victim type | collider speed | victim speed | collision type | lane id | pos on lane | 
Generic Parameter Retrieval 0x7e#
The simulation supports retrieval of additional object parameters using the generic parameter retrieval call.
Stoppping Place Information#
The object id of getParameter refers to the object (i.e. chargingStation) id. The following parameters
are supported:
- chargingStation.totalEnergyCharged
- chargingStation.name
- chargingStation.lane
- parkingArea.capacity
- parkingArea.occupancy
- parkingArea.name
- parkingArea.lane
- busStop.name
- busStop.lane
Note
Since version 1.7.0 these and other values can be retrieved via new domains (i.e. traci.busstop)
Device Parameter Retrieval#
The following parameters can be retrieved. They are not for a specific device holder but are instead global measures. The object id must be the empty string "".
- device.tripinfo.count
- device.tripinfo.routeLength
- device.tripinfo.speed
- device.tripinfo.duration
- device.tripinfo.waitingTime
- device.tripinfo.timeLoss
- device.tripinfo.departDelay
- device.tripinfo.departDelayWaiting
- device.tripinfo.totalTravelTime
- device.tripinfo.totalDepartDelay
- device.tripinfo.vehicleTripStatistics.count
- device.tripinfo.vehicleTripStatistics.routeLength
- device.tripinfo.vehicleTripStatistics.speed
- device.tripinfo.vehicleTripStatistics.duration
- device.tripinfo.vehicleTripStatistics.waitingTime
- device.tripinfo.vehicleTripStatistics.timeLoss
- device.tripinfo.vehicleTripStatistics.departDelay
- device.tripinfo.vehicleTripStatistics.departDelayWaiting
- device.tripinfo.vehicleTripStatistics.totalTravelTime
- device.tripinfo.vehicleTripStatistics.totalDepartDelay
- device.tripinfo.bikeTripStatistics.count
- device.tripinfo.bikeTripStatistics.routeLength
- device.tripinfo.bikeTripStatistics.speed
- device.tripinfo.bikeTripStatistics.duration
- device.tripinfo.bikeTripStatistics.waitingTime
- device.tripinfo.bikeTripStatistics.timeLoss
- device.tripinfo.bikeTripStatistics.totalTravelTime
- device.tripinfo.pedestrianStatistics.count
- device.tripinfo.pedestrianStatistics.number
- device.tripinfo.pedestrianStatistics.routeLength
- device.tripinfo.pedestrianStatistics.duration
- device.tripinfo.pedestrianStatistics.timeLoss
- device.tripinfo.rideStatistics.count
- device.tripinfo.rideStatistics.number
- device.tripinfo.rideStatistics.waitingTime
- device.tripinfo.rideStatistics.routeLength
- device.tripinfo.rideStatistics.duration
- device.tripinfo.rideStatistics.bus
- device.tripinfo.rideStatistics.train
- device.tripinfo.rideStatistics.taxi
- device.tripinfo.rideStatistics.bike
- device.tripinfo.rideStatistics.aborted
- device.tripinfo.transportStatistics.count
- device.tripinfo.transportStatistics.number
- device.tripinfo.transportStatistics.waitingTime
- device.tripinfo.transportStatistics.routeLength
- device.tripinfo.transportStatistics.duration
- device.tripinfo.transportStatistics.bus
- device.tripinfo.transportStatistics.train
- device.tripinfo.transportStatistics.taxi
- device.tripinfo.transportStatistics.bike
- device.tripinfo.transportStatistics.aborted
Statistics Parameter Retrieval#
The retrievable values are those described at statistic-output as applicable to the current simulation time.
- stats.vehicles.loaded
- stats.vehicles.inserted
- stats.vehicles.running
- stats.vehicles.waiting
- stats.teleports.total
- stats.teleports.jam
- stats.teleports.yield
- stats.teleports.wrongLane
- stats.safety.collisions
- stats.safety.emergencyStops
- stats.safety.emergencyBraking
- stats.persons.loaded
- stats.persons.running
- stats.persons.jammed
- stats.personTeleports.total
- stats.personTeleports.abortWait
- stats.personTeleports.wrongDest
