高大上的分形几何

分形几何是一种迭代的几何图形,广泛存在于自然界中(树叶,菜花)(这个东西的整体与他的局部具有很相似的特点)

分形几何中有一种特殊的曲线叫做科赫曲线,也叫雪花曲线

科赫曲线是一种用于分形的曲线。

用python绘制科赫曲线

取一条直线 ,去这条直线的1/3处画一个三角形的角,与右边的1/3处进行连接,这样子四条1/3直线即组成一次科赫曲线的转换

一条直线即为0阶科赫曲线

四条一条直线的1/3曲线即为1阶科赫曲线

在四条一条直线的1/3曲线上再在每条1/3曲线上画四条该1/3曲线的1/3曲线即为2阶科赫曲线

每分隔一次为一阶。依此类推,即为科赫曲线。

代码示例如下:

import turtle
def koch(m,n):if n==0:turtle.fd(m)else:for angle in [0,60,-120,60]:turtle.left(angle)koch(m/3,n-1)
def main():m= int(input("请输入直线的长度:"))n=int(input("请输入曲线的阶数:"))turtle.setup(800,400)turtle.pencolor("red")turtle.penup()turtle.goto(-300,-50)turtle.pendown()turtle.pensize(2)koch(m,n)turtle.done()
main()

运行界面如下:

通过代码界面,我们来进行分析一下思路,解析如下:

我们进行科赫曲线的绘制,我们采用了递归的方法进行实现,递归的格式为函数+分支结构,还有递归基例与递归链条的存在。首先我们进行寻找递归基例,因为当我们选择0阶的时候,所画的为一条直线,所以基例为0,进行画一条直线,下来我们进行递归链条的设置,当阶数为2时,我们将这条直线分为三段,在中间绘制一个凸起的三角形与另外两端相连。我们继续进行判断,如果仍不符合条件,我们再将每条直线分为三段,在每条直线的中间绘制一个凸起的三角形与另外两端相连。依次类推,与前一个形成递归关系。即可形成科赫曲线。

科赫雪花:

在科赫曲线的基础之上,我们可以绘制科赫雪花

示例代码如下:

import turtle
def koch(size,n):if n==0:turtle.fd(size)else:for angle in [0,60,-120,60]:turtle.left(angle)koch(size/3,n-1)
def main():size= int(input("请输入雪花直线的长度:"))level=int(input("请输入雪花的阶数:"))turtle.setup(600,600)turtle.pencolor("red")turtle.penup()turtle.goto(-200,100)turtle.pendown()turtle.pensize(2)koch(size, level)turtle.right(120)koch(size, level)turtle.right(120)koch(size, level)turtle.done()
main()

运行界面如下:

通过代码界面,我们来进行分析一下思路,解析如下:

我们进行科赫雪花的绘制,即在科赫曲线的基础之上进行科赫雪花的绘制,我们采用了递归的方法进行实现,递归的格式为函数+分支结构,还有递归基例与递归链条的存在。首先我们进行寻找递归基例,因为当我们选择0阶的时候,所画的为一条直线,所以基例为0,进行画一条直线,下来我们进行递归链条的设置,当阶数为2时,我们将这条直线分为三段,在中间绘制一个凸起的三角形与另外两端相连。我们继续进行判断,如果仍不符合条件,我们再将每条直线分为三段,在中间绘制一个凸起的三角形与另外两端相连。依次类推,与前一个形成递归关系。

在进行雪花绘制的时候,我们将雪花初始图形看作等边三角形,根据他们的阶数,先选择一条直线进行绘制,绘制完成后,此时角度为向右正方向,此时画向另一条边,由于三角形为60度,我们右转达到第二条边,画完之后,我们继续右转120度,画第三条边,完成之后。即可出现科赫雪花形状。

举一反三:绘制条件的扩展时

修改分形几何绘制阶数

修改科赫曲线的基本定义即旋转角度

修改绘制科赫雪花的基础框架图形(五边形,八边形,使用不同的图形)

分形几何千千万

摩托尔集、谢尔宾斯基三角形、门格海绵

龙形曲线、空间填充曲线、科赫曲线

科赫雪花小包裹实例详解相关推荐

  1. python中pyinstaller库的使用(第三方库) 实例8:科赫雪花小包裹

    模块一:turtle库 模块二:time库 模块三:random库 模块四:pyinstaller库(第三方库) 我们希望用可执行文件的方式来执行一段代码 而不是直接用源代码 将.py源代码转换成无需 ...

  2. python绘制n阶科赫曲线线段_034 实例8-科赫雪花小包裹

    [TOC] 一."科赫雪花小包裹"问题分析 1.1 科赫雪花 高大上的分形几何 分形几何是一种迭代的几何图形,广泛存在于自然界中 科赫曲线,也叫雪花曲线 1.2 用Python绘制 ...

  3. SVG实例详解系列(一)(svg概述、位图和矢量图区别(图解)、SVG应用实例)

    SVG实例详解系列(一) (svg概述.位图和矢量图区别(图解).SVG应用实例) 目录 一.什么是SVG? (1).位图和矢量图概念(图解) (2).SVG的小例子 (a)笑脸符 (b).小鸟 (c ...

  4. scratch教程----4.科赫雪花新积木的运用

    Hi!又是一期scratch教程出炉啦! 这期我们来讲scratch中的递归(以下给出目录,老手可以跳过) 目录 1.初学: 2.进阶: 学过别的编程语言中的递归的小伙伴可以在目录跳过咯: 1.初学: ...

  5. Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(三)

    Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(三) 本篇目录: 六.完整构建整个[旋转的精灵女孩]实例 (1).新建.启动webGL工程空间 (2).构建项目的目录层次结构 (2. ...

  6. Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(二)

    Three.js实例详解___旋转的精灵女孩(附完整代码和资源)(二) 本篇目录: 五.实例中所使用的代码语法详细解释 (1).构建一个三维空间场景 (2).选择一个透视投影相机作为观察点 (a).创 ...

  7. 《 Python List 列表全实例详解系列(九)》__列表反转(6种方法)

    < Python List 列表全实例详解系列(九)> __列表反转(6种方法) 本章目录: 十一.列表反转的6种方法 (11.1).通过列表的切片操作实现列表反转 (11.2).使用列表 ...

  8. python用科赫迭代正方形_基于python绘制科赫雪花

    什么是科赫曲线 科赫曲线是de Rham曲线的特例.给定线段AB,科赫曲线可以由以下步骤生成: 将线段分成三等份(AC,CD,DB) 以CD为底,向外(内外随意)画一个等边三角形DMC 将线段CD移去 ...

  9. Element Plus 实例详解(三)___Date Picker 日期选择

    Element Plus 实例详解(三) ___Date Picker 日期选择 文章目录: 一.前言 二.搭建Element Plus试用环境 1.搭建Vue3项目(基于Vite + Vue) 2. ...

  10. Element Plus 实例详解(一)___安装设置

    Element Plus 实例详解(一) ___安装设置 本篇目录: 一.前言 二.安装方法 1.环境支持 2.Element Plus安装使用方式 (1).使用包管理器 (2).浏览器直接引入 3. ...

最新文章

  1. python中子类调用父类的初始化方法
  2. 前端学习(3035):vue+element今日头条管理-关于问题的一个解析
  3. 最小生成树唯一吗_最小生成树 - 齐芒
  4. 字节跳动的一面内容记录
  5. python 编程服务_Python编写Windows Service服务程序
  6. PHP:header()函数
  7. 线阵相机工作模式解读
  8. 项目启动报错ignoring option MaxPermSize=256M;support was removed in 8.0
  9. 表白代码大全,快来向你的ta表白吧~~~
  10. Cesium gltf(1.70)三维人物动画制作
  11. informatica学习1-数据仓库,ETL,数据仓库工具Informatica介绍
  12. rs232接口_各类PLC都支持RS232和485通讯,原理和方法普及一下
  13. 通过Java 画一个太极图
  14. U盘插入电脑提示未能成功安装设备驱动程序,这个要怎么处理呢
  15. 你的网名OUT了吗?盘点那些曾经超in的网名
  16. NOIP初赛知识点总结
  17. ios html fixed,ios下position:fixed失效的问题解决
  18. 403高校毕业设计选题
  19. PyMol2.4安装教程
  20. H5移动端出生日期插件

热门文章

  1. oracle学习札记94
  2. WIN10下速腾聚创RS-Ruby lite80线激光雷达ip地址和端口号port修改
  3. Linux调用Windows指纹识别,生物识别--指纹识别用于web登录
  4. google“退出”中国?
  5. Android音视频【五】H265/HEVC码流结构
  6. python凹多边形分割_Unity 凹多边形三角剖分
  7. 软件生成问候图片_设计师注意啦!欧美风双色图片一键生成的软件来啦!
  8. gitlab使用教程
  9. Vue安装教程(保姆级详细教程)
  10. 关于“Pycharm复制到word文档出现乱码”问题——解决方法