蕨型叶分形

news2024/11/29 21:18:44

目录

要点

基本语句

 EraseMode

习题

1 设置颜色

2 旋转蕨型叶图

3 枝干

4 塞平斯基三角形


要点


        蕨型叶是通过一个点的反复变换产生的,假设x是一个含有两个分量的向量,可以用来表示平面内的一个点,则可以用Ax+b的形式对其进行变换。


基本语句


 

 语句darkgreen=[0 2/3 0]设置深绿色的颜色变量,在matlab中用红绿蓝分量来表示颜色,这里将绿色分量设置为2/3,其余为0。

采用animatedline来绘制蕨型叶,h为蕨型叶图形的句柄。

function fern_a


    shg
    clf reset
    set(gcf,'color','white','menubar','none', ...
        'numbertitle','off','name','Fractal Fern')
    x = [.5; .5];
    h = animatedline('Marker', '.', 'LineStyle', 'none', 'Color', [0 2/3 0]);
    axis([-3 3 0 10])
    axis off  %不显示坐标轴,只显示叶子本身
    stop = uicontrol('style','toggle','string','stop', ...
        'background','white');
    drawnow %绘制

    p  = [ .85  .92  .99  1.00];
    A1 = [ .85  .04; -.04  .85];  b1 = [0; 1.6];
    A2 = [ .20 -.26;  .23  .22];  b2 = [0; 1.6];
    A3 = [-.15  .28;  .26  .24];  b3 = [0; .44];
    A4 = [  0    0 ;   0   .16];

    cnt = 1; %将计数器的初始值设置为1
    tic
    while ~get(stop,'value')
        r = rand;
        if r < p(1)
            x = A1*x + b1;
        elseif r < p(2)
            x = A2*x + b2;
        elseif r < p(3)
            x = A3*x + b3;
        else
            x = A4*x;
        end
        addpoints(h, x(1), x(2));
        drawnow %重新绘制图形
        cnt = cnt + 1; %生成新的点后计数器的数值自增1
    end
    t = toc; %读取秒表数据
    s = sprintf('%8.0f points in %6.3f seconds',cnt,t);
    text(-1.5,-0.5,s,'fontweight','bold');
    set(stop,'style','pushbutton','string','close','callback','close(gcf)')
end


 EraseMode


EraseMode 属性不再受支持,而且在以后的版本中会出错。

初始语句:

h = plot(x(1),x(2),'.');
darkgreen = [0 2/3 0];
set(h,'markersize',1,'color',darkgreen,'erasemode','none');

修改后:

h = animatedline('Marker', '.', 'LineStyle', 'none', 'Color', [0 2/3 0]);

习题


1 设置颜色

   在MATLAB中,颜色可以使用多种方式来表示,其中一种常用的方式是使用RGB(Red-Green-Blue)表示法。在RGB表示法中,每个颜色的红、绿、蓝三个分量的取值范围为0到1,表示颜色的深浅程度。

  

function fern_a


    shg
    clf reset
    set(gcf,'color','black','menubar','none', ...
        'numbertitle','off','name','Fractal Fern')
    x = [.5; .5];
    h = animatedline('Marker', '.', 'LineStyle', 'none', 'Color', [1 0.75 0.8]);
    axis([-3 3 0 10])
    axis off
    stop = uicontrol('style','toggle','string','stop', ...
        'background','black','ForegroundColor','white');
    drawnow

    p  = [ .85  .92  .99  1.00];
    A1 = [ .85  .04; -.04  .85];  b1 = [0; 1.6];
    A2 = [ .20 -.26;  .23  .22];  b2 = [0; 1.6];
    A3 = [-.15  .28;  .26  .24];  b3 = [0; .44];
    A4 = [  0    0 ;   0   .16];

    cnt = 1;
    tic
    while ~get(stop,'value')
        r = rand;
        if r < p(1)
            x = A1*x + b1;
        elseif r < p(2)
            x = A2*x + b2;
        elseif r < p(3)
            x = A3*x + b3;
        else
            x = A4*x;
        end
        addpoints(h, x(1), x(2));
        drawnow
        cnt = cnt + 1;
    end
    t = toc;
    s = sprintf('%8.0f points in %6.3f seconds',cnt,t);
    text(-1.5,-0.5,s,'fontweight','bold','Color','red');
    set(stop,'style','pushbutton','string','close','callback','close(gcf)')
end


2 旋转蕨型叶图

%修改坐标
addpoints(h, x(2), x(1));

%修改标注位置
s = sprintf('%8.0f points in %6.3f seconds',cnt,t);
text(2.5,-2.9,s,'fontweight','bold','Color','red');


3 枝干

A4 = [0, 0; 0, 0.16];
%修改为
A4 = [0, 0; 0, 0.08];
%这将使得蕨型叶的枝干更加瘦长

蕨型叶的起始点均为(0,0)。


4 塞平斯基三角形

function sierpinski_triangle_a
    shg
    clf reset
    set(gcf, 'color', 'white', 'menubar', 'none', ...
        'numbertitle', 'off', 'name', 'Fractal Sierpinski Triangle')
    x = [.5; sqrt(3)/6];
    h = animatedline('Marker', '.', 'LineStyle', 'none', 'Color', [0 2/3 0]);
    axis([0 1 0 sqrt(3)/2])
    axis off
    stop = uicontrol('style', 'toggle', 'string', 'stop', ...
        'background', 'white');
    hold on
    plot([0, 1, 0.5, 0], [0, 0, sqrt(3)/2, 0], 'k-*'); % 绘制三角形的顶点
    drawnow

    A1 = [0.5, 0; 0, 0.5];  b1 = [0; 0];
    A2 = [0.5, 0; 0, 0.5];  b2 = [0.5; 0];
    A3 = [0.5, 0; 0, 0.5];  b3 = [0.25; sqrt(3)/4];

    cnt = 1;
    tic
    while ~get(stop, 'value')
        r = rand;
        if r <= 1/3
            x = A1 * x + b1;
        elseif r <= 2/3 & r>1/3
            x = A2 * x + b2;
        else
            x = A3 * x + b3;
        end
        addpoints(h, x(1), x(2));
        drawnow
        cnt = cnt + 1;
    end
    t = toc;
    s = sprintf('%8.0f points in %6.3f seconds', cnt, t);
    text(0.25, -0.05, s, 'fontweight', 'bold');
    set(stop, 'style', 'pushbutton', 'string', 'close', 'callback', 'close(gcf)')
end

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/792766.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

衡器关于检定分度值e和实际分度值d的一点认识

在看衡器认证的文档时有两个概念很容易混淆d(actual scale interval)和e(verification scale interval)&#xff0c;国内文档上翻译为实际分度值和检定分度值。 实际分度值(d)就是称能显示的最小刻度或最小能显示的值跨度&#xff0c;可以理解为可读精度&#xff0c;例如电子秤…

[虚幻引擎] UE里面监控每帧循环里面 C++ 函数的性能, 函数耗时,函数效率,函数执行时间

在使用C开发UE引擎&#xff0c;有时候需要监控函数的执行的执行效率&#xff0c;这个时候有两种方式可以使用。 1. 执行代码耗时时间 double ThisTime 0;{SCOPE_SECONDS_COUNTER(ThisTime);// ...// 一串代码// ...}UE_LOG(LogTemp, Log, TEXT("Stats::Broadcast %.2f&qu…

【Spring Boot】Web开发 — 数据验证

Web开发 — 数据验证 对于应用系统而言&#xff0c;任何客户端传入的数据都不是绝对安全有效的&#xff0c;这就要求我们在服务端接收到数据时也对数据的有效性进行验证&#xff0c;以确保传入的数据安全正确。接下来介绍Spring Boot是如何实现数据验证的。 1.Hibernate Vali…

mysql(三)用户权限管理

目录 前言 一、概述 二、用户权限类型 三、用户赋权 四、权限删除 五、删除用户 前言 为什么要设置用户权限&#xff1f; MySQL设置用户管理权限的主要目的是为了确保数据库的安全性和数据的机密性。以下是一些原因&#xff1a; 1. 安全性&#xff1a;MySQL是一个开源的关系型…

多线程案例 | 单例模式、阻塞队列、定时器、线程池

多线程案例 1、案例一&#xff1a;线程安全的单例模式 单例模式 单例模式是设计模式的一种 什么是设计模式&#xff1f; 设计模式好比象棋中的 “棋谱”&#xff0c;红方当头炮&#xff0c;黑方马来跳&#xff0c;针对红方的一些走法&#xff0c;黑方应招的时候有一些固定的…

【C++初阶】:模板进阶

模板进阶 一.非类型模板参数二.模板的特化1.概念2.函数模板特化3.类的特化1.全特化2.偏特化 三.模板的分离编译 一.非类型模板参数 模板参数分类类型形参与非类型形参。 类型形参即&#xff1a;出现在模板参数列表中&#xff0c;跟在class或者typename之类的参数类型名称。 非类…

Play 资产分发(Play Asset Delivery)

一、前言 Google Play发布应用&#xff0c;只支持上传aab格式文件。在之前&#xff0c;Google Play对上传apk文件限制大小不超过150MB&#xff0c;对于新的aab格式文件&#xff0c;也要求生成的目标apk不超过150MB&#xff08;GooglePlay后台使用bundletool生成apk文件&#xf…

虚拟机网络桥接,详细操作步骤,本地连接虚拟机

虚拟机网络桥接 文章目录 虚拟机网络桥接一&#xff0c;首先查看主机连接网络的网关二、打开虚拟机的worksation服务三、修改主机的VMnet8的IPV4属性四、修改虚拟机的workstation的虚拟网络五、修改VMnet8的IP,网关六、把虚拟机设置为桥接模式七、修改虚拟机的静态ip和对应的网…

JAVA面试总结-Redis篇章(三)——缓存雪崩

JAVA面试总结-Redis篇章&#xff08;三&#xff09;——缓存雪崩

测试开发之系统篇 - 常用系统命令

目录 前言&#xff1a; 查看占用端口的进程 Linux Windows 杀死进程 Linux Windows 按名称查看进程 命令行管道 后台运行服务 修改文件 Linux Mac 复制目录到远程 实时查看文件内容 查看正在运行的服务 查看服务状态 重启服务 查看内存状况 查看磁盘状况 …

基于MAXENT模型的生物多样性生境模拟与保护优先区甄选、自然保护区布局优化及未来气候变化下评估及论文写作教程

详情点击链接&#xff1a;基于MAXENT模型的生物多样性生境模拟与保护优先区甄选、自然保护区布局优化及未来气候变化下评估中的应用及论文写作 一&#xff1a;生物多样性保护格局与自然保护区格局优化 1.我国生物多样性格局与分布&#xff1b; 2.我国自然保护区格局与分布&…

前端年度工作述职报告优秀

前端年度工作述职报告优秀篇1 尊敬的各位领导、各位同仁&#xff1a; 大家好!按照20__年度我公司就职人员工作评估的安排和要求&#xff0c;我认真剖析、总结了自己的工作情况&#xff0c;现将本人工作开展情况向各位领导、同仁做以汇报&#xff0c;有不妥之处&#xff0c;希…

注册外部的AudioPolicy,监听焦点变化

开始 AudioFocus分发流程 在上面分发流程分析中&#xff0c;最终是在MediaFocusControl中进行处理的&#xff0c;在requestAudioFocus​方法中可以看到在执行焦点栈逻辑时会先执行AudioPolicy相关逻辑&#xff0c; 因此我们试一试可不可以利用这一点&#xff0c;来注册外部的…

用于开漏模式和推拉模式的 4bit 双向电平转换器MS4554N/MS4554N1

MS4554N/MS4554N1 是一款双向电平转换器&#xff0c;可以应用在 混合电压的数字信号系统。其使用两个独立构架的电源供电&#xff0c; A 端供电电压范围是 1.65V 到 5.5V &#xff0c; B 端供电电压范围是 2.3V 到 5.5V 。可用在电源电压为 1.8V 、 2.5V 、 3.3V 和…

FPGA学习——按键消抖的两种实现方法

文章目录 一、按键消抖简介1.1、为什么要按键消抖 二、C4开发板原理图三、按键消抖源码3.1、方案一&#xff08;每当检测到下降沿便开始重新计数&#xff09;3.2、方案二&#xff08;检测到第一次下降沿后便开始计数&#xff09; 四、仿真代码及仿真波形图五、拓展&#xff1a;…

【金万维】使用天联高级版登录用友U8,文件输出操作。

【操作步骤】 1、通过天高客户端登录U8后&#xff0c;打开对应的报表或者列表&#xff08;以余额表为例&#xff09;。 2、点击“输出”按钮后&#xff0c;弹出“另存为”窗口&#xff0c; 注意&#xff1a;当前“保存在&#xff1a;桌面”这个路径为服务器的桌面&#xff0c;…

matlab 读取fig中的数据

1.使用命令打开fig open(文件名.fig) 2.查看图像包含的数据和属性 Location是原始的&#xff0c;Normal 可能是调整了顺序后的。

echarts制作多个纵轴的折线图

代码 <script type"text/javascript"> $(function (){var myChart echarts.init(document.getElementById(main));option {color: ["#9bbb59","#0B438B","#4141F1","#F81945","#4bacc6","#F89E19&q…

怎么把知识问答做成二维码?分享简单的二维码制作工具

现在无论是工厂的职工还是学校的学生&#xff0c;都会有各种各样的知识问答。传统的纸质知识问答&#xff0c;不仅浪费人力物力&#xff0c;还需要占用上班或是上学的时间来完成。为了方便大家使用&#xff0c;我们可以把知识问答做成二维码图片&#xff0c;随时随地手机扫一扫…

【代码随想录day20】二叉搜索树中的搜索

题目 给定二叉搜索树&#xff08;BST&#xff09;的根节点 root 和一个整数值 val。 你需要在 BST 中找到节点值等于 val 的节点。 返回以该节点为根的子树。 如果节点不存在&#xff0c;则返回 null 。 示例 1: 思路 因为这里是二叉排序树&#xff0c;所以不用爆搜所有节点…