在数学可视化中,显函数$ y=f(x) \(相对容易处理,但**隐函数**\) F(x,y)=0 $的绘制则更具挑战性。

Manim库中的ImplicitFunction类专门用于解决这个问题,它能够高效地绘制各种复杂的隐函数曲线。

ImplicitFunction典型应用场景包括:

  • 高等数学教学:绘制圆锥曲线(椭圆、双曲线)、心形线、双纽线等
  • 工程应用:可视化等值线、等高线、势能面
  • 物理模拟:绘制电场/磁场的等势线、相平面轨迹
  • 计算机图形学:生成特殊曲线和曲面
  • 代数几何:研究代数曲线的性质

今天,我们将深入探讨Manim中的ImplicitFunction类,了解其作用、应用场景以及如何通过实际示例展示其强大功能。

1. 主要参数

ImplicitFunction的主要参数有:

参数 类型 说明
func Callable[[float, float], float] 必需参数,二元函数F(x,y)
x_range Sequence[float] x轴的取值范围,如[-3,3]
y_range Sequence[float] y轴的取值范围,如[-3,3]
color Color 曲线颜色,默认为WHITE
min_distance float 点之间的最小距离(控制曲线精度)
max_quads int 用于渲染的最大四边形数量(性能优化)
use_smoothing bool 是否使用平滑处理(默认True)
delta float 采样步长(影响曲线精度)

func参数是隐式函数的形式,这个函数需要接受两个浮点数$ x \(和\) y $,并返回一个浮点数。

2. 主要方法

ImplicitFunction的主要方法有:

名称 说明
generate_points 初始化points属性,从而定义形状。这个方法在对象创建时被调用
init_points generate_points类似,用于初始化points属性

3. 使用示例

为了更好地理解ImplicitFunction的功能,我们将通过几个示例来展示其在不同场景中的应用。

3.1. 基本隐函数(圆)

这个示例展示最基本的隐函数绘制,通过方程$ x^2+ y^2 = 1 $绘制单位圆。

注意x_rangey_range的设置需要包含整个曲线。

# 创建隐函数图像(单位圆)
circle = ImplicitFunction(
lambda x, y: x**2 + y**2 - 1,
color=RED,
x_range=[-1.5, 1.5],
y_range=[-1.5, 1.5],
) # 添加标签
label = MathTex("x^2 + y^2 = 1").next_to(circle, DOWN) # 动画展示
self.play(Create(circle), Write(label))

3.2. 动态参数变化(椭圆)

这个示例使用ValueTrackeralways_redraw实现动态变化的椭圆,展示如何通过改变参数实时更新隐函数图像。

# 创建参数跟踪器
a = ValueTracker(1)
b = ValueTracker(1) # 创建动态椭圆
ellipse = always_redraw(
lambda: ImplicitFunction(
lambda x, y: (x**2) / (a.get_value() ** 2)
+ (y**2) / (b.get_value() ** 2)
- 1,
color=GREEN,
x_range=[-4, 4],
y_range=[-3, 3],
)
) # 添加参数标签
param_label = always_redraw(
lambda: MathTex(
f"\\frac{{x^2}}{{{a.get_value()**2:.1f}}} + \\frac{{y^2}}{{{b.get_value()**2:.1f}}} = 1",
color=RED,
)
.shift(DOWN * 1.5 + RIGHT * 1.8)
.scale(0.6)
) self.add(ellipse, param_label)
self.play(a.animate.set_value(2), b.animate.set_value(1.5), run_time=3)
self.play(a.animate.set_value(3), b.animate.set_value(1), run_time=3)

3.3. 复杂曲线(笛卡尔心形线)

这个示例展示复杂隐函数的绘制,绘制了一个心形曲线。

        # 创建心形线
heart = ImplicitFunction(
lambda x, y: (x**2 + y**2 - 1) ** 3 - x**2 * y**3,
color=PINK,
x_range=[-1.5, 1.5],
y_range=[-1.2, 1.8],
) # 添加标签
label = (
MathTex("(x^2 + y^2 - 1)^3 = x^2 y^3", color=GREEN)
.shift(DOWN + RIGHT * 1.8)
.scale(0.6)
) self.play(Create(heart), Write(label))

4. 附件

文中的代码只是关键部分的截取,完整的代码共享在网盘中(implicit_function.py),

下载地址: 完整代码 (访问密码: 6872)

manim边做边学--隐函数图像的更多相关文章

  1. 边做边学入门微信小程序之仿豆瓣评分

    微信小程序由于适用性强.逻辑简要.开发迅速的特性,叠加具有海量活跃用户的腾讯公司背景,逐渐成为了轻量级单一功能应用场景的较佳承载方式,诸如电影购票.外卖点餐.移动商城.生活服务等场景服务提供商迅速切入 ...

  2. Grails边做边学入门篇[1]--------大家一起来动手建立project和Domain

    近期工作比較忙,没空写博客了.我发现每周五的下午都是我最放松的时候,可能是迟延症的缘故吧...总是寄希望于周末,慢慢的.我的周末就被工作占领了. 希望大家不要有这种坏毛病.今日事,今日毕.当然我们程序 ...

  3. 技术的止境(客户价值第一,快速实现第二,边做边学,迅速成为牛人。紧贴客户的需求去做技术,立于不败之地。追求的目标:把一项产品去做好,用产品去养活自己和家人)good

    作为一个依靠技术来谋生的程序员,我最近一直在思考一个问题,有限的生命里,面对无限的技术更新,我要研究到什么程度才能算是完成我的成为技术大牛的目标呢?换而言之,那就是技术的止境在哪儿呢?深入的思考下去, ...

  4. 【Leetcode 做题学算法周刊】第四期

    首发于微信公众号<前端成长记>,写于 2019.11.21 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 67 ...

  5. 做fzu oj 1045 做减法学到的sprintf()函数

    题目 做题一直输不出答案,于是就上网去百度了这题的解题,发现解答十分的简短,而且其中我看见了平时没见过的函数,sprintf(). 于是就百度sprintf()的使用. 如下: 函数功能:把格式化的数 ...

  6. 我用JAVA做了个简易图像相似度计算器

    简单说两句: 笔主利用这个七夕前后两天的寂寞时光,用JAVA磨了一个简单的图像相似度计算小程序,就在刚才终于纠结完毕,输出了1.0版本,小小的满足了一下可怜的虚荣心..→_→ 使用最简单最基础的感知哈 ...

  7. 使用CNN做文本分类——将图像2维卷积换成1维

    使用CNN做文本分类 from __future__ import division, print_function, absolute_import import tensorflow as tf ...

  8. 【Leetcode 做题学算法周刊】第一期

    首发于微信公众号<前端成长记>,写于 2019.10.28 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 1. ...

  9. 【Leetcode 做题学算法周刊】第二期

    首发于微信公众号<前端成长记>,写于 2019.11.05 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 20 ...

  10. 【Leetcode 做题学算法周刊】第三期

    首发于微信公众号<前端成长记>,写于 2019.11.13 背景 本文记录刷题过程中的整个思考过程,以供参考.主要内容涵盖: 题目分析设想 编写代码验证 查阅他人解法 思考总结 目录 35 ...

随机推荐

  1. ppt 实用技巧总结

    全是图片且颜色单一 解决方案:在图片上添加图形,加图标 效果图 2.文本功能10个 解决方案:添加背景图片+文本+图标 效果图 只有文本 没有过多内容怎么办

  2. wxpython SetValue 获取列表数据获取不到

    self.m_textCtrl4.SetValue(files) 同样的方法获取其他值就获取到了 ,后来想了想files是列表数据,于是将类型变为str型成功 self.m_textCtrl4.Set ...

  3. 大模型评测之幻觉检测hallucination_evaluation_model

    大背景: 2025开年deepseek铺天盖地的新闻 参会代表已经表明,年度主线就是以AI为基础 Manus于3月初横空出世 国内各种模型竞赛的现状,只要是和科技沾边的公司不可能没有大模型,哪怕是里三 ...

  4. 赞美Syscall

    知道程序员在编写程序时直接和硬件打交道是一件非常麻烦的事,同时不受保障的程序直接运行在硬件上如果出错可能造成计算机宕机,于是可以编写一个应用程序驻留在计算机上管理硬件资源为上层应用提供系统调用(sys ...

  5. MySQL常用SQL 语句

    --备份数据库 mysqldump -u用户名 -h主机名 -p密码 数据库名 > filename.sql --备份数据库中的某个表 mysqldump -u用户名 -h主机名 -p密码 数据 ...

  6. Docker管理面板系列——Portainer

    一.介绍 Portainer是个轻量级的Docker管理面板,和Rancher这种重量级选手没法比,Portainer倾向于单机的管理(后来发现能够添加多个单机节点切换着管理),当然,在Docker搞 ...

  7. Zotero设置

    1. 说明 Zotero 中文社区 | 百度网盘 使用 zotero 仅同步题录信息,使用其他云同步程序同步文献的附件,此处以坚果云为例进行演示,前期的坚果云同步设置参考文章:Zotero坚果云同步. ...

  8. leetcode每日一题:转换二维数组

    题目 2610. 转换二维数组 给你一个整数数组 nums .请你创建一个满足以下条件的二维数组: 二维数组应该 只 包含数组 nums 中的元素. 二维数组中的每一行都包含 不同 的整数. 二维数组 ...

  9. 在 .NET 中 使用 ANTLR4

    前言 本文将介绍如何在 .NET 中使用 ANTLR4 构建语法分析器.由于篇幅限制,本文不会深入讲解 ANTLR4 的语法规则,相关内容可参考 ANTLR4 的官方文档或其他资料.本文将涵盖以下内容 ...

  10. CH390使用注意事项

    关于CH390使用注意事项 CH390替换DM90xx硬件注意事项 1.CH390L替换DM9000 AVDD33的对地电容建议1uF贴近芯片放置,42脚为主电源AVDD33需10uF并联0.1uF. ...