首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用版本9时,Mathematica代码不起作用

使用版本9时,Mathematica代码不起作用
EN

Stack Overflow用户
提问于 2014-08-07 03:30:28
回答 1查看 344关注 0票数 1

我已经编写了以下代码,在Mathematica 8中运行正常。但是,当我在Mathematica 9中打开完全相同的笔记本时,出现以下消息:"InterpolatingFunction::dmval:“输入值{0.000408163}位于插值函数中的数据范围之外。将使用外推法。",并且没有图表。

代码如下:

代码语言:javascript
复制
Manipulate[
 ParametricPlot[
  Evaluate[{x1[t], a YP[[2]]/YP[[1]] x1[t] + (1 - a) YP[[2]] x3[t]} /.
    Quiet@NDSolve[
      {x1'[t] == x2[t],
       x2'[t] == -1/
         Mass (c x2[t] + 
           a YP[[2]]/YP[[1]] x1[t] + (1 - a) YP[[2]] x3[t] - 
           Fmax Sin[(2 π)/T t]),
       x3'[t] == 
        x2[t]/YP[[
          1]] (1 - Abs[x3[t]]^n (γ Sign[x2[t] x3[t]] + (1 - γ))),
       x1[0] == 0,
       x2[0] == 0,
       x3[0] == 0},
      {x1[t], x2[t], x3[t]},
      {t, 0, tTotal}]],
  {t, 0, tTotal},
  ImageSize -> {450, 450}, PlotRange -> 10, AxesLabel -> {"u", "F"}],
 {{tTotal, 20, "Total time"}, 0.5, 100, Appearance -> "Labeled"},
 {{Mass, 2.86, "m"}, 0.1, 10, 0.01, Appearance -> "Labeled"},
 {{T, 4.0, "T"}, 0.1, 10, 0.01, Appearance -> "Labeled"},
 {{Fmax, 8.0, "Fmax"}, 0.1, 10, 0.01, Appearance -> "Labeled"},
 {{n, 2.0, "n"}, 0.1, 10, 0.01, Appearance -> "Labeled"},
 {{c, 0.0, "c"}, 0.0, 10, 0.01, Appearance -> "Labeled"},
 {{a, 0.05, "a"}, 0.0, 1, 0.01, Appearance -> "Labeled"},
 {{γ, 0.5, "γ"}, 0.01, 1, 0.01, Appearance -> "Labeled"},
 {{YP, {0.111, 2.86}}, {0, 0}, {10, 10}, Locator}]

有什么想法吗?

提亚

EN

回答 1

Stack Overflow用户

发布于 2014-08-07 19:35:05

总结问题。这在版本7和8中有效,但在版本9中失败:-

代码语言:javascript
复制
tTotal = 20; Mass = 2.86; T = 4.0;
Fmax = 8.0; n = 2.0; c = 0.0; a = 0.05;
\[Gamma] = 0.5; YP = {0.111, 2.86};

NDSolve[{x1'[t] == x2[t],
  x2'[t] == -1/Mass (c x2[t] + a YP[[2]]/YP[[1]] x1[t] +
      (1 - a) 2.86 x3[t] - Fmax Sin[(2 \[Pi])/4.0 t]),
  x3'[t] == x2[t]/0.111 (1 -
      Abs[x3[t]]^2.0 (\[Gamma] Sign[x2[t] x3[t]] + (1 - \[Gamma]))),
  x1[0] == 0, x2[0] == 0, x3[0] == 0},
 {x1[t], x2[t], x3[t]}, {t, 0, 20}]

在版本9中使用更具体的方法。

代码语言:javascript
复制
NDSolve[... , Method -> {"DiscontinuityProcessing" -> False}]
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25168619

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档