Aimsun Next API Vehicle Information(Meso)¶
Functions related to Vehicle Information¶
Get Vehicle Information¶
In C++ and Python¶
Explanation¶
Get the current vehicle information
Format¶
AMesoVehicleInfo AMesoGetVehicleInfo(void * simhandler, void * vehhandler);
Parameters¶
- simhandler: simulator handler
- vehhandler: vehicle handler
Output¶
struct AMesoVehicleInfo {
int id;
int vehicleTypeIndex;
int origin;
int entranceSection;
int destination;
double valueOfTime;
double entranceTime;
double generationTime;
int currentSection;
int currentTurning;
int currentEntranceLane;
int currentExitLane;
double currentExitTime;
int nextSection;
};
Where:
- Id: vehicle identifier
- Vehicle Type Index: vehicle type index.
- origin: origin centroid identifier
- destination: destination centroid identifier
- valueOfTime: value of time used by this vehicle
- entranceTime: entrance vehicle time into the network
- generationTime: generation vehicle time, this time is always lower than or equal to entranceTime
- currentSection: current section identifier, if the vehicle is in a turn then this current section is set to 0
- currentTurning: current turn identifier, if the vehicle is in a section it is set to 0
- currentEntranceLane: current entrance lane identifier from 0 to number of section lanes -1. If there’s no current entrance lane then it is -1
- currentExitLane: current exit lane identifier from 0 to number of section lanes -1. If there’s no current exit lane then it is -1
- currentExitTime: this is the estimated exit time of the vehicle. It's the estimated section exit time if currentSection > 0 otherwise is the current turn exit time.
- nextSectionId: next section id. If the vehicle is in the last section of its path then it returns 0.
Set new estimated vehicle exit time in section or turn¶
In C++ and Python¶
Explanation¶
Sets a new minimum time for a vehicle exit time in a section or turn.
Format¶
int AMesoSetVehicleExitTime(void * simhandler, void * vehhandler, double exittime);
Parameters¶
- simhandler: simulator handler
- vehhandler: vehicle handler
- exittime: new minimum exit time
Output¶
Returns 0 if could execute the action -1 otherwise.
Get number vehicles following a transit line¶
In C++ and Python¶
Explanation¶
It gets the current number of vehicles following a transit line.
Format¶
int AMesoGetNbVehiclesFollowingPTLine(void * simhandler, int idline);
Parameters¶
- simhandler: simulator handler
- idline: transit line identifier
Output¶
Returns number of vehicles following a transit line.
Get the vehicle following a transit line¶
In C++ and Python¶
Explanation¶
It gets the vehicle following a transit line.
Format¶
void * AMesoGetVehicleFollowingPTLine(void * simhandler, int idline, int vehPos)
Parameters¶
- simhandler: simulator handler
- idline: transit line identifier
- vehPos: transit vehicle identifier from 0 to AMesoGetNbVehiclesFollowingPTLine-1
Output¶
Returns the vehicle following a transit line.
Get the current accumulated delay of a vehicle¶
In C++ and Python¶
Explanation¶
It gets the accumulated delay of a vehicle. The dwell time of the vehicle is not included.
Format¶
double AMesoVehGetAccumulatedDelay(void * simhandler, void* vehhandler)
Parameters¶
- simhandler: simulator handler
- vehhandler: vehicle handler
Output¶
Returns the current accumulated delay of the vehicle.
Get the current accumulated travel time of a vehicle¶
In C++ and Python¶
Explanation¶
It gets the accumulated travel time of a vehicle.
Format¶
double AMesoVehGetAccumulatedTravelTime(void * simhandler, void* vehhandler)
Parameters¶
- simhandler: simulator handler
- vehhandler: vehicle handler
Output¶
Returns the current accumulated travel time of the vehicle.
Get the ID of a vehicle¶
In C++ and Python¶
Explanation¶
It gets the identificator (ID) of a vehicle.
Format¶
int AMesoGetVehicleID(void* vehhandler)
Parameters¶
- vehhandler: vehicle handler
Output¶
Returns the ID of the vehicle.
Get next exit time from section or turn¶
In C++ and Python¶
Explanation¶
Returns the current exit vehicle time to the section if the vehicle is in the section or exit turn time if the vehicle is in the node.
Format¶
double AMesoVehGetSectionExitTime(void* vehhandler)
Parameters¶
- vehhandler: vehicle handler
Output¶
Returns expected exit time. Relative time in the simulation.
Get the next turn in vehicle's path¶
In C++ and Python¶
Explanation¶
Returns the next turn in vehicle's path. When the vehicle is located in the turn, the next turn is the current turn.
Format¶
int AMesoVehNextTurn(void* vehhandler)
Parameters¶
- vehhandler: vehicle handler
Output¶
Returns vehicle's next turn ID.
Get the current vehicle's waiting time¶
In C++ and Python¶
Explanation¶
Returns the current vehicle waiting time. This is the current simulation time minus the initial expected exit time. The initial expected exit time is the earliest time the vehicle could exit the section when it's been the first in the queue.
Format¶
double AMesoVehGetWaitingTime(void* simhandler, void* vehhandler)
Parameters¶
- simhandler: simulation handler
- vehhandler: vehicle handler
Output¶
Returns waiting time in seconds.
Returns the expected arrival time to a section¶
In C++ and Python¶
Explanation¶
Returns the expected arrival time to the section id. The section has to be part of the path from the current position. Otherwise the expected arrival time is 0.
Format¶
double AMesoExpectedArrivalTimeToSection( void* simhandler, void* vehhandler, int sectionId )
Parameters¶
- simhandler: simulation handler
- vehhandler: vehicle handler
- sectionId: section identifier
Output¶
Returns an expected arrival time.
Returns if a turn has a yield sign or not¶
In C++ and Python¶
Explanation¶
Returns true if the turn with turn id has a yield/give way
Format¶
bool AMesoIsTurnWithGiveway( void* simhandler, int turnId )
Parameters¶
- simhandler: simulation handler
- turnId: turn identifier
Output¶
Returns true if the turn has a yield sign false otherwise.
Returns the initial safety margin for the turn id¶
In C++ and Python¶
Explanation¶
Returns the initial safety margin for the turn id.
Format¶
double AMesoGetInitialSafteyMargin( void* simhandler, int turnId )
Parameters¶
- simhandler: simulation handler
- turnId: turn identifier
Output¶
Returns the initial safety margin.
Returns the final safety margin for the turn id¶
In C++ and Python¶
Explanation¶
Returns the final safety margin for the turn id.
Format¶
double AMesoGetFinalSafteyMargin( void* simhandler, int turnId )
Parameters¶
- simhandler: simulation handler
- turnId: turn identifier
Output¶
Returns the final safety margin.
Returns the free flow travel time of the turn id¶
In C++ and Python¶
Explanation¶
Returns the free flow travel time of turn specified by turnId. If vehhandler is different from null it will use the vehicle speed acceptance, otherwise it will use the turn speed limit.
Format¶
double AMesoGetTurnFreeFlowTravelTime( void* simhandler, void * vehhandler, int turnId )
Parameters¶
- simhandler: simulation handler
- vehhandler: vehicle handler
- turnId: turn identifier
Output¶
Returns free flow travel time.
Returns the free flow travel time of the section id¶
In C++ and Python¶
Explanation¶
Returns the free flow travel time of section specified by sectionId. If vehhandler is different from null it will use the vehicle speed acceptance, otherwise it will use the turn speed limit.
Format¶
double AMesoGetTurnFreeFlowTravelTime( void* simhandler, void * vehhandler, int sectionId )
Parameters¶
- simhandler: simulation handler
- vehhandler: vehicle handler
- sectionId: section identifier
Output¶
Returns free flow travel time.