2

我正在尝试为数学中的非线性演化方程规定自由边界条件,并且我想作为我所做的是否正确的第二意见。

边界条件已标有注释,即(自由边界条件

我还想为固定边界条件运行它。

Needs["VectorAnalysis`"]
Needs["DifferentialEquations`InterpolatingFunctionAnatomy`"];
Clear[Eq5, Complete, h, S, G, E1, K1, D1, VR, M]
Eq5[h_, {S_, G_, E1_, K1_, D1_, VR_, M_}] := \!\(
\*SubscriptBox[\(\[PartialD]\), \(t\)]h\) + 
    Div[-h^3 G Grad[h] + 
      h^3 S Grad[Laplacian[h]] + (VR E1^2 h^3)/(D1 (h + K1)^3)
        Grad[h] + M (h/(1 + h))^2 Grad[h]] + E1/(h + K1) == 0;
SetCoordinates[Cartesian[x, y, z]];
Complete[S_, G_, E1_, K1_, D1_, VR_, M_] := 
  Eq5[h[x, y, t], {S, G, E1, K1, D1, VR, M}];
TraditionalForm[Complete[S, G, E1, K1, D1, VR, M]]




  L = 185.62; TMax = 100; km = 0.0381; 
Off[NDSolve::mxsst]; 
Off[NDSolve::ibcinc]; 
hSol = h /. NDSolve[{Complete[100, 0, 0, 0, 0.001, 0, 5], 



(*FREE BOUNDARY CONDITIONS*)

     Derivative[2, 0, 0][h][0, y, t] == 0, 
     Derivative[2, 0, 0][h][L, y, t] == 0, 
     Derivative[0, 2, 0][h][x, 0, t] == 0, 
     Derivative[0, 2, 0][h][x, L, t] == 0, 
     Derivative[3, 0, 0][h][0, y, t] == 0, 
     Derivative[3, 0, 0][h][L, y, t] == 0, 
     Derivative[0, 3, 0][h][x, 0, t] == 0, 
     Derivative[0, 3, 0][h][x, L, t] == 0, 

    (*FREE BOUNDARY CONDITIONS*)

     h[x, y, 0] == 1 + (-0.05*Cos[2*Pi*(x/L)] - 0.05*Sin[2*Pi*(x/L)])*
                 Cos[2*Pi*(y/L)]}, 
    h, {x, 0, L}, {y, 0, L}, {t, 0, TMax}][[1]]
hGrid = InterpolatingFunction[hSol]; 
{TMin, TRup} = InterpolatingFunctionDomain[hSol][[3]]
4

1 回答 1

1

阅读评论达成的共识是,上面代码中自由边界条件的实现是正确的。

更多详细信息应在涉及材料力学或材料强度的书籍中参考弯曲力矩和剪应力图的章节中获得,其中经常使用自由自由或自由固定或固定固定边界条件。

于 2012-01-12T19:08:41.300 回答