QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2786|回复: 0
打印 上一主题 下一主题

龙贝格求积法源代码,效率很好的

[复制链接]
字体大小: 正常 放大
maleesky        

3

主题

2

听众

19

积分

升级  14.74%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-4-1 16:34 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>积分的源代码,效率很好的
, l2 a/ i5 g* n. j- @2 {- D, o9 m
5 r. C: M$ t# y
2 Q- @7 M. d6 P; ^. _//////////////////////////////////////////////////////////////////////
& g  n' K- S5 M- b- k// 龙贝格求积法
1 U- ]) c- ~" r//$ W7 g  a) Z6 y  R1 @  C1 y' o
// 调用时,须覆盖计算函数f(x)值的虚函数double Func(double x)* ?% H" ?( l- {. i3 l9 @
//
% ~; q* ?2 |4 z1 H// 参数:
8 V' v. t2 v3 m, Q1 V// 1. a - Double型变量,积分下限9 I) l) E' b- v/ @' y, F
// 2. b - Double型变量,积分上限,要求b&gt;a8 i. k2 ?* n. W0 V5 e. [
// 3. eps - Double型变量,积分精度要求
( }& \% \9 Y: m" w//
6 U4 i; y1 h+ {// 返回值:double 型,积分值3 f& Q# d& [% g6 O8 J* G( P. C
//////////////////////////////////////////////////////////////////////
% H# `4 K: j2 \. ndouble Integral_Romberg(double a, double b, double eps /*= 0.000001*/)7 s5 r. h. J% \8 e$ P
{ * C% c# {/ @. [+ i# T
    int m,n,i,k;
1 W  R' l' c- h5 w    double y[10],h,ep,p,x,s,q;</P>
, S$ F% H, W8 ^<> // 迭代初值0 H. V4 R/ o: t8 T5 N7 i/ T
    h=b-a;$ R) D+ Q& ]; G: k. g, e
    y[0]=h*(Func(a)+Func(b))/2.0;$ d. U) Z' s" q9 n( z, a
    m=1; ; {( A" C4 j% ]6 y/ r
n=1;
. {% a$ e4 F/ ]' x. a ep=eps+1.0;! j+ b& F. a% B2 q; Y! [
   
( t+ ]& k# w; Q2 w // 迭代计算$ S9 ^  J, e8 s% H+ ^6 E
while ((ep&gt;=eps)&amp;&amp;(m&lt;=9))
+ a/ T' q" L. H3 u) \    {
' c% i& e0 e7 }/ f8 [- v  p=0.0;
6 Y0 Z$ X  {2 d1 q$ x        for (i=0;i&lt;=n-1;i++)
, k" j7 n$ h3 U7 j( ?, ^7 O( x        { 1 M( ?  E" [; I7 A' q& H; }
   x=a+(i+0.5)*h;2 }7 W  _1 W+ q- i; {8 v) A5 [( a1 I' Y
            p=p+Func(x);9 U0 @4 f2 j* D' n+ Q8 F/ [
        }' R7 i* h& ^/ Z1 X; [7 P
        1 x3 y. v' f8 E) m2 S5 D9 W1 r
  p=(y[0]+h*p)/2.0;
0 ^/ |7 k" l+ [/ I# Z        s=1.0;
3 r4 U+ r  h5 c8 q! i% R, A, _6 H        for (k=1;k&lt;=m;k++)) \4 I4 S+ a0 z7 W
        { : c  t% V* l$ {) i. Z
   s=4.0*s;' m$ K1 b/ W; g6 |/ ~
            q=(s*p-y[k-1])/(s-1.0);4 x" S5 A2 z) G" l$ _
            y[k-1]=p; p=q;" p  }" E; S% Z
        }</P>
7 U7 s* i- g$ S# c+ g9 A6 F<>        ep=fabs(q-y[m-1]);
4 O: f7 X) N0 ^- g4 W: a  R        m=m+1;
0 o4 z0 `# X  _0 t" _) ]. B  y[m-1]=q;
; g/ ~* S  E: q$ a/ `( j  n=n+n; 6 R, o7 o' ]- R, O7 S7 \
  h=h/2.0;) H  `' N9 q/ {% w1 q. g
    }
! b- I( z0 C. N/ H% s    # G% K8 t6 e  y9 f& I, f9 w
return(q);
( v- |$ N' l1 C9 y}</P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-22 22:42 , Processed in 0.428177 second(s), 52 queries .

回顶部