VanderPolDemo.m
Contents
Overview
This script illustrates the stiffness of the Van der Pol equation
Beginning of code
Initialize
clear all close all f = @(t,y,mu) [y(2); mu*(1 - y(1)^2)*y(2) - y(1)]; t0 = 0; y0 = [2 0]; % initial condition tol = 1e-4;
Example 1
We use , which results in a non-stiff problem which ode23 can easily handle
tmax = 20; mu = 0; opts = odeset('RelTol',tol); ode23(f,[t0 tmax],y0,opts,mu); title(strcat('ode23 solution of van der Pol equation, \mu = ',int2str(mu))); xlabel('time t'); ylabel('solution y'); legend('y_1','y_2')
data:image/s3,"s3://crabby-images/2c8df/2c8df7d7e11847c0c7adec16878ed9fc36081402" alt=""
Plot of first component (position) vs. time
pause [t,y] = ode23(f,[t0 tmax],y0,opts,mu); plot(t,y(:,1),'-o'); title(strcat('First component of ode23s solution of van der Pol equation, \mu = ',int2str(mu))); xlabel('time t'); ylabel('solution y_1');
data:image/s3,"s3://crabby-images/b42d1/b42d157f19db2097cf4e259fdc29d4eaa7378c61" alt=""
Solving the same problem with ode23s
pause ode23s(f,[t0 tmax],y0,opts,mu); title(strcat('ode23s solution of van der Pol equation, \mu = ',int2str(mu))); xlabel('time t'); ylabel('solution y'); legend('y_1','y_2') pause
data:image/s3,"s3://crabby-images/bcb3d/bcb3dd662a37cfe66454698c0bcee4fd5d920c89" alt=""
Example 2
If we change , then the problem becomes stiff, and we need see that ode23 is very slow. Note the short
-range in the plot. The stiff solver ode23s does a much better job below.
tmax = 1000; mu = 1000; opts = odeset('RelTol',tol); ode23(f,[t0 tmax],y0,opts,mu); title(strcat('ode23 solution of van der Pol equation, \mu = ',int2str(mu))); xlabel('time t'); ylabel('solution y'); legend('y_1','y_2')
data:image/s3,"s3://crabby-images/2d8fc/2d8fc2993e35d58bbe3cf542649dff2ebe341565" alt=""
Plot of first component (position) vs. time (using ode23s)
pause [t,y] = ode23s(f,[t0 tmax],y0,opts,mu); plot(t,y(:,1),'-o'); title(strcat('First component of ode23s solution of van der Pol equation, \mu = ',int2str(mu))); xlabel('time t'); ylabel('solution y_1');
data:image/s3,"s3://crabby-images/c7c27/c7c2734ecb8638715fc730dd8fac74852951ac44" alt=""
Solving the same problem with ode23s
pause ode23s(f,[t0 tmax],y0,opts,mu); title(strcat('ode23s solution of van der Pol equation, \mu = ',int2str(mu))); xlabel('time t'); ylabel('solution y'); legend('y_1','y_2','Location','SouthWest') pause
data:image/s3,"s3://crabby-images/d5450/d5450ecab2e06739b3127c70c4883daa5a88a374" alt=""