24小时热门版块排行榜    

Znn3bq.jpeg
查看: 589  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 314求调剂 +18 xhhdjdjsjks 2026-04-09 19/950 2026-04-10 18:53 by HPUCZ
[考研] 一志愿京区985,085401电子信息,本科电子信息 +3 阳光开朗的男孩 2026-04-10 3/150 2026-04-10 16:29 by sophia_93
[考研] 071000生物学调剂求助 +17 zzzzwww 2026-04-09 20/1000 2026-04-10 15:55 by 求调剂zz
[考研] 086003调剂求助 +19 苏弋万 2026-04-09 20/1000 2026-04-09 20:48 by bljnqdcc
[考研] 考研调剂-材料类-284 +28 想换手机不想解 2026-04-08 28/1400 2026-04-09 20:08 by 倒数321?
[考研] 一志愿电子科技大学085600材料与化工 329分求调剂 +14 Naiko 2026-04-04 14/700 2026-04-09 16:56 by luoyongfeng
[考博] 材料方向考博,求推荐 +3 言语aaa 2026-04-05 4/200 2026-04-08 22:22 by nxgogo
[考研] 机械工程313分找工科调剂 +3 双一流本科机械 2026-04-08 3/150 2026-04-08 20:41 by 土木硕士招生
[考研] 336求调剂,一志愿中科大 +9 墨彧 yuyu 2026-04-06 9/450 2026-04-08 11:24 by 想读书的菌菌
[考研] 263分B区求调剂 +6 李nihao 2026-04-08 6/300 2026-04-08 09:38 by 南开小綦
[考研] 调剂求助(生物与医药) +6 @6952 2026-04-06 6/300 2026-04-07 23:52 by lys0704
[考研] 085602调剂 初试总分335 +3 19123253302 2026-04-06 3/150 2026-04-07 18:00 by jp9609
[考研] 081200-11408-367学硕求调剂 +4 1_2_3111 2026-04-06 4/200 2026-04-07 08:13 by jp9609
[考研] 求调剂 +4 电气小神童 2026-04-04 6/300 2026-04-07 00:14 by guanxin1001
[考研] 材料调剂 +5 小刘同学吖吖 2026-04-06 5/250 2026-04-06 18:34 by sherry_1901
[考研] 化学357分,考研调剂 +11 .Starry. 2026-04-04 12/600 2026-04-06 06:28 by houyaoxu
[考研] 一志愿青科085500,初试295分,公共课213分 +3 遇到的人愿望都 2026-04-05 3/150 2026-04-05 18:45 by 蓝云思雨
[考研] 326求调剂 +3 顾若浮生 2026-04-05 3/150 2026-04-05 18:32 by 蓝云思雨
[考研] 323求调剂 +8 李佳乐1 2026-04-04 8/400 2026-04-04 22:26 by hemengdong
[考研] 309求调剂 +4 快乐的小白鸽 2026-04-04 5/250 2026-04-04 15:55 by cql1109
信息提示
请填处理意见