Eclipse SUMO - Simulation of Urban MObility
CC_VehicleVariables.cpp
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 // Copyright (C) 2001-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 /****************************************************************************/
18 /****************************************************************************/
19 #include "CC_VehicleVariables.h"
20 
21 //initialize default L and K matrices
23  {0, 0, 0, 0, 0, 0, 0, 0},
24  {1, 0, 0, 0, 0, 0, 0, 0},
25  {1, 1, 0, 0, 0, 0, 0, 0},
26  {1, 0, 1, 0, 0, 0, 0, 0},
27  {1, 0, 0, 1, 0, 0, 0, 0},
28  {1, 0, 0, 0, 1, 0, 0, 0},
29  {1, 0, 0, 0, 0, 1, 0, 0},
30  {1, 0, 0, 0, 0, 0, 1, 0}
31 };
32 const double CC_VehicleVariables::defaultK[][MAX_N_CARS] = {
33  {0, 0, 0, 0, 0, 0, 0, 0},
34  {460, 0, 0, 0, 0, 0, 0, 0},
35  {80, 860, 0, 0, 0, 0, 0, 0},
36  {80, 0, 860, 0, 0, 0, 0, 0},
37  {80, 0, 0, 860, 0, 0, 0, 0},
38  {80, 0, 0, 0, 860, 0, 0, 0},
39  {80, 0, 0, 0, 0, 860, 0, 0},
40  {80, 0, 0, 0, 0, 0, 860, 0}
41 };
42 const double CC_VehicleVariables::defaultB[MAX_N_CARS] = {1800, 1800, 1800, 1800, 1800, 1800, 1800, 1800};
43 const double CC_VehicleVariables::defaultH[MAX_N_CARS] = {0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8, 0.8};
44 
46  controllerAcceleration(0), frontSpeed(0), frontAcceleration(0),
47  frontControllerAcceleration(0), frontDataReadTime(0), frontAngle(0), frontInitialized(false),
48  autoFeed(false), leaderVehicle(nullptr), leaderVehicleId(""), frontVehicle(nullptr), frontVehicleId(""),
49  isLeader(true),
50  accHeadwayTime(1.5), accLambda(0.1),
51  useControllerAcceleration(true), leaderSpeed(0),
52  leaderAcceleration(0), leaderControllerAcceleration(0), leaderDataReadTime(0), leaderAngle(0),
53  leaderInitialized(false), caccInitialized(false),
54  useFixedAcceleration(0), fixedAcceleration(0),
55  crashed(false),
56  ccDesiredSpeed(14), ccKp(1), activeController(Plexe::DRIVER),
57  nInitialized(0), position(-1), nCars(8),
58  caccXi(-1), caccOmegaN(-1), caccC1(-1), caccAlpha1(-1), caccAlpha2(-1),
59  caccAlpha3(-1), caccAlpha4(-1), caccAlpha5(-1), caccSpacing(5),
60  engineTau(0.5),
61  uMin(-1e6), uMax(1e6),
62  ploegH(0.5), ploegKp(0.2), ploegKd(0.7),
63  flatbedKa(2.4), flatbedKv(0.6), flatbedKp(12), flatbedD(5), flatbedH(4),
64  engine(0), engineModel(CC_ENGINE_MODEL_FOLM),
65  usePrediction(false),
66  autoLaneChange(false),
67  platoonFixedLane(-1),
68  commitToLaneChange(true), noCommitReason(0), laneChangeCommitTime(-1) {
72  fakeData.frontSpeed = 0;
76  leaderPosition.set(0, 0);
77  frontPosition.set(0, 0);
78  //init L, K, b, and h with default values
79  memcpy(L, defaultL, sizeof(int)*MAX_N_CARS * MAX_N_CARS);
80  memcpy(K, defaultK, sizeof(double)*MAX_N_CARS * MAX_N_CARS);
81  memcpy(b, defaultB, sizeof(double)*MAX_N_CARS);
82  memcpy(h, defaultH, sizeof(double)*MAX_N_CARS);
83  //no data about any vehicle has been set
84  for (int i = 0; i < MAX_N_CARS; i++) {
85  initialized[i] = false;
86  }
87 }
88 
90  if (engine) {
91  delete engine;
92  }
93 }
#define MAX_N_CARS
Definition: CC_Const.h:77
#define CC_ENGINE_MODEL_FOLM
Definition: CC_Const.h:79
struct FAKE_CONTROLLER_DATA fakeData
fake controller data.
bool initialized[MAX_N_CARS]
tells whether data about a certain vehicle has been initialized
double K[MAX_N_CARS][MAX_N_CARS]
K matrix.
int L[MAX_N_CARS][MAX_N_CARS]
L matrix.
static const double defaultH[]
static const double defaultB[]
double b[MAX_N_CARS]
vector of damping ratios b
GenericEngineModel * engine
engine model employed by this car
double h[MAX_N_CARS]
vector of time headways h
Position frontPosition
current front vehicle position
static const double defaultK[MAX_N_CARS][MAX_N_CARS]
static const int defaultL[MAX_N_CARS][MAX_N_CARS]
Position leaderPosition
platoon's leader position
void set(double x, double y)
set positions x and y
Definition: Position.h:85
Definition: CC_Const.h:26
@ DRIVER
Definition: CC_Const.h:49