24小时热门版块排行榜    

Znn3bq.jpeg
查看: 591  |  回复: 3

ilovexiaomu

金虫 (小有名气)

[求助] mathematica中如何实现c++程序转换为mathematica语句 已有1人参与

各位虫友:
我遇到了一个比较复杂的2重积分,我的积分函数表达式如下:
如图片所示
在对上面的kx及ky求二重积分时无法用mathematica中的语句直接计算,因为积分函数相当复杂,用直接的mathematica语句无法积分,在网上查阅了一个用c++编写出来的版本,现在我想把他转换成mathematica的语句。希望对此熟悉的朋友能帮忙转换一下。
c++语句如下:
/* ============================================================= *
* trapzd2d. Computes the nth stage of refinement of an extended *
* 2d trapezian rule. func is a pointer to a function with two   *
* real variables, it is to be integrated                         *
* between ax<=x<=ay and ay<=y<=by. Works analogous to the one-  *
* dimensional trapzd (Numerical Recipes, p.137).                 *
* ============================================================= */

typedef double real;      /* can be put e.g. to float if single precission is sufficient */
#define FUNC(x,y) ((*func)(x,y))

real trapzd2d(real (*func)(real, real), real ax, real bx, real ay, real by, int n)
{
   real x, y, tnm, sum, delx, dely;
   static real s;
   int it, j, k;

   if (n==1) {
      /* 1. stage: Function is evaluated only at the corners. */
      return (s=0.25*(bx-ax)*(by-ay)*(FUNC(ax,ay)+FUNC(bx,ay)+FUNC(ax,by)+FUNC(bx,by)));
   } else {
      for (it=1, j=1; j<n-1; j++) it <<= 1;
      tnm = it;
      /* delx, dely are the spacings of the points to be added */
      delx = (bx-ax)/tnm;
      dely = (by-ay)/tnm;
      x = ax + 0.5*delx;
      /* Evaluates function at the borders of the integration area */
      for (sum=0.0, j=1; j<=it; j++, x+=delx) {
         sum += 0.5*(FUNC(x,ay) + FUNC(x,by));
      }
      y = ay + 0.5*dely;
      for (j=1; j<=it; j++, y+=dely) {
         sum += 0.5*(FUNC(ax,y) + FUNC(bx,y));
      }
      /* Interiour of the area */
      x = ax + 0.5*delx;
      for (j=1; j<=it; j++, x+= delx) {
         y = ay + 0.5*dely;
         for (k=1; k<=it; k++, y+=dely) {
            sum += FUNC(x,y);
         }
      }
      x = ax + delx;
      for (j=1; j<it; j++, x+=delx) {
         y = ay + 0.5*dely;
         for (k=1; k<=it; k++, y+=dely) {
            sum += FUNC(x,y);
         }
      }
      x = ax + 0.5*delx;
      for (j=1; j<=it; j++, x+=delx) {
         y = ay + dely;
         for (k=1; k<it; k++, y+=dely) {
            sum += FUNC(x,y);
         }
      }
      /* Replace s by its refined value */
      s = 0.25*(s + (bx-ax)*(by-ay)*sum/(tnm*tnm));
      return s;
   }
}

#undef FUNC

或者各位虫友能有更好的解决这个积分的办法,也可以麻烦告知,多谢
mathematica中如何实现c++程序转换为mathematica语句
积分函数.png
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

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

xzczd

木虫 (小有名气)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
ilovexiaomu: 金币+2, 谢谢,我下来试试 2015-05-13 16:35:27
既然你只是要数值积分的话那用NIntegrate不就得了吗?还有就算是Integrate你那语法也明显是错的。用软件前要仔细看看自带帮助!
小木虫Mathematica版块已毁(当然原本也不咋的),建议大家前往百度贴吧或Stackexchange。
2楼2015-05-13 10:38:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

walk1997

金虫 (著名写手)

目测这种2维积分对Mathematica应该很简单的吧
另外 看C代码的名字,可能用的是比较简单的求和规则做积分
建议自己先把被积函数的表达式写成Mathematica代码 这样别人也方便调试
3楼2015-05-13 16:23:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ilovexiaomu

金虫 (小有名气)

问题已经解决
4楼2015-05-19 11:38:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 ilovexiaomu 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 302分求调剂 +9 凡语祈愿 2026-04-08 10/500 2026-04-10 23:26 by 314126402
[考研] 本科南方医科大学 一志愿985 药学学硕284分 求调剂 +4 弱水听文 2026-04-09 4/200 2026-04-10 22:01 by doctff
[考研] 本9 一志愿西工大085601 324求调剂 +5 wysyjs25 2026-04-10 5/250 2026-04-10 16:57 by luoyongfeng
[考研] 298求调剂 +13 钉叮咚冬瓜 2026-04-09 13/650 2026-04-10 15:49 by jiajinhpu
[考研] 314求调剂 +23 wakeluofu 2026-04-09 24/1200 2026-04-10 15:31 by MOF_Catal
[考研] 269求调剂 +10 啊啊我我 2026-04-07 10/500 2026-04-10 10:38 by 高维春
[考研] 347材料专硕求调剂 +19 zj8215216 2026-04-06 19/950 2026-04-10 09:36 by 690616278
[考研] 08600生物与医药-327 +10 18755400796 2026-04-05 10/500 2026-04-10 08:14 by kangsm
[考研] 工科273调剂 +5 X1999 2026-04-09 6/300 2026-04-10 07:52 by 1753564080
[考研] 考研调剂-材料类-284 +28 想换手机不想解 2026-04-08 28/1400 2026-04-09 20:08 by 倒数321?
[考研] 化学工程与技术专业一志愿哈工程 291分B区 国家级大创负责人 有一作论文 +13 Emmy~ 2026-04-09 13/650 2026-04-09 14:47 by only周
[考研] 275 求调剂 +8 Lei812514 2026-04-07 8/400 2026-04-08 12:46 by chemisry
[考研] 336求调剂,一志愿中科大 +9 墨彧 yuyu 2026-04-06 9/450 2026-04-08 11:24 by 想读书的菌菌
[考研] 071000生物学,一志愿深圳大学296分,求调剂 +12 TIckLw 2026-04-06 13/650 2026-04-07 20:34 by lijunpoly
[考博] 博士申请 +3 IQwQl 2026-04-05 3/150 2026-04-07 20:31 by greychen00
[考研] 生物调剂 +5 橙子橙子橙子啊 2026-04-05 9/450 2026-04-07 15:31 by 上岸快快
[考研] 0855求调剂材料 +11 红桃灼灼 2026-04-04 12/600 2026-04-06 10:26 by 蓝云思雨
[考研] 材料调剂 +7 dxy调剂 2026-04-04 7/350 2026-04-05 09:15 by 陌秋26
[考研] 材料调剂 +9 革微桂 2026-04-04 9/450 2026-04-05 08:27 by 544594351
[考研] 求生物学学硕调剂——364分 +7 云朵遛弯指南 2026-04-04 7/350 2026-04-04 22:49 by zhyzzh
信息提示
请填处理意见