网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
12月21日漏签0天
mathematica吧 关注:19,919贴子:74,210
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 3回复贴,共1页
<<返回mathematica吧
>0< 加载中...

在NDSolve中调用含参变量的NIntegrate

  • 只看楼主
  • 收藏

  • 回复
  • Repentanze
  • 还未摆脱
    8
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
我简化一下我的问题:
我定义了一个含参的数值积分函数
f[R_]:=NIntegrate[R,{r,0,10}]
然后我希望在NDSolve中调用它
sol=NDSolve[{a'[t]==f[t],a[0]==1},{a},{t,0,1}]
然而此时会报错NIntegrate::inumr。我明白问题出现的原因,但是我不知道怎么解决。
注:两个函数都是well-defined,我在这里简化了一下。


  • Repentanze
  • 还未摆脱
    8
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
自我回复:
我没有找到直接的解决方案,但是我用一个间接的方法实现了我的目标。
方案是使用插值函数:
List1 = Table[f[i], {i, 0, 30, 1];
f1 = ListInterpolation[List1, {{0, 30}}];
sol=NDSolve[{a'[t]==f1[t],a[0]==1},{a},{t,0,1}];
其中的f1是使用插值函数得到的数值函数,因此可以在ndsolve中使用。


2025-12-21 09:49:09
广告
不感兴趣
开通SVIP免广告
  • 无影东瓜
  • 小吧主
    12
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
报错是NIntegrate得到非数值结果,出现原因是R作为符号而非数值被传入,解决方法很简单,给f添加一个NumericQ判断即可
ClearAll[f];
f[R_?NumericQ] := NIntegrate[R, {r, 0, 10}]
sol = NDSolve[{a'[t] == f[t], a[0] == 1}, {a}, {t, 0, 1}]
另:在NDSolve中调用NIntegrate的时间开销可能会非常大,所以你的间接解决方案在某种意义上其实是更好的方案,只要注意取点够密让插值函数误差不要太大就可以


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 3回复贴,共1页
<<返回mathematica吧
分享到:
©2025 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示