Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

490 remodel acc concept #516

Merged
merged 13 commits into from
Dec 5, 2024
Binary file added doc/assets/research_assets/ACC_FLC_Example_1.PNG
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
115 changes: 115 additions & 0 deletions doc/research/paf24/planning/ACC.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
# ACC

This file gives a general overview on possible ACC implementations and reflects the current state of the ACC.

## General

The main goal of an ACC (Adaptive Cruise Control) is to follow a car driving in front while keeping a safe distance to it. This can be achieved by adjusting the speed to the speed of the car in front.
In general, classic ACC systems are designed for higher velocity (e.g. > 40 km/h). Apart from that, there are Stop & Go systems that support lower velocites (e.g. < 40 km/h). In our case, both systems might be needed and it might be reasonable to develop two different systems for ACC and Stop & Go.
Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
The threshold to distinguish between the two systems has to be chosen reasonably.
There are basically three different techniques that can be used to implement an ACC: PID Control, Model Predictive Control and Fuzzy Logic Control. Another option is CACC (Cooperative Adaptive Cruise Control) but this is not relevant for our project since it requires communication between the vehicles.

### PID Control

The PID Controller consists of three terms: the proportional term, the integral term and the derivative term. One possible simple controller model looks as follows:

$$ v_f(t) = v_f(t - t_s) + k_p e(t-t_s) + k_i \int_{0}^{t} e(\tau) d\tau + k_d \dot{e}(t - t_s) $$
$$ e(t-t_s) = \Delta x(t - t_s) - t_{hw,d} v_f (t - t_s) $$

- $v_f$: follower vehicle velocity (transmitted to the acting component)
- $t_s$: sampling time
- $k_p$ and $k_i$ and $k_d$: coefficients for proportional, integral and derivative terms
- $e$: distance error (difference between actual distance $\Delta x$ and desired distance $\Delta x_d$)
- $t_{hw,d}$: desired time headway (duration between the arrival of the first car at a certain waypoint and the arrival of the following car at the same waypoint)

Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
### Model Predictive Control (MPC)

It calculates the current control action by solving an online, iterative and finite-horizon optimization of the model.
Procedure:

1. Prediction of future system states based on current states
2. Computation of the cost function for a finite time horizon in the future
3. Implementation of the first step of the solved control sequence
4. Application of the feedback control loop to compensate for the predictive error and model inaccuracy
5. Sampling of new current states and repitition of the process

Comment on lines +27 to +35
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Enhance MPC section with implementation specifics

The MPC section needs more detailed information to be implementable:

  1. Define the prediction model
  2. Specify the cost function components
  3. Document the optimization constraints
  4. Provide the control horizon parameters

Would you like me to help draft the detailed MPC implementation specifications?

### Fuzzy Logic Control (FLC)

Provides a unified control framework to offer both functions: ACC and Stop & Go.

![Example of a FLC control algorithm showing input variables (relative distance, host vehicle speed), fuzzy rules processing, and output variable](../../../assets/research_assets/ACC_FLC_Example_1.PNG)

Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
## ACC in our project

### Current implementation

- General behaviour:
checks for obstacle distance < safety distance

calculates new speed based on obstacle distance

else keep current speed

- publishes speed to acc_velocity
- safe distance calculation is currently not correct, uses speed + (speed * 0.36)² which results in wrong distances
- if car in front of us ignores speed limits we ignore them as well
Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
- some parts of unstuck routine are in ACC and need to be refactored
- same goes for publishing of current waypoint, this should not be in ACC

Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
Comment on lines +54 to +58
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

⚠️ Potential issue

Critical: Address safety distance calculation and architectural issues

Several critical issues require immediate attention:

  1. Safety distance calculation is incorrect and unsafe
  2. Component responsibilities are mixed:
    • Unstuck routine in ACC
    • Waypoint publishing in ACC

Proposed actions:

  1. Create a dedicated SafetyDistance class with physics-based calculations
  2. Move unstuck routine to a behavior module
  3. Implement waypoint management in planning component
  4. Add comprehensive unit tests

Would you like me to help draft the SafetyDistance class implementation?

In summary, the current implementation is not sufficient and needs major refactoring.

### Concept for new implementation

The new concept for the ACC is to take the trajectory, look at all or a limited subset of the next points and add a target velocity and the current behaviour to each point.
This way the Acting has more knowledge about what the car is doing and can adjust accordingly in a local manner.
For this a new trajectory message type was implemented in #511.

![trajectoryMsg](https://github.com/user-attachments/assets/0b452f1a-4c60-45b2-882f-3a50118c9cb9)
Vroni27 marked this conversation as resolved.
Show resolved Hide resolved

Since behaviour is passed as an ID a new enum for behaviours was implemented in utils.py as well.
Vroni27 marked this conversation as resolved.
Show resolved Hide resolved

The general idea for speeds above the 40 km/h mark is to calculate a proper safety distance, a general target velocity and velocity targets based on PID. For speeds lower than that a stop and go system can be discussed if it is really needed.

For safety distance we would like to calculate it like FLC but that most likely needs some adjustments as setting the distance to 100m when there is no vehicle ahead seems unreasonable.
We can just directly set the velocity to the speed limit in that case.

For a general speed target we either take the speed of the car in front or the speed limit, whichever is lower. In cases where the car in front is substantially slower than the speed limit ACC could inititate overtaking.

Since we want to calculate the desired speed at each point of the trajectory, the way PID calculates velocity seems reasonable since we can treat the trajectory points as different points in time for the sampling time.
For example let's say we sample every fifth point and calculate the velocity for that, then we can just interpolate every other point inbetween.

$v_f(t - t_s)$ would then simply be the velocity of the fifth point before the current one. Theoretically this allows us to dynamically adjust the sampling time as well if needed.

Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
For the distance error we can use the safety distance as the desired distance. The distance at time t needs to be predicted based on the (predicted) distance at the prior sample point and the calculated speed at the prior sample point.

We calculate velocities like that up to the point where the actual distance is within 5% of the optimal safety distance. For points further than that we simply use the desired general speed.

![accDiagram](https://github.com/user-attachments/assets/9a7b4572-f041-4da0-900c-51ab20d1904b)

Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
### Possible next steps

A seperate file for the new ACC should be created to not disturb the system.

The parts that might get cut from ACC like current waypoint and unstuck routine need to be evaluated for necessity and if need be moved to somewhere more fitting.

Implement publisher for new message type.

Start implementing safety distance and general target speed logic. Subscriber logic could be taken from old implementation.

Implement PID logic

Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
### Requirements

- obstacle speed
- obstacle distance
Comment on lines +103 to +104
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🛠️ Refactor suggestion

Expand system requirements with specific metrics

The requirements section needs quantitative metrics:

  1. Obstacle Detection:
    • Detection range
    • Speed measurement accuracy
    • Position accuracy
    • Update rate
  2. System Performance:
    • Control loop frequency
    • Response time
    • Speed control accuracy
  3. Safety Requirements:
    • Minimum time gap
    • Maximum deceleration
    • Fail-safe behavior

Would you like me to help draft detailed requirements specifications?


Vroni27 marked this conversation as resolved.
Show resolved Hide resolved
## Discussion

- How to test adaptations of the ACC? (Suggestion: Create test scenarios which represent different situations like driving straight forward behing a leading vehicle, no leading vehicle, sudden breaking, etc.)
- Which output should be transfered to the Acting component? (Suggestion: The desired speed is published in the new trajectory. No acceleration data is needed, the acceleration is handled by the acting component.)
- Which input do we get from the Perception component? (Suggestion: The distance and velocity of the car in front would be really helpful.)

## Sources

He, Yinglong et al. (2019). Adaptive Cruise Control Strategies Implemented on Experimental Vehicles: A Review. IFAC-PapersOnLine. 52. 21-27. 10.1016/j.ifacol.2019.09.004.
[Link](https://www.researchgate.net/publication/335934496_Adaptive_Cruise_Control_Strategies_Implemented_on_Experimental_Vehicles_A_Review)
Loading