duffing.m

来自「几种常见混沌时间序列matlab实现 1)chua flow 2)duffi」· M 代码 · 共 36 行

M
36
字号
% Duffing 吸引子三维相空间图,这里用四阶 Runge-Kutta 法得到微方程的离散序列
% 时间步长 h = 0.01, 而不是1

% 方程表达式
% dx/dt = y
% dy/dt = -delta*y - a*x*(1+x^2) + f*cos(z)
% dz/dt = omega

clc
clear
close all

delta = 0.05;
a = 0.5;
f = 7.5;
omega = 1;

y = [-1,0,1];          % 起始点 (1 x 3 的行向量)
h = 0.05;              % 积分时间步长

k1 = 8000;             % 前面的过渡点数
k2 = 6000;             % 前面的迭代点数

z = DuffingData(y,h,k1+k2,delta,a,f,omega);     % 用四阶 Runge-Kutta 法产生 k1+k2 个点
z = z(k1+1:end,:);                              % 去掉前面 k1 个过渡点

X = z(:,1);
Y = z(:,2);
Z = z(:,3);

figure(1)
plot3(Z,Y,X);
xlabel('z');ylabel('y');zlabel('x');
title('Duffing attractor');

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?