- The first plot, with r,g,b,k traces, shows that N goes asymptotically to about N=32.5 when N0=2, 25, and 40. The phase plane plot shows what I interpret as a stable equilibrium at N~=27 (the value of N where dN/dtau crosses zero, with negative slope). Why is the equilibrium value for N not the same in the first plot and the phase plane plot?
- The phase plane plot shows dN/dtau<0 when N=2. By tracing the expected path on the phase plane plot, starting at N=2 , I expect N to decrease asymptotically to zero. But the first plot shows dN/dt>0 when N=N0=2. Why the mismatch?
Population Growth Model Analysis
26 views (last 30 days)
Show older comments
Athanasios Paraskevopoulos
on 15 May 2024
Commented: William Rose
on 16 May 2024
Below I tried to solve Population Growth problem, I provide you the mathematical solution. Also, I create MATLAB code, however i feel like that i repeat this code to each part of this code as you can see. How could I improve this code?
Assume a continuous growth model where the function that gives the rate of change R is defined as
. Provide the function n, which represents the population size.
data:image/s3,"s3://crabby-images/fc557/fc5573b98ccb1ff18a44ad35add6b7b8d747ef07" alt=""
If the growth of a population follows the logistic law but there is also a term for population reduction (e.g., from a predator while the members of the population are the prey), the equation that expresses the population size is of the form
data:image/s3,"s3://crabby-images/d8f1f/d8f1f02957c5637bf9e12b8650f3f85f23f28ab9" alt=""
data:image/s3,"s3://crabby-images/8c381/8c38163bda86669a24a00e8ee21fbf380d0549f2" alt=""
data:image/s3,"s3://crabby-images/ba128/ba128212b1b01ad933c8821458b2f59074b8a2f4" alt=""
data:image/s3,"s3://crabby-images/a9e15/a9e150ee20950b3846dbae21bf1e9499a6f8b840" alt=""
data:image/s3,"s3://crabby-images/94e19/94e19563d57f0d9554b0977213a4158d89815d4d" alt=""
data:image/s3,"s3://crabby-images/5f50b/5f50b526fb01ec99f4c87577f6bc6455186735e5" alt=""
data:image/s3,"s3://crabby-images/1a15b/1a15b7e58751d9c11d49e01e0744713d1a8e3d2b" alt=""
data:image/s3,"s3://crabby-images/0cfa8/0cfa853e212549d7f768083e30cffedeb47e9f16" alt=""
data:image/s3,"s3://crabby-images/b5e14/b5e14475ebfe2852c778006a40249bf2d9957923" alt=""
data:image/s3,"s3://crabby-images/80650/806500c13b972cc8949145c5341ee34ce4003e1c" alt=""
So we have
data:image/s3,"s3://crabby-images/bf580/bf580b638e12b0c8f044bab3ee9259ab27d7c5b9" alt=""
- We are going to find the function
:
To find
, we integrate
:
data:image/s3,"s3://crabby-images/52d49/52d498beabca1bc32767ff978ee67b269cf07b05" alt=""
data:image/s3,"s3://crabby-images/9d807/9d807e0c5d53f93cc7871a0f31d3ff467cc20d2a" alt=""
data:image/s3,"s3://crabby-images/a0c6f/a0c6fff9c428f0225126d90f8fa2805f7ae3815f" alt=""
data:image/s3,"s3://crabby-images/95619/95619141be4239cb86f8c6e5bb9a3a5b593a609c" alt=""
data:image/s3,"s3://crabby-images/0f13b/0f13bd82a3089e2b8423bf86501dae8f15ba8b25" alt=""
where C is the integration constant, which can be determined if an initial condition is given, such as
.
data:image/s3,"s3://crabby-images/61e8e/61e8e15a686eeb672f0d991327197cc40de9d20b" alt=""
- Now we are going to normalize the equation:
Let
and
. Then:
data:image/s3,"s3://crabby-images/74726/74726cf99f8c644687c6d429a7b0b6df26dee775" alt=""
data:image/s3,"s3://crabby-images/a8753/a87532579905d188ab02c963114868055304fed0" alt=""
data:image/s3,"s3://crabby-images/08b38/08b385d7cfe005c778d323c8714f59daf873f4cd" alt=""
data:image/s3,"s3://crabby-images/5c275/5c275ae7857033c4426d6c3cb1fae0a52923f5b9" alt=""
We substitute into the original equation:
data:image/s3,"s3://crabby-images/0aa66/0aa6609de76f95752820bb515eeec2c3889b8c15" alt=""
data:image/s3,"s3://crabby-images/42137/4213749ffb04e802aeb73c9d3c797b843a3c3f72" alt=""
data:image/s3,"s3://crabby-images/a2e33/a2e33c2cb19189a71f03c5ad62b591376513407a" alt=""
- Then we are going to calculate the Stationary Points:
Set
:
data:image/s3,"s3://crabby-images/74332/7433247b4e52ca494e401aa2b89a136c33cbbf7a" alt=""
data:image/s3,"s3://crabby-images/0a8c5/0a8c58f697ce4db2ca04ab84f434e6d102a87dfa" alt=""
data:image/s3,"s3://crabby-images/4ba48/4ba488af1909f04ee809678a5a067fa16d1f3844" alt=""
For
:
data:image/s3,"s3://crabby-images/b910a/b910a837ba50c3671b504c290fc4857ee767e847" alt=""
data:image/s3,"s3://crabby-images/80317/803171d96bfaf171accd227af410605d67b6ad62" alt=""
data:image/s3,"s3://crabby-images/f465f/f465f0414edb5570fa3917db80a802c07027e923" alt=""
% Define the normalized logistic equation with reduction term
% K/a = 35, ar/b = 0.4
Ka = 35;
ar_b = 0.4;
% Define the function for the normalized logistic equation
f = @(tau, N) ar_b * N * (1 - N/Ka) - N / (1 + N);
% Time span for the simulation
tspan = [0 50]; % Adjust if needed to observe long-term behavior
% Initial conditions
N0 = [40, 25, 2, 0.05];
% Prepare the figure for plotting
figure(1);
hold on;
% Colors for different trajectories
colors = ['r', 'g', 'b', 'k']; % Red, Green, Blue, Black
% Solve the equation for each initial condition and plot
for i = 1:length(N0)
[T, N] = ode45(f, tspan, N0(i));
plot(T, N, 'Color', colors(i), 'LineWidth', 2);
legendInfo{i} = ['N_0 = ' num2str(N0(i))]; % Create legend entry
end
% Add graph details
title('Numerical solutions of the normalized logistic equation');
xlabel('Normalized time τ');
ylabel('Normalized population size N');
legend(legendInfo, 'Location', 'northeastoutside');
grid on;
hold off;
% Equilibrium analysis
syms N
eqn = ar_b * N * (1 - N / Ka) - N / (1 + N) == 0;
equilibria = double(solve(eqn, N));
% Stability analysis
f = @(N) ar_b * N * (1 - N / Ka) - N / (1 + N);
J = diff(f(N), N);
eigenvalues = double(subs(J, N, equilibria));
disp('Equilibrium Points and their Stability:');
for i = 1:length(equilibria)
if real(eigenvalues(i)) < 0
stability = 'Stable';
else
stability = 'Unstable';
end
fprintf('N = %f: Eigenvalue = %f, %s\n', equilibria(i), eigenvalues(i), stability);
end
% Bifurcation analysis setup
ar_b_values = linspace(0.1, 1, 100);
bifurcation_results = zeros(length(ar_b_values), 10); % Adjust the columns based on expected number of roots
% Compute equilibrium points for varying ar/b
for i = 1:length(ar_b_values)
eqn = ar_b_values(i) * N * (1 - N / Ka) - N / (1 + N) == 0;
solutions = double(solve(eqn, N));
bifurcation_results(i, 1:length(solutions)) = solutions';
end
% Plot bifurcation diagram
figure;
plot(ar_b_values, bifurcation_results, 'b*');
title('Bifurcation Diagram');
xlabel('ar/b');
ylabel('Equilibrium Points');
% Set up the ODE function for phase plane analysis
f = @(N) ar_b * 0.4 * N .* (1 - N / Ka) - N ./ (1 + N);
% Create a grid of N values and compute their time derivatives
N_values = linspace(0, 50, 400);
dN_dtau = f(N_values);
% Plot phase plane
figure;
plot(N_values, dN_dtau);
title('Phase Plane Analysis');
xlabel('Population Size N');
ylabel('dN/dτ');
grid on;
hold on;
% Mark zero crossings (equilibrium points)
zero_crossings = N_values(abs(dN_dtau) < 1e-3);
for i = 1:length(zero_crossings)
plot(zero_crossings(i), 0, 'ro');
end
hold off;
0 Comments
Accepted Answer
William Rose
on 16 May 2024
I see that you have
f = @(tau, N) ar_b * N * (1 - N/Ka) - N / (1 + N);
and
syms N
eqn = ar_b * N * (1 - N / Ka) - N / (1 + N) == 0;
...
f = @(N) ar_b * N * (1 - N / Ka) - N / (1 + N);
and
eqn = ar_b_values(i) * N * (1 - N / Ka) - N / (1 + N) == 0; % inside a for loop
and
f = @(N) ar_b * 0.4 * N .* (1 - N / Ka) - N ./ (1 + N);
I wouldn;t worry about the redundancy. The code is clear, which makes it easier to understand, for others, and for you, if you sxccome back to it in a couple of years.
I don't understand why there is "0.4" in the last equation.
I have two other questions - which reveal my lack of understanding of the model, but I'm curious:
3 Comments
William Rose
on 16 May 2024
@Sam Chak, thanks. Once again, I wish I could give a thumbs up to your explanation.
@Athanasios Paraskevopoulos, good luck with your work.
More Answers (0)
See Also
Categories
Find more on 2-D and 3-D Plots in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!