24小时热门版块排行榜    

查看: 571  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 286分人工智能专业请求调剂愿意跨考! +3 lemonzzn 2026-03-17 3/150 2026-03-19 23:58 by 23Postgrad
[考研] 081700化工学硕调剂 +3 【1】 2026-03-16 3/150 2026-03-19 23:40 by edmund7
[考研] 294求调剂材料与化工专硕 +14 陌の森林 2026-03-18 14/700 2026-03-19 22:38 by 学员8dgXkO
[考研] 296求调剂 +3 www_q 2026-03-18 6/300 2026-03-19 22:28 by zhq0425
[考研] 招收调剂硕士 +4 lidianxing 2026-03-19 10/500 2026-03-19 16:05 by 余麟余
[考研] 332求调剂 +3 ydfyh 2026-03-17 3/150 2026-03-19 10:14 by 功夫疯狂
[考研] 26调剂/材料/英一数二/总分289/已过A区线 +7 步川酷紫123 2026-03-13 7/350 2026-03-18 17:12 by 尽舜尧1
[考研] 08工科 320总分 求调剂 +5 梨花珞晚风 2026-03-17 5/250 2026-03-18 14:49 by haxia
[考研] 070300化学319求调剂 +6 锦鲤0909 2026-03-17 6/300 2026-03-18 13:22 by Iveryant
[考研] 0703化学调剂 +3 妮妮ninicgb 2026-03-17 3/150 2026-03-18 10:29 by macy2011
[考研] 085601求调剂 +4 Du.11 2026-03-16 4/200 2026-03-17 17:08 by ruiyingmiao
[考博] 26申博 +4 八6八68 2026-03-16 4/200 2026-03-17 13:00 by 轻松不少随
[考研] 283求调剂 +3 听风就是雨; 2026-03-16 3/150 2026-03-17 07:41 by 热情沙漠
[考研] 274求调剂 +5 时间点 2026-03-13 5/250 2026-03-17 07:34 by 热情沙漠
[考研] 333求调剂 +3 文思客 2026-03-16 7/350 2026-03-16 18:21 by 文思客
[考研] 0856求调剂 +3 刘梦微 2026-03-15 3/150 2026-03-16 10:00 by houyaoxu
[考研] 326求调剂 +3 mlpqaz03 2026-03-15 3/150 2026-03-16 07:33 by Iveryant
[考研] 26考研一志愿中国石油大学(华东)305分求调剂 +3 嘉年新程 2026-03-15 3/150 2026-03-15 13:58 by 哈哈哈哈嘿嘿嘿
[考研] 294求调剂 +3 Zys010410@ 2026-03-13 4/200 2026-03-15 10:59 by zhq0425
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
信息提示
请填处理意见