0

0

如何用 SymPy 精确计算形如 (m/n)π 的正弦与余弦值

霞舞

霞舞

发布时间:2026-01-25 10:11:10

|

343人浏览过

|

来源于php中文网

原创

如何用 SymPy 精确计算形如 (m/n)π 的正弦与余弦值

本文介绍如何利用 sympy 获取 sin(mπ/n) 和 cos(mπ/n) 的**严格代数表示**——包括根式解(当存在时)和通用的 rootof 精确表示(对任意整数 m, n 均有效),并解释其数学原理与实用边界。

在初等三角函数学习中,我们熟悉如 sin(π/3) = √3/2、cos(π/4) = √2/2 这类“漂亮”的根式表达。但当分母 n 变大(如 n = 13, 25, 97),或含高次不可约因子(如 7, 11, 13)时,传统手工推导或递归公式(如倍角、半角、Chebyshev 多项式展开)将迅速遭遇理论瓶颈:并非所有代数数都可用有限嵌套根式表示。这正是 Abel-Ruffini 定理的核心结论——五次及以上一般多项式无根式求解公式,而 cos(2π/n) 和 sin(2π/n) 恰好是分圆多项式(cyclotomic polynomial)相关方程的根,其最小多项式次数为 φ(2n)/2(φ 为欧拉函数),随 n 增长而快速升高。

幸运的是,SymPy 并不依赖根式解——它提供更本质、更普适的精确表示:RootOf。该对象封装了代数数的完整定义信息:一个有理系数不可约多项式 + 根的序号(按实部/虚部排序)。例如:

from sympy import *
x = symbols('x')
theta = 5*pi/13

# 获取 sin(theta) 的最小多项式(有理系数、不可约、次数最低)
min_poly = minpoly(sin(theta))
print("sin(5π/13) 的最小多项式:")
pprint(min_poly)

# 构造 RootOf 表示(精确、可计算、可参与符号运算)
root_repr = CRootOf(min_poly, 10)  # 第10个实根(SymPy 编号)
print(f"\nsin(5π/13) 的精确代数表示:{root_repr}")

# 高精度数值验证(任意位数)
print(f"数值近似(50位):{root_repr.evalf(50)}")
print(f"与 math.sin 对比:{float(sin(theta).evalf(50)):.50f}")

输出显示 sin(5π/13) 是一个 12 次多项式的第 10 个实根。尽管无法写成有限根式,但 CRootOf(...) 是完全精确的符号对象:它支持加减乘除、幂运算、嵌套函数(如 sin(root_repr)),且所有运算保持代数封闭性——SymPy 内部会自动约简至最小多项式或合并表达式。

对于你的原始代码,瓶颈在于手动构造高次方程并调用 solve(),而 solve() 仅对低次(≤4)或特殊可解情形返回根式;一旦遇到不可约五次及以上方程(如 n=25 时的 20 次方程),便退化为数值近似或失败。改用 minpoly() + CRootOf() 组合,可无条件覆盖所有整数 m, n

AdsGo AI
AdsGo AI

全自动 AI 广告专家,助您在数分钟内完成广告搭建、优化及扩量

下载
def exact_trig(m: int, n: int) -> tuple:
    """返回 sin(mπ/n) 和 cos(mπ/n) 的精确 RootOf 表示"""
    if n <= 0:
        raise ValueError("n must be positive integer")

    # 化简分数:sin(mπ/n) = sin((m mod 2n) π / n),利用周期性与奇偶性
    k = Rational(m, n) % 2
    theta = k * pi

    sin_val = sin(theta)
    cos_val = cos(theta)

    return (
        CRootOf(minpoly(sin_val), 0),  # 实根中第一个(通常为所求)
        CRootOf(minpoly(cos_val), 0)
    )

# 示例:n=25,m=1 → sin(π/25)
sin_pi25, cos_pi25 = exact_trig(1, 25)
print("sin(π/25) =", sin_pi25)
print("cos(π/25) =", cos_pi25)
print("sin² + cos² =", simplify(sin_pi25**2 + cos_pi25**2))  # 输出:1(严格成立!)

⚠️ 注意事项:

  • CRootOf 是首选精确表示:比手动根式更可靠、更通用,且支持 evalf()、simplify()、expand() 等全部符号操作;
  • 避免 solve() 对高次多项式盲目求根:它不保证返回你所需的特定实根,且易因浮点近似引入误差;
  • 数学背景延伸建议:此问题深层关联分圆域(Cyclotomic Fields)Galois 理论——cos(2π/n) 生成的扩域次数为 φ(n)/2,当 φ(n)/2 ≤ 4 时(即 n ∈ {1,2,3,4,5,6,8,10,12})才存在根式解;
  • 进阶实践:结合 solveset(domain=S.Reals) 或 real_roots() 精确定位所需实根编号,确保 CRootOf 指向正确分支。

总结而言,放弃“必须写出根式”的执念,拥抱 RootOf ——它不是妥协,而是通向代数数本质的更强大、更严谨的符号语言。你的学习目标(理解数学结构 + 提升 Python 符号计算能力)正可通过这一转变获得双重深化。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

773

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

684

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

766

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

719

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1425

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

570

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

751

2023.08.11

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

25

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 19.3万人学习

Django 教程
Django 教程

共28课时 | 3.5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号