关于斐波那契螺旋线和平方和的讲解

2023-10-10 01:59

本文主要是介绍关于斐波那契螺旋线和平方和的讲解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

黄金螺线是对数螺线的一种。在极坐标中,对数螺线的方程是:ρ=αe^(φk),其中:α和k为常数,φ是极角,ρ是极径,e是自然对数的底。

黄金螺线是对数螺线的一种。其中:α和k为常数,φ是极角,ρ是极径,e是自然对数的底。则螺线中同一半径线上相邻极半径之比都有黄金分割关系。这样形成的螺线就是黄金螺线,她有很多优美的特点。同时说明黄金比例律为以e为自然底数的“自然律”逻辑所蕴含。换言之,“自然律”囊括了黄金比例律。黄金比例律表现了事物的相对静止状态,而“自然律”则表现了事物运动发展的普遍状态。因此,从某种意义上说,黄金比例律是凝固的“自然律”,“自然比例律”是运动着的黄金律。在黄金矩形(宽长之比为0.618的矩形)里靠着三边做成一个正方形,剩下的那部分则又是一个黄金矩形,可以依次再做成正方形。将这些正方形中心都按顺序联结,可得到一条“黄金螺线”。 

黄金螺线

一直有一种谣传说在鹦鹉螺的身上和一些动物角质体上,或有甲壳的软体动物身上,都曾发现有“黄金螺线”。

但各种动物的甲壳形成方式千差万别,故这种说法并不准确。

黄金螺线的每一点的曲率的变化率是相等的,因为黄金螺线由n个半径大小成黄金比例关系的1/4圆构成。但也因此,曲率在每个1/4圆的交接的地方是不连续的,既整个黄金螺线的曲率并不连续。对于一个无时无刻不在生长的甲壳来说,这显然是不可能的。

所以说,鹦鹉螺身上的螺线一定是一种天然螺线,但绝不可能是黄金螺线。

 

 

 IDLE的代码:

import turtle as t#导入turtle库
t.speed(0)#笔的速度:0
t.pensize(3)#笔的粗细:3
t.pencolor('blue')#笔的颜色:蓝色
def fibarc(n):#定义函数,叫fibarc(斐波那契)a,b=1,1#a=1,b=1,斐波那契数列的前两项for i in range(n):#range循环n遍a,b=b,a+b#赋值,把a的值赋值给b,把b的值赋值给a+bt.circle(a,90)#画弧线,半径a,度数90
fibarc(13)#调用
#t.exitonclick()#关闭

 

IDLE斐波那契数列平方和的代码:(图片随机颜色,仅供参考)

# 使用turtle绘制彩色Fibonacci螺旋   平方和
import turtle#导入turtle(海龟)库
import random#导入random(随机)库
def draw_fibonacci(x):#定义draw_fibonacci(画斐波那契)函数,值是x# F0=1# F1=1# Fn=F(n-1)+F(n-2) # 产生斐波那契数列,用于查表# 像这种计算复杂性指数增长的计算,不要写个函数去每次求一个数# 最好的办法是,按照规律写出查找表,用查找的方法来得到数据f_list = []#创建一个空列表,叫f_listfor i in range(x):#range函数,运行x遍if i == 0:#判断i如果=0f_list.append(1)#f_list追加1elif i == 1:#i如果=1f_list.append(1)#f_list追加1else:#其他情况f_list.append(f_list[i-1]+f_list[i-2])#f_list追加自己的前一项和前第二项# 像素比例f0 = 50# 设置画笔属性turtle.pensize(5)#笔的粗细:5turtle.color("black")#笔的颜色:黑色turtle.penup()#抬笔turtle.home()#画笔回到原点turtle.pendown()#落笔(可删)for i in range(0, len(f_list)):#range函数从0到f_list列表的长度# 绘制速度,1~10个不同速度等级,小于1或者大于10立即绘制turtle.speed(1)#笔的速度:1turtle.pendown()#落笔(不可删)# 绘制矩形if i == 0:#判断i=0fill_color = "black"#第一个矩形的填充颜色:黑色else:#其他情况fill_color = (random.random(), random.random(), random.random())#矩形随机颜色(rgb->red,green,blue->红色,绿色,蓝色)print(fill_color)#打印矩形随机颜色turtle.fillcolor(fill_color)#填充刚刚的随机颜色turtle.begin_fill()#开始填充矩形颜色for j in range(4):#range函数循环四遍turtle.forward(f_list[i]*f0)#画笔画f_list列表的i值*F0(F0=1)turtle.left(90)#画笔转90度"""turtle.forward(f_list[i]*f0)turtle.left(90)turtle.forward(f_list[i]*f0)turtle.left(90)turtle.forward(f_list[i]*f0)turtle.left(90)"""turtle.end_fill()#结束填充矩形颜色# 绘制圆弧fill_color = (random.random(), random.random(), random.random())#圆弧随机颜色(rgb->red,green,blue->红色,绿色,蓝色)#fill_color = (random.randint(0,255), random.randint(0,255), random.randint(0,255))print(fill_color)#打印圆弧的随机颜色turtle.fillcolor(fill_color)#填充刚刚的随机颜色if i == 0:#判断i=0turtle.forward(f_list[i] * f0 / 2)#画笔移动f_list列表的i值*FO(F0=1)/2turtle.begin_fill()#开始填充圆弧颜色turtle.circle(f_list[i] * f0 / 2, 360)#第一个矩形中的圆 turtle.circle(f_list[i] * f0 / 2, 360)turtle.end_fill()#结束填充圆弧颜色# 移动到一下起点turtle.forward(f_list[i] * f0 / 2)#画笔移动f_list列表的i值*FO(F0=1)/2continue#继续执行else:#其他情况turtle.begin_fill()#开始填充圆弧颜色turtle.circle(f_list[i] * f0, 90)#画笔画圈f_list列表的i值*FO(F0=1),半径90turtle.left(90)#画笔左转90度turtle.forward(f_list[i] * f0)#画笔移动f_list列表的i值*FO(F0=1)turtle.left(90)#画笔左转90度turtle.forward(f_list[i] * f0)#画笔移动f_list列表的i值*FO(F0=1)turtle.end_fill()#结束填充圆弧颜色# 移动到一下起点turtle.speed(0)#笔的速度turtle.penup()#抬笔turtle.left(90)#画笔左转90度turtle.forward(f_list[i] * f0)#画笔移动f_list列表的i值*FO(F0=1)turtle.left(90)#画笔左转90度turtle.forward(f_list[i] * f0)#画笔移动f_list列表的i值*FO(F0=1)turtle.done()#画笔完成#if __name__ == "__main__":
draw_fibonacci(6)#调用draw_fibonacci函数

 

这篇关于关于斐波那契螺旋线和平方和的讲解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/177132

相关文章

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

ispunct函数讲解 <ctype.h>头文件函数

目录 1.头文件函数 2.ispunct函数使用  小心!VS2022不可直接接触,否则..!没有这个必要,方源一把抓住VS2022,顷刻 炼化! 1.头文件函数 以上函数都需要包括头文件<ctype.h> ,其中包括 ispunct 函数 #include<ctype.h> 2.ispunct函数使用 简述: ispunct函数一种判断字符是否为标点符号的函

深度学习速通系列:深度学习算法讲解

深度学习算法是一系列基于人工神经网络的算法,它们通过模拟人脑处理信息的方式来学习和解决复杂问题。这些算法在图像识别、语音识别、自然语言处理、游戏等领域取得了显著的成就。以下是一些流行的深度学习算法及其基本原理: 1. 前馈神经网络(Feedforward Neural Networks, FNN) 原理:FNN 是最基本的神经网络结构,它由输入层、隐藏层和输出层组成。信息从输入层流向隐藏层,最

C#设计模式(1)——单例模式(讲解非常清楚)

一、引言 最近在学设计模式的一些内容,主要的参考书籍是《Head First 设计模式》,同时在学习过程中也查看了很多博客园中关于设计模式的一些文章的,在这里记录下我的一些学习笔记,一是为了帮助我更深入地理解设计模式,二同时可以给一些初学设计模式的朋友一些参考。首先我介绍的是设计模式中比较简单的一个模式——单例模式(因为这里只牵涉到一个类) 二、单例模式的介绍 说到单例模式,大家第一

[项目][CMP][直接向堆申请页为单位的大块内存]详细讲解

目录 1.系统调用 1.系统调用 Windows和Linux下如何直接向堆申请页为单位的大块内存: VirtualAllocbrk和mmap // 直接去堆上按页申请空间static inline void *SystemAlloc(size_t kpage){#ifdef _WIN32void *ptr = VirtualAlloc(0, kpage << 13,

高斯平面直角坐标讲解,以及地理坐标转换高斯平面直角坐标

高斯平面直角坐标系(Gauss-Krüger 坐标系)是基于 高斯-克吕格投影 的一种常见的平面坐标系统,主要用于地理信息系统 (GIS)、测绘和工程等领域。该坐标系将地球表面的经纬度(地理坐标)通过一种投影方式转换为平面直角坐标,以便在二维平面中进行距离、面积和角度的计算。 一 投影原理 高斯平面直角坐标系使用的是 高斯-克吕格投影(Gauss-Krüger Projection),这是 横

车险该怎么买?行业人讲解车险

很多车主对汽车保险知识不了解,稀里糊涂的买了车辆保险,但是出险时发现很多不赔的,还有很多对自己来说没什么用的保险,花了不少钱,还没买到自己想要的,殊不知只要多了解点汽车保险知识就能轻松省下一大笔钱并且买到自己真正想要的,何乐而不为呢! 因为卖保险的或者4S店,都是按照常规情况给你推荐保险,具体用车情况,只有你自己最清楚,所以保险是个个性化定制的产品,需要什么买什么,不需要的就没必要购买了。 一般

VB和51单片机串口通信讲解(只针对VB部分)

标记:该篇文章全部搬自如下网址:http://www.crystalradio.cn/thread-321839-1-1.html,谢谢啦            里面关于中文接收的部分,大家可以好好学习下,题主也在研究中................... Commport;设置或返回串口号。 SettingS:以字符串的形式设置或返回串口通信参数。 Portopen:设置或返回串口

Spring点滴五:Spring中的后置处理器BeanPostProcessor讲解

https://www.cnblogs.com/sishang/p/6576665.html BeanPostProcessor接口作用:      如果我们想在Spring容器中完成bean实例化、配置以及其他初始化方法前后要添加一些自己逻辑处理。我们需要定义一个或多个BeanPostProcessor接口实现类,然后注册到Spring IoC容器中。   package com.t

Java异常体系----深入讲解

JAVA异常体系 1.error 错误 程序无法处理的异常, 它是由JVM产生和抛出的,比如OutOfMemoryError.ThreadDeath等 示例: public class Test {public static void main(String[] args) {run();}public static void run(){run();}} 堆栈溢出,这是由于JV