Line data Source code
1 : /****************************************************************************/
2 : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 : // Copyright (C) 2017-2024 German Aerospace Center (DLR) and others.
4 : // This program and the accompanying materials are made available under the
5 : // terms of the Eclipse Public License 2.0 which is available at
6 : // https://www.eclipse.org/legal/epl-2.0/
7 : // This Source Code may also be made available under the following Secondary
8 : // Licenses when the conditions for such availability set forth in the Eclipse
9 : // Public License 2.0 are satisfied: GNU General Public License, version 2
10 : // or later which is available at
11 : // https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12 : // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13 : /****************************************************************************/
14 : /// @file Vehicle.cpp
15 : /// @author Jakob Erdmann
16 : /// @author Michael Behrisch
17 : /// @author Mirko Barthauer
18 : /// @date 30.05.2012
19 : ///
20 : // C++ TraCI client API implementation
21 : /****************************************************************************/
22 : #include <config.h>
23 : #include <sstream>
24 :
25 : #define LIBTRACI 1
26 : #include <libsumo/StorageHelper.h>
27 : #include <libsumo/Vehicle.h>
28 : #include "Domain.h"
29 :
30 : namespace libtraci {
31 :
32 : typedef Domain<libsumo::CMD_GET_VEHICLE_VARIABLE, libsumo::CMD_SET_VEHICLE_VARIABLE> Dom;
33 :
34 :
35 : // ===========================================================================
36 : // static member definitions
37 : // ===========================================================================
38 : std::vector<std::string>
39 20938 : Vehicle::getIDList() {
40 41875 : return Dom::getStringVector(libsumo::TRACI_ID_LIST, "");
41 : }
42 :
43 :
44 : int
45 31 : Vehicle::getIDCount() {
46 62 : return Dom::getInt(libsumo::ID_COUNT, "");
47 : }
48 :
49 :
50 31763 : LIBTRACI_SUBSCRIPTION_IMPLEMENTATION(Vehicle, VEHICLE)
51 1086 : LIBTRACI_PARAMETER_IMPLEMENTATION(Vehicle, VEHICLE)
52 :
53 : double
54 3685 : Vehicle::getSpeed(const std::string& vehID) {
55 3685 : return Dom::getDouble(libsumo::VAR_SPEED, vehID);
56 : }
57 :
58 : double
59 18 : Vehicle::getLateralSpeed(const std::string& vehID) {
60 18 : return Dom::getDouble(libsumo::VAR_SPEED_LAT, vehID);
61 : }
62 :
63 : double
64 1176 : Vehicle::getAcceleration(const std::string& vehID) {
65 1176 : return Dom::getDouble(libsumo::VAR_ACCELERATION, vehID);
66 : }
67 :
68 :
69 : double
70 1028 : Vehicle::getSpeedWithoutTraCI(const std::string& vehID) {
71 1028 : return Dom::getDouble(libsumo::VAR_SPEED_WITHOUT_TRACI, vehID);
72 : }
73 :
74 :
75 : libsumo::TraCIPosition
76 331140 : Vehicle::getPosition(const std::string& vehID, const bool includeZ) {
77 331140 : return includeZ ? getPosition3D(vehID) : Dom::getPos(libsumo::VAR_POSITION, vehID);
78 : }
79 :
80 :
81 : libsumo::TraCIPosition
82 399 : Vehicle::getPosition3D(const std::string& vehID) {
83 399 : return Dom::getPos3D(libsumo::VAR_POSITION3D, vehID);
84 : }
85 :
86 :
87 : double
88 98 : Vehicle::getAngle(const std::string& vehID) {
89 98 : return Dom::getDouble(libsumo::VAR_ANGLE, vehID);
90 : }
91 :
92 :
93 : double
94 2 : Vehicle::getSlope(const std::string& vehID) {
95 2 : return Dom::getDouble(libsumo::VAR_SLOPE, vehID);
96 : }
97 :
98 :
99 : std::string
100 914 : Vehicle::getRoadID(const std::string& vehID) {
101 914 : return Dom::getString(libsumo::VAR_ROAD_ID, vehID);
102 : }
103 :
104 :
105 : double
106 18 : Vehicle::getDeparture(const std::string& vehID) {
107 18 : return Dom::getDouble(libsumo::VAR_DEPARTURE, vehID);
108 : }
109 :
110 :
111 : double
112 18 : Vehicle::getDepartDelay(const std::string& vehID) {
113 18 : return Dom::getDouble(libsumo::VAR_DEPART_DELAY, vehID);
114 : }
115 :
116 :
117 : std::string
118 2586 : Vehicle::getLaneID(const std::string& vehID) {
119 2586 : return Dom::getString(libsumo::VAR_LANE_ID, vehID);
120 : }
121 :
122 :
123 : int
124 1258 : Vehicle::getLaneIndex(const std::string& vehID) {
125 1258 : return Dom::getInt(libsumo::VAR_LANE_INDEX, vehID);
126 : }
127 :
128 :
129 : std::string
130 24 : Vehicle::getSegmentID(const std::string& vehID) {
131 24 : return Dom::getString(libsumo::VAR_SEGMENT_ID, vehID);
132 : }
133 :
134 :
135 : int
136 23 : Vehicle::getSegmentIndex(const std::string& vehID) {
137 23 : return Dom::getInt(libsumo::VAR_SEGMENT_INDEX, vehID);
138 : }
139 :
140 :
141 : std::string
142 82 : Vehicle::getTypeID(const std::string& vehID) {
143 82 : return Dom::getString(libsumo::VAR_TYPE, vehID);
144 : }
145 :
146 :
147 : std::string
148 26 : Vehicle::getRouteID(const std::string& vehID) {
149 26 : return Dom::getString(libsumo::VAR_ROUTE_ID, vehID);
150 : }
151 :
152 :
153 : int
154 992 : Vehicle::getRouteIndex(const std::string& vehID) {
155 992 : return Dom::getInt(libsumo::VAR_ROUTE_INDEX, vehID);
156 : }
157 :
158 :
159 : libsumo::TraCIColor
160 40 : Vehicle::getColor(const std::string& vehID) {
161 40 : return Dom::getCol(libsumo::VAR_COLOR, vehID);
162 : }
163 :
164 : double
165 4013 : Vehicle::getLanePosition(const std::string& vehID) {
166 4013 : return Dom::getDouble(libsumo::VAR_LANEPOSITION, vehID);
167 : }
168 :
169 : double
170 798 : Vehicle::getLateralLanePosition(const std::string& vehID) {
171 798 : return Dom::getDouble(libsumo::VAR_LANEPOSITION_LAT, vehID);
172 : }
173 :
174 : double
175 98 : Vehicle::getCO2Emission(const std::string& vehID) {
176 98 : return Dom::getDouble(libsumo::VAR_CO2EMISSION, vehID);
177 : }
178 :
179 : double
180 18 : Vehicle::getCOEmission(const std::string& vehID) {
181 18 : return Dom::getDouble(libsumo::VAR_COEMISSION, vehID);
182 : }
183 :
184 : double
185 18 : Vehicle::getHCEmission(const std::string& vehID) {
186 18 : return Dom::getDouble(libsumo::VAR_HCEMISSION, vehID);
187 : }
188 :
189 : double
190 18 : Vehicle::getPMxEmission(const std::string& vehID) {
191 18 : return Dom::getDouble(libsumo::VAR_PMXEMISSION, vehID);
192 : }
193 :
194 : double
195 18 : Vehicle::getNOxEmission(const std::string& vehID) {
196 18 : return Dom::getDouble(libsumo::VAR_NOXEMISSION, vehID);
197 : }
198 :
199 : double
200 88 : Vehicle::getFuelConsumption(const std::string& vehID) {
201 88 : return Dom::getDouble(libsumo::VAR_FUELCONSUMPTION, vehID);
202 : }
203 :
204 : double
205 18 : Vehicle::getNoiseEmission(const std::string& vehID) {
206 18 : return Dom::getDouble(libsumo::VAR_NOISEEMISSION, vehID);
207 : }
208 :
209 : double
210 38 : Vehicle::getElectricityConsumption(const std::string& vehID) {
211 38 : return Dom::getDouble(libsumo::VAR_ELECTRICITYCONSUMPTION, vehID);
212 : }
213 :
214 : int
215 18 : Vehicle::getPersonNumber(const std::string& vehID) {
216 18 : return Dom::getInt(libsumo::VAR_PERSON_NUMBER, vehID);
217 : }
218 :
219 : int
220 18 : Vehicle::getPersonCapacity(const std::string& vehID) {
221 18 : return Dom::getInt(libsumo::VAR_PERSON_CAPACITY, vehID);
222 : }
223 :
224 :
225 : double
226 18 : Vehicle::getBoardingDuration(const std::string& vehID) {
227 18 : return Dom::getDouble(libsumo::VAR_BOARDING_DURATION, vehID);
228 : }
229 :
230 :
231 : double
232 24 : Vehicle::getImpatience(const std::string& vehID) {
233 24 : return Dom::getDouble(libsumo::VAR_IMPATIENCE, vehID);
234 : }
235 :
236 :
237 : std::vector<std::string>
238 40 : Vehicle::getPersonIDList(const std::string& vehID) {
239 40 : return Dom::getStringVector(libsumo::LAST_STEP_PERSON_ID_LIST, vehID);
240 : }
241 :
242 : std::pair<std::string, double>
243 6177 : Vehicle::getLeader(const std::string& vehID, double dist) {
244 6177 : tcpip::Storage content;
245 : StoHelp::writeTypedDouble(content, dist);
246 6177 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
247 : tcpip::Storage& ret = Dom::get(libsumo::VAR_LEADER, vehID, &content);
248 6177 : ret.readInt(); // components
249 6177 : ret.readUnsignedByte();
250 6177 : const std::string leaderID = ret.readString();
251 6177 : ret.readUnsignedByte();
252 6177 : const double gap = ret.readDouble();
253 6177 : return std::make_pair(leaderID, gap);
254 6177 : }
255 :
256 :
257 : std::pair<std::string, double>
258 59 : Vehicle::getFollower(const std::string& vehID, double dist) {
259 59 : tcpip::Storage content;
260 : StoHelp::writeTypedDouble(content, dist);
261 59 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
262 : tcpip::Storage& ret = Dom::get(libsumo::VAR_FOLLOWER, vehID, &content);
263 58 : ret.readInt(); // components
264 59 : const std::string leaderID = StoHelp::readTypedString(ret);
265 174 : return std::make_pair(leaderID, StoHelp::readTypedDouble(ret));
266 59 : }
267 :
268 :
269 : std::vector<libsumo::TraCIJunctionFoe>
270 30 : Vehicle::getJunctionFoes(const std::string& vehID, double dist) {
271 : std::vector<libsumo::TraCIJunctionFoe> result;
272 30 : tcpip::Storage content;
273 : StoHelp::writeTypedDouble(content, dist);
274 30 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
275 : tcpip::Storage& ret = Dom::get(libsumo::VAR_FOES, vehID, &content);
276 30 : ret.readInt(); // compound size
277 30 : const int n = StoHelp::readTypedInt(ret); // number of foe informations
278 75 : for (int i = 0; i < n; ++i) {
279 : libsumo::TraCIJunctionFoe info;
280 45 : info.foeId = StoHelp::readTypedString(ret);
281 45 : info.egoDist = StoHelp::readTypedDouble(ret);
282 45 : info.foeDist = StoHelp::readTypedDouble(ret);
283 45 : info.egoExitDist = StoHelp::readTypedDouble(ret);
284 45 : info.foeExitDist = StoHelp::readTypedDouble(ret);
285 45 : info.egoLane = StoHelp::readTypedString(ret);
286 45 : info.foeLane = StoHelp::readTypedString(ret);
287 45 : info.egoResponse = StoHelp::readBool(ret);
288 45 : info.foeResponse = StoHelp::readBool(ret);
289 45 : result.emplace_back(info);
290 45 : }
291 30 : return result;
292 30 : }
293 :
294 :
295 : double
296 50 : Vehicle::getWaitingTime(const std::string& vehID) {
297 50 : return Dom::getDouble(libsumo::VAR_WAITING_TIME, vehID);
298 : }
299 :
300 :
301 : double
302 25 : Vehicle::getAccumulatedWaitingTime(const std::string& vehID) {
303 25 : return Dom::getDouble(libsumo::VAR_ACCUMULATED_WAITING_TIME, vehID);
304 : }
305 :
306 :
307 : double
308 23 : Vehicle::getAdaptedTraveltime(const std::string& vehID, double time, const std::string& edgeID) {
309 23 : tcpip::Storage content;
310 : StoHelp::writeCompound(content, 2);
311 : StoHelp::writeTypedDouble(content, time);
312 : StoHelp::writeTypedString(content, edgeID);
313 46 : return Dom::getDouble(libsumo::VAR_EDGE_TRAVELTIME, vehID, &content);
314 23 : }
315 :
316 :
317 : double
318 22 : Vehicle::getEffort(const std::string& vehID, double time, const std::string& edgeID) {
319 22 : tcpip::Storage content;
320 : StoHelp::writeCompound(content, 2);
321 : StoHelp::writeTypedDouble(content, time);
322 : StoHelp::writeTypedString(content, edgeID);
323 44 : return Dom::getDouble(libsumo::VAR_EDGE_EFFORT, vehID, &content);
324 22 : }
325 :
326 :
327 : bool
328 18 : Vehicle::isRouteValid(const std::string& vehID) {
329 18 : return Dom::getInt(libsumo::VAR_ROUTE_VALID, vehID) != 0;
330 : }
331 :
332 :
333 : std::vector<std::string>
334 1045 : Vehicle::getRoute(const std::string& vehID) {
335 1045 : return Dom::getStringVector(libsumo::VAR_EDGES, vehID);
336 : }
337 :
338 :
339 : int
340 18 : Vehicle::getSignals(const std::string& vehID) {
341 18 : return Dom::getInt(libsumo::VAR_SIGNALS, vehID);
342 : }
343 :
344 :
345 : std::vector<libsumo::TraCIBestLanesData>
346 18 : Vehicle::getBestLanes(const std::string& vehID) {
347 18 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
348 : std::vector<libsumo::TraCIBestLanesData> result;
349 : tcpip::Storage& ret = Dom::get(libsumo::VAR_BEST_LANES, vehID);
350 18 : ret.readInt();
351 18 : ret.readUnsignedByte();
352 :
353 18 : const int n = ret.readInt(); // number of following edge information
354 30 : for (int i = 0; i < n; ++i) {
355 : libsumo::TraCIBestLanesData info;
356 12 : ret.readUnsignedByte();
357 12 : info.laneID = ret.readString();
358 :
359 12 : ret.readUnsignedByte();
360 12 : info.length = ret.readDouble();
361 :
362 12 : ret.readUnsignedByte();
363 12 : info.occupation = ret.readDouble();
364 :
365 12 : ret.readUnsignedByte();
366 12 : info.bestLaneOffset = ret.readByte();
367 :
368 12 : ret.readUnsignedByte();
369 12 : info.allowsContinuation = (ret.readUnsignedByte() == 1);
370 :
371 12 : ret.readUnsignedByte();
372 12 : int m = ret.readInt();
373 56 : while (m-- > 0) {
374 88 : info.continuationLanes.push_back(ret.readString());
375 : }
376 12 : result.push_back(info);
377 : }
378 18 : return result;
379 0 : }
380 :
381 :
382 : std::vector<libsumo::TraCINextTLSData>
383 276 : Vehicle::getNextTLS(const std::string& vehID) {
384 276 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
385 : std::vector<libsumo::TraCINextTLSData> result;
386 : tcpip::Storage& ret = Dom::get(libsumo::VAR_NEXT_TLS, vehID);
387 273 : ret.readInt(); // components
388 : // number of items
389 273 : ret.readUnsignedByte();
390 273 : const int n = ret.readInt();
391 624 : for (int i = 0; i < n; ++i) {
392 : libsumo::TraCINextTLSData d;
393 351 : ret.readUnsignedByte();
394 351 : d.id = ret.readString();
395 :
396 351 : ret.readUnsignedByte();
397 351 : d.tlIndex = ret.readInt();
398 :
399 351 : ret.readUnsignedByte();
400 351 : d.dist = ret.readDouble();
401 :
402 351 : ret.readUnsignedByte();
403 351 : d.state = (char)ret.readByte();
404 :
405 351 : result.push_back(d);
406 : }
407 273 : return result;
408 3 : }
409 :
410 : std::vector<libsumo::TraCINextStopData>
411 26 : Vehicle::getNextStops(const std::string& vehID) {
412 26 : return getStops(vehID, 0);
413 : }
414 :
415 : std::vector<libsumo::TraCIConnection>
416 1 : Vehicle::getNextLinks(const std::string& vehID) {
417 1 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
418 : std::vector<libsumo::TraCIConnection> result;
419 : tcpip::Storage& ret = Dom::get(libsumo::VAR_NEXT_LINKS, vehID);
420 1 : ret.readInt(); // components
421 : // number of items
422 1 : ret.readUnsignedByte();
423 :
424 1 : const int linkNo = ret.readInt();
425 3 : for (int i = 0; i < linkNo; ++i) {
426 : libsumo::TraCIConnection con;
427 2 : con.approachedLane = StoHelp::readTypedString(ret);
428 2 : con.approachedInternal = StoHelp::readTypedString(ret);
429 2 : con.hasPrio = StoHelp::readBool(ret);
430 2 : con.isOpen = StoHelp::readBool(ret);
431 2 : con.hasFoe = StoHelp::readBool(ret);
432 2 : con.state = StoHelp::readTypedString(ret);
433 2 : con.direction = StoHelp::readTypedString(ret);
434 2 : con.length = StoHelp::readTypedDouble(ret);
435 2 : result.emplace_back(con);
436 2 : }
437 1 : return result;
438 0 : }
439 :
440 : std::vector<libsumo::TraCINextStopData>
441 629 : Vehicle::getStops(const std::string& vehID, int limit) {
442 : std::vector<libsumo::TraCINextStopData> result;
443 629 : tcpip::Storage content;
444 : StoHelp::writeTypedInt(content, limit);
445 629 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
446 : tcpip::Storage& ret = Dom::get(libsumo::VAR_NEXT_STOPS2, vehID, &content);
447 628 : ret.readInt(); // components
448 : // number of items
449 628 : const int n = StoHelp::readCompound(ret);
450 2099 : for (int i = 0; i < n; ++i) {
451 2943 : libsumo::TraCINextStopData s;
452 1471 : s.lane = StoHelp::readTypedString(ret);
453 1471 : s.endPos = StoHelp::readTypedDouble(ret);
454 1471 : s.stoppingPlaceID = StoHelp::readTypedString(ret);
455 1471 : s.stopFlags = StoHelp::readTypedInt(ret);
456 1471 : s.duration = StoHelp::readTypedDouble(ret);
457 1471 : s.until = StoHelp::readTypedDouble(ret);
458 1471 : s.startPos = StoHelp::readTypedDouble(ret);
459 1471 : s.intendedArrival = StoHelp::readTypedDouble(ret);
460 1471 : s.arrival = StoHelp::readTypedDouble(ret);
461 1471 : s.depart = StoHelp::readTypedDouble(ret);
462 1471 : s.split = StoHelp::readTypedString(ret);
463 1471 : s.join = StoHelp::readTypedString(ret);
464 1471 : s.actType = StoHelp::readTypedString(ret);
465 1471 : s.tripId = StoHelp::readTypedString(ret);
466 1471 : s.line = StoHelp::readTypedString(ret);
467 1471 : s.speed = StoHelp::readTypedDouble(ret);
468 1471 : result.emplace_back(s);
469 1471 : }
470 628 : return result;
471 630 : }
472 :
473 : std::string
474 91 : Vehicle::getStopParameter(const std::string& vehID, int nextStopIndex, const std::string& param, bool customParam) {
475 91 : tcpip::Storage content;
476 : StoHelp::writeCompound(content, 3);
477 : StoHelp::writeTypedInt(content, nextStopIndex);
478 : StoHelp::writeTypedString(content, param);
479 91 : StoHelp::writeTypedByte(content, customParam);
480 182 : return Dom::getString(libsumo::VAR_STOP_PARAMETER, vehID, &content);
481 91 : }
482 :
483 : int
484 309 : Vehicle::getStopState(const std::string& vehID) {
485 309 : return Dom::getInt(libsumo::VAR_STOPSTATE, vehID);
486 : }
487 :
488 :
489 : double
490 128 : Vehicle::getDistance(const std::string& vehID) {
491 128 : return Dom::getDouble(libsumo::VAR_DISTANCE, vehID);
492 : }
493 :
494 :
495 : double
496 683 : Vehicle::getDrivingDistance(const std::string& vehID, const std::string& edgeID, double pos, int laneIndex) {
497 683 : tcpip::Storage content;
498 : StoHelp::writeCompound(content, 2);
499 683 : content.writeUnsignedByte(libsumo::POSITION_ROADMAP);
500 683 : content.writeString(edgeID);
501 683 : content.writeDouble(pos);
502 683 : content.writeUnsignedByte(laneIndex);
503 683 : content.writeUnsignedByte(libsumo::REQUEST_DRIVINGDIST);
504 1366 : return Dom::getDouble(libsumo::DISTANCE_REQUEST, vehID, &content);
505 683 : }
506 :
507 :
508 : double
509 18 : Vehicle::getDrivingDistance2D(const std::string& vehID, double x, double y) {
510 18 : tcpip::Storage content;
511 : StoHelp::writeCompound(content, 2);
512 18 : content.writeUnsignedByte(libsumo::POSITION_2D);
513 18 : content.writeDouble(x);
514 18 : content.writeDouble(y);
515 18 : content.writeUnsignedByte(libsumo::REQUEST_DRIVINGDIST);
516 36 : return Dom::getDouble(libsumo::DISTANCE_REQUEST, vehID, &content);
517 18 : }
518 :
519 :
520 : double
521 18 : Vehicle::getAllowedSpeed(const std::string& vehID) {
522 18 : return Dom::getDouble(libsumo::VAR_ALLOWED_SPEED, vehID);
523 : }
524 :
525 :
526 : double
527 49 : Vehicle::getSpeedFactor(const std::string& vehID) {
528 49 : return Dom::getDouble(libsumo::VAR_SPEED_FACTOR, vehID);
529 : }
530 :
531 :
532 : int
533 14 : Vehicle::getSpeedMode(const std::string& vehID) {
534 14 : return Dom::getInt(libsumo::VAR_SPEEDSETMODE, vehID);
535 : }
536 :
537 :
538 : int
539 15 : Vehicle::getLaneChangeMode(const std::string& vehID) {
540 15 : return Dom::getInt(libsumo::VAR_LANECHANGE_MODE, vehID);
541 : }
542 :
543 :
544 : int
545 18 : Vehicle::getRoutingMode(const std::string& vehID) {
546 18 : return Dom::getInt(libsumo::VAR_ROUTING_MODE, vehID);
547 : }
548 :
549 :
550 : std::string
551 18 : Vehicle::getLine(const std::string& vehID) {
552 18 : return Dom::getString(libsumo::VAR_LINE, vehID);
553 : }
554 :
555 :
556 :
557 : std::vector<std::string>
558 18 : Vehicle::getVia(const std::string& vehID) {
559 18 : return Dom::getStringVector(libsumo::VAR_VIA, vehID);
560 : }
561 :
562 :
563 : std::pair<int, int>
564 3493 : Vehicle::getLaneChangeState(const std::string& vehID, int direction) {
565 3493 : tcpip::Storage content;
566 : StoHelp::writeTypedInt(content, direction);
567 3493 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
568 : tcpip::Storage& ret = Dom::get(libsumo::CMD_CHANGELANE, vehID, &content);
569 3493 : ret.readInt(); // components
570 3493 : ret.readUnsignedByte();
571 3493 : const int stateWithoutTraCI = ret.readInt();
572 3493 : ret.readUnsignedByte();
573 3493 : const int state = ret.readInt();
574 3493 : return std::make_pair(stateWithoutTraCI, state);
575 3493 : }
576 :
577 :
578 : std::vector<std::pair<std::string, double> >
579 856 : Vehicle::getNeighbors(const std::string& vehID, const int mode) {
580 : std::vector<std::pair<std::string, double> > neighs;
581 856 : tcpip::Storage content;
582 856 : content.writeUnsignedByte(libsumo::TYPE_UBYTE);
583 856 : content.writeUnsignedByte(mode);
584 856 : std::unique_lock<std::mutex> lock{ libtraci::Connection::getActive().getMutex() };
585 : tcpip::Storage& ret = Dom::get(libsumo::VAR_NEIGHBORS, vehID, &content);
586 856 : const int items = ret.readInt(); // components
587 1328 : for (int i = 0; i < items; i++) {
588 472 : const std::string neighID = ret.readString();
589 472 : neighs.emplace_back(neighID, ret.readDouble());
590 : }
591 856 : return neighs;
592 856 : }
593 :
594 :
595 : double
596 177 : Vehicle::getFollowSpeed(const std::string& vehID, double speed, double gap, double leaderSpeed, double leaderMaxDecel, const std::string& leaderID) {
597 177 : tcpip::Storage content;
598 : StoHelp::writeCompound(content, 5);
599 : StoHelp::writeTypedDouble(content, speed);
600 : StoHelp::writeTypedDouble(content, gap);
601 : StoHelp::writeTypedDouble(content, leaderSpeed);
602 : StoHelp::writeTypedDouble(content, leaderMaxDecel);
603 : StoHelp::writeTypedString(content, leaderID);
604 354 : return Dom::getDouble(libsumo::VAR_FOLLOW_SPEED, vehID, &content);
605 177 : }
606 :
607 :
608 : double
609 2 : Vehicle::getSecureGap(const std::string& vehID, double speed, double leaderSpeed, double leaderMaxDecel, const std::string& leaderID) {
610 2 : tcpip::Storage content;
611 : StoHelp::writeCompound(content, 4);
612 : StoHelp::writeTypedDouble(content, speed);
613 : StoHelp::writeTypedDouble(content, leaderSpeed);
614 : StoHelp::writeTypedDouble(content, leaderMaxDecel);
615 : StoHelp::writeTypedString(content, leaderID);
616 4 : return Dom::getDouble(libsumo::VAR_SECURE_GAP, vehID, &content);
617 2 : }
618 :
619 :
620 : double
621 2 : Vehicle::getStopSpeed(const std::string& vehID, const double speed, double gap) {
622 2 : tcpip::Storage content;
623 : StoHelp::writeCompound(content, 2);
624 : StoHelp::writeTypedDouble(content, speed);
625 : StoHelp::writeTypedDouble(content, gap);
626 4 : return Dom::getDouble(libsumo::VAR_STOP_SPEED, vehID, &content);
627 2 : }
628 :
629 : double
630 125 : Vehicle::getStopDelay(const std::string& vehID) {
631 125 : return Dom::getDouble(libsumo::VAR_STOP_DELAY, vehID);
632 : }
633 :
634 : double
635 125 : Vehicle::getStopArrivalDelay(const std::string& vehID) {
636 125 : return Dom::getDouble(libsumo::VAR_STOP_ARRIVALDELAY, vehID);
637 : }
638 :
639 : double
640 18 : Vehicle::getTimeLoss(const std::string& vehID) {
641 18 : return Dom::getDouble(libsumo::VAR_TIMELOSS, vehID);
642 : }
643 :
644 : std::vector<std::string>
645 1821 : Vehicle::getTaxiFleet(int taxiState) {
646 1821 : tcpip::Storage content;
647 : StoHelp::writeTypedInt(content, taxiState);
648 3642 : return Dom::getStringVector(libsumo::VAR_TAXI_FLEET, "", &content);
649 1821 : }
650 :
651 : std::vector<std::string>
652 46 : Vehicle::getLoadedIDList() {
653 92 : return Dom::getStringVector(libsumo::VAR_LOADED_LIST, "");
654 : }
655 :
656 : std::vector<std::string>
657 36 : Vehicle::getTeleportingIDList() {
658 72 : return Dom::getStringVector(libsumo::VAR_TELEPORTING_LIST, "");
659 : }
660 :
661 : std::string
662 38 : Vehicle::getEmissionClass(const std::string& vehID) {
663 38 : return Dom::getString(libsumo::VAR_EMISSIONCLASS, vehID);
664 : }
665 :
666 : std::string
667 18 : Vehicle::getShapeClass(const std::string& vehID) {
668 18 : return Dom::getString(libsumo::VAR_SHAPECLASS, vehID);
669 : }
670 :
671 :
672 : double
673 20 : Vehicle::getLength(const std::string& vehID) {
674 20 : return Dom::getDouble(libsumo::VAR_LENGTH, vehID);
675 : }
676 :
677 :
678 : double
679 20 : Vehicle::getAccel(const std::string& vehID) {
680 20 : return Dom::getDouble(libsumo::VAR_ACCEL, vehID);
681 : }
682 :
683 :
684 : double
685 201 : Vehicle::getDecel(const std::string& vehID) {
686 201 : return Dom::getDouble(libsumo::VAR_DECEL, vehID);
687 : }
688 :
689 :
690 22 : double Vehicle::getEmergencyDecel(const std::string& vehID) {
691 22 : return Dom::getDouble(libsumo::VAR_EMERGENCY_DECEL, vehID);
692 : }
693 :
694 :
695 20 : double Vehicle::getApparentDecel(const std::string& vehID) {
696 20 : return Dom::getDouble(libsumo::VAR_APPARENT_DECEL, vehID);
697 : }
698 :
699 :
700 20 : double Vehicle::getActionStepLength(const std::string& vehID) {
701 20 : return Dom::getDouble(libsumo::VAR_ACTIONSTEPLENGTH, vehID);
702 : }
703 :
704 :
705 18 : double Vehicle::getLastActionTime(const std::string& vehID) {
706 18 : return Dom::getDouble(libsumo::VAR_LASTACTIONTIME, vehID);
707 : }
708 :
709 :
710 : double
711 20 : Vehicle::getTau(const std::string& vehID) {
712 20 : return Dom::getDouble(libsumo::VAR_TAU, vehID);
713 : }
714 :
715 :
716 : double
717 22 : Vehicle::getImperfection(const std::string& vehID) {
718 22 : return Dom::getDouble(libsumo::VAR_IMPERFECTION, vehID);
719 : }
720 :
721 :
722 : double
723 18 : Vehicle::getSpeedDeviation(const std::string& vehID) {
724 18 : return Dom::getDouble(libsumo::VAR_SPEED_DEVIATION, vehID);
725 : }
726 :
727 :
728 : std::string
729 18 : Vehicle::getVehicleClass(const std::string& vehID) {
730 18 : return Dom::getString(libsumo::VAR_VEHICLECLASS, vehID);
731 : }
732 :
733 :
734 : double
735 60 : Vehicle::getMinGap(const std::string& vehID) {
736 60 : return Dom::getDouble(libsumo::VAR_MINGAP, vehID);
737 : }
738 :
739 :
740 : double
741 18 : Vehicle::getMinGapLat(const std::string& vehID) {
742 18 : return Dom::getDouble(libsumo::VAR_MINGAP_LAT, vehID);
743 : }
744 :
745 :
746 : double
747 20 : Vehicle::getMaxSpeed(const std::string& vehID) {
748 20 : return Dom::getDouble(libsumo::VAR_MAXSPEED, vehID);
749 : }
750 :
751 :
752 : double
753 18 : Vehicle::getMaxSpeedLat(const std::string& vehID) {
754 18 : return Dom::getDouble(libsumo::VAR_MAXSPEED_LAT, vehID);
755 : }
756 :
757 :
758 : std::string
759 18 : Vehicle::getLateralAlignment(const std::string& vehID) {
760 18 : return Dom::getString(libsumo::VAR_LATALIGNMENT, vehID);
761 : }
762 :
763 :
764 : double
765 20 : Vehicle::getWidth(const std::string& vehID) {
766 20 : return Dom::getDouble(libsumo::VAR_WIDTH, vehID);
767 : }
768 :
769 :
770 : double
771 18 : Vehicle::getHeight(const std::string& vehID) {
772 18 : return Dom::getDouble(libsumo::VAR_HEIGHT, vehID);
773 : }
774 :
775 :
776 : double
777 22 : Vehicle::getMass(const std::string& vehID) {
778 22 : return Dom::getDouble(libsumo::VAR_MASS, vehID);
779 : }
780 :
781 :
782 : void
783 42 : Vehicle::setStop(const std::string& vehID,
784 : const std::string& edgeID,
785 : double pos,
786 : int laneIndex,
787 : double duration,
788 : int flags,
789 : double startPos,
790 : double until) {
791 42 : tcpip::Storage content;
792 : StoHelp::writeCompound(content, 7);
793 : StoHelp::writeTypedString(content, edgeID);
794 : StoHelp::writeTypedDouble(content, pos);
795 : StoHelp::writeTypedByte(content, laneIndex);
796 : StoHelp::writeTypedDouble(content, duration);
797 : StoHelp::writeTypedByte(content, flags);
798 : StoHelp::writeTypedDouble(content, startPos);
799 : StoHelp::writeTypedDouble(content, until);
800 42 : Dom::set(libsumo::CMD_STOP, vehID, &content);
801 42 : }
802 :
803 :
804 : void
805 43 : Vehicle::replaceStop(const std::string& vehID,
806 : int nextStopIndex,
807 : const std::string& edgeID,
808 : double pos,
809 : int laneIndex,
810 : double duration,
811 : int flags,
812 : double startPos,
813 : double until,
814 : int teleport) {
815 43 : tcpip::Storage content;
816 : StoHelp::writeCompound(content, 9);
817 : StoHelp::writeTypedString(content, edgeID);
818 : StoHelp::writeTypedDouble(content, pos);
819 : StoHelp::writeTypedByte(content, laneIndex);
820 : StoHelp::writeTypedDouble(content, duration);
821 : StoHelp::writeTypedInt(content, flags);
822 : StoHelp::writeTypedDouble(content, startPos);
823 : StoHelp::writeTypedDouble(content, until);
824 : StoHelp::writeTypedInt(content, nextStopIndex);
825 : StoHelp::writeTypedByte(content, teleport);
826 43 : Dom::set(libsumo::CMD_REPLACE_STOP, vehID, &content);
827 43 : }
828 :
829 :
830 : void
831 28 : Vehicle::insertStop(const std::string& vehID,
832 : int nextStopIndex,
833 : const std::string& edgeID,
834 : double pos,
835 : int laneIndex,
836 : double duration,
837 : int flags,
838 : double startPos,
839 : double until,
840 : int teleport) {
841 28 : tcpip::Storage content;
842 : StoHelp::writeCompound(content, 9);
843 : StoHelp::writeTypedString(content, edgeID);
844 : StoHelp::writeTypedDouble(content, pos);
845 : StoHelp::writeTypedByte(content, laneIndex);
846 : StoHelp::writeTypedDouble(content, duration);
847 : StoHelp::writeTypedInt(content, flags);
848 : StoHelp::writeTypedDouble(content, startPos);
849 : StoHelp::writeTypedDouble(content, until);
850 : StoHelp::writeTypedInt(content, nextStopIndex);
851 : StoHelp::writeTypedByte(content, teleport);
852 28 : Dom::set(libsumo::CMD_INSERT_STOP, vehID, &content);
853 28 : }
854 :
855 :
856 : void
857 35 : Vehicle::setStopParameter(const std::string& vehID, int nextStopIndex,
858 : const std::string& param, const std::string& value,
859 : bool customParam) {
860 35 : tcpip::Storage content;
861 : StoHelp::writeCompound(content, 4);
862 : StoHelp::writeTypedInt(content, nextStopIndex);
863 : StoHelp::writeTypedString(content, param);
864 : StoHelp::writeTypedString(content, value);
865 35 : StoHelp::writeTypedByte(content, customParam);
866 35 : Dom::set(libsumo::VAR_STOP_PARAMETER, vehID, &content);
867 35 : }
868 :
869 :
870 : void
871 3 : Vehicle::rerouteParkingArea(const std::string& vehID, const std::string& parkingAreaID) {
872 3 : tcpip::Storage content;
873 : StoHelp::writeCompound(content, 1);
874 : StoHelp::writeTypedString(content, parkingAreaID);
875 3 : Dom::set(libsumo::CMD_REROUTE_TO_PARKING, vehID, &content);
876 3 : }
877 :
878 :
879 : void
880 1 : Vehicle::resume(const std::string& vehID) {
881 1 : tcpip::Storage content;
882 : StoHelp::writeCompound(content, 0);
883 1 : Dom::set(libsumo::CMD_RESUME, vehID, &content);
884 1 : }
885 :
886 :
887 : void
888 8 : Vehicle::changeTarget(const std::string& vehID, const std::string& edgeID) {
889 8 : Dom::setString(libsumo::CMD_CHANGETARGET, vehID, edgeID);
890 6 : }
891 :
892 :
893 : void
894 2222 : Vehicle::changeLane(const std::string& vehID, int laneIndex, double duration) {
895 2222 : tcpip::Storage content;
896 : StoHelp::writeCompound(content, 2);
897 : StoHelp::writeTypedByte(content, laneIndex);
898 : StoHelp::writeTypedDouble(content, duration);
899 2222 : Dom::set(libsumo::CMD_CHANGELANE, vehID, &content);
900 2222 : }
901 :
902 : void
903 55 : Vehicle::changeLaneRelative(const std::string& vehID, int indexOffset, double duration) {
904 55 : tcpip::Storage content;
905 : StoHelp::writeCompound(content, 3);
906 : StoHelp::writeTypedByte(content, indexOffset);
907 : StoHelp::writeTypedDouble(content, duration);
908 : StoHelp::writeTypedByte(content, 1);
909 55 : Dom::set(libsumo::CMD_CHANGELANE, vehID, &content);
910 55 : }
911 :
912 :
913 : void
914 75 : Vehicle::changeSublane(const std::string& vehID, double latDist) {
915 75 : Dom::setDouble(libsumo::CMD_CHANGESUBLANE, vehID, latDist);
916 75 : }
917 :
918 :
919 : void
920 7475 : Vehicle::add(const std::string& vehID,
921 : const std::string& routeID,
922 : const std::string& typeID,
923 : const std::string& depart,
924 : const std::string& departLane,
925 : const std::string& departPos,
926 : const std::string& departSpeed,
927 : const std::string& arrivalLane,
928 : const std::string& arrivalPos,
929 : const std::string& arrivalSpeed,
930 : const std::string& fromTaz,
931 : const std::string& toTaz,
932 : const std::string& line,
933 : int personCapacity,
934 : int personNumber) {
935 7475 : tcpip::Storage content;
936 : StoHelp::writeCompound(content, 14);
937 : StoHelp::writeTypedString(content, routeID);
938 : StoHelp::writeTypedString(content, typeID);
939 : StoHelp::writeTypedString(content, depart);
940 : StoHelp::writeTypedString(content, departLane);
941 : StoHelp::writeTypedString(content, departPos);
942 : StoHelp::writeTypedString(content, departSpeed);
943 :
944 : StoHelp::writeTypedString(content, arrivalLane);
945 : StoHelp::writeTypedString(content, arrivalPos);
946 : StoHelp::writeTypedString(content, arrivalSpeed);
947 :
948 : StoHelp::writeTypedString(content, fromTaz);
949 : StoHelp::writeTypedString(content, toTaz);
950 : StoHelp::writeTypedString(content, line);
951 :
952 : StoHelp::writeTypedInt(content, personCapacity);
953 : StoHelp::writeTypedInt(content, personNumber);
954 :
955 7475 : Dom::set(libsumo::ADD_FULL, vehID, &content);
956 7475 : }
957 :
958 :
959 : void
960 1011 : Vehicle::moveToXY(const std::string& vehID, const std::string& edgeID, const int laneIndex,
961 : const double x, const double y, double angle, const int keepRoute, double matchThreshold) {
962 1011 : tcpip::Storage content;
963 : StoHelp::writeCompound(content, 7);
964 : StoHelp::writeTypedString(content, edgeID);
965 : StoHelp::writeTypedInt(content, laneIndex);
966 : StoHelp::writeTypedDouble(content, x);
967 : StoHelp::writeTypedDouble(content, y);
968 : StoHelp::writeTypedDouble(content, angle);
969 : StoHelp::writeTypedByte(content, keepRoute);
970 : StoHelp::writeTypedDouble(content, matchThreshold);
971 1011 : Dom::set(libsumo::MOVE_TO_XY, vehID, &content);
972 1011 : }
973 :
974 : void
975 8 : Vehicle::slowDown(const std::string& vehID, double speed, double duration) {
976 8 : tcpip::Storage content;
977 : StoHelp::writeCompound(content, 2);
978 : StoHelp::writeTypedDouble(content, speed);
979 : StoHelp::writeTypedDouble(content, duration);
980 8 : Dom::set(libsumo::CMD_SLOWDOWN, vehID, &content);
981 8 : }
982 :
983 : void
984 17 : Vehicle::openGap(const std::string& vehID, double newTimeHeadway, double newSpaceHeadway, double duration, double changeRate, double maxDecel, const std::string& referenceVehID) {
985 17 : tcpip::Storage content;
986 17 : StoHelp::writeCompound(content, referenceVehID != "" ? 6 : 5);
987 : StoHelp::writeTypedDouble(content, newTimeHeadway);
988 : StoHelp::writeTypedDouble(content, newSpaceHeadway);
989 : StoHelp::writeTypedDouble(content, duration);
990 : StoHelp::writeTypedDouble(content, changeRate);
991 : StoHelp::writeTypedDouble(content, maxDecel);
992 17 : if (referenceVehID != "") {
993 : StoHelp::writeTypedString(content, referenceVehID);
994 : }
995 17 : Dom::set(libsumo::CMD_OPENGAP, vehID, &content);
996 17 : }
997 :
998 : void
999 2 : Vehicle::deactivateGapControl(const std::string& vehID) {
1000 2 : openGap(vehID, -1, -1, -1, -1);
1001 2 : }
1002 :
1003 : void
1004 0 : Vehicle::requestToC(const std::string& vehID, double leadTime) {
1005 0 : std::ostringstream oss;
1006 : oss.setf(std::ios::fixed, std::ios::floatfield);
1007 : oss << std::setprecision(2);
1008 : oss << leadTime;
1009 0 : setParameter(vehID, "device.toc.requestToC", oss.str());
1010 0 : }
1011 :
1012 : void
1013 242 : Vehicle::setSpeed(const std::string& vehID, double speed) {
1014 242 : Dom::setDouble(libsumo::VAR_SPEED, vehID, speed);
1015 242 : }
1016 :
1017 : void
1018 3 : Vehicle::setAcceleration(const std::string& vehID, double acceleration, double duration) {
1019 3 : tcpip::Storage content;
1020 : StoHelp::writeCompound(content, 2);
1021 : StoHelp::writeTypedDouble(content, acceleration);
1022 : StoHelp::writeTypedDouble(content, duration);
1023 3 : Dom::set(libsumo::VAR_ACCELERATION, vehID, &content);
1024 3 : }
1025 :
1026 : void
1027 49 : Vehicle::setPreviousSpeed(const std::string& vehID, double prevSpeed, double prevAcceleration) {
1028 49 : tcpip::Storage content;
1029 : StoHelp::writeCompound(content, 2);
1030 : StoHelp::writeTypedDouble(content, prevSpeed);
1031 : StoHelp::writeTypedDouble(content, prevAcceleration);
1032 49 : Dom::set(libsumo::VAR_PREV_SPEED, vehID, &content);
1033 49 : }
1034 :
1035 : void
1036 27 : Vehicle::setSpeedMode(const std::string& vehID, int speedMode) {
1037 27 : Dom::setInt(libsumo::VAR_SPEEDSETMODE, vehID, speedMode);
1038 27 : }
1039 :
1040 : void
1041 108 : Vehicle::setLaneChangeMode(const std::string& vehID, int laneChangeMode) {
1042 108 : Dom::setInt(libsumo::VAR_LANECHANGE_MODE, vehID, laneChangeMode);
1043 108 : }
1044 :
1045 : void
1046 23 : Vehicle::setRoutingMode(const std::string& vehID, int routingMode) {
1047 23 : Dom::setInt(libsumo::VAR_ROUTING_MODE, vehID, routingMode);
1048 23 : }
1049 :
1050 : void
1051 73 : Vehicle::setType(const std::string& vehID, const std::string& typeID) {
1052 73 : Dom::setString(libsumo::VAR_TYPE, vehID, typeID);
1053 73 : }
1054 :
1055 : void
1056 5 : Vehicle::setRouteID(const std::string& vehID, const std::string& routeID) {
1057 5 : Dom::setString(libsumo::VAR_ROUTE_ID, vehID, routeID);
1058 5 : }
1059 :
1060 : void
1061 1 : Vehicle::setRoute(const std::string& vehID, const std::string& edgeID) {
1062 3 : setRoute(vehID, std::vector<std::string>({edgeID}));
1063 0 : }
1064 :
1065 : void
1066 7 : Vehicle::setRoute(const std::string& vehID, const std::vector<std::string>& edgeIDs) {
1067 7 : Dom::setStringVector(libsumo::VAR_ROUTE, vehID, edgeIDs);
1068 6 : }
1069 :
1070 : void
1071 2 : Vehicle::setLateralLanePosition(const std::string& vehID, double posLat) {
1072 2 : Dom::setDouble(libsumo::VAR_LANEPOSITION_LAT, vehID, posLat);
1073 2 : }
1074 :
1075 : void
1076 59 : Vehicle::updateBestLanes(const std::string& vehID) {
1077 59 : tcpip::Storage content;
1078 59 : Dom::set(libsumo::VAR_UPDATE_BESTLANES, vehID, &content);
1079 59 : }
1080 :
1081 :
1082 : void
1083 39 : Vehicle::setAdaptedTraveltime(const std::string& vehID, const std::string& edgeID,
1084 : double time, double begSeconds, double endSeconds) {
1085 39 : tcpip::Storage content;
1086 39 : if (time == libsumo::INVALID_DOUBLE_VALUE) {
1087 : // reset
1088 : StoHelp::writeCompound(content, 1);
1089 : StoHelp::writeTypedString(content, edgeID);
1090 37 : } else if (begSeconds == libsumo::INVALID_DOUBLE_VALUE) {
1091 : // set value for the whole simulation
1092 : StoHelp::writeCompound(content, 2);
1093 : StoHelp::writeTypedString(content, edgeID);
1094 : StoHelp::writeTypedDouble(content, time);
1095 : } else {
1096 : StoHelp::writeCompound(content, 4);
1097 : StoHelp::writeTypedDouble(content, begSeconds);
1098 : StoHelp::writeTypedDouble(content, endSeconds);
1099 : StoHelp::writeTypedString(content, edgeID);
1100 : StoHelp::writeTypedDouble(content, time);
1101 : }
1102 39 : Dom::set(libsumo::VAR_EDGE_TRAVELTIME, vehID, &content);
1103 39 : }
1104 :
1105 :
1106 : void
1107 6 : Vehicle::setEffort(const std::string& vehID, const std::string& edgeID,
1108 : double effort, double begSeconds, double endSeconds) {
1109 6 : tcpip::Storage content;
1110 6 : if (effort == libsumo::INVALID_DOUBLE_VALUE) {
1111 : // reset
1112 : StoHelp::writeCompound(content, 1);
1113 : StoHelp::writeTypedString(content, edgeID);
1114 4 : } else if (begSeconds == libsumo::INVALID_DOUBLE_VALUE) {
1115 : // set value for the whole simulation
1116 : StoHelp::writeCompound(content, 2);
1117 : StoHelp::writeTypedString(content, edgeID);
1118 : StoHelp::writeTypedDouble(content, effort);
1119 : } else {
1120 : StoHelp::writeCompound(content, 4);
1121 : StoHelp::writeTypedDouble(content, begSeconds);
1122 : StoHelp::writeTypedDouble(content, endSeconds);
1123 : StoHelp::writeTypedString(content, edgeID);
1124 : StoHelp::writeTypedDouble(content, effort);
1125 : }
1126 6 : Dom::set(libsumo::VAR_EDGE_EFFORT, vehID, &content);
1127 6 : }
1128 :
1129 :
1130 : void
1131 73 : Vehicle::rerouteTraveltime(const std::string& vehID, const bool /* currentTravelTimes */) {
1132 73 : tcpip::Storage content;
1133 : StoHelp::writeCompound(content, 0);
1134 73 : Dom::set(libsumo::CMD_REROUTE_TRAVELTIME, vehID, &content);
1135 73 : }
1136 :
1137 :
1138 : void
1139 2 : Vehicle::rerouteEffort(const std::string& vehID) {
1140 2 : tcpip::Storage content;
1141 : StoHelp::writeCompound(content, 0);
1142 2 : Dom::set(libsumo::CMD_REROUTE_EFFORT, vehID, &content);
1143 2 : }
1144 :
1145 :
1146 : void
1147 4 : Vehicle::setSignals(const std::string& vehID, int signals) {
1148 4 : Dom::setInt(libsumo::VAR_SIGNALS, vehID, signals);
1149 4 : }
1150 :
1151 :
1152 : void
1153 102 : Vehicle::moveTo(const std::string& vehID, const std::string& laneID, double pos, int reason) {
1154 102 : tcpip::Storage content;
1155 : StoHelp::writeCompound(content, 3);
1156 : StoHelp::writeTypedString(content, laneID);
1157 : StoHelp::writeTypedDouble(content, pos);
1158 : StoHelp::writeTypedInt(content, reason);
1159 102 : Dom::set(libsumo::VAR_MOVE_TO, vehID, &content);
1160 102 : }
1161 :
1162 :
1163 : void
1164 4 : Vehicle::setActionStepLength(const std::string& vehID, double actionStepLength, bool resetActionOffset) {
1165 : //if (actionStepLength < 0) {
1166 : // raise TraCIException("Invalid value for actionStepLength. Given value must be non-negative.")
1167 : //{
1168 : // Use negative value to indicate resetActionOffset == False
1169 4 : if (!resetActionOffset) {
1170 2 : actionStepLength *= -1;
1171 : }
1172 4 : Dom::setDouble(libsumo::VAR_ACTIONSTEPLENGTH, vehID, actionStepLength);
1173 4 : }
1174 :
1175 :
1176 : void
1177 4 : Vehicle::remove(const std::string& vehID, char reason) {
1178 4 : tcpip::Storage content;
1179 4 : content.writeUnsignedByte(libsumo::TYPE_BYTE);
1180 4 : content.writeUnsignedByte(reason);
1181 4 : Dom::set(libsumo::REMOVE, vehID, &content);
1182 4 : }
1183 :
1184 :
1185 : void
1186 44 : Vehicle::setColor(const std::string& vehID, const libsumo::TraCIColor& color) {
1187 44 : Dom::setCol(libsumo::VAR_COLOR, vehID, color);
1188 44 : }
1189 :
1190 :
1191 : void
1192 2047 : Vehicle::setSpeedFactor(const std::string& vehID, double factor) {
1193 2047 : Dom::setDouble(libsumo::VAR_SPEED_FACTOR, vehID, factor);
1194 2047 : }
1195 :
1196 :
1197 : void
1198 3 : Vehicle::setLine(const std::string& vehID, const std::string& line) {
1199 3 : Dom::setString(libsumo::VAR_LINE, vehID, line);
1200 3 : }
1201 :
1202 :
1203 : void
1204 4 : Vehicle::setVia(const std::string& vehID, const std::vector<std::string>& edgeList) {
1205 4 : Dom::setStringVector(libsumo::VAR_VIA, vehID, edgeList);
1206 4 : }
1207 :
1208 :
1209 : void
1210 23 : Vehicle::setLength(const std::string& vehID, double length) {
1211 23 : Dom::setDouble(libsumo::VAR_LENGTH, vehID, length);
1212 23 : }
1213 :
1214 :
1215 : void
1216 9 : Vehicle::setMaxSpeed(const std::string& vehID, double speed) {
1217 9 : Dom::setDouble(libsumo::VAR_MAXSPEED, vehID, speed);
1218 9 : }
1219 :
1220 :
1221 : void
1222 2 : Vehicle::setVehicleClass(const std::string& vehID, const std::string& clazz) {
1223 2 : Dom::setString(libsumo::VAR_VEHICLECLASS, vehID, clazz);
1224 2 : }
1225 :
1226 :
1227 : void
1228 2 : Vehicle::setShapeClass(const std::string& vehID, const std::string& clazz) {
1229 2 : Dom::setString(libsumo::VAR_SHAPECLASS, vehID, clazz);
1230 2 : }
1231 :
1232 :
1233 : void
1234 5 : Vehicle::setEmissionClass(const std::string& vehID, const std::string& clazz) {
1235 5 : Dom::setString(libsumo::VAR_EMISSIONCLASS, vehID, clazz);
1236 5 : }
1237 :
1238 :
1239 : void
1240 3 : Vehicle::setWidth(const std::string& vehID, double width) {
1241 3 : Dom::setDouble(libsumo::VAR_WIDTH, vehID, width);
1242 3 : }
1243 :
1244 :
1245 : void
1246 2 : Vehicle::setHeight(const std::string& vehID, double height) {
1247 2 : Dom::setDouble(libsumo::VAR_HEIGHT, vehID, height);
1248 2 : }
1249 :
1250 :
1251 : void
1252 2 : Vehicle::setMass(const std::string& vehID, double mass) {
1253 2 : Dom::setDouble(libsumo::VAR_MASS, vehID, mass);
1254 2 : }
1255 :
1256 :
1257 : void
1258 3 : Vehicle::setMinGap(const std::string& vehID, double minGap) {
1259 3 : Dom::setDouble(libsumo::VAR_MINGAP, vehID, minGap);
1260 3 : }
1261 :
1262 :
1263 : void
1264 5 : Vehicle::setAccel(const std::string& vehID, double accel) {
1265 5 : Dom::setDouble(libsumo::VAR_ACCEL, vehID, accel);
1266 5 : }
1267 :
1268 :
1269 : void
1270 3 : Vehicle::setDecel(const std::string& vehID, double decel) {
1271 3 : Dom::setDouble(libsumo::VAR_DECEL, vehID, decel);
1272 3 : }
1273 :
1274 :
1275 : void
1276 5 : Vehicle::setEmergencyDecel(const std::string& vehID, double decel) {
1277 5 : Dom::setDouble(libsumo::VAR_EMERGENCY_DECEL, vehID, decel);
1278 5 : }
1279 :
1280 :
1281 : void
1282 3 : Vehicle::setApparentDecel(const std::string& vehID, double decel) {
1283 3 : Dom::setDouble(libsumo::VAR_APPARENT_DECEL, vehID, decel);
1284 3 : }
1285 :
1286 :
1287 : void
1288 4 : Vehicle::setImperfection(const std::string& vehID, double imperfection) {
1289 4 : Dom::setDouble(libsumo::VAR_IMPERFECTION, vehID, imperfection);
1290 4 : }
1291 :
1292 :
1293 : void
1294 3 : Vehicle::setTau(const std::string& vehID, double tau) {
1295 3 : Dom::setDouble(libsumo::VAR_TAU, vehID, tau);
1296 3 : }
1297 :
1298 :
1299 : void
1300 2 : Vehicle::setMinGapLat(const std::string& vehID, double minGapLat) {
1301 2 : Dom::setDouble(libsumo::VAR_MINGAP_LAT, vehID, minGapLat);
1302 2 : }
1303 :
1304 :
1305 : void
1306 2 : Vehicle::setMaxSpeedLat(const std::string& vehID, double speed) {
1307 2 : Dom::setDouble(libsumo::VAR_MAXSPEED_LAT, vehID, speed);
1308 2 : }
1309 :
1310 :
1311 : void
1312 2 : Vehicle::setLateralAlignment(const std::string& vehID, const std::string& latAlignment) {
1313 2 : Dom::setString(libsumo::VAR_LATALIGNMENT, vehID, latAlignment);
1314 2 : }
1315 :
1316 :
1317 : void
1318 6 : Vehicle::setImpatience(const std::string& vehID, double impatience) {
1319 6 : Dom::setDouble(libsumo::VAR_IMPATIENCE, vehID, impatience);
1320 6 : }
1321 :
1322 : void
1323 2 : Vehicle::setBoardingDuration(const std::string& vehID, double boardingDuration) {
1324 2 : Dom::setDouble(libsumo::VAR_BOARDING_DURATION, vehID, boardingDuration);
1325 2 : }
1326 :
1327 :
1328 : void
1329 10 : Vehicle::highlight(const std::string& vehID, const libsumo::TraCIColor& col, double size, const int alphaMax, const double duration, const int type) {
1330 10 : tcpip::Storage content;
1331 10 : StoHelp::writeCompound(content, alphaMax > 0 ? 5 : 2);
1332 10 : content.writeUnsignedByte(libsumo::TYPE_COLOR);
1333 10 : content.writeUnsignedByte(col.r);
1334 10 : content.writeUnsignedByte(col.g);
1335 10 : content.writeUnsignedByte(col.b);
1336 10 : content.writeUnsignedByte(col.a);
1337 : StoHelp::writeTypedDouble(content, size);
1338 10 : if (alphaMax > 0) {
1339 6 : content.writeUnsignedByte(libsumo::TYPE_UBYTE);
1340 6 : content.writeUnsignedByte(alphaMax);
1341 : StoHelp::writeTypedDouble(content, duration);
1342 6 : content.writeUnsignedByte(libsumo::TYPE_UBYTE);
1343 6 : content.writeUnsignedByte(type);
1344 : }
1345 10 : Dom::set(libsumo::VAR_HIGHLIGHT, vehID, &content);
1346 10 : }
1347 :
1348 : void
1349 30 : Vehicle::dispatchTaxi(const std::string& vehID, const std::vector<std::string>& reservations) {
1350 30 : Dom::setStringVector(libsumo::CMD_TAXI_DISPATCH, vehID, reservations);
1351 28 : }
1352 :
1353 :
1354 : void
1355 17 : Vehicle::subscribeLeader(const std::string& vehID, double dist, double begin, double end) {
1356 17 : subscribe(vehID, std::vector<int>({ libsumo::VAR_LEADER }), begin, end,
1357 51 : libsumo::TraCIResults({ {libsumo::VAR_LEADER, std::make_shared<libsumo::TraCIDouble>(dist)} }));
1358 17 : }
1359 :
1360 :
1361 : void
1362 43 : Vehicle::addSubscriptionFilterLanes(const std::vector<int>& lanes, bool noOpposite, double downstreamDist, double upstreamDist) {
1363 43 : tcpip::Storage content;
1364 43 : content.writeUnsignedByte((int)lanes.size());
1365 115 : for (int lane : lanes) {
1366 72 : content.writeUnsignedByte(lane < 0 ? lane + 256 : lane);
1367 : }
1368 43 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_LANES, &content);
1369 43 : if (noOpposite) {
1370 1 : addSubscriptionFilterNoOpposite();
1371 : }
1372 43 : if (downstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1373 2 : addSubscriptionFilterDownstreamDistance(downstreamDist);
1374 : }
1375 43 : if (upstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1376 2 : addSubscriptionFilterUpstreamDistance(upstreamDist);
1377 : }
1378 43 : }
1379 :
1380 :
1381 : void
1382 14 : Vehicle::addSubscriptionFilterNoOpposite() {
1383 14 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_NOOPPOSITE);
1384 14 : }
1385 :
1386 :
1387 : void
1388 51 : Vehicle::addSubscriptionFilterDownstreamDistance(double dist) {
1389 51 : tcpip::Storage content;
1390 : StoHelp::writeTypedDouble(content, dist);
1391 51 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_DOWNSTREAM_DIST, &content);
1392 51 : }
1393 :
1394 :
1395 : void
1396 43 : Vehicle::addSubscriptionFilterUpstreamDistance(double dist) {
1397 43 : tcpip::Storage content;
1398 : StoHelp::writeTypedDouble(content, dist);
1399 43 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_UPSTREAM_DIST, &content);
1400 43 : }
1401 :
1402 :
1403 : void
1404 1 : Vehicle::addSubscriptionFilterCFManeuver(double downstreamDist, double upstreamDist) {
1405 1 : addSubscriptionFilterLeadFollow(std::vector<int>(1));
1406 1 : if (downstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1407 0 : addSubscriptionFilterDownstreamDistance(downstreamDist);
1408 : }
1409 1 : if (upstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1410 0 : addSubscriptionFilterUpstreamDistance(upstreamDist);
1411 : }
1412 1 : }
1413 :
1414 :
1415 : void
1416 4 : Vehicle::addSubscriptionFilterLCManeuver(int direction, bool noOpposite, double downstreamDist, double upstreamDist) {
1417 4 : if (direction == libsumo::INVALID_INT_VALUE) {
1418 1 : addSubscriptionFilterLeadFollow({ -1, 0, 1 });
1419 3 : } else if (direction != -1 && direction != 1) {
1420 : // warnings.warn("Ignoring lane change subscription filter with non-neighboring lane offset direction=%s." % direction)
1421 : return;
1422 : } else {
1423 3 : addSubscriptionFilterLeadFollow({ 0, direction });
1424 : }
1425 4 : if (noOpposite) {
1426 0 : addSubscriptionFilterNoOpposite();
1427 : }
1428 4 : if (downstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1429 0 : addSubscriptionFilterDownstreamDistance(downstreamDist);
1430 : }
1431 4 : if (upstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1432 0 : addSubscriptionFilterUpstreamDistance(upstreamDist);
1433 : }
1434 : }
1435 :
1436 :
1437 : void
1438 5 : Vehicle::addSubscriptionFilterLeadFollow(const std::vector<int>& lanes) {
1439 5 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_LEAD_FOLLOW);
1440 5 : addSubscriptionFilterLanes(lanes);
1441 5 : }
1442 :
1443 :
1444 : void
1445 8 : Vehicle::addSubscriptionFilterTurn(double downstreamDist, double foeDistToJunction) {
1446 8 : tcpip::Storage content;
1447 : StoHelp::writeTypedDouble(content, foeDistToJunction);
1448 8 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_TURN, &content);
1449 8 : if (downstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1450 8 : addSubscriptionFilterDownstreamDistance(downstreamDist);
1451 : }
1452 8 : }
1453 :
1454 :
1455 : void
1456 3 : Vehicle::addSubscriptionFilterVClass(const std::vector<std::string>& vClasses) {
1457 3 : tcpip::Storage content;
1458 : StoHelp::writeTypedStringList(content, vClasses);
1459 3 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_VCLASS, &content);
1460 3 : }
1461 :
1462 :
1463 : void
1464 3 : Vehicle::addSubscriptionFilterVType(const std::vector<std::string>& vTypes) {
1465 3 : tcpip::Storage content;
1466 : StoHelp::writeTypedStringList(content, vTypes);
1467 3 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_VTYPE, &content);
1468 3 : }
1469 :
1470 :
1471 : void
1472 8 : Vehicle::addSubscriptionFilterFieldOfVision(double openingAngle) {
1473 8 : tcpip::Storage content;
1474 : StoHelp::writeTypedDouble(content, openingAngle);
1475 8 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_FIELD_OF_VISION, &content);
1476 8 : }
1477 :
1478 :
1479 : void
1480 8 : Vehicle::addSubscriptionFilterLateralDistance(double lateralDist, double downstreamDist, double upstreamDist) {
1481 8 : tcpip::Storage content;
1482 : StoHelp::writeTypedDouble(content, lateralDist);
1483 8 : libtraci::Connection::getActive().addFilter(libsumo::FILTER_TYPE_LATERAL_DIST, &content);
1484 7 : if (downstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1485 7 : addSubscriptionFilterDownstreamDistance(downstreamDist);
1486 : }
1487 7 : if (upstreamDist != libsumo::INVALID_DOUBLE_VALUE) {
1488 7 : addSubscriptionFilterUpstreamDistance(upstreamDist);
1489 : }
1490 8 : }
1491 :
1492 :
1493 : }
1494 :
1495 :
1496 : /****************************************************************************/
|