manim边做边学--参数化曲线
在数学可视化领域,参数方程提供了一种灵活描述曲线的方式。
Manim
库中的ParametricFunction
类正是为此而生,它允许用户通过参数方程创建各种复杂的二维和三维曲线。
ParametricFunction
的核心作用是将数学参数方程转换为可视化的曲线。与普通函数不同,参数方程使用独立参数t
表示曲线上点的坐标:
x = f(t)
y = g(t)
z = h(t)
其典型应用场景包括:
- 绘制无法用$ y=f(x) $显式表示的曲线(如圆、椭圆)
- 创建随时间变化的动态轨迹
- 可视化三维空间曲线(如螺旋线)
- 实现复杂的几何图案(如心形线、星形线)
本文将详细介绍ParametricFunction
的作用、主要参数和方法,并通过动画示例来展示其强大的功能。
1. 主要参数
ParametricFunction
主要参数有:
参数 | 类型 | 说明 | 默认值 |
---|---|---|---|
function |
Callable | 参数方程函数,接收t返回[x,y,z] | 必填 |
t_range |
Sequence[float] | 参数范围[start, end, step] | [0,1,0.1] |
dt |
float | 计算导数的微小增量 | 0.01 |
use_smoothing |
bool | 是否使用平滑算法 | True |
discontinuities |
list[float] | 函数不连续点列表 | None |
color |
颜色常量 | 曲线颜色 | WHITE |
stroke_width |
float | 线宽 | 2.0 |
其中function
参数是一个可调用的函数,形式为(lambda t: (x(t), y(t), z(t)))
。
它定义了曲线的参数化形式,t
是参数,x(t)
、y(t)
和z(t)
分别是x
、y
和z
坐标随参数t
的变化函数。
2. 主要方法
ParametricFunction
主要方法包括:
名称 | 说明 |
---|---|
get_point_from_function | 获取参数t对应的曲线点坐标 |
get_function | 返回参数方程函数 |
get_t_range | 返回参数范围 |
3. 使用示例
下面通过几个典型的例子来演示如何使用ParametricFunction
类。
3.1. 三维螺旋线
这个示例通过引入z轴参数,我们创建了一个优美的三维螺旋结构,展示ParametricFunction
处理3D曲线的能力。
self.set_camera_orientation(phi=80 * DEGREES, theta=-60 * DEGREES)
curve = ParametricFunction(
lambda u: (1.2 * np.cos(u), 1.2 * np.sin(u), u * 0.05),
color=RED,
t_range=(-3 * TAU, 5 * TAU, 0.01),
).set_shade_in_3d(True)
axes = ThreeDAxes(x_length=6, y_length=5, z_length=4)
self.add(axes, curve)
self.play(Create(curve))
3.2. 处理不连续函数
这个示例展示了如何处理不连续函数。
通过指定discontinuities
参数,可以正确地绘制不连续函数的图形,这对于展示数学函数的不连续点非常有用。
# 定义不连续函数
def discontinuous_func(t):
if t in [-2, 2]:
return (t, 0, 0) # 在不连续点返回一个默认值
return (t, (t**2 - 2) / (t**2 - 4), 0)
# 创建 ParametricFunction 对象
func = (
ParametricFunction(
discontinuous_func,
t_range=(-3, 3),
discontinuities=[-2, 2], # 指定不连续点
dt=0.1, # 不连续点的容差
color=GREEN,
)
.scale(0.5)
.shift(DOWN)
)
# 添加到场景中
self.play(Create(func))
3.3. 跳动的心形线
这个浪漫的示例展示了如何创建复杂的心形图案,并通过缩放动画赋予其"跳动"效果。
# 心形线参数方程
heart = (
ParametricFunction(
lambda t: np.array(
[
16 * np.sin(t) ** 3,
13 * np.cos(t)
- 5 * np.cos(2 * t)
- 2 * np.cos(3 * t)
- np.cos(4 * t),
0,
]
),
t_range=[0, TAU, 0.01],
color=PINK,
)
.scale(0.1)
.shift(UP * 2)
)
self.play(Create(heart, run_time=2))
self.play(heart.animate.scale(1.2), rate_func=there_and_back)
self.play(heart.animate.scale(1.5), rate_func=there_and_back)
self.play(heart.animate.scale(1.2), rate_func=there_and_back)
4. 附件
文中的代码只是关键部分的截取,完整的代码共享在网盘中(parametric_function.py
),
下载地址: 完整代码 (访问密码: 6872)
manim边做边学--参数化曲线的更多相关文章
- 边做边学入门微信小程序之仿豆瓣评分
微信小程序由于适用性强.逻辑简要.开发迅速的特性,叠加具有海量活跃用户的腾讯公司背景,逐渐成为了轻量级单一功能应用场景的较佳承载方式,诸如电影购票.外卖点餐.移动商城.生活服务等场景服务提供商迅速切入 ...
- Grails边做边学入门篇[1]--------大家一起来动手建立project和Domain
近期工作比較忙,没空写博客了.我发现每周五的下午都是我最放松的时候,可能是迟延症的缘故吧...总是寄希望于周末,慢慢的.我的周末就被工作占领了. 希望大家不要有这种坏毛病.今日事,今日毕.当然我们程序 ...
- 【Leetcode 做题学算法周刊】第四期
首发于微信公众号<前端成长记>,写于 2019.11.21 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 67 ...
- 技术的止境(客户价值第一,快速实现第二,边做边学,迅速成为牛人。紧贴客户的需求去做技术,立于不败之地。追求的目标:把一项产品去做好,用产品去养活自己和家人)good
作为一个依靠技术来谋生的程序员,我最近一直在思考一个问题,有限的生命里,面对无限的技术更新,我要研究到什么程度才能算是完成我的成为技术大牛的目标呢?换而言之,那就是技术的止境在哪儿呢?深入的思考下去, ...
- 做fzu oj 1045 做减法学到的sprintf()函数
题目 做题一直输不出答案,于是就上网去百度了这题的解题,发现解答十分的简短,而且其中我看见了平时没见过的函数,sprintf(). 于是就百度sprintf()的使用. 如下: 函数功能:把格式化的数 ...
- Tween 若干年后我尽然还要学数学 曲线到底是什么鬼啊
var Tween = { linear: function (t, b, c, d){ //匀速 return c*t/d + b; }, easeIn: function(t, b, c, d){ ...
- 【Leetcode 做题学算法周刊】第一期
首发于微信公众号<前端成长记>,写于 2019.10.28 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 1. ...
- 【Leetcode 做题学算法周刊】第二期
首发于微信公众号<前端成长记>,写于 2019.11.05 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 20 ...
- 【Leetcode 做题学算法周刊】第三期
首发于微信公众号<前端成长记>,写于 2019.11.13 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 35 ...
- 【Leetcode 做题学算法周刊】第六期
首发于微信公众号<前端成长记>,写于 2019.12.15 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 11 ...
随机推荐
- Netty基础—2.网络编程基础二
大纲 1.网络编程简介 2.BIO网络编程 3.AIO网络编程 4.NIO网络编程之Buffer 5.NIO网络编程之实战 6.NIO网络编程之Reactor模式 1.网络编程简介 既然是通信,那么肯 ...
- 【面试题】实现 queryParse 函数,完成解析 URL 参数的功能
问题:实现 queryParse 函数,完成解析 URL 参数的功能 /** * 问题:实现 queryParse 函数,完成解析 URL 参数的功能 * * 用法: * ```js * const ...
- 一文搞懂 Redis 架构演化之路
作者:ryetan,腾讯 CSIG 后台开发工程师 现如今 Redis 变得越来越流行,几乎在很多项目中都要被用到,不知道你在使用 Redis 时,有没有思考过,Redis 到底是如何稳定.高性能地提 ...
- OpenGL与GLSL各版本对应说明
OpenGL 4.6 (API Core Profile) (API Compatibility Profile) OpenGL Shading Language 4.60 Specification ...
- 解决VuePress中的”Error from chokidar : Error: EBUSY“问题
.title { padding: 10px; background-color: rgba(3, 169, 244, 1); font-size: 16px; color: rgba(255, 25 ...
- Delphi 判断操作系统是32位或是64位
function IsWin64: Boolean; var Kernel32Handle: THandle; IsWow64Process: function(Handle: Windows.THa ...
- 离线版nRF Connect for Desktop安装方法
首先确保两台电脑都安装了nRF Connect for Desktop 先在一台能连网的电脑上安装自己想要的App 然后把APP拷贝到没有网的电脑上 从%USERPROFILE%\.nrfconnec ...
- 新装ubuntu电脑的一些调整
必要命令的安装 必要开发工具的安装 更换国内软件源 /etc/apt/sources.list文件,后面添加下面地址用来添加阿里源 deb http://mirrors.aliyun.com/ubun ...
- leetcode001 两数之和
问题描述:两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标. 你可以假设每种输入只会对应一个答 ...
- 判断返回值长度(比如是否为空),执行后续步骤(if..else、len的用法)
爬基金数据,净值因涨跌不同,对应的元素路径也不会一样 比如当天是涨的时候,涨跌元素的class信息为"<span class="fix_dwjz bold ui-color ...