function main
%求解LE代码:
% 计算Rossler吸引子的Lyapunov指数
% Rossler吸引子,用来计算Lyapunov指数
% a=0.25,b=1,c=5.5
% dx/dt = -y-z,
% dy/dt = x+ay,
% dz/dt = b+z(x-c),
clear;
yinit = [1,1,1];
orthmatrix = [1 0 0;
0 1 0;
0 0 1];
a = 0.25;
b = 1;
c = 5.5;
y = zeros(12,1);
% 初始化输入
y(1:3) = yinit;
y(4:12) = orthmatrix;
tstart = 0; % 时间初始值
tstep = 1e-3; % 时间步长
wholetimes = 1e5; % 总的循环次数
steps = 10; % 每次演化的步数
iteratetimes = wholetimes/steps; % 演化的次数
mod = zeros(3,1);
lp = zeros(3,1);
% 初始化三个Lyapunov指数
Lyapunov1 = zeros(iteratetimes,1);
Lyapunov2 = zeros(iteratetimes,1);
Lyapunov3 = zeros(iteratetimes,1);
for i=1:iteratetimes
tspan = tstart:tstep:(tstart + tstep*steps);
[T,Y] = ode45('Rossler_ly', tspan, y);
% 取积分得到的最后一个时刻的值
function main
%求解LE代码:
% 计算Rossler吸引子的Lyapunov指数
% Rossler吸引子,用来计算Lyapunov指数
% a=0.25,b=1,c=5.5
% dx/dt = -y-z,
% dy/dt = x+ay,
% dz/dt = b+z(x-c),
clear;
yinit = [1,1,1];
orthmatrix = [1 0 0;
0 1 0;
0 0 1];
a = 0.25;
b = 1;
c = 5.5;
y = zeros(12,1);
% 初始化输入
y(1:3) = yinit;
y(4:12) = orthmatrix;
tstart = 0; % 时间初始值
tstep = 1e-3; % 时间步长
wholetimes = 1e5; % 总的循环次数
steps = 10; % 每次演化的步数
iteratetimes = wholetimes/steps; % 演化的次数
mod = zeros(3,1);
lp = zeros(3,1);
% 初始化三个Lyapunov指数
Lyapunov1 = zeros(iteratetimes,1);
Lyapunov2 = zeros(iteratetimes,1);
Lyapunov3 = zeros(iteratetimes,1);
for i=1:iteratetimes
tspan = tstart:tstep:(tstart + tstep*steps);
[T,Y] = ode45('Rossler_ly', tspan, y);
% 取积分得到的最后一个时刻的值
y = Y(size(Y,1),:);
% 重新定义起始时刻
tstart = tstart + tstep*steps;
y0 = [y(4) y(7) y(10);
y(5) y(8) y(11);
y(6) y(9) y(12)];
%正交化
y0 = ThreeGS(y0);
% 取三个向量的模
mod(1) = sqrt(y0(:,1)'*y0(:,1));
mod(2) = sqrt(y0(:,2)'*y0(:,2));
mod(3) = sqrt(y0(:,3)'*y0(:,3));
y0(:,1) = y0(:,1)/mod(1);
y0(:,2) = y0(:,2)/mod(2);
y0(:,3) = y0(:,3)/mod(3);
lp = lp+log(abs(mod));
%三个Lyapunov指数
Lyapunov1(i) = lp(1)/(tstart);
Lyapunov2(i) = lp(2)/(tstart);
Lyapunov3(i) = lp(3)/(tstart);
y(4:12) = y0';
end
% 作Lyapunov指数谱图
i = 1:iteratetimes;
plot(i,Lyapunov1,i,Lyapunov2,i,Lyapunov3)
Le1=Lyapunov1(end),Le2=Lyapunov2(end),Le3=Lyapunov3(end)
title('Lyapunov指数谱图')
end
%计算得到的Rossler系统的LE为———— 0.0992 0.0755 -5.2644
%计算得到的Rossler系统的LE为———— 0.0992 0.0755 -5.2644
function dX = Rossler_ly(t,X)
a = 0.25;
b = 1;
c = 5.5;
x=X(1); y=X(2); z=X(3);
% Y的三个列向量为相互正交的单位向量
Y = [X(4), X(7), X(10);
X(5), X(8), X(11);
X(6), X(9), X(12)];
% 输出向量的初始化,必不可少
dX = zeros(12,1);
% Rossler吸引子
dX(1) = -y-z;
dX(2) = x+a*y;
dX(3) = b+z*(x-c);
% Rossler吸引子的Jacobi矩阵
Jaco = [0 -1 -1;
1 a 0;
z 0 x-c];
dX(4:12) = Jaco*Y;
%程序中用到的ThreeGS程序如下:
%G-S正交化
function A = ThreeGS(V) % V 为3*3向量
v1 = V(:,1);
v2 = V(:,2);
v3 = V(:,3);
a1 = zeros(3,1);
a2 = zeros(3,1);
a3 = zeros(3,1);
a1 = v1;
a2 = v2-((a1'*v2)/(a1'*a1))*a1;
a3 = v3-((a1'*v3)/(a1'*a1))*a1-((a2'*v3)/(a2'*a2))*a2;
A = [a1,a2,a3];
wouderw
- 粉丝: 342
- 资源: 2959
最新资源
- 激光摆动焊接abaqus温度场分析 圆形 正弦摆动 同金属 异种金属摆动焊接温度场分析 基于高斯热源 双椭球热源 柱热源 模型和子程序文件
- TPU-MLIR算法量化及YOLOv5s模型转换与优化实践
- EXE格式应用程序11
- API加解密签名算法-实验代码
- onnx量化裁减调优TPU-MLIR使用
- 盼盼短剧系统整合版.pptx
- 基于FPGA的HDMI显示控制器+项目源码+文档说明
- iXhash2-4.00.tar.gz SpamAssassin 的非官方改进版 iXhash 插件
- 机械设计鱼缸玻璃贴膜sw21可编辑非常好的设计图纸100%好用.zip
- IT8导入云程序,联网,双击打开指定目录即可
- iXhash2-2.05.tar.gz iXhash2 是 SpamAssassin 的非官方改进版 iXhash 插件
- 机械设计永磁转子清洁机sw21非常好的设计图纸100%好用.zip
- 色彩 IT8 Delta E差值大数据计算,配合上传文件使用,下载中查找
- 毕业设计答辩模板PPT
- iC65N 2P 用于EPLAN部件EDZ,包含图片、STP、窗口宏ema、部件库EDZ
- VS2022 C++ gRPC demo 程序
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈