基于Matlab绘制洛伦兹吸引子相图

目录
  • 1.公式及Lorenz函数
  • 2.混沌吸引子图像
  • 3.混沌吸引子图像
  • 4.封面图绘制

洛伦兹吸引子(Lorenz attractor)是由MIT大学的气象学家Edward Lorenz在1963年给出的,他给出第一个混沌现象——蝴蝶效应。。。。。。。。废话不多说。

反正咱就是,好看且有用咱就写代码,第零部分给出公式。第一部分给出 混沌吸引子 图像,第二部分给出庞加莱截面法 分岔图 绘制。

1.公式及Lorenz函数

Lorenz微分方程组定义如下:

非常容易能写出该微分方程组函数:

function dL=Lorenz(t,L)
% L=[x;y;z;a;r;b];
% dL=[dx/dt;dy/dt;dz/dt;0,0,0];
% dz/dt=-a*(x-y)
% dy/dt=x*(r-z)-y
% dz/dt=x*y-b*z
dL=zeros([6,1]);
dL(1)=-L(4)*(L(1)-L(2));
dL(2)=L(1)*(L(5)-L(3))-L(2);
dL(3)=L(1)*L(2)-L(6)*L(3);
dL(4:6)=0;
end

2.混沌吸引子图像

基础绘图:

[~,L]=ode45(@(t,L)Lorenz(t,L),0:.01:100,[1;1;1;10;28;8/3]);
plot3(L(:,1),L(:,2),L(:,3))
grid on

修饰动态图:

% ode45求解
[~,L]=ode45(@(t,L)Lorenz(t,L),0:.01:100,[1;1;1;10;28;8/3]);
% 修饰及属性设置
ax=gca;
hold on;grid on
plhdl=plot3(0,0,0,'Color',[0.9843 0.8588 0.5333 0.5],'LineWidth',1.3);
ax.XColor=[1,1,1].*.6;ax.XLim=[-20,20];
ax.YColor=[1,1,1].*.6;ax.YLim=[-30,30];
ax.ZColor=[1,1,1].*.6;ax.ZLim=[0,50];
ax.LineWidth=1.5;
ax.GridAlpha=.09;
ax.GridLineStyle='-.';
ax.FontName='cambria';
ax.Color=[0 0 0];
ax.DataAspectRatio=[1,1,1];
view([-159,18]);
% 循环绘图
for i=1:size(L,1)
    plhdl.XData=L(1:i,1);
    plhdl.YData=L(1:i,2);
    plhdl.ZData=L(1:i,3);
    drawnow
end

3.混沌吸引子图像

基本代码:

这里使用庞加莱截面法,即绘制y=x平面上|y|的图像,基本代码如下:

Z=[];
for r=1:500
    % 舍弃前面迭带的结果,用后面的结果画图
    [~,L]=ode45(@(t,L)Lorenz(t,L),[0,1],[1;1;1;10;r;8/3]);
    [T,L]=ode45(@(t,L)Lorenz(t,L),[0,50],L(end,:));
    D=L(:,2)-L(:,1); 

    for k2=2:size(L,1)
        k1=k2-1;
        if D(k1)*D(k2)<=0
            y=(L(k2,1).*L(k1,2)-L(k1,1).*L(k2,2))./(D(k2)-D(k1));
            Z=[Z,r+abs(y').*1i];
        end
    end

end
plot(Z,'.','markersize',1)
title('Lorenz映射分岔图')
xlabel('r'),ylabel('|y| where x=y')

代码有一些地方详细讲解一下,首先说明为什么要用

Z=[Z,r+abs(y').*1i];

的格式进行存储,这样存储可以少构造一个数组,一般情况下我们需要分别存储γ和|y|到两个矩阵,存储为复数形式就可以复平面绘图减少初始化矩阵数量。

其次代码中用了D(k1)*D(k2)<=0来判断是否采点,

D(k1)=x1-y1,D(k2)=x2-y2

当D(k1)*D(k2)<=0时说明(x1,y1),(x2,y2)两点分别在 y=x直线两侧。

另外说明一下:

y=(L(k2,1).*L(k1,2)-L(k1,1).*L(k2,2))./(D(k2)-D(k1));

是啥。

其实就是构造的两点连线与直线y=x的交点:

PS:为了进一步减少空间复杂度,我们可以将上述函数更改为完全由x,y差值以及y代替,这样就可以直接将中间变量D存储到原来x的位置,减少中间变量的数量:

因此代码可以改写为(当然为了可读性最后并没有采取这个策略hiahiahia):

L(:,1)=L(:,2)-L(:,1); 

    for k2=2:size(L,1)
        k1=k2-1;
        if L(k1,1)*L(k2,1)<=0
            y=L(k2,2)+(L(k1,2)-L(k2,2)).*L(k2,1)./(L(k2,1)-L(k1,1));
            Z=[Z,r+abs(y').*1i];
        end
    end

最后,这部分代码依赖循环我们完全可以将其向量化,即修改为:

Z=[];
for r=1:500
    % 舍弃前面迭带的结果,用后面的结果画图
    [~,L]=ode45(@(t,L)Lorenz(t,L),[0,1],[1;1;1;10;r;8/3]);
    [T,L]=ode45(@(t,L)Lorenz(t,L),[0,50],L(end,:)); 

    % 找到穿过直线y=x的前后两个点
    D=L(:,2)-L(:,1);
    logInd=D(2:end).*D(1:end-1)<=0;
    k1=[logInd;false];k2=[false;logInd];

    % 对找到的两个点进行插值
    y=(L(k2,1).*L(k1,2)-L(k1,1).*L(k2,2))./(D(k2,:)-D(k1,:));
    Z=[Z,r+abs(y').*1i];
end
plot(Z,'.','markersize',1)
title('Lorenz映射分岔图')
xlabel('r'),ylabel('|y| where x=y')

4.封面图绘制

fig=gcf;

% 左图
ax1=axes('Parent',fig);
ax1.Position=[1/12 1/12 1/2-1/6 1-1/6];
hold on;grid on
[~,L]=ode45(@(t,L)Lorenz(t,L),0:.01:100,[1;1;1;10;28;8/3]);
plot3(L(:,1),L(:,2),L(:,3),'Color',[0 0.2510 0.4510 0.5],'LineWidth',1.2)
ax1.XColor=[1,1,1].*.6;
ax1.YColor=[1,1,1].*.6;
ax1.ZColor=[1,1,1].*.6;
ax1.LineWidth=1.5;
ax1.GridAlpha=.09;
ax1.GridLineStyle='-.';
ax1.FontName='cambria';
ax1.DataAspectRatio=[1,1,1];
view([-159,18]);

% 右图
ax2=axes('Parent',fig);
ax2.Position=[1/2 1/12 1/2-1/18 1-1/6];
hold on;grid on
Z=[];
for r=1:500
    % 舍弃前面迭带的结果,用后面的结果画图
    [~,L]=ode45(@(t,L)Lorenz(t,L),[0,1],[1;1;1;10;r;8/3]);
    [T,L]=ode45(@(t,L)Lorenz(t,L),[0,50],L(end,:)); 

    % 找到穿过直线y=x的前后两个点
    D=L(:,2)-L(:,1);
    logInd=D(2:end).*D(1:end-1)<=0;
    k1=[logInd;false];k2=[false;logInd];

    % 对找到的两个点进行插值
    y=L(k2,2)+(L(k1,2)-L(k2,2)).*D(k2,:)./(D(k2,:)-D(k1,:));
    Z=[Z,r+abs(y').*1i];
end
plot(Z,'.','markersize',1,'Color',[0 0.2510 0.4510 0.5])
ax2.YLabel.String='|y| where x=y';
ax2.YLabel.FontSize=14;
ax2.XColor=[1,1,1].*.4;
ax2.YColor=[1,1,1].*.4;
ax2.ZColor=[1,1,1].*.4;
ax2.LineWidth=1.5;
ax2.GridAlpha=.09;
ax2.GridLineStyle='-.';
ax2.FontName='cambria';

% Lorenz函数
function dL=Lorenz(t,L)
% L=[x;y;z;a;r;b];
% dL=[dx/dt;dy/dt;dz/dt;0,0,0];
% dz/dt=-a*(x-y)
% dy/dt=x*(r-z)-y
% dz/dt=x*y-b*z
dL=zeros([6,1]);
dL(1)=-L(4)*(L(1)-L(2));
dL(2)=L(1)*(L(5)-L(3))-L(2);
dL(3)=L(1)*L(2)-L(6)*L(3);
dL(4:6)=0;
end

以上就是基于Matlab绘制洛伦兹吸引子相图的详细内容,更多关于Matlab洛伦兹吸引子相图的资料请关注我们其它相关文章!

(0)

相关推荐

  • 如何利用Matlab绘制出好看的火山图

    这里画了一个示例: 数据来源 绘制效果: 代码及说明: 使用代码时只需要改一开始导入的数据,和代码提示中X坐标区域范围和Y坐标区域范围,完整代码如下所示: % 读取数据 data=readmatrix('volcano.txt'); logFC=data(:,2); padj=data(:,3); DB_not=(padj>0.5)|(logFC<0.5&logFC>-0.5); DB_up=padj<=0.05&logFC>=0.5; DB_down=pad

  • Python&Matlab实现伏羲八卦图的绘制

    目录 1 与达尔文对话 2 与老子对话 2.1 Python实现 2.2 Matlab实现 1 与达尔文对话 140年前,1858年7月1日,达尔文在英伦岛发表了自己有关自然选择的杰出论文.他提出,生物的发展规律是物竞天择.经过物竞,自然界选择并存留最具生命优势的物种.这些物种愈竞愈强.直至人,已无所不能,成为统治世界的物种,这已是不争的事实.但在地球的漫长的演化史上,我们又看见,曾经统治地球的庞然大物恐龙消亡了.一-些科学家将其归之于小行星对地球的撞击.但就在我们这一代人眼前,兽中之王的老虎正

  • 详解Matlab如何绘制小提琴图

    目录 1使用示例 基础使用,Y为矩阵 基础使用,Y为向量,X为标签 基础使用多个图像绘制,并添加图例 2完整代码 写了个matlab绘制小提琴图的函数: 1.图中小提琴状区域为核密度曲线 2.白色方块为25%,75%分位数 3.中间横线为中位数 4.白色点为离群值点 5.竖着的黑线是去掉离群值点后点的上下限 1使用示例 基础使用,Y为矩阵 X=1:5; Y=randn(100,5); Hdl1=violinChart(gca,X,Y,[0 0.447 0.741],0.6); X:横坐标 Y:数

  • Matlab绘制散点密度图的教程详解

    目录 效果 1工具函数完整代码 2参数说明 3使用方式 3.1散点赋色 3.2等高线图 3.3带直方图的散点图 3.4带直方图的等高线图 4使用方式扩展–与ggplot修饰器联动 效果 原理也很简单,通过matlab自带的ksdensity获得网格每一点密度,通过密度拟合曲面,再计算每个数据点对应的概率,并将概率映射到颜色即可为了怕大家找不到函数这次工具函数放到最前面 1工具函数完整代码 function [CData,h,XMesh,YMesh,ZMesh,colorList]=density

  • Matlab绘制中国地图超全教程详解

    目录 各省边界线绘图 省份填色图 中国公路交通图 中国铁路交通图 中国河流图 组合美化图 美化图一 美化图二 依旧需要用到Mapping Toolbox不会安装的可以看我上一篇 虽然我们只读取shp文件,但需要保证文件夹里还有shx文件及dbf文件 各省边界线绘图 provinces=shaperead('bou2_4l.shp','UseGeoCoords',true); % 绘图 worldmap('China'); geoshow(provinces) 省份填色图 provinces=sh

  • 详解Matlab如何绘制桑基图

    目录 详细用法 1使用示例 2输入参数 3输出 函数完整代码 使用示例代码 这次主要是分享自己写的一个函数,用来绘制桑基图,效果大概是下面这样子: 先说明函数(sankey2)怎么用,函数完整代码放在博客最后 详细用法 1 使用示例 新建一个m文件,运行如下代码 List={'a1',1,'A'; 'a2',1,'A'; 'a3',1,'A'; 'a3',0.5,'C'; 'b1',1,'B'; 'b2',1,'B'; 'b3',1,'B'; 'c1',1,'C'; 'c2',1,'C'; 'c

  • 基于Matlab绘制洛伦兹吸引子相图

    目录 1.公式及Lorenz函数 2.混沌吸引子图像 3.混沌吸引子图像 4.封面图绘制 洛伦兹吸引子(Lorenz attractor)是由MIT大学的气象学家Edward Lorenz在1963年给出的,他给出第一个混沌现象——蝴蝶效应........废话不多说. 反正咱就是,好看且有用咱就写代码,第零部分给出公式.第一部分给出 混沌吸引子 图像,第二部分给出庞加莱截面法 分岔图 绘制. 1.公式及Lorenz函数 Lorenz微分方程组定义如下: 非常容易能写出该微分方程组函数: func

  • 基于Matlab绘制超绚丽的烟花的过程详解

    目录 1.使用效果 2.随机点生成 3.图像膨胀 4.特效「风」模拟 5.级坐标变换 6.图像模糊及再映射 7.图像上色 8.完整代码 1.使用效果 2.随机点生成 我们要构造一个黑色背景,对其添加高斯噪声,然后依据阈值删掉部分噪声,生成一张随机点图片: % 构造黑色背景并生成白色杂点 blackPic=uint8(zeros(800,800)); distPic=imnoise(blackPic,'gaussian',0, 0.11); distPic(distPic<254)=0; 3.图像

  • 基于Matlab绘制小提琴图的示例代码

    目录 violinChart 函数使用方法 基础使用,Y为矩阵 基础使用,Y为向量,X为标签 基础使用,多个图像绘制,并添加图例 violinChart 完整函数 ggtheme violin 函数介绍 ggtheme violin 主题 ggtheme violin 修饰函数代码 本文将为大家详细讲解Matlab中小提琴图的绘制函数及ggtheme主题修饰函数 violinChart 函数使用方法 写了个matlab绘制小提琴图的函数: 1.图中小提琴状区域为核密度曲线. 2.白色方块为25%

  • Matlab绘制雨云图的方法详解

    目录 介绍 横向雨云图 纵向雨云图 介绍 写了俩代码模板,用来绘制横向云雨图与纵向云雨图,云雨图其实就是用把小提琴图拆开来的模板,想获取小提琴图绘制函数的可以看这里:基于Matlab绘制小提琴图的示例代码 后面的俩模板用的时候只需要换换数据,颜色及每一类名称即可,雨云图绘制效果如下: 横向雨云图 function rainCloudsTMPL1 % @author: slandarer % 在这里放入你的数据============================================

  • 基于Matlab实现离散系统分岔图的绘制

    目录 1.一维离散分岔图 2.二维离散分岔图 3.封面图绘制 1.一维离散分岔图 一维那非常简单哈,就循环着画呗,以下举两个简单的例子 : % x(n+1)=1-r*x(n)^2 % (r∈(0,2),x∈[-1,1])的分支混沌图. hold on f=@(x,r)1-r.*x.^2; r=0:.01:2; x=0; % x初值 for n=1:1000 x=f(x,r); if n>100 % 稳定后开始绘图 plot(r,x,'k.','MarkerSize',1); drawnow en

  • 基于Matlab实现山脊图的绘制

    目录 纯色山脊图模板 渐变色山脊图模板 写了一个用于绘制山脊图的模板,仅需要往需要填写数据的区域填入数据点击运行即可,以下提供两款模板,第一款为纯色模板而第二款为渐变色模板: 纯色山脊图模板 模板代码: function ridgeMapTMPL1 % @author: slandarer % 在这里放入你的数据======================================================= X1=normrnd(2,2,1,1000); X2=[normrnd(4

  • 基于Matlab实现绘制3D足球的示例代码

    目录 绘制讲解 数据来源及说明 硬算顶点连接情况 三角剖分 正交变换 充气 完整代码 世界杯教你用MATLAB画个超逼真的足球, 需要准备Partial Differential Equation Toolbox工具箱,同时因为用到了polyshape类所以至少需要R2017b版本. 绘制讲解 数据来源及说明 我是真的不想写注释了太麻烦了,给大家讲一下我的思路希望能够看懂,首先足球的数据点是通过: [B,XYZ]=bucky; 导入的,但是导入的只有边链接信息,并没有给出哪几个点构成正五边形哪几

  • 基于Matlab实现有雪花飘落的圣诞树的绘制

    目录 圣诞树及礼物绘制 基础修饰 绘制星星和光晕 绘制彩灯 绘制雪花 动态变化实现 完整代码 圣诞节快到了(虽然还有十天),一起来用MATLAB画个简单圣诞树叭~树的整体构造参考大佬Anselm,同时一部分装饰代码参考了大佬Hanchu Wang. 代码几乎取消了全部的循环,因此至少需要17b之后的版本,仅存的循环用来让树旋转起来,让雪花飘落起来,让树顶上的星光摇曳起来~ 圣诞树及礼物绘制 % 生成树本体曲面 treeFunc=@(h)[h(1),h(h>0&h<=3).*0+1.5,

  • 基于Matlab实现中国象棋的示例代码

    目录 设置变量 绘图 绘制棋盘 绘制棋子 棋子移动规则 判断是否可以移动 移动棋子 吃子 设置变量 nRowNum = 8; % 画布行数 nColNum = 9; % 画布列数 offset_x = 0;% 红车坐标起点 offset_y = 0;% 红车坐标起点 chess_name = {{'帥','仕','相','马','車','炮','兵'},{'將','仕','象','马','車','炮','卒'}}; chess_type = [5 4 3 2 1 2 3 4 5 6 6 7 7

  • 基于Matlab实现数字音频分析处理系统

    目录 一.语音处理简介 1语音信号的特点 2语音信号的采集 3语音信号分析技术 4语音信号的时域分析 5语音信号的频域分析 二.部分源代码 三.运行结果 一.语音处理简介 1 语音信号的特点 通过对大量语音信号的观察和分析发现,语音信号主要有下面两个特点: ①在频域内,语音信号的频谱分量主要集中在300-3400Hz的范围内.利用这个特点,可以用一个防混迭的带通滤波器将此范围内的语音信号频率分量取出,然后按8kHz的采样率对语音信号进行采样,就可以得到离散的语音信号. ②在时域内,语音信号具有“

随机推荐