前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用 Mathematica 求解多项式

用 Mathematica 求解多项式

作者头像
WolframChina
发布2018-05-31 11:21:11
3.6K0
发布2018-05-31 11:21:11
举报
文章被收录于专栏:WOLFRAMWOLFRAM

█ 本文译自 Bill Gosper 在 Wolfram 社区发表的热点文章:Solving polynomials

多项式是由一组常数系数,a、b、c、……(数值)确定的。

代码语言:javascript
复制
TableForm[{a x + b, a x^2 + b x + c, a x^3 + b x^2 + c x + d, ". . ."}] // TraditionalForm

多项式求解问题就是找到一个值 x,使这些项的总和等于 0. 根据 x 的最高次数分别称为线性、二次、三次、四次、五次、六次、七次、八次...... 多项式。我们称 y = a x + b 为线性,是因为它的图线是一条直线. 比如令 a = 2,b = 3,

代码语言:javascript
复制
Plot[2 x + 3, {x, -2, 1}]

2 x + 3 = 0 的(唯一)解是 x = -3/2. 一般情况下,有 x = -b/a. 由于含有 x 的平方项,y = a x^2 + b x + c 是二次的. 你会记得一元二次方程有两个通解:

代码语言:javascript
复制
Solve[a x^2 + b x + c == 0, x]

这样的表达式被称为不尽根式. 最常见的应用是在几何上. 圆、抛物线和双曲线通常由二次多项式指定。当我们想知道一个二次多项式与已知直线何时相交时,我们就得到一个二次方程. 这甚至发生在 双曲线是矩形的,例如:

代码语言:javascript
复制
Plot[{(1 - x)/(x + 2), 2 x + 3}, {x, -4, 1}, PlotRange -> {{-4, 1}, {-6, 6}}, AspectRatio -> 4/5]

表示双曲线的分支与直线相交的方程为

代码语言:javascript
复制
(1 - x)/(x + 2) == 2 x + 3;

要得到形如 x^2 + b x + c ==0 的方程,需要两边同时乘以 x + 2,

代码语言:javascript
复制
Distribute[(x + 2)*%, Equal]

1 - x == (2 + x) (3 + 2 x)

再两边同时减去(2 + x) (3 + 2 x),

代码语言:javascript
复制
(2 + x) (3 + 2 x) - # & /@ %

-1 + x + (2 + x) (3 + 2 x) == 0

然后展开:

代码语言:javascript
复制
Expand@%

5 + 8 x + 2 x^2 == 0

因为 Mathematica 不是使用传统的方法处理方程,"两边同时减去"这一步需要解释一下. 它使用 & 定义了一个函数,从 (2 + x) (3 + 2 x)减去(#),然后"映射" ( /@ ) 到等式两边.

不管怎样,求解二次方程:

代码语言:javascript
复制
Solve[%]

{{x -> 1/2 (-4 - Sqrt[6])}, {x -> 1/2 (-4 + Sqrt[6])}}

或者近似

代码语言:javascript
复制
N@%

{{x -> -3.22474}, {x -> -0.775255}}

当然,Mathematica 非常乐意直接求解:

代码语言:javascript
复制
Solve[(1 - x)/(x + 2) == 2 x + 3]

{{x -> 1/2 (-4 - Sqrt[6])}, {x -> 1/2 (-4 + Sqrt[6])}}

我们可以把这些值作为绘图范围

代码语言:javascript
复制
Flatten[% /. Rule -> List]

{x, 1/2 (-4 - Sqrt[6]), x, 1/2 (-4 + Sqrt[6])}

来直观地检查合理性:

代码语言:javascript
复制
Plot[{(1 - x)/(x + 2), 2 x + 3}, %[[{1, 2, 4}]]]

该图形以交点作为起点和终点. ( {1, 2, 4} 是为了去除额外的 x.)

要是双曲线是颠倒的,貌似就没解了:

代码语言:javascript
复制
Plot[{(x - 1)/(x + 2), 2 x + 3}, {x, -4, 1}, PlotRange -> {{-4, 1}, {-6, 6}},
 AspectRatio -> 4/5]

但 Mathematica 很聪明,它给的结果不是{},而是

代码语言:javascript
复制
Solve[(x - 1)/(x + 2) == 2 x + 3]

{{x -> 1/2 (-3 - I Sqrt[5])}, {x -> 1/2 (-3 + I Sqrt[5])}}

也就是说,解含有虚数. 二次方程是通过配方法来求解的,两边同时加上b^2/4a-c:

代码语言:javascript
复制
# + b^2/(4 a) - c & /@ (a x^2 + b x + c == 0)

b^2/(4 a) + b x + a x^2 == b^2/(4 a) - c

然后左边配成平方除以4a:

代码语言:javascript
复制
Factor /@ %

(b + 2 a x)^2/(4 a) == -((-b^2 + 4 a c)/(4 a))

然后乘以 4a 后

代码语言:javascript
复制
4 a # & /@ %

(b + 2 a x)^2 == b^2 - 4 a c

我们可以取两边的平方根.

代码语言:javascript
复制
Sqrt /@ % // PowerExpand

b + 2 a x == Sqrt[b^2 - 4 a c]

现在它变成了一个线性方程. PowerExpand 强制 Mathematica 选择 b + 2 a x,而不是 - b - 2 a x 作为平方的方根.

正如"每个人"都记着二次方程的解,"没有人"记得三次方程的解。原因是:

代码语言:javascript
复制
Solve[ a x^3 + b x^2 + c x + d == 0, x] // TraditionalForm

现在考虑一个简单情形:

代码语言:javascript
复制
Plot[x^3 - x + 1/3, {x, -3/2, 3/2}]

显然它有三个实根,在 - 1.1, .35, 和 .75 附近. 具体是多少呢?

代码语言:javascript
复制
Solve[x^3 - x + 1/3 == 0]

嘿,等一下,根不是实数吗?是不是 Mathematica 忘了化简了?

代码语言:javascript
复制
Simplify@%%

这么复杂的式子怎么会是实数呢?让我们看一下虚部:

代码语言:javascript
复制
ComplexExpand@Im[x /. %]

{0, 0, 0}

那好吧,老天爷,告诉我们实部是啥吧!

代码语言:javascript
复制
ComplexExpand@Re[x /. %%]

三角函数?!还不如平方根和立方根呢!

代码语言:javascript
复制
Developer`TrigToRadicals@%%

天啊!那些三角函数是实数,但为啥这里却跟着一堆虚数单位?- 1.1、.35 和 .75 在哪呢??请给出数来.

代码语言:javascript
复制
N@%

{0.742227 + 0. I, 0.394931 + 0. I, -1.13716 + 0. I}

它们就在那,但这些 0. i 是怎么回事?奇怪的是,它们是不可避免的. 作为一个数学分支的伽罗瓦理论已经证明,不含虚数立方根的解式是不存在的,即使它们的加和为实数.

Henry Baker 的动画(本文顶部可以看到实际动画)展示了均为实数的三个根之间的关系:

这是张一般情况下的图片——三个实根的三次方程有一个拐点,它们关于拐点对称. 如果将拐点平移到原点,则会得到一个奇函数 f(-x )= -f(x).

四次方程可以通过将两条曲线相交得到. 一般情况下的四次方程会让人有点抓狂,如果不怕的话就按住 shift return 键试试吧.

代码语言:javascript
复制
Solve[ a x^4 + b x^3 + c x^2 + d x + e == 0, x]

求解五次方程就更是不要命了.

代码语言:javascript
复制
Solve[ a x^5 + b x^4 + c x^3 + d x^2 + e x + f == 0, x]

哈哈,Mathematica 放了我们一马,结果被剪切了,但为什么不至少提供一下互动大型表达式浏览器呢?因为它不能. 不存在一般五次方程的根表达式. 显然,通过因式分解我们可以求解某些五次方程.

代码语言:javascript
复制
Expand@# == # &[(x^2 + 1) (x^3 - x - 1)]

-1 - x - x^2 + x^5 == (1 + x^2) (-1 - x + x^3)

历经几个世纪的挫败,求解五次方程已经与三等分角和倍立方问题一样成为困扰人们的几大数学难题。

许多人错误地认为唯一可解的五次方程要么是可因式分解的,要么是显而易见的,如(x + a)^ 5 + b = 0. 但只有一小部分,接近0%,可以巧妙地解决,比如:

代码语言:javascript
复制
x^5 - 5 x^2 - 3 == 0

它的根相当繁琐. 唯一的实根是

至少从外观看来是实数. 平凡的 Mathematica 无法求解——连验证都不行!只能近似:

代码语言:javascript
复制
%^5 - 5`69 %^2

3.0000000000000000000000000000000000000000000000000000000000000000000

我曾经(正确地?)说服自己,每个可求解的六次方程都可以降次到具有二次不尽根系数的三次方程或具有三次不尽根系数的二次方程. 但谁会想要求解这样一个方程呢?几何再次派上用场了. 问题:将一个正方形拆分成有限个锐角、等腰三角形. 可以用十个:

确定 Subscript[x, 1]、Subscript[y, 1]、Subscript[x, 2] 和 Subscript[r, 3] 的方程是12次的!这些方程可以通过因式分解降为具有不尽根系数的六次方程,但专家 Noam Elkies 认为这是不可求解的. 然而当次数为6、8、9、……或任何复合数(或称非质数)时,有时候会比较幸运.

代码语言:javascript
复制
Factor[5 + 4 x^2 - 4 x^3 + x^4 - 2 x^5 + x^6]

5 + 4 x^2 - 4 x^3 + x^4 - 2 x^5 + x^6

不能进行因式分解. 然而

代码语言:javascript
复制
Solve[% == 0]

可以求得所有六个解!怎么实现呢?这个六次方程可以写作

代码语言:javascript
复制
x^2 - 4 x + 5 /. x -> x^3 - x^2

5 - 4 (-x^2 + x^3) + (-x^2 + x^3)^2

代码语言:javascript
复制
Factor@%

5 + 4 x^2 - 4 x^3 + x^4 - 2 x^5 + x^6

也就是说,将三次方程替换为二次方程。如果我们注意到这一点,我们只是用y来代替 x ^ 3 - x ^ 2 - 2 ,对得到的二次方程求 y,然后求解关于 x 的三次方程,用 y 表示。我们是怎么注意到这一点的?用魔法函数

代码语言:javascript
复制
Decompose[5 + 4 x^2 - 4 x^3 + x^4 - 2 x^5 + x^6, x]

{5 - 4 x + x^2, -x^2 + x^3}

这正好是 Solve 函数所了解的. 知道吗?你的八次方程可能只是三个二次方程的组合.

但请注意:这个六次方程的解,既不能因式分解

5 + 18 x + 36 x^2 + 36 x^6

也不能正常分解.

{570630428688384000000 + 4891824455002619904 x + 161093791317491712 x^2 + 12153384861696 x^3 + 984379392 x^4 - 17280 x^5 + x^6}

代码语言:javascript
复制
Simplify[% /. x -> %%]

{0}

所以括号中的数量满足最小次数为36的最小多项式!

令人惊奇的是,这是一个甚至连 Mathematica 第11版都不知道的诀窍:如果系数形成回文,六次甚至八次方程总是可以求解!例如,

代码语言:javascript
复制
Solve[1 + x + x x - x^3 + x^4 + x^5 + x^6 == 0]

(失败。)但是我们可以对付完全一般的情况! 对于任意a,b,c,d,假设 x 满足互反多项式(所以被称作回文式)

代码语言:javascript
复制
a x^6 + b x^5 + c x^4 + d x^3 + c x x + b x + a

a + b x + c x^2 + d x^3 + c x^4 + b x^5 + a x^6

现在假设 y = x + 1/x (或写作 x y = x^2 + 1),求六次多项式除以这个二次多项式(关于 x)的余式:

代码语言:javascript
复制
Factor[PolynomialRemainder[%, x + 1/x - y, x]]

(-x - y + x y^2) (-2 b + d - 3 a y + c y + b y^2 + a y^3)

求这个余式意味着减去二次式的倍数,使得六次多项式将简化为关于 x 的线性多项式. 但是我们假定了二次和六次多项式都是0,所以我们从0减去0,得到x和y之间的可疑关系, 乘以我们可以求解的 y 的三次式! 通过 y = x + 1 / x 来求解x.

回文多项式被称作互逆多项式的原因是,如果用 1/x 代替 x,两者具有相同的根,从而将系数的次序逆转(并除以 x^6).

这个令 y = x + 1/x 的技巧可以成功的关键是我们可以将各项用它们的倒数匹配,并利用关系:

代码语言:javascript
复制
1/x^3 + x^3 == -3 (1/x + x) + (1/x + x)^3

1/x^2 + x^2 == -2 + (1/x + x)^2

朱利安和我有一个七次方程求解程序,但他不相信它能找到所有的解. 超过七次以后,能找到一个强有力的求解器机会会大大减小,TA在理论上可以求解的概率也是如此. 但是如果你的问题不是随机组成的,那么总是值得一试.

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-10-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 WOLFRAM 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • █ 本文译自 Bill Gosper 在 Wolfram 社区发表的热点文章:Solving polynomials
相关产品与服务
大数据
全栈大数据产品,面向海量数据场景,帮助您 “智理无数,心中有数”!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档