本帖最后由 Asdmath2020 于 2020-3-5 17:37 编辑 3 W2 x' E; U8 ^) j0 {" t$ W( J
; H( Y4 s, |7 p' p6 G█ 本文译自算法R&D,内核开发工程师 Devendra Kapadia 于2017年11月9日的博客文章: Limits without Limits in Version 11.2.
/ z$ w6 V( K" E, d# P, c; i% H
/ ]7 g8 s& K: V g8 h1 E* \$ L a Y W0 ~( g9 g
这是一个序列的10个项:
0 |* Q' L0 q( @- x V& {0 I
5 Y- J% ? J% G' |. {! n0 B# U1 ?: I9 @
( h) G7 Q; p) b! {, }这是它们的数值:
( q, s5 E. V+ `# H4 |( h9 y& }
; x! I, ^3 k8 A9 B; Y Q0 d* n
2 {0 b; Y( Y& @* c" W) y
! q: J' G4 d% m3 V1 p0 Q* s" Q这个数列的极值是什么?如果这个数列无限继续下去,我们会得到什么?
: b9 C& w4 k( ?1 v4 v$ y
* u" t8 y4 {9 C2 ?2 E7 Z在 Mathematica 和 Wolfram 语言中,有一个直接求解这一问题的函数:
, A" {+ E( W1 N. b1 B! p
' }# W$ x+ i! K0 x3 K# B, N W; D( m! Y
极限是包括数论、几何学和计算复杂性理论在内的许多领域的中心概念。它们还是微积分的核心,不仅是因为它们被用来定义导数和积分的概念。 ) s8 E! T4 v* d- E8 g
计算极限是 Mathematica 和 Wolfram 语言一直以来就具有的功能。在版本11 .2 中,这一功能被大幅扩展。我们综合利用 Wolfram 语言的许多特色功能,并发明了一些全新的算法来实现这一点。为了确保我们所做的一切满足用户的需要,我们从Wolfram|Alpha 抽选了100多万个极限问题。 % J+ X9 o, ^: E9 E* C/ y
) I4 ^: Q; n4 M; g' [
# I* ~- v, E5 _; p/ ~3 M$ c
; C& A8 f# F. u* i7 F这是该数列前10个值的表格:% O& `$ D6 `* e- A+ m
% M& M, U+ d% e' h7 @& D1 e
' w7 q' {9 Y0 M9 f# J/ k
下图表明,当 n 趋向于无穷时,数列收敛于 0。: \* E2 N0 e3 l @
3 j( b M: ^: p6 S' v7 J
+ D0 [: f* V$ x) z* m T, C在版本11 .2 中引入的 DiscreteLimit 函数证实了这个数列的极限是0。 9 E& R1 ]' c; o: ?! W
+ t ~; v- V* x
& ` J! q! A% b+ E$ B3 S- H7 k在现实生活中出现的许多序列 (例如,在信号通信中) 是周期性的,它们的值在规则的间隔时间内重复出现。此类间隔的长度称为序列的周期。例如,考虑一个使用 Mod 定义的序列。$ A# R4 V- ?' q: p# y
& q7 c9 y# V" n, p% B0 Q
$ C, L: f" ~! P% ~$ I2 E* Q. W' E序列图表明该序列是周期性的,周期为6。: v8 R; ^5 x# k, h- F8 S
+ U: u& y7 T: i( ^8 W( g3 r( T1 U' K2 H- o( i* N3 f
与我们的第一个例子相反,这个序列不收敛,它在0和5之间振荡。因此,在这种情况下, DiscreteLimit 返回 Indeterminate(不定)。" \. K+ T* Q3 t/ u8 K) n
6 `4 n+ v# \ @6 ~4 S
% b# x0 n0 l" _: E5 w! U1 Y a在这种情况下,版本11.2 的新增函数 DiscreteMinLimit 和 DiscreteMaxLimit 可以分别用于计算振荡的下限和上限。因此,我们有:
3 v7 P8 R. `' ~+ D& U) V* d6 a# K
7 c5 C6 r6 u( S5 X& v* b' Q
3 [7 R; `7 M1 S7 x0 V" ]! I
, ]8 F. z5 {) C. @( _
在数学文献中,DiscreteMinLimit 和 DiscreteMaxLimit 通常被称为 "lim inf" 和 "lim sup"。这些极限的传统底线和顶线符号是可用的,如下所示。
- A1 h$ E4 y) G" z6 o
, a- f7 A. S$ p1 i7 L3 T
! F5 U/ R! t9 ^! O6 _! ?* L+ I6 v
, d7 `# P o3 \
我们的下一个例子是由三角函数 Sin 和 Cos 得到的一个振荡序列,定义如下。: s$ U8 [6 Q2 G3 e% U6 @/ t0 W, v
8 x' F! J; p# N6 o# w' H: i* ~3 R
: C1 S! J# H- f/ A6 J尽管在实数范围内 Sin 和 Cos 作为函数是周期性的,这个整数序列的行为很奇特,远远不是一个周期序列,可以通过下图证实。
3 a- A0 K( O. L2 |# I) j
3 D7 D' M1 ?( g* ~; S) v
* `% k9 w/ K) M1 z; ?7 q$ b4 E4 ]因此,该序列的极限不存在。
, L" Q" g V" }: O) ]
& H9 m. s' P8 t( r, J0 Q7 R5 S
7 n* A) ^" N+ p, m, c3 _# `) R然而,事实证明,对于这种 "密集型非周期序列",极值可以通过将它们作为实际函数来计算。不出所料,DiscreteMinLimit使用此方法返回该示例的答案0。
5 n! Z2 {& Q% v2 x
: C: p2 q6 K O' K) i, Y+ C
9 A4 Z' e7 H3 {0 z% p使用相同的方法,DiscreteMaxLimit返回一个含有根式对象的相当凌乱的结果。+ y6 I5 U# y! v
3 F8 M* e2 \2 R4 l3 q: x! N" Z( x" a' L
这个结果的数值近似于 0.8,正如人们可能从图中猜到的那样。( j+ q& g( q! p6 j0 s4 x& u3 ^8 x& u
6 g. {& m7 F7 D$ E9 ^' q. k4 j9 N% L" ~* D
: u, T6 A/ _( c4 O0 Q1 U当我们试图计算无限嵌套的根式值时,离散极限也会以自然的方式出现。例如,考虑以下嵌套根式的求值问题。4 }: _0 K9 `* Z l
/ E' p, l% A- L" r
由于该序列满足非线性重复性,因此可以使用 RSolveValue 来生成根式展开式的连续项。例如,展开式的第三个项可以通过以下所示得到。
4 r; j3 l1 J* U$ U/ D9 B, J3 {
" H6 p% p$ E" y2 r8 p0 ^* ]5 o
通过 RecurrenceTable 所生成的下图可以看出,无限嵌套的根式值似乎是 2。
" N$ U0 `* A4 ~ }$ M( J! [4 r, b
2 T" L& v$ p5 `- z3 ]使用版本 11.2,通过求解 RSolveValue 中的值 r(∞),我们可以确认极值确实是 2,如下所示。: V7 R" g, E- r0 i) E
: h$ [) e) t3 p; q$ h
极限的研究是数学的一个分支,称为渐近分析。渐近分析提供了在特定值 (如0或无穷大) 附近获取问题近似解的方法。事实证明,在实际中,渐进逼近的效率通常恰恰会在相应的精确计算变得困难的情况下得到提高!这一现象的一个著名的例子是在研究整数分区时,随着数量的增加,分区会增长非常快。例如,数字6可以使用IntegerPartitions 以11种不同的方式进行分区,如下所示。
, W$ S8 u" L$ k: B( d' Z( D b2 H& e
. _' R* B- }& r: k: H$ v
0 Y4 ]8 Y: Z1 f J8 j: |- U* R% w6 l# d可以直接使用 PartitionsP 找到不同分区的数量,如下所示。
/ L9 L( }9 l( v! f4 h& G8 h* B
' d; q6 V7 b1 l; q9 ^如前所述,分区的数量随着整数的大小而快速增长。例如,数字200有近4兆分区。
+ o. o4 D( O# X' I. t: ^
5 ^; r& j/ T# d
g/ R2 _$ q) k3 B# e1 }8 H$ P
在 1918年,哈代和拉马努金提供了这个数字的渐近逼近,由以下公式给出。4 H( t; v5 ` K1 l3 W
' W7 e" B4 B: h. f, Y$ d根据上式估计,数字200的答案相当接近4兆。
: O& S; O7 V! l
8 q" M: A: K' i9 X( q) B
提供有一个更大的整数,我们几乎可以瞬间得到一个更好的分区数量近似,如下例所示。) _/ f6 I0 p7 y% G
3 z+ l: t- j8 @* y) y- J( d$ I
. w r2 |7 p3 F2 K E1 M' O3 k最后,我们可以证实,使用 DiscreteLimit,当 n 趋于无穷时,渐近估计接近于分区数,这正印证了上面讨论的哈迪-拉马努金公式。
1 f% c9 r7 e& E! l8 o/ s% X- ~8 m# v
1 D8 ~) c! _7 S
正式的表述是,当n 接近无穷时,精确和近似公式的分区数是渐近等价的。 % m9 n/ l1 x. L2 L5 K7 f/ t; N
渐近概念在函数极限的研究中也起着重要的作用。例如,三角学中的小角度逼近断言 "在 x 取很小的值时,sin (x) 近似等于 x 。" 还可以表述成, "当 x 趋向于 0 时,sin (x) 与x渐近等价。" 这个结果可以使用计算函数极值的 Limit 正式表述如下。
, ]! q: G4 y# r) W' ]+ T. z2 r, d( Z) f
这个图形直观地证实,极限确实是1。0 U- e& t* m; O: {' W1 @
; |$ S! U2 p( O" y4 R. ^' v1 p$ [
# G% G4 j* v+ `; o) a6 y R- X& j$ K
上述极限也可以使用洛必达法则,通过分别计算分子和分母的导数 cos(x) 和1 得到,如图所示。. C4 `+ H/ l/ f& q5 F& S
" p9 m8 F6 E) G' v( t- `
洛必达法则为计算许多极限提供了一个强有力的方法。然而,在得出答案之前,可能需要大量的步骤。例如,考虑以下极限。
0 D8 @" S2 k% i" j9 g6 |0 p
$ p5 s0 T9 f3 X7 {1 P3 D# f }" X
由于所有的中间计算都给出了不确定的结果,这个极限要求重复应用六次洛必达法则规则才能得到答案0。
& m' T2 t7 m1 `) K0 c: F: f9 w: G7 P* O t6 y( z2 D, I
我们看到在求函数极值时,洛必达法则作为一个实用的算法,仍存在一定的局限性,因为我们不可能确定算法应该在什么时候停止!而内置函数 Limit 使用级数展开和现代算法的组合,可以对涉及指数和对数的输入(即所谓的"exp-log"类)很好地工作。事实上,在版本11 .2 中,Limit 得到了大幅更新,可以以相当全面的方式,对各种难题迎刃而解,如下所示(最后两个示例仅适用于最新版本)。
) \$ ? G9 P* ?- O% {& Y
% `. k. X/ @4 }0 W6 b
2 ?! _2 D; J6 L+ P/ d
" |/ R% }* M1 I9 E7 M! `
/ C) j+ L8 Q+ @1 [5 [0 d与序列的情况相同,周期函数和振荡函数的极限往往不存在。你可以使用 MaxLimit 和MinLimit,就像它们对应的离散情况一样,给函数的振荡设置严格的边界,就像下面这个经典的例子所示。
- [5 J2 a1 Z5 c& L
- V+ {7 h# J2 b* _) `' o( |/ P
/ s; i& F+ D; P; X# o2 J如图所示,函数在-1和1之间接近0处快速振荡。这些界限由 MaxLimit 和 MinLimit确认,而 Limit 本身返回 Indeterminate。: \) b" s' x3 Z1 p/ N- p# W% b
. c3 I& N+ F, W% v
在前面的示例中,由于函数在原点附近剧烈振荡,极限不存在。不连续函数还可以提供在某点处极限可能不存在的其他类型示例。我们这里考虑这样一个函数,它在原点和其他值上有跳跃不连续性。该函数由 SquareWave 和 FresnelS 定义,如下所示。7 S" |* S4 w+ z. |8 |+ z! C+ ^0 t
% y5 ] {/ M. _; s0 x
从这个图可以看到跳跃不连续性,这是由于函数定义中存在方波所导致。
6 B+ S1 C$ o' g# u+ i, T9 ^3 [
* z9 Y' V& R+ ^. x
我们看到,取决于我们接近原点的方向,函数在0点有极值。可以使用 Direction (方向)选项计算右侧 ("FromAbove")的极值。
# r; Z! X4 Z* [( l& v2 S- L2 |8 L
5 O$ F% e; g: I0 o同样,左侧的极值可以计算如下。
1 J5 o8 V* `7 s& K7 R( y
. v( {) n" E6 N, c极值如果存在的话,是函数的 "双面" 极值,在本例中不存在。
- P# r* e# o7 M6 g. Q7 F" Q7 k
7 G# @, z, J: _4 k4 K8 p
默认情况下,在版本11 .2 中 Limit 计算双面极值。这与早期版本不同,后者在默认情况下,从上面计算极值。因此,在不设定 Direction 选项时, 我们从Limit 得到一个不确定的结果 Indeterminate。
/ {; R& |* b5 f! w
9 @4 R6 I# ?3 M+ `6 x4 H5 Q
0 a6 _% G' N* M: {方向极值在多变量情况下更有意义,因为在更高的维度中有许多可能的方向接近给定点。例如,考虑定义如下的二元函数 f (x,y)。
7 T: c5 ~/ p3 g; w R
) k! {5 W! M/ V$ z& V4 C如果我们沿着 x 轴(由 y=0 给出)求解,则这个函数在原点的极值是 0,因为函数沿着这条线有常数值0。
/ y, h$ u0 Z& o5 P* t
" w4 Q. r4 ~, Z n- R& ]0 G; o' N1 {8 j
同样,如果我们沿着 y 轴(即x=0),则函数在原点的极值为0。1 C9 {4 c4 t7 V3 a! y' q- f' D* l+ L
6 k5 Q' f; {3 r y8 L但是,如果我们沿着线 y=x 的方向接近原点,则极限为 1/2,如下所示。
0 G% _+ M9 b1 Q! h+ X
# p* d3 x" F$ l: O! O! ^2 F更一般地,当我们沿着不同的线 y=m x 接近原点时,极值会发生变化。/ K/ s# r. ~9 c0 P/ d. C2 f
+ \4 d# q) d* f L$ |3 D5 C
极值的方向依赖性意味着不存在真正的多元极值。在版本11 .2 中,Limit 可以轻松处理多变量情况,并且快速返回该函数在原点上极值的预期答案 Indeterminate。
( L* }! H i% p4 A& v1 Q2 I4 a
( e5 ?% G0 p+ s: {% h; [曲面z=f(x,y)的图形确认函数在原点附近的行为。9 ~5 F1 h& m, _: w5 @ V! q
- V, a; ]0 Z K. M# u+ J
答案可以通过对函数直接应用 Limit 来确定。( u, }5 Z1 v% ?4 X0 @5 ?
( U6 T1 t$ M- N$ U' [9 V4 w, o v
用户每天从 Wolfram|Alpha 所输入的查询语句是我们获取多变量极值示例的一个丰富来源。我们获得了大约10万个匿名 Wolfram|Alpha 查询,然后用版本11 .2 运算。这个示例是最新版本中 Limit 能轻松求解的浩如烟海的问题之一。# l; z& f& k* g3 p" i
5 b1 v4 z6 z @ @, C
0 z6 H* `1 a$ ]0 b
浏览 Wolfram|Alpha 示例本身就乐趣无穷,我们在此与你分享其中1000个精彩示例(在后台发送“极限”,便可获取这1000个范例的下载链接)。示例图像如下所示。. C& Z; u' J. C% k; i8 C' R
# o7 Q! c! W x G( k/ }! ^% N版本11 .2 能够计算整个集合的90 %,这是相当了不起的,因为多元极限是本版本推出的最新功能。
% ?* q. w5 V4 z8 Z0 T5 s# ?9 t: i' w+ f. |
对于更大的集合——来自 Wolfram|Alpha 的100万个单变量极限问题,版本11 .2 能够求解的比例更高(96%),而版本11 .1为94 %。这两个版本之间的微小百分比差异可以解释为,大多数Wolfram|Alpha单变量极限查询与大学微积分中的第一或第二个课程有关,在任一版本中都很容易用 Limit 计算。
+ K) [ u# D; o: C x7 }1 K* \! V" a' E2 Y. x$ m! O
自 Wolfram 语言首次发布版本 1 开始(1988年),Limit 一直是最可靠的函数之一。版本11 .2 中对该函数的改进,以及 DiscreteLimit 和其他新函数的推出,为我们求解极限世界的难题提供了便利。希望您能喜欢本文简介,并欢迎您对新功能提出任何评论或建议。! O0 l$ I+ a* v" J% L2 ^
# ?. k& V4 u. l# o |