首页 > 编程语言 >Python绘制完整正弦余弦函数曲线

Python绘制完整正弦余弦函数曲线

时间:2024-11-09 15:15:40浏览次数:3  
标签:scale goto start Python 正弦 value 余弦 int math

1,将正弦函数,余弦函数及坐标轴绘制在同一个界面方便对比观察,不同函数的曲线变化

import turtle  # 导入turtle图形库,用于绘图
import math    # 导入math库,用于数学计算,如三角函数

# 设置绘图窗口
screen = turtle.Screen()
screen.title('正弦余弦函数曲线')  # 设置窗口标题
screen.bgcolor('#AFEEEE')  # 设置窗口背景颜色为浅天蓝色

# 创建一个turtle对象,用于绘图
p = turtle.Turtle()
p.pencolor('red')  # 设置画笔颜色为红色

# 定义绘制函数曲线的参数
x_start = -2*math.pi  # x轴起始点,-2π
x_end = 2*math.pi     # x轴结束点,2π
step = 0.01           # x轴上的步长
scale = 100           # 缩放比例,用于将x,y值转换为屏幕上的像素位置

# 绘制余弦函数曲线
p.penup()  # 提起画笔,移动时不绘制
# 移动到余弦函数在x_start处的起始点
p.goto(int(x_start*scale), math.cos(x_start)*scale)
p.pendown()  # 放下画笔,开始绘制

# 使用for循环绘制余弦曲线
for i in range(int(x_start*scale), int(x_end*scale)+1, int(step*scale)):
    value_x = i / scale  # 将屏幕上的x坐标转换为实际的x值
    value_y = math.cos(value_x)*scale  # 计算对应的y值
    p.goto(value_x*scale, value_y)  # 移动到下一个点

# 绘制余弦函数的负值曲线
p.penup()
p.goto(int(x_start*scale), -math.cos(x_start)*scale)  # 移动到起始点
p.pendown()

for i in range(int(x_start*scale), int(x_end*scale)+1, int(step*scale)):
    value_x = i / scale
    value_y = -math.cos(value_x)*scale
    p.goto(value_x*scale, value_y)
p.penup()

# 绘制正弦函数曲线,设置画笔颜色为紫色
p.pencolor('#FF00FF')
p.goto(int(x_start*scale), math.sin(x_start)*scale)  # 移动到起始点
p.pendown()

for i in range(int(x_start*scale), int(x_end*scale)+1, int(step*scale)):
    value_x = i / scale
    value_y = math.sin(value_x)*scale
    p.goto(value_x*scale, value_y)
p.penup()

# 绘制正弦函数的负值曲线
p.goto(int(x_start*scale), -math.sin(x_start)*scale)
p.pendown()

for i in range(int(x_start*scale), int(x_end*scale)+1, int(step*scale)):
    value_x = i / scale
    value_y = -math.sin(value_x)*scale
    p.goto(value_x*scale, value_y)
p.penup()

# 绘制坐标轴
p.pencolor('blue')  # x轴为蓝色
p.goto(int(x_start*scale)-50, 0)  # 移动到x轴起始点
p.pendown()

for i in range(int(x_start*scale)-50, int(x_end*scale)+50, int(step*scale)):
    value_x = i
    p.goto(value_x, 0)  # 绘制x轴
p.penup()

p.pencolor('yellow')  # y轴为黄色
p.goto(0, int(x_start*scale)/2-25)  # 移动到y轴起始点,注意这里y轴的缩放比例做了调整以适应屏幕
p.pendown()

for i in range(int(x_start*scale)-50, int(x_end*scale)+50, int(step*scale)):
    value_y = i/2  # 注意这里y轴的缩放比例做了调整以适应屏幕
    p.goto(0, value_y)  # 绘制y轴
p.penup()

# 隐藏turtle图标,完成绘图
p.hideturtle()
turtle.done()

标签:scale,goto,start,Python,正弦,value,余弦,int,math
From: https://blog.csdn.net/2202_75561400/article/details/143562666

相关文章

  • 基于YOLO11/v10/v8/v5深度学习的煤矿传送带异物检测系统设计与实现【python源码+Pyqt5
    《------往期经典推荐------》一、AI应用软件开发实战专栏【链接】项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.......
  • 零基础快速掌握python【函数】相关内容及【操作练习】(内附代码)
    1.函数1.1函数的定义函数的定义:实现【特定功能】的代码块。函数的作用:简化代码提高代码重用性便于维护和修改提高代码的可扩展性函数的三要素:功能  len()  max()   sum()参数  s.clear()   s.append('hello')返回值 s.sort()   s1=sor......
  • Python代码文件不只是“.py”
       今天同事给我扔了一个.pyd文件,说让我跑个数据。然后我就傻了。。不知道多少粉丝小伙伴会run.pyd代码文件?如果你也懵懵的,请继续往下读吧。。今天科普下各类Python代码文件的后缀,给各位Python开发“扫扫盲”。.py最常见的Python代码文件后缀名,官方称Python源代码文......
  • Python基础(九):字典
    目录1、字典基础2、键与值的特性3、创建空字典4、访问字典中的值5、修改字典6、删除字典元素7、字典内置函数&方法    在Python的世界里,字典是一种强大的数据结构,它允许我们以键值对的形式存储和检索数据。这种结构不仅灵活,而且功能强大,是处理复杂数据时不可......
  • Python内置函数1详解案例
    1.列表的最值运算描述牛牛给了牛妹一个一串无规则的数字,牛妹将其转换成列表后,使用max和min函数快速的找到了这些数字的最值,你能用Python代码实现一下吗?输入描述:输入一行多个整数,数字之间以空格间隔。输出描述:输出这些数字的zuizhi示例1输入:35691062输出:10......
  • Python和Terraform和状态管理
    让我为您详细介绍如何基于Python和Terraform实现云端自动部署,包括最佳实践、状态管理以及如何使用Python管理Terraform的状态。目录整体架构概述项目结构Terraform状态管理使用Python管理Terraform最佳实践示例代码1.项目结构2.Terraform配置3.Python脚......
  • 基于Python+django的爬虫的李宁品牌销售数据分析系统设计与实现(源码+文档+部署讲解等
    课题简介基于Python+django的爬虫的李宁品牌销售数据分析系统是企业了解市场表现、优化销售策略的有力工具。系统的爬虫部分能够从多个电商平台、官方销售网站等渠道收集李宁品牌产品的销售数据,包括商品名称、型号、价格、销量、销售时间、购买者地区等信息。利用Py......
  • 基于Python+Django的旅游景点数据分析与推荐系统的设计与实(源码+文档+部署讲解等)
    课题简介基于Python+Django的旅游景点数据分析与推荐系统,为游客提供了智能化的旅游决策支持。系统从多个数据源收集旅游景点数据,包括景点名称、位置、类型(如自然景观、历史古迹)、门票价格、开放时间、游客评价等。利用Python的数据分析库,对这些数据进行清洗和整理,......
  • 基于python+django的粮食行业媒体舆情分析系统(源码+文档+部署讲解等)
    课题简介基于python+django的粮食行业媒体舆情分析系统,是全面洞察粮食行业舆论动态的关键平台。系统利用网络爬虫技术,从各大新闻网站、社交媒体、行业论坛等多种媒体渠道收集与粮食行业相关的文本信息,包括粮食价格波动、政策调整、生产技术创新、市场供需变化等内容......
  • 运用python关于无界面版猜数游戏的设计与实现
    importrandom      这行代码导入了Python的 random 模块defguess_number_game():        number_to_guess=random.randint(1,100)  randint是random模块中的一个函数,用于生成                    ......