Tanh函数展开法

来自testwiki
跳转到导航 跳转到搜索

Template:NoteTA Tanh 函数展开法是目前求解非线性偏微分方程行波解的最强劲的和行之有效的方法。1992年数学家 Malfliet 首先应用 tanh 展开法[1] 运用这个方法要进行的大量繁杂的运算,必须借助MapleMathematicaMatlab等计算机代数系统。

设一个非线性偏微分方程可以用下列表述:

ψ(u,ut,ux,utt,uxx,utx)=0

作变数代换:

u(x,t)U(ξ)

ξ=k*(xc*t)

得到常微分方程

ψ(U(ψ),kc*dUdψ,k*dUdψ,k2*c2*d2Udψ2,k2*d2Udψ2,k3*c3*d3Udψ3,k3*d3Udψ3)=0

作Malfliet 的 tanh 函数代换,引入新函数:

Y=tanh(ξ)

由此:

dYdξ=1tanh2(ξ)=1Y2

dF(Y)dξ=dF(Y)dY*dYdξ=dF(Y)dY*(1Y2)

显然

ddξ=L=(1Y2)*ddY

d2dξ2=L2=2*(1Y2)*Y*ddY+(1Y2)2*d2dY2

依此类推。 设 F(Y)=Σ(a_{i}*Y^i)

代入 常微分方程 ψ(U(ψ),kc*dUdψ,k*dUdψ,k2*c2*d2Udψ2,k2*d2Udψ2,k3*c3*d3Udψ3,k3*d3Udψ3)=0

得到Y的多项式。用机械代数法或吴文俊消元法解多项式,反代入原式,即得偏微分方程的行波解。

实例

用tanh函数展开法求KdV方程的行波解[2]

tϕ+6ϕxϕ+x3ϕ=0

作行波代换

tr1:=t=tau,u=U(ξ),x=ξ/k+c*tau 得常微分方程:


ckdU(ξ)dξ+6kU(ξ)dU(ξ)dξ+k3d3U(ξ)dξ3=0

对ξ积分,得:

ckU(ξ)+3kU(ξ)2+k3d(U(ξ)d2ξ2=0U(ξ)=F(Y)得:

ckF(Y)+3kF(Y)2+k3(1Y2)(2Yd(F(Y)dY+(1Y2)d2(F(Y)d2Y)=0

U(ξ)=F(Y)=a[0]+a[1]Y+a[2]Y2+a[3]Y3+a[4]Y4+a[5]Y5++a[M]YM+…… 得: ck(a[0]+a[1]Y+a[2]Y2+a[3]Y3+a[4]Y4+a[5]Y5++a[M]YM)+3k(a[0]+a[1]Y+a[2]Y2+a[3]Y3+a[4]Y4+a[5]Y5++a[M]YM)2+k3(1Y2)(2Y(a[1]+2a[2]Y+3a[3]Y2+4a[4]Y3+5a[5]Y4++Ma[M]YM1)+(1Y2)(2a[2]+6a[3]Y+12a[4]Y2+20a[5]Y3+30a[6]Y4))

由此得 M=2;而且:

(3ka[2]2+6k3a[2])Y4+(2k3a[1]+6ka[1]a[2])Y3+(cka[2]+3ka[1]2+6ka[0]a[2]8k3a[2])Y2+(cka[1]+6ka[0]a[1]2k3a[1])Ycka[0]+3ka[0]2+2k3a[2]=0

令系数为0,得下列关于 a[0],a[1],a[2],c,k 的五元多项式方程组:

cka[0]+3ka[0]2+2k3a[2]=0

cka[1]+6ka[0]a[1]2k3a[1]=0

>cka[2]+3ka[1]2+6ka[0]a[2]8k3a[2]=0

2k3a[1]+6ka[1]a[2]=0

3ka[2]2+6k3a[2]=0

利用Maple,Mathematica,Matlab等计算机代数系统,解多项式方程组,得两组非平凡解:

a[0]=2k^2,a[1]=0,a[2]=-2k^2,c=4k^2;

a[0]=(2/3)k^2,a[1]=0,a[2]=-2k^2,c=-4k^2;

于是KdV 方程的行波解为:

u(x,t)=2k2(1tanh2(k(x4k2t))=2k2sech2(k(x4k2t))

u(x,t)=23k2(13tanh2(k(+4k2t)))

推广

Malfliet 的tanh 函数展开法被后人推广到 三角函数、雅可比橢圓函數、魏爾斯特拉斯橢圓函數。

JacobiCN, JacobiDN, JacobiNC, JacobiND, JacobiNS, JacobiSN, WeierstrassP, arcsinh, cos, cosh, cot, coth, csc, csch, exp, ln, sec, sech, sin, sinh, tan, tanh 等。

软件包

Maple商业计算机代数系统内包括一个求解偏微分方程的软件包,可用于多种非线性性偏微分方程,求得显式解析解。这个软件包称为为TWSolutions,功能丰富,可求多数非线性偏微分方程的行波解,但仍非万能,对有些非线性偏微分方程无解或只有平凡解[3]

基本用法

tws:={TWSolutions(pdes,functions = [arcsinh, cos, cosh, cot, coth, csc, csch, exp, identity, ln, sec, sech, sin, sinh, tan, tanh, JacobiCN, JacobiDN, JacobiNC, JacobiND, JacobiNS, JacobiSN])};

其中 pdes 代表 非线性偏微分方程,或非线性偏微分方程组;若function= 列出所有可用的函数集合,常可一下子给出十几个到几十个解如果不写"function=",则只作tanh展开[3]。用包括所有可用函数的Tanh 函数展开法在Intel Core i7笔记本电脑计算,一道非线性偏微分方程往往需时几十分以至十几小时。

中国数学家李志斌写了一个名为RATH 的Maple学术软件包,用双曲函数展开法和吴文俊消元解非线性偏微分方程 [4]软件包RATH可以下载[5]

参考文献

  1. W. Malfliet, Solitary Wave Solution of Nonlinear wave equation, Am J.of Physics 60(7) 1992,650-654
  2. Graham W Griffiths, William E.Schiesser, Traveling Wave Analysis of Partial Differential Equations p393-396 Academic Press 2012
  3. 3.0 3.1 Graham Griffiths, p436-437 Maple Built-in Procedure TWSolutions
  4. 李志斌 《非线性数学物理方程的行波解》第119-130
  5. Template:Cite web

Template:非线性偏微分方程理论与解法