24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 256  |  回复: 2
当前主题已经存档。
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

zhanghuashan

[交流] 【求助】请教Mathematica问题!

下面两段程序,感觉应该是同样的结果,但是却不同。请高手指点!
第一段程序:
\!\(\*
  RowBox[{\(c\_11 = \((2.1`30)\)*10^11; c\_13 = \((1.05`30)\)*10^11;
          c\_33 = \((2.11`30)\)*10^11; c\_44 = \((0.423`30)\)*10^11;\),
        "\[IndentingNewLine]", \(e\_15 = \(-0.48`30\); e\_31 = \(-0.573`30\); \
e\_33 = 1.321`30;\), "\[IndentingNewLine]", \(pϵ\_11 = 8.55`30;
    pϵ\_33 = 10.2`30;\), "\[IndentingNewLine]", \(pρ =
    5670`30;\), "\[IndentingNewLine]",
    RowBox[{\(FPiezo[GC_]\), ":=",
      RowBox[{"Module", "[",
        RowBox[{\({Tp, K, DK, a1, a2, a3, a4, b, de, V}\), ",",
          RowBox[{\(V = GC\), ";", "\[IndentingNewLine]",
            RowBox[{"K", "=",
              RowBox[{"(", GridBox[{
                    {\(c\_11 + c\_44*b\^2 - pρ*
    V\^2\), \(\((c\_13 + c\_44)\)*b\), \(\((e\_15 + e\_31)\)*b\)},
                    {\(\((c\_13 + c\_44)\)*b\), \(c\_44 + c\_33*b\^2 - pρ*
      V\^2\), \(e\_15 + e\_33*b\^2\)},
                    {\(\((e\_15 + e\_31)\)*
        b\), \(e\_15 + e\_33*b\^2\), \(-\((pϵ\_11 + pϵ\_33*b\^2)\)\)}
                    }], ""}]}],
      ";", "\[IndentingNewLine]", \(DK = Det[K]\), ";",
             "\[IndentingNewLine]", \(a1 = Coefficient[DK, b,
6]\), ";", \(a2 = Coefficient[DK, b, 4]\), ";", \(a3 = Coefficient[DK,
             b, 2]\),
            ";", \(a4 = Coefficient[DK, b, 0]\),
                ";", "\[IndentingNewLine]", \(Tp =
            Solve[a1\ x^6 +
              a2\ x^4 + a3\ x^2 + a4 == 0, x]\), ";
                ", "\[IndentingNewLine]", \(pdecay =
              Array[de, {1, 6}]\), ";
                ", "\[IndentingNewLine]", \(Do[pdecay[\([1, m]\)] = Tp[\([m, \
1, 2]\)], {m, 6}]\),
            ";", "\[IndentingNewLine]",
                 "pdecay"}]}], "]"}]}], "\[IndentingNewLine]", \(F1[GC_] :=
                    Module[{}, temp = FPiezo[GC];
            Im[temp[\([1, 1]\)]]]\), "\[IndentingNewLine]", \(Plot[
            F1[x], {x, 0, 2000}]\)}]\)
第二段程序:
\!\(\*
  RowBox[{\(c\_11 = \((2.1`30)\)*10^11; c\_13 = \((1.05`30)\)*10^11;
          c\_33 = \((2.11`30)\)*10^11; c\_44 = \((0.423`30)\)*10^11;\),
        "\[IndentingNewLine]", \(e\_15 = \(-0.48`30\); e\_31 = \(-0.573`30\); \
e\_33 = 1.321`30;\), "\[IndentingNewLine]", \(pϵ\_11 = 8.55`30;
    pϵ\_33 = 10.2`30;\), "\[IndentingNewLine]", \(pρ =
    5670`30;\), "\[IndentingNewLine]",
    RowBox[{\(FPiezo[GC_]\), ":=",
      RowBox[{"Module", "[",
        RowBox[{\({Tp, K, DK, a1, a2, a3, a4, b, de, V}\), ",",
         
    RowBox[{\(V = GC\), ";", "\[IndentingNewLine]", \(Teq =
       Solve[a1\ x^6 + a2\ x^4 +
    a3\ x^2 + a4 == 0, x]\), ";", "\[IndentingNewLine]",
            RowBox[{"K", "=",
              RowBox[{"(", GridBox[{
                    {\(c\_11 +
    c\_44*b\^2 - pρ*V\^2\), \(\((c\_13 + c\_44)\)*b\), \(\((e\_15 + e\_31)\)*
      b\)},
                    {\(\((c\_13 + c\_44)\)*b\), \(c\_44 + c\_33*
        b\^2 - pρ*V\^2\), \(e\_15 + e\_33*b\^2\)},
                    {\(\((e\_15 +
       e\_31)\)*b\), \(e\_15 + e\_33*b\^2\), \(-\((pϵ\_11 + pϵ\_33*b\^2)\)\)}
                    }], ""}]}], ";", "\[IndentingNewLine]", \(DK = Det[K]\),
            ";", "\[IndentingNewLine]", \(Tp = Teq //. {a1 -> Coefficient[DK,
              b, 6], a2 -> Coefficient[DK, b, 4],
             a3 -> Coefficient[DK, b, 2], a4 -> Coefficient[DK, b,
              0]}\), ";",
                "\[IndentingNewLine]", \(pdecay = Array[de, {1, 6}]\), ";",
                      "\[IndentingNewLine]", \(Do[pdecay[\([1, m]\)] = \
Tp[\([m, 1, 2]\)], {m, 6}]\),
                    ";", "\[IndentingNewLine]", "pdecay"}]}], "]"}]}],
                    "\[IndentingNewLine]", \(F1[GC_] := Module[{}, temp =
              FPiezo[GC]; Im[
            temp[\([1, 1]\)]]]\), "\[IndentingNewLine]", \(Plot[F1[x], {x,
              0, 2000}]\)}]\)
这两段程序的区别是,第一段程序直接求解了一个系数已经确定了的一员六次方程,儿第二段程序是先求解了一个系数待定的一员六次方程再将系数值代入。

[ Last edited by kuhailangyu on 2008-12-10 at 08:18 ]
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

mshwangg

至尊木虫 (正式写手)

★ ★
wuguocheng(金币+2,VIP+0):谢谢参与 8-11 13:02
你的问题在于用Solve函数分别作解析解和数值解。而使用Solve函数作解析解不能保证每次求解所得到的解的顺序都是一样的,即第一次求解得到解的顺序是x1,x2,x3,x4,x5,x6,第二次求解是顺序可能变成了x1,x2,x3,x4,x6,x5。另外作解析解和数值解得到的解的顺序也是不一样的。而你的两个程序中都只是选取第一个解作图,显然会得到不一样的结果。你可以自己验证上述说法。
    因此,有两个建议:1、做数值解,这样解的顺序能保持一致,而且计算速度快;2、对解出的6个解作合理性判断,舍去不符合要求的解。
3楼2009-03-28 17:25:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 3 个回答

abingchem

木虫 (著名写手)


wuguocheng(金币+1,VIP+0):谢谢参与 8-11 13:02
这格式太难懂了,附上伪代码啊
冰是从最寒冷的那天开始融化的
2楼2009-03-27 14:58:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿北京化工大学,初试成绩350求调剂 +4 沿岸?贝壳 2026-04-04 4/200 2026-04-04 10:01 by 唐沐儿
[考研] 求调剂 +4 xzghyuj 2026-04-04 4/200 2026-04-04 09:51 by 唐沐儿
[考研] 26调剂 086003 +6 失活的细胞 2026-04-04 6/300 2026-04-04 09:50 by zhangdingwa
[考研] 0856调剂 +8 曲听筠 2026-03-30 8/400 2026-04-04 08:46 by tianyyysss
[考研] 工科求调剂 +10 11ggg 2026-04-03 10/500 2026-04-03 22:35 by syjjj0321
[考研] 调剂 +5 asdasdassda 2026-04-03 6/300 2026-04-03 20:27 by 岸上的一条鱼
[考研] 070300一志愿211,312分求调剂院校 +16 小黄鸭宝 2026-03-30 16/800 2026-04-03 19:53 by lijunpoly
[考研] 一志愿南昌大学324求调剂 +13 hanamiko 2026-04-01 13/650 2026-04-03 18:30 by ls刘帅
[考研] 土木水利328分求调剂 +6 疾风知劲草666 2026-04-02 6/300 2026-04-03 11:38 by znian
[考研] 08工科275分求调剂 +14 AaAa7420 2026-03-31 14/700 2026-04-03 11:13 by cocolv
[考研] 调剂 +3 osbbx 2026-04-02 3/150 2026-04-03 07:47 by cc8418
[考博] 材料工程专业硕士申博 +3 麟正宇 2026-03-30 3/150 2026-04-02 15:04 by greychen00
[考研] 一志愿同济大学323分(080500)求调剂 +6 yikeniu 2026-04-01 6/300 2026-04-02 14:19 by smileboy2006
[考研] 考研调剂0702 +3 梅子味晚霞 2026-03-28 3/150 2026-04-02 10:10 by jp9609
[考研] 0710生物学求调剂 +9 manman511 2026-04-01 9/450 2026-04-02 10:00 by zxl830724
[考研] 0856 335分 +9 cccchenso 2026-03-29 9/450 2026-03-31 16:37 by lishahe
[考研] 269求调剂 +4 我想读研11 2026-03-31 4/200 2026-03-31 10:04 by cal0306
[考研] 274求调剂 +6 xiao爱同学 2026-03-30 6/300 2026-03-31 10:04 by cal0306
[考研] 一志愿中海洋320化学工程与技术学硕求调剂 +8 披星河 2026-03-30 8/400 2026-03-31 08:53 by lbsjt
[考研] 调剂 +4 GK72 2026-03-30 4/200 2026-03-30 20:32 by dick_runner
信息提示
请填处理意见