Control barrier functions basic example in 1d
13 次查看(过去 30 天)
显示 更早的评论
Hi,
I'm trying to program a basic example of a control barrier functions, for a system of 1D. The idea is that this system should not go for the negatives values
.
data:image/s3,"s3://crabby-images/8b257/8b257c80333ef710996a0d644633e8c79a961084" alt=""
The dynamic of my system is defined by
,
data:image/s3,"s3://crabby-images/fb639/fb63972985e0774955988ae12ffe89e0885bfa33" alt=""
The function h that is the constinst restriction is given by
, such that
data:image/s3,"s3://crabby-images/e8cd5/e8cd5c61dd1540f241feaecc9b0d23dee1da37e2" alt=""
data:image/s3,"s3://crabby-images/6de44/6de44c0f65d622f50f1cf607c61d0053366243b4" alt=""
The enforce condition is given by,
data:image/s3,"s3://crabby-images/9e42b/9e42bad9886b8fbfe1b4b7cc3f16611e908abc63" alt=""
data:image/s3,"s3://crabby-images/b3336/b3336de3f46654ac8fe2738976e07c6ebdfac21e" alt=""
The question is that I don't know how to program this example, I tried with the assumption that
data:image/s3,"s3://crabby-images/8c90d/8c90d2b92179a8aa784259a69e8b367e7ec4cc82" alt=""
But my code is not working.
This is my code
%% CASE: x \in R, x can only take positive values
%time interval
t_int = 0:0.001:20;
%initial condition
x_0 = 10;
b = 0.00000001;
%differential eqation
dxdt = @(t, x) -1 - x;
[t, x] = ode45(dxdt, t_int, x_0);
% Graficar la solución
figure;
plot(t, x);
xlabel('Time');
ylabel('x(t)');
grid on;
Can someone help me?
2 个评论
William Rose
2024-11-14
编辑:Voss
2024-11-14
I agree with @Torsten. I am unable to understand the dynamics of hte system you wish to simulate. You define b in your code but uyou do not use b in the differential equation, and you do not refer to b in your explanation.
The differential equation you use in your code
dx/dt=-x-1
is a decaying exponential which decays to x=-1, with time constant=1.
%% CASE: x \in R, x can only take positive values
%time interval
tSpan = [0,20];
%initial condition
x_0 = 10;
b = 0.00000001; % not used
%differential eqation
dxdt = @(t, x) -1 - x;
[t, x] = ode45(dxdt, tSpan, x_0);
% Graficar la solución
figure;
plot(t, x);
xlabel('Time');
ylabel('x(t)');
grid on;
采纳的回答
Ashok
2024-11-25
编辑:Ashok
2024-11-25
From the equations mentioned in the query, it seems the condition for the system is incorrectly stated as
, and should instead be
, where
is a class-K function. Additionally, the equation
, suggests that the class-K function is chosen to be
.
data:image/s3,"s3://crabby-images/3d339/3d339c56422a4bbb4e88a18e5cea0df0cadf9a51" alt=""
data:image/s3,"s3://crabby-images/b5c14/b5c14600c5434724467f7701f7e16681b2daf9ac" alt=""
data:image/s3,"s3://crabby-images/24ed4/24ed46f37a1201ce0b36e97deade49325409076c" alt=""
data:image/s3,"s3://crabby-images/ca3fa/ca3fa819caebe3ed877b21b5cbbd1a448671ac90" alt=""
data:image/s3,"s3://crabby-images/27f33/27f330aa1b82e783de522d471979e857087fac08" alt=""
To ensure the condition
on the control input, u can be chosen as
, where ρ is a positive constant. However, the below line in the shared code suggests that the constant is chosen as
which is contradictory.
data:image/s3,"s3://crabby-images/ca3fa/ca3fa819caebe3ed877b21b5cbbd1a448671ac90" alt=""
data:image/s3,"s3://crabby-images/e6494/e6494a8570b88ed34a732cf673374dd771bbf4ac" alt=""
data:image/s3,"s3://crabby-images/f5183/f5183665a97db5f268f40ceaadd260e78fe2eb5f" alt=""
dxdt = @(t, x) -1 - x;
To resolve the issue, replace ‘-1’ in the above line with some positive constant. Here’s a plot showing the system response for different values of ρ.
data:image/s3,"s3://crabby-images/1293e/1293e477592281b0c993d7e7a26f0f7f534f2937" alt=""
Kindly refer the following link to read more about Barrier Certificate Enforcement:
0 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Global or Multiple Starting Point Search 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!