how to modify code for distributed delay

I have a code, which gives a solution of a delay logistic equation with discrete delay.
tau = 1;
tspan = [0 20];
y0 = 0.5;
sol = dde23(@ddefunc, tau, y0, tspan);
% Plot the solution
figure;
plot(sol.x, sol.y, 'LineWidth', 2);
xlabel('Time (days)');
ylabel('Population');
legend('y');
% Define the delay differential equation
function g = ddefunc(t, y, Z)
r = 1.5;
y_tau = Z;
g = r * y * (1 - y_tau);
end
Now I want to modify my code for distributed delay as attached below.
Can someone guide me how to deal with distributed delay

 Akzeptierte Antwort

Torsten
Torsten am 16 Aug. 2024
r = 1.5;
fun = @(t,x)[r*x(1)*(1-x(2));x(1)];
x0 = [0.5;0];
tspan = [0 20];
[t,x] = ode45(fun,tspan,x0);
plot(t,x(:,1))
grid on

4 Kommentare

William Rose
William Rose am 16 Aug. 2024
@Muhammad, @Torsten, nice answer.
Muhammad
Muhammad am 16 Aug. 2024
@William Rose,@Torsten Thank you for your response! However, I think there might be some confusion. My original question was about how to modify the delay logistic equation code to account for a distributed delay rather than a simple delay.
Torsten
Torsten am 16 Aug. 2024
Bearbeitet: Torsten am 16 Aug. 2024
This is the solution for equation (1.6) with r=1.5 and x(0) = 0.5.
If you have something different in mind, you must post it.
Note that the second equation
dy/dt = x, y(0) = 0
gives
y(t) = integral_{tau=0}^{tau=t} x(tau) dtau
as solution, thus the integral in (1.6).
Muhammad
Muhammad am 17 Aug. 2024
Thank you for your clear response!

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Mathematics finden Sie in Hilfe-Center und File Exchange

Gefragt:

am 16 Aug. 2024

Kommentiert:

am 17 Aug. 2024

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by