-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCOM Basic Commands.py
524 lines (442 loc) · 27.7 KB
/
COM Basic Commands.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
r"""
=========================================================================
Python-Script for PTV Vissim
Copyright (c) Jochen Lohmiller, PTV Planung Transport Verkehr GmbH.
All rights reserved.
- - - - - - - - - - - - - - - - -
Example of basic syntax - DO NOT MODIFY
=========================================================================
This script demonstrates how to use the COM interface in Python.
Basic commands for loading a network and layout, reading and setting
attributes of network objects, running a simulation and retrieving
evaluations are shown. This example is also available for the programming
languages VBA, VBS Matlab, C#, C++ and Java.
If you start using COM, please see also our COM introduction document:
C:\Program Files\PTV Vision\PTV Vissim xx\Doc\Eng\Vissim xx - COM Intro.pdf (xx = version number)
For information about the attributes and methods of PTV Vissim objects, see
the COM Help, which is located in the PTV Vissim menu: Help > COM Help.
Hint: You can easily see all attributes of the PTV Vissim objects in the lists in
Vissim. In case your PTV Vissim language is set to English, the name in the
headline of the list correspond to the command to access via COM.
Example: If you want to access the number of lanes of a link, go to PTV Vissim
and see the headline of "Number of lanes" in the list, which is
"NumLanes". To access this attribute via COM use:
Vissim.Net.Links.ItemByKey(1).AttValue('NumLanes')
For adding network objects with COM, please see the example Network Objects Adding
"""
from __future__ import print_function
import os
# COM-Server
import win32com.client as com
## Connecting the COM Server => Open a new Vissim Window:
Vissim = com.gencache.EnsureDispatch("Vissim.Vissim") #
# Vissim = com.Dispatch("Vissim.Vissim") # once the cache has been generated, its faster to call Dispatch which also creates the connection to Vissim.
# If you have installed multiple Vissim Versions, you can open a specific Vissim version adding the version number
# Vissim = com.gencache.EnsureDispatch("Vissim.Vissim.10") # Vissim 10
# Vissim = com.gencache.EnsureDispatch("Vissim.Vissim.22") # Vissim 2022
### for advanced users, with this command you can get all Constants from PTV Vissim with this command (not required for the example)
##import sys
##Constants = sys.modules[sys.modules[Vissim.__module__].__package__].constants
Path_of_COM_Basic_Commands_network = 'C:\\Users\\Public\\Documents\\PTV Vision\\PTV Vissim 2022\\Examples Training\\COM\\Basic Commands\\'
## Load a Vissim Network:
Filename = os.path.join(Path_of_COM_Basic_Commands_network, 'COM Basic Commands.inpx')
flag_read_additionally = False # you can read network(elements) additionally, in this case set "flag_read_additionally" to true
Vissim.LoadNet(Filename, flag_read_additionally)
## Load a Layout:
Filename = os.path.join(Path_of_COM_Basic_Commands_network, 'COM Basic Commands.layx')
Vissim.LoadLayout(Filename)
## ========================================================================
# Read and Set attributes
#==========================================================================
# Note: All of the following commands can also be executed during a
# simulation.
# Read Link Name:
Link_number = 1
Name_of_Link = Vissim.Net.Links.ItemByKey(Link_number).AttValue('Name')
Vissim.Log(16384, 'Name of Link(%d): %s' % (Link_number, Name_of_Link))
print('Name of Link(%d): %s' % (Link_number, Name_of_Link))
# Set Link Name:
new_Name_of_Link = 'New Link Name'
Vissim.Net.Links.ItemByKey(Link_number).SetAttValue('Name', new_Name_of_Link)
# Set a signal controller program:
SC_number = 1 # SC = SignalController
SignalController = Vissim.Net.SignalControllers.ItemByKey(SC_number)
new_signal_programm_number = 2
SignalController.SetAttValue('ProgNo', new_signal_programm_number)
# Set relative flow of a static vehicle route of a static vehicle routing decision:
SVRD_number = 1 # SVRD = Static Vehicle Routing Decision
SVR_number = 1 # SVR = Static Vehicle Route (of a specific Static Vehicle Routing Decision)
new_relativ_flow = 0.6
Vissim.Net.VehicleRoutingDecisionsStatic.ItemByKey(SVRD_number).VehRoutSta.ItemByKey(SVR_number).SetAttValue('RelFlow(1)', new_relativ_flow)
# 'RelFlow(1)' means the first defined time interval; to access the third defined time interval: 'RelFlow(3)'
# Set vehicle input:
VI_number = 1 # VI = Vehicle Input
new_volume = 600 # vehicles per hour
Vissim.Net.VehicleInputs.ItemByKey(VI_number).SetAttValue('Volume(1)', new_volume)
# 'Volume(1)' means the first defined time interval
# Hint: The Volumes of following intervals Volume(i) i = 2...n can only be
# edited, if continuous is deactivated: (otherwise error: "AttValue failed: Object 2: Attribute Volume (300) is no subject to changes.")
Vissim.Net.VehicleInputs.ItemByKey(VI_number).SetAttValue('Cont(2)', False)
Vissim.Net.VehicleInputs.ItemByKey(VI_number).SetAttValue('Volume(2)',400)
# Set vehicle composition:
Veh_composition_number = 1
Rel_Flows = Vissim.Net.VehicleCompositions.ItemByKey(Veh_composition_number).VehCompRelFlows.GetAll()
Rel_Flows[0].SetAttValue('VehType', 100) # Changing the vehicle type
Rel_Flows[0].SetAttValue('DesSpeedDistr', 50) # Changing the desired speed distribution
Rel_Flows[0].SetAttValue('RelFlow', 0.9) # Changing the relative flow
Rel_Flows[1].SetAttValue('RelFlow', 0.1) # Changing the relative flow of the 2nd Relative Flow.
## ========================================================================
# Accessing Multiple Attributes:
#========================================================================
def toList(NestedTuple):
"""
function to convert a nested tuple to a nested list
"""
return list(map(toList, NestedTuple)) if isinstance(NestedTuple, (list, tuple)) else NestedTuple
# GetMultiAttValues Read one attribute of all objects:
Attribute = "Name"
NameOfLinks = Vissim.Net.Links.GetMultiAttValues(Attribute)
NameOfLinks = toList(NameOfLinks) # convert to list
# SetMultiAttValues Set one attribute of multiple (not necessarily all) objects
NameOfLinks[0][1] = 'New Link Name of Link #1'
NameOfLinks[1][1] = 'New Link Name of Link #2'
NameOfLinks[3][1] = 'New Link Name of Link #4'
Vissim.Net.Links.SetMultiAttValues(Attribute, NameOfLinks) # 1st input is the consecutively number of links (not the ID), 2nd the link name
# Please note: The first column of GetMultiAttValues or SetMultiAttValues is not the ID of an object, it is consecutively numbered all available objects.
# GetMultipleAttributes Read multiple attributes of all objects:
Attributes1 = ("Name", "Length2D")
Name_Length_of_Links = Vissim.Net.Links.GetMultipleAttributes(Attributes1)
# SetMultipleAttributes Set multiple attribute of multiple (always the first x) objects:
Attributes2 = ("Name", "CostPerKm")
Link_Name_Cost = (("Name1", 12),("Name2", 7),("Name3", 5),("Name4", 3))
Vissim.Net.Links.SetMultipleAttributes(Attributes2, Link_Name_Cost)
# SetAllAttValues Set all attributes of one object to one value:
Attribute = "Name"
Link_Name = "All Links have the same Name"
Vissim.Net.Links.SetAllAttValues(Attribute, Link_Name)
Attribute = "CostPerKm"
Cost = 5.5
Vissim.Net.Links.SetAllAttValues(Attribute, Cost)
# Note the method SetAllAttValues has a 3rd optional input: Optional ByVal add As Boolean = False; Use only for numbers!
Vissim.Net.Links.SetAllAttValues(Attribute, Cost, True) # setting the 3rd input to true, will add 5.5 to all previous costs!
## ========================================================================
# Simulation
#==========================================================================
# Chose Random Seed
Random_Seed = 42
Vissim.Simulation.SetAttValue('RandSeed', Random_Seed)
# Set simulation parameters
End_of_simulation = 600 # simulation second [s]
Vissim.Simulation.SetAttValue('SimPeriod', End_of_simulation)
Sim_break_at = 200 # simulation second [s]
Vissim.Simulation.SetAttValue('SimBreakAt', Sim_break_at)
# Set maximum speed:
Vissim.Simulation.SetAttValue('UseMaxSimSpeed', True)
# Hint: to change the simulation speed use: Vissim.Simulation.SetAttValue('SimSpeed', 10) # 10 => 10 Sim. sec. / s
# To start a simulation you can run a single step:
Vissim.Simulation.RunSingleStep()
# Or run the simulation continuous (it stops at breakpoint or end of simulation)
Vissim.Simulation.RunContinuous()
# To stop the simulation:
Vissim.Simulation.Stop()
## ========================================================================
# Access during simulation
#==========================================================================
# Note: All of commands of "Read and Set attributes (vehicles)" can also be executed during a
# simulation (e.g. changing signal controller program, setting relative flow of a static vehicle route,
# changing the vehicle input, changing the vehicle composition).
Sim_break_at = 198 # simulation second [s]
Vissim.Simulation.SetAttValue('SimBreakAt', Sim_break_at)
Vissim.Simulation.RunContinuous() # start the simulation until SimBreakAt (198s)
# Get the state of a signal head:
SH_number = 1 # SH = SignalHead
State_of_SH = Vissim.Net.SignalHeads.ItemByKey(SH_number).AttValue('SigState') # possible output see COM Help: SignalizationState Enumeration
Vissim.Log(16384, 'Actual state of SignalHead(%d) is: %s' % (SH_number, State_of_SH))
print('Actual state of SignalHead(%d) is: %s' % (SH_number, State_of_SH))
# Set the state of a signal controller:
# Note: Once a state of a signal group is set, the attribute "ContrByCOM" is automatically set to True. Meaning the signal group will keep this state until another state is set by COM or the end of the simulation
# To switch back to the defined signal controller, set the attribute signal "ContrByCOM" to False (example see below).
SC_number = 1 # SC = SignalController
SG_number = 1 # SG = SignalGroup
SignalController = Vissim.Net.SignalControllers.ItemByKey(SC_number)
SignalGroup = SignalController.SGs.ItemByKey(SG_number)
new_state = "GREEN" # possible values 'GREEN', 'RED', 'AMBER', 'REDAMBER' and more, see COM Help: SignalizationState Enumeration
SignalGroup.SetAttValue("SigState", new_state)
# Note: The signal controller can only be called at whole simulation seconds, so the state will be set in Vissim at the next whole simulation second, here 199s
# Simulate so that the new state is active in the Vissim simulation:
Sim_break_at = 200 # simulation second [s]
Vissim.Simulation.SetAttValue("SimBreakAt", Sim_break_at)
Vissim.Simulation.RunContinuous() # start the simulation until SimBreakAt (200s)
# Give the control back:
SignalGroup.SetAttValue("ContrByCOM", False)
# Information about all vehicles in the network (in the current simulation second):
# In the following, 5 different methods to access attributes are shown:
# Method #1: Loop over all Vehicles using "GetAll"
# Method #2: Loop over all Vehicles using Object Enumeration
# Method #3: Using the Iterator
# Method #4: Accessing all attributes directly using "GetMultiAttValues" (fast way if you want the attributes of all vehicles)
# Method #5: Accessing all attributes directly using "GetMultipleAttributes" (even more faster)
# The result of the four methods is the same (except the format).
# Method #1: Loop over all Vehicles:
All_Vehicles = Vissim.Net.Vehicles.GetAll() # get all vehicles in the network at the actual simulation second
Vissim.Log(16384, 'All vehicles by GetAll():')
print('All vehicles by GetAll():')
for cur_Veh in All_Vehicles:
veh_number = cur_Veh.AttValue('No')
veh_type = cur_Veh.AttValue('VehType')
veh_speed = cur_Veh.AttValue('Speed')
veh_position = cur_Veh.AttValue('Pos')
veh_linklane = cur_Veh.AttValue('Lane')
Vissim.Log(16384, '%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
print('%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
# Method #2: Loop over all Vehicles using Object Enumeration
Vissim.Log(16384, 'All vehicles by object enumeration:')
print('All vehicles by object enumeration:')
for Vehicle in Vissim.Net.Vehicles:
veh_number = Vehicle.AttValue('No')
veh_type = Vehicle.AttValue('VehType')
veh_speed = Vehicle.AttValue('Speed')
veh_position = Vehicle.AttValue('Pos')
veh_linklane = Vehicle.AttValue('Lane')
Vissim.Log(16384, '%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
print('%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
# Method #3: Using the Iterator
Vehicles_Iterator = Vissim.Net.Vehicles.Iterator
Vissim.Log(16384, 'All vehicles by iterator:')
print('All vehicles by iterator:')
while Vehicles_Iterator.Valid:
Vehicle = Vehicles_Iterator.Item
veh_number = Vehicle.AttValue('No')
veh_type = Vehicle.AttValue('VehType')
veh_speed = Vehicle.AttValue('Speed')
veh_position = Vehicle.AttValue('Pos')
veh_linklane = Vehicle.AttValue('Lane')
Vissim.Log(16384, '%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
print('%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
Vehicles_Iterator.Next()
# Method #4: Accessing all Attributes directly using "GetMultiAttValues" (fast way if you want the attributes of all vehicles)
veh_numbers = Vissim.Net.Vehicles.GetMultiAttValues('No') # Output 1. column:consecutive number; 2. column: AttValue
veh_types = Vissim.Net.Vehicles.GetMultiAttValues('VehType') # Output 1. column:consecutive number; 2. column: AttValue
veh_speeds = Vissim.Net.Vehicles.GetMultiAttValues('Speed') # Output 1. column:consecutive number; 2. column: AttValue
veh_positions = Vissim.Net.Vehicles.GetMultiAttValues('Pos') # Output 1. column:consecutive number; 2. column: AttValue
veh_linklanes = Vissim.Net.Vehicles.GetMultiAttValues('Lane') # Output 1. column:consecutive number; 2. column: AttValue
Vissim.Log(16384, 'All vehicles by GetMultiAttValues:')
print('All vehicles by GetMultiAttValues:')
for cnt, vehNum in enumerate(veh_numbers):
Vissim.Log(16384, '%s | %s | %.2f | %.2f | %s' % (vehNum[1], vehNum[1], vehNum[1], vehNum[1], veh_linklanes[cnt][1])) # only display the 2nd column
print('%s | %s | %.2f | %.2f | %s' % (vehNum[1], vehNum[1], vehNum[1], vehNum[1], veh_linklanes[cnt][1])) # only display the 2nd column
# Method #5: Accessing all attributes directly using "GetMultipleAttributes" (even more faster)
all_veh_attributes = Vissim.Net.Vehicles.GetMultipleAttributes(('No', 'VehType', 'Speed', 'Pos', 'Lane'))
Vissim.Log(16384, 'All vehicles by GetMultipleAttributes:')
print('All vehicles by GetMultipleAttributes:')
for vahAttr in all_veh_attributes:
Vissim.Log(16384, '%s | %s | %.2f | %.2f | %s' % (vahAttr[0], vahAttr[1], vahAttr[2], vahAttr[3], vahAttr[4])) # only display the 2nd column
print('%s | %s | %.2f | %.2f | %s' % (vahAttr[0], vahAttr[1], vahAttr[2], vahAttr[3], vahAttr[4])) # only display the 2nd column
# Method #6: Acessing data for a filtered set of vehicles only
Vehicles_Filtered_Iterator = Vissim.Net.Vehicles.GetFilteredSet('[SPEED]<25').Iterator
Vissim.Log(16384, 'Filtered slower vehicles by GetFilteredSet:')
print('Filtered slower vehicles by GetFilteredSet:')
while Vehicles_Filtered_Iterator.Valid:
Vehicle = Vehicles_Filtered_Iterator.Item
veh_number = Vehicle.AttValue('No')
veh_type = Vehicle.AttValue('VehType')
veh_speed = Vehicle.AttValue('Speed')
veh_position = Vehicle.AttValue('Pos')
veh_linklane = Vehicle.AttValue('Lane')
Vissim.Log(16384, '%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
print('%s | %s | %.2f | %.2f | %s' % (veh_number, veh_type, veh_speed, veh_position, veh_linklane))
Vehicles_Filtered_Iterator.Next()
## Operations at one specific vehicle:
All_Vehicles = Vissim.Net.Vehicles.GetAll() # get all vehicles in the network at the actual simulation second
Vehicle = All_Vehicles[0]
# alternatively with ItemByKey:
# veh_number = 66 # the same as: All_Vehicles[0].AttValue('No')
# Vehicle = Vissim.Net.Vehicles.ItemByKey(veh_number)
# Set Desired Speed to a vehicle:
DesSpeed_new = 30
Vehicle.SetAttValue('DesSpeed', DesSpeed_new)
# Move a vehicle:
link_number = 1
lane_number = 1
link_coordinate = 70
Vehicle.MoveToLinkPosition(link_number, lane_number, link_coordinate) # This function will operate during the next simulation step
# Note: In earlier PTV Vissim releases, the name of the function was: MoveToLinkCoordinate
Vissim.Simulation.RunSingleStep() # Next Step, so that the vehicle gets moved.
# Remove a vehicle:
veh_number = Vehicle.AttValue('No')
Vissim.Net.Vehicles.RemoveVehicle(veh_number)
# Putting a new vehicle to the network:
vehicle_type = 100
desired_speed = 53 # unit according to the user setting in Vissim [km/h or mph]
link = 1
lane = 1
xcoordinate = 15 # unit according to the user setting in Vissim [m or ft]
interaction = True # optional boolean
new_Vehicle = Vissim.Net.Vehicles.AddVehicleAtLinkPosition(vehicle_type, link, lane, xcoordinate, desired_speed, interaction)
# Note: In earlier Vissim releases, the name of the function was: AddVehicleAtLinkCoordinate
# Make Screenshots of the intersection 2D and 3D:
# ZoomTo:
# Zooms the view to the rectangle defined by the two points (x1, y1) and (x2,y2), which are given in world coordinates. If the rectangle proportions differ
# from the proportions of the network window, the specified rectangle will be centred in the network editor window.
X1 = 250
Y1 = 30
X2 = 350
Y2 = 135
Vissim.Graphics.CurrentNetworkWindow.ZoomTo(X1, Y1, X2, Y2)
# Make a Screenshot in 2D:
# It creates a graphic file of the VISSIM main window formatted according to its extension: PNG, TIFF, GIF, JPG, JPEG or BMP. A BMP file will be written if the extension can not be recognized.
Filename_screenshot = "screenshot2D.jpg" # to set to a specific path: "C:\\Screenshots\\screenshot2D.jpg"
sizeFactor = 1 # 1: original size, 2: doubles size
Vissim.Graphics.CurrentNetworkWindow.Screenshot(Filename_screenshot, sizeFactor)
# Make a Screenshot in 3D:
# Set 3D Mode:
Vissim.Graphics.CurrentNetworkWindow.SetAttValue("3D", 1)
# Set the camera position (viewing angle):
xPos = 270
yPos = 30
zPos = 15
yawAngle = 45
pitchAngle = 10
Vissim.Graphics.CurrentNetworkWindow.SetCameraPositionAndAngle(xPos, yPos, zPos, yawAngle, pitchAngle)
Filename_screenshot = "screenshot3D.jpg" # to set to a specific path: "C:\\Screenshots\\screenshot3D.jpg"
Vissim.Graphics.CurrentNetworkWindow.Screenshot(Filename_screenshot, sizeFactor)
# Set 2D Mode and old Network position:
Vissim.Graphics.CurrentNetworkWindow.SetAttValue("3D", 0)
X1 = -10
Y1 = -10
X2 = 600
Y2 = 300
Vissim.Graphics.CurrentNetworkWindow.ZoomTo(X1, Y1, X2, Y2)
# Continue the simulation until end of simulation (get(Vissim.Simulation, 'AttValue', 'SimPeriod'))
Vissim.Simulation.RunContinuous()
## ========================================================================
# Results of Simulations:
#==========================================================================
# Run 3 Simulations at maximum speed:
# Delete all previous simulation runs first:
for simRun in Vissim.Net.SimulationRuns:
Vissim.Net.SimulationRuns.RemoveSimulationRun(simRun)
# Activate QuickMode:
Vissim.Graphics.CurrentNetworkWindow.SetAttValue("QuickMode", 1)
Vissim.SuspendUpdateGUI() # stop updating of the complete Vissim workspace (network editor, list, chart and signal time table windows)
# Alternatively, load a layout (*.layx) where dynamic elements (vehicles and pedestrians) are not visible:
# Vissim.LoadLayout(os.path.join(Path_of_COM_Basic_Commands_network, 'COM Basic Commands - Hide vehicles.layx')) # loading a layout where vehicles are not displayed
End_of_simulation = 600
Vissim.Simulation.SetAttValue('SimPeriod', End_of_simulation)
Sim_break_at = 0 # simulation second [s] => 0 means no break!
Vissim.Simulation.SetAttValue('SimBreakAt', Sim_break_at)
# Set maximum speed:
Vissim.Simulation.SetAttValue('UseMaxSimSpeed', True)
for cnt_Sim in range(3):
Vissim.Simulation.SetAttValue('RandSeed', cnt_Sim + 1) # Note: RandSeed 0 is not allowed
Vissim.Simulation.RunContinuous()
Vissim.ResumeUpdateGUI(True) # allow updating of the complete Vissim workspace (network editor, list, chart and signal time table windows)
Vissim.Graphics.CurrentNetworkWindow.SetAttValue("QuickMode", 0) # deactivate QuickMode
# Vissim.LoadLayout(os.path.join(Path_of_COM_Basic_Commands_network, 'COM Basic Commands.layx')) # loading a layout to display vehicles again
# List of all Simulation runs:
Attributes = ['Timestamp', 'RandSeed', 'SimEnd']
number_of_runs = Vissim.Net.SimulationRuns.Count
List_Sim_Runs = Vissim.Net.SimulationRuns.GetMultipleAttributes(Attributes)
Vissim.Log(16384, 'List of all simulation runs:')
print('List of all simulation runs:')
for cnt_S in range(number_of_runs):
Vissim.Log(16384, '%s | %d | %d ' % (List_Sim_Runs[cnt_S][0], List_Sim_Runs[cnt_S][1], List_Sim_Runs[cnt_S][2]))
print('%s | %d | %d ' % (List_Sim_Runs[cnt_S][0], List_Sim_Runs[cnt_S][1], List_Sim_Runs[cnt_S][2]))
# Get the results of Vehicle Travel Time Measurements:
Veh_TT_measurement_number = 2
Veh_TT_measurement = Vissim.Net.VehicleTravelTimeMeasurements.ItemByKey(Veh_TT_measurement_number)
# Syntax to get the travel times:
# Veh_TT_measurement.AttValue('TravTm(sub_attribut_1, sub_attribut_2, sub_attribut_3)')
#
# sub_attribut_1: SimulationRun
# 1, 2, 3, ... Current: the value of one specific simulation (number according to the tribute "No" of Simulation Runs (see List of Simulation Runs))
# Avg, StdDev, Min, Max: aggregated value of all simulations runs: Avg, StdDev, Min, Max
# sub_attribut_2: TimeInterval
# 1, 2, 3, ... Last: the value of one specific time interval (number of time interval always starts at 1 (first time interval), 2 (2nd TI), 3 (3rd TI), ...)
# Avg, StdDev, Min, Max: aggregated value of all time interval of one simulation: Avg, StdDev, Min, Max
# Total: sum of all time interval of one simulation
# sub_attribut_3: VehicleClass
# 10, 20 or All values only from vehicles of the defined vehicle class number (according to the attribute "No" of Vehicle Classes)
# Note: You can only access the results of specific vehicle classes if you set it in Evaluation > Configuration > Result Attributes
#
# The value of on time interval is the arithmetic mean of all single travel times of the vehicles.
# Example #1:
# Average of all simulations (1. input = Avg)
# of the average of all time intervals (2. input = Avg)
# of all vehicle classes (3. input = All)
TT = Veh_TT_measurement.AttValue('TravTm(Avg,Avg,All)')
No_Veh = Veh_TT_measurement.AttValue('Vehs (Avg,Avg,All)')
Vissim.Log(16384, 'Average travel time all time intervalls of all simulation of all vehicle classes: %.2f (number of vehicles: %s)' % (TT, No_Veh))
print('Average travel time all time intervalls of all simulation of all vehicle classes: %.2f (number of vehicles: %s)' % (TT, No_Veh))
# Example #2:
# Value of the Current simulation (1. input = Current)
# of the maximum of all time intervals (2. input = Max)
# of vehicle class HGV (3. input = 20)
TT = Veh_TT_measurement.AttValue('TravTm(Current,Max,20)')
No_Veh = Veh_TT_measurement.AttValue('Vehs (Current,Max,20)')
Vissim.Log(16384, 'Maximum travel time of all time intervalls of the current simulation of vehicle class HGV: %.2f (number of vehicles: %s)' % (TT, No_Veh))
print('Maximum travel time of all time intervalls of the current simulation of vehicle class HGV: %.2f (number of vehicles: %s)' % (TT, No_Veh))
# Example #3: Note: A Travel times from 2nd simulation run must be available
# Value of the 2nd simulation (1. input = 2)
# of the 1st time interval (2. input = 1)
# of all vehicle classes (3. input = All)
# TT = Veh_TT_measurement.AttValue('TravTm(2,1,All)')
# No_Veh = Veh_TT_measurement.AttValue('Vehs (2,1,All)')
# print 'Travel time of the 1st time interval of the 2nd simulation of all vehicle classes: %.2f (number of vehicles: %s)' % (TT, No_Veh)
# Data Collection
DC_measurement_number = 1
DC_measurement = Vissim.Net.DataCollectionMeasurements.ItemByKey(DC_measurement_number)
# Syntax to get the data:
# DC_measurement.AttValue('Vehs(sub_attribut_1, sub_attribut_2, sub_attribut_3)')
#
# sub_attribut_1: SimulationRun (same as described at Vehicle Travel Time Measurements)
# sub_attribut_2: TimeInterval (same as described at Vehicle Travel Time Measurements)
# sub_attribut_3: VehicleClass (same as described at Vehicle Travel Time Measurements)
#
# The value of on time interval is the arithmetic mean of all single values of the vehicles.
# Example #1:
# Average value of all simulations (1. input = Avg)
# of the 1st time interval (2. input = 1)
# of all vehicle classes (3. input = All)
No_Veh = DC_measurement.AttValue('Vehs (Avg,1,All)') # number of vehicles
Speed = DC_measurement.AttValue('Speed (Avg,1,All)') # Speed of vehicles
Acceleration = DC_measurement.AttValue('Acceleration(Avg,1,All)') # Acceleration of vehicles
Length = DC_measurement.AttValue('Length (Avg,1,All)') # Length of vehicles
Vissim.Log(16384, 'Data Collection #%d: Average values of all Simulations runs of 1st time intervall of all vehicle classes: ' % (DC_measurement_number))
print('Data Collection #%d: Average values of all Simulations runs of 1st time intervall of all vehicle classes: ' % (DC_measurement_number))
Vissim.Log(16384, '#vehicles: %d; Speed: %.2f; Acceleration: %.2f; Length: %.2f' % (No_Veh, Speed, Acceleration, Length))
print('#vehicles: %d; Speed: %.2f; Acceleration: %.2f; Length: %.2f' % (No_Veh, Speed, Acceleration, Length))
# Queue length
# Syntax to get the data:
# QueueCounter.AttValue('QLen(sub_attribut_1, sub_attribut_2)')
#
# sub_attribut_1: SimulationRun (same as described at Vehicle Travel Time Measurements)
# sub_attribut_2: TimeInterval (same as described at Vehicle Travel Time Measurements)
#
# Example #1:
# Average value of all simulations (1. input = Avg)
# of the average of all time intervals (2. input = Avg)
QC_number = 1
maxQ = Vissim.Net.QueueCounters.ItemByKey(QC_number).AttValue('QLenMax(Avg, Avg)')
Vissim.Log(16384, 'Average maximum Queue length of all simulations and time intervals of Queue Counter #%d: %.2f' % (QC_number, maxQ))
print('Average maximum Queue length of all simulations and time intervals of Queue Counter #%d: %.2f' % (QC_number, maxQ))
# Example #1:
# There is currently no COM object that represents link evaluation segments as such.
# As a workaround their values can be accessed via the relations of links. This results
# in a string that contains the sequence of the chosen values along the sequence of
# the link evaluation segments.
Link_number = 1
volume = Vissim.Net.Links.ItemByKey(Link_number).AttValue('Concatenate:LinkEvalSegs\Volume(Avg, Avg, All)')
Vissim.Log(16384, 'Average volumes of all simulations and time intervals for all vehicle types of the evaluation segments of the link #%d: %s' % (Link_number, volume))
print('Average volumes of all simulations and time intervals for all vehicle types of the evaluation segments of the link #%d: %s' % (Link_number, volume))
## ========================================================================
# Saving
#==========================================================================
Filename = os.path.join(Path_of_COM_Basic_Commands_network, 'COM Basic Commands saved.inpx')
Vissim.SaveNetAs(Filename)
Filename = os.path.join(Path_of_COM_Basic_Commands_network, 'COM Basic Commands saved.layx')
Vissim.SaveLayout(Filename)
## ========================================================================
# End Vissim
#==========================================================================
Vissim = None