倒代换 令 `t = 1/x`. 于是 `x t = 1` `rArr x dt + t dx = 0` `rArr dt/t = -dx/x`.
Euler 代换的几何解释 被积函数有理化, 几何上就是寻找二次曲线
`C: y^2 = a x^2 + b x + c` 的一个有理参数表示 `(x(t), y(t))`,
其中 `x(t)`, `y(t)` 是有理函数.
考虑曲线 `C` 在 `(x_0, y_0)` 的割线 `l: y-y_0 = t(x-x_0)`, 为求 `l` 与
`C` 的另一交点 `P`, 将它们联立得
`(y_0 + t(x-x_0))^2 = a x^2 + b x + c`,
又代入 `y_0^2 = a x_0^2 + b x_0 + c` 得
`2 y_0 t(x-x_0) + t^2 (x-x_0)^2 = a (x^2 - x_0)^2 + b(x-x_0)`,
`2 y_0 t + t^2(x-x_0) = a(x+x_0) + b`.
总之 `P` 的坐标 `(x, y)` 可以用 `t` 的有理函数表示.
当 `t` 变化时, `P` 在曲线上运动, 就得到曲线 `C` 的有理参数表示.
`I = int sqrt(a^2 - x^2) dx`.
一种方法是是作三角代换 `x = a sin t`. 也可以将原式拆开, 第一项做分子有理化, 第二项分部积分: `I = 1/2 int sqrt(a^2 - x^2) dx + 1/2 int sqrt(a^2 - x^2) dx` `= ( 1/2 int (a^2 text(d)x) / sqrt(a^2-x^2) - 1/2 int (x^2 text(d)x) / sqrt(a^2-x^2) )` `+ ( 1/2 x sqrt(a^2 - x^2) + 1/2 int (x^2 text(d)x)/sqrt(a^2 - x^2) )` `= a^2/2 arcsin{:x/a:} + x/2 sqrt(a^2 - x^2) + C`. 这个积分的几何意义是, “从四分之一圆中减去半个弓形, 余下的面积等于一个扇形的面积加一个直角三角形的面积”. 类似地可以算出 ` int sqrt(a^2+x^2) dx = a^2/2 ln (x + sqrt(a^2+x^2)) + x/2 sqrt(a^2+x^2) + C`.
`int sqrt(1+x^4) / (x^3) dx`.
依然是分子有理化. 令 `t = x^2`, 则 `dt = 2x dx`. 原式等于 ` 1/2 int sqrt(1 + t^2)/t^2 dt = 1/2 int 1/(t^2 sqrt(1+t^2)) dt + 1/2 int 1/sqrt(1+t^2) dt`. 令 `t = sinh u`, 则 `dt = cosh u "d"u`, 从而第一项等于 ` 1/2 int ("d"u)/(sinh^2 u) = - cosh u/(2 sinh u) + C_1 = -sqrt(1+t^2) / (2t) + C_1`. 第二项积分的结果是 `1/2 ln (t + sqrt(1+t^2)) + C_2`. 所以原式等于 `1/2 ln (x^2 + sqrt(1+x^4)) - sqrt(1+x^4) / (2x^2) + C`.
`int sqrt((a+x)/(a-x)) dx`.
常规思路是作代换 `t = sqrt((a+x)/(a-x))` 将被积函数有理化, 计算量较大. 比较简单的做法是 原式 `= int (a+x)/sqrt(a^2-x^2) dx` `= a arcsin {:x/a:} - sqrt(a^2-x^2) + C`.
`int x^2 "e"^(3x) dx`.
连续使用分部积分: 不停地微分多项式项, 积分指数项, 而且隔项改变符号: 原式 `= (x^2) (1/3 "e"^(3x)) - (2x) (1/9"e"^(3x)) + (2) (1/27"e"^(3x)) + C` `= "e"^(3x)(1/3 x^2 - (2x)/9 + 2/27) + C`.
`int x^n/(n!) "e"^x dx = "e"^x sum_(k=0)^n (-1)^(n-k) x^k/(k!) + C`.
用分部积分及归纳法证明之.
`int x cos x dx`.
连续使用分部积分: 不停地微分多项式项, 积分三角项, 而且隔项改变符号: 原式 `= (x) (sin x) - (1)(-cos x) + C` `= x sin x + cos x + C`.
`int x^2 sin^3 x dx`.
(繁琐) 原式等于 ` int x^2 sin x dx - int x^2 sin x cos^2 x dx` `= - int x^2 "d" cos x + 1/3 int x^2 "d" cos^3 x` `= - x^2 cos x + 2 int x cos x dx + 1/3 x^2 cos^3 x - 2/3 int x cos^3 x dx` `= - x^2 cos x + 2 int x cos x dx + 1/3 x^2 cos^3 x - 2/3 int x cos x dx + 2/3 int x cos x sin^2 x dx` `= - x^2 cos x + 4/3 x sin x + 4/3 cos x + 1/3 x^2 cos^3 x + 2/9 int x "d" sin^3 x` `= - x^2 cos x + 4/3 x sin x + 4/3 cos x + 1/3 x^2 cos^3 x + 2/9 x sin^3 x - 2/9 int sin^3 x dx`. 因为 ` int sin^3 x dx = int (cos^2 x - 1) "d" cos x` `= 1/3 cos^3 x - cos x + C`, 所以原式等于 `- x^2 cos x + 4/3 x sin x + 14/9 cos x + 1/3 x^2 cos^3 x + 2/9 x sin^3 x - 2/27 cos^3 x + C`.
(先将三角函数做 Fourier 展开) 原式 `= int x^2/4 (3 sin x - sin 3x) dx` `= 3/4 (- x^2 cos x + 2x sin x + 2 cos x)` `-1/4 (- x^2/3 cos 3x + (2x)/9 sin 3x + 2/27 cos 3x) + C`.
`int x ln x dx`.
连续使用分部积分, 但是需要小心地写出每一项: 原式 `= x^2/2 ln x - int x^2/2 "d" ln x` `= x^2/2 ln x - 1/2 int x dx` `= x^2/2 ln x - x^2/4 + C`.
`int x arctan x dx`.
连续使用分部积分, 但是需要小心地写出每一项: 原式 `= x^2/2 arctan x - int x^2/2 "d" arctan x` `= x^2/2 arctan x - 1/2 int (1+x^2-1)/(1+x^2) dx` `= x^2/2 arctan x - x/2 + 1/2 arctan x + C`.
`I = int "e"^(ax) cos bx dx`.
分别对指数项和三角项使用分部积分然后相消: ` (a^2+b^2)I` `= a^2 int "e"^(ax) cos bx dx + b^2 int "e"^(ax) cos bx dx` `= a int cos bx "d" "e"^(ax) + b int "e"^(ax) "d" sin bx` `= a "e"^(ax) cos bx + ab int "e"^(ax) sin bx dx + b "e"^(ax) sin bx - ab int "e"^(ax) sin bx dx` `= a "e"^(ax) cos bx + b "e"^(ax) sin bx + C_0`. 所以 `I = "e"^(ax)/(a^2+b^2) (a cos bx + b sin bx) + C`.
计算
`int "e"^((a+b"i")x) dx`
`= "e"^((a+b"i")x)/(a+b"i") + C`
`= (a-b"i")/(a^2+b^2) "e"^((a+b"i")x) + C`.
分别取实部虚部得到
`int "e"^(a x) cos b x dx`
`= "e"^(a x)/(a^2+b^2) (a cos b x + b sin b x) + C`,
`int "e"^(a x) sin b x dx`
`= "e"^(a x)/(a^2+b^2) (a sin b x - b cos b x ) + C`.
求 `I_n = int sin^n x dx`, `J_n = int cos^n x dx` 的递推公式.
`n in ZZ\\{0}` 时,
`I_n = int sin^n x dx`
`= -int sin^(n-1) x "d"(cos x)`
`= -sin^(n-1) x cos x + (n-1)int cos^2 x sin^(n-2) x dx`
`= -sin^(n-1) x cos x + (n-1)int (1-sin^2 x) sin^(n-2) x dx`
`= -sin^(n-1) x cos x + (n-1) (I_(n-2) - I_n)`.
于是
`I_n = (n-1)/n I_(n-2) -1/n sin^(n-1) x cos x`.
取 `n = -n` 得
`I_(-n-2) = n/(n+1) I_(-n) - (cos x)/((n+1) sin^(n+1) x)`.
类似可得
`J_n = (n-1)/n J_(n-2) + 1/n cos^(n-1) x sin x`,
`J_(-n-2) = n/(n+1) J_(-n) + (sin x)/((n+1) cos^(n+1) x)`.
其中
`I_0 = J_0 = x + C`,
`I_1 = - cos x + C`, `quad J_1 = sin x + C`,
`I_(-1) = ln|csc x - cot x| + C`,
`quad J_(-1) = ln|sec x + tan x| + C`,
`I_(-2) = - cot x + C`, `quad J_(-2) = tan x + C`.
求 `I_n = int "e"^(-x^2) x^n dx` 的递推公式.
`I_1 = int "e"^(-x^2) x dx` `= 1/2 int "e"^(-x^2) "d"(x^2)` `= -1/2 "e"^(-x^2) + C`, 所以 `I_n = int x^(n-1) "d"(-1/2 "e"^(-x^2))` `= -1/2 "e"^(-x^2) x^(n-1) + (n-1)/2 int "e"^(-x^2) x^(n-2) dx` `= -1/2 "e"^(-x^2) x^(n-1) + (n-1)/2 I_(n-2)`.
`I = int x/(x+1)^3 dx`.
常规做法是令 `t = x+1`, 也可以直接将 `x+1` 视为整体: `I = int (x+1)/(x+1)^3 dx - int (dx)/(x+1)^3` `= -1/(x+1) + 1/(2(x+1)^2) + C`.
求 `int dx/(1+x+x^2)^2`.
记 `I_n = int x^n/(1+x+x^2)^2 dx`, 于是
`I_0 + I_1 + I_2 = int dx/(1+x+x^2) := J`,
`J = x/cdots + int (x(2x+1))/cdots^2 dx`
`= x/cdots + I_1 + 2 I_2`,
`2 I_1 + I_0 = int (2x+1)/cdots^2 dx := K`.
解得 `3 I_0 = 2J - K + (2x)/cdots`, 其中
`J = int dx/((x+1/2)^2 + 3/4)`
`= 2/sqrt 3 arctan{:(2x+1)/sqrt 3:}`,
`quad K = -1/cdots`.
求不定积分 `int dx/(1+x^n)`, 其中 `n = 3, 4, 5, 6`.
分解 `(5x-4)/((x-2)(x+1)) = A/(x-2) + B/(x+1)`.
计算分子: `5x-4 = (x+1)A + (x-2)B`. 常规做法是比较上式两端各次项系数, 得出相应的线性代数方程组. 现在使用零点代入法. 分别令 `x = -1, 2`, 代入上式: `-9 = -3B rArr B = 3`, `quad` `6 = 3A rArr A = 2`. 事实上我们得到 `A = {:(5x-4)/(x+1)|_(x=2) = 2`, `quad B = {:(5x-4)/(x-2)|_(x=-1) = 3`.
sympy.apart(1/(x*(2*x-1)**3)) # 2/(2*x - 1) - 2/(2*x - 1)**2 + 2/(2*x - 1)**3 - 1/x
一般地, 我们有如下定理:
设 `p(x), q(x)` 为多项式. 若 `a` 是 `q(x)` 的 `r` 重根, 设 `q(x) = (x-a)^r q_1(x)`, 其中 `q_1(a) != 0`. 容易知道函数 `f(x) = p(x) // q_1(x)` 在 `x = a` 处全纯, 将它在这一点 Taylor 展开得 `f(x) = sum_(n ge 0) A_n (x-a)^n`, `quad A_n = (f^((n))(a))/(n!)`. 于是有理分式 `p(x) // q(x)` 具有分解式 `(p(x))/(q(x)) = (f(x))/(x-a)^r` `= sum_(0 le n lt r) (f^((n))(a))/(n!) (x-a)^(n-r) + **/(q_1(x))`, 特别当 `r = 1` 时有 `(p(x))/(q(x)) = (f(a)) / (x-a) + **/(q_1(x))`. `r = 2` 时有 `(p(x))/(q(x)) = (f'(a)) / (x-a) + (f(a))/(x-a)^2 + **/(q_1(x))`. 如果极点的阶数在 2 阶以上 (`r gt 2`),建议使用幂级数除法进行 Taylor 展开,避免计算复杂的高阶导数.
分解 `(2x^2)/(x^2-1)^2 = A/(x+1) + B/(x+1)^2 + C/(x-1) + D/(x-1)^2`.
先在 `x=-1` 处展开, 令 `f(x) = (2x^2)/(x-1)^2`, 于是 `A = f'(-1)` `= {:(4x(x-1)^2 - 4(x-1)x^2)/(x-1)^4|_(x=-1) = -1/2`, `quad B = f(-1) = 1/2`. 再考虑 `x=1` 处, 令 `g(x) = (2x^2)/(x+1)^2`, 有 `C = g'(1)` `= {:(4x(x+1)^2 - 4(x+1)x^2)/(x+1)^4|_(x=1) = 1/2`, `quad D = g(1) = 1/2`.
分解 `16/((x+3)^3(x-1)) = A_0/(x+3)^3 + A_1/(x+3)^2 + A_2 /(x+3) + B/(x-1)`.
-4 | -1 | -1/4 | |
-4 | 16 | 4 | 1 |
1 | -4 | -1 |
`1/(1+-x^n)` 在 `CC` 上的的有理分式分解为 `1/(1+-x^n) = -1/n sum_r r/(x-r)`, 其中 `r` 取遍分母的 `n` 个根. 因此 `int dx/(1+-x^n) = -1/n sum_r r ln (x-r) + C`.
只证 `1//(1+x^n)` 的情形. 记 `omega = "e"^(pi"i"//n)`, 则 `omega^n = -1`, 且 `x^n+1` 的 `n` 个根为 `r_k = omega^(2k+1)`, `quad k = 0, 1, cdots, n-1`. 由, `1/(1+x^n) = sum_(0 le k lt n) A_k/(x-r_k)`, 其中 `A_k = prod_(0 le j lt n; j != k) (r_k-r_j)^-1` `= prod (omega^(2k+1) - omega^(2j+1))^-1` `= omega^((2k+1) (1-n)) prod (1-omega^(2(j-k)))^-1` `= -omega^(2k+1) prod_(0 lt j lt n) (1-omega^(2j))^-1` `= -r_k/n`. 最后一步利用了恒等式 `prod_s (1-s) = n`, 其中 `s` 取遍 `x^n-1` 除了 1 以外的所有根.
奥斯特洛格拉德斯基定理 (奥氏定理) [来自 猎户座の数学] 设 `p(x)//q(x)` 为实系数有理真分式, 则 `int (p(x))/(q(x)) dx` `= (p_1(x))/(q_1(x)) + int (p_2(x))/(q_2(x)) dx`, 其中 `q_1 = gcd(q, q')`, `q = q_1 q_2`. 因此 `q_2` 的因式均为一重. 例如 `x-a` 是 `q` 的 `m` 重因式, 则它在 `q_1` 的重数为 `m-1`, 在 `q_2` 的重数为 `1`. 等号右边第一项称为积分 `int p(x)//q(x) dx` 的有理部分, 第二项仍为有理真分式的积分, 它是超越函数, 称为超越部分.
考虑 `p(x)//q(x)` 的部分分式分解:
`(p(x))/(q(x))`
`= sum_j sum_k a_(j k)/(x-x_j)^k`
`+ sum_j sum_k (b_(j k) x + c_(j k))/(x^2+p_(j k) x + q_(j k))^k`.
如果分母均为一重因式, 则
`int dx/(x-x_j) = ln|x-x_j| + C`,
`int (b x + c)/(x^2 + p x + q) dx`
`= b/2 ln (x^2 + p x + q) + (2c-p b)/sqrt(4q-p^2) arctan{:(2x+p)/sqrt(4q-p^2):} + C`
均为超越函数.
反之若分母的重数 `k gt 1`, 则
`int dx/(x-x_j)^k = 1/(1-k) 1/(x-x_j)^(k-1) + C`,
`int (b x + c)/(x^2 + p x + q)^k dx`
`==^(u=x+p//2) b int (u "d"u)/(u^2 + a^2)^k`
`+ (c - p b//2) int ("d"u)/(u^2+a^2)^k`.
`= b/(2(1-k)) 1/(u^2+a^2)^(k-1)`
`+ (c - p b//2) I_k`.
其中
`I_k = int ("d"u)/(u^2+a^2)^k`,
`I_(k+1) = 1/(2k a^2) u/(u^2+a^2)^k + (2k-1)/(2k a) I_k`.
于是 `I_k = R_1(x) + A_k I_1`, 其中 `R_1(x)` 为有理函数, `A_k` 是常数,
`I_1 = int ("d"u)/(u^2+a^2)` 是超越函数.
综上知 `int p(x)//q(x) dx` 的超越部分, 分母的重数均为 1.
而且, 有理部分的分母, 其重数比积分前降低了一次 (从 `k` 次变成 `k-1` 次).
将有理部分和超越部分分别通分, 可知奥氏公式成立, 且有 `q = q_1 q_2`.
由于 `q_1 = gcd(q, q')`, 可记 `q' = q_1 h`. 对奥氏公式右边的有理部分求导得 `"d"/dx p_1/q_1` `= "d"/dx (p_1 q_2)/q` `= ((p_1 q_2)' q - q' p_1 q_2)/q^2` `= ((p_1 q_2)' - h p_1 q_2)/q`. 于是分母为 `q`, 而不是比 `q` 次数高的多项式, 和积分前的函数 `p//q` 相符.
求 `int (x dx)/((x-1)^2(x+1)^3)`
待定系数 `x/((x-1)^2(x+1)^3) = ((A x^2+B x+C)/((x-1)(x+1)^2))' + (D x+E)/((x-1)(x+1))`, 等号右边的两项中, 第一项已经在积分号外, 第二项的积分相比原式已经大大简化.
`int R("e"^x) dx`, `R` 为有理函数.
令 `t = "e"^x`, 则 `x = ln t`, `dx = dt/t`. 原式 `= int (R(t))/t dt`.
`int R(tan x) dx`, `R` 为有理函数.
令 `t = tan x`, 则 `x = arctan t`, `dx = dt/(1+t^2)`. 原式 `= int (R(t))/(1+t^2) dt`.
`int P(sin x, cos x) dx`, `P` 为多项式.
参看 Chebyshev 多项式的反向表示.
将 `P(sin x, cos x)` 做 Fourier 展开, 再积分.
通项 `sin^m x cos^n x` 先利用 `sin^k x cos^k x = ((sin 2x)/2)^k`
将其展开, 再由积化和差公式
`2 sin n x cos m x = sin(n+m)x + sin(n-m)x`,
`2 cos n x cos m x = cos(n-m)x + cos(n+m)x`,
`2 sin n x sin m x = cos(n-m)x - cos(n+m)x`.
把两个展式相乘. 例如
`sin^4 x cos^7 x`
`= ((sin 2x)/2)^4 cos^3 x`
`= 1/128 (3 - 4 cos 4x + cos 8x) 1/4 (3 cos x + cos 3x)`
`= 1/512 (9 cos x + 3 cos 3x - 6(cos 3x + cos 5x):}`
`- 2(cos x + cos 7x) + 3/2(cos 7x + cos 9x)`
`+ {:1/2(cos 5x + cos 11x))`
`= 1/1024 (14 cos x -6 cos 3x -11 cos 5x:}`
`- {:cos 7x + 3 cos 9x + cos 11x)`.
`int R(sin x, cos x) dx`, `R` 为有理函数.
(万能代换) 令 `t = tan{:x/2:}`, 则 `x = 2 arctan t`, `dx = (2 dt)/(1+t^2)`, `sin x = (2t)/(1+t^2)`, `tan x = (2t)/(1-t^2)`, `cos x = (sin x)/(tan x) = (1-t^2)/(1+t^2)`.