QQ登录

只需要一步,快速开始

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

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

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

3

主题

2

听众

19

积分

升级  14.74%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-4-1 16:34 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>积分的源代码,效率很好的
' g" n4 ~2 ?" H' T) I! Q4 v  M
1 V6 F: q4 F1 p/ n) n0 h0 g: u* V9 ?/ O4 \! y* {2 W9 v' K
//////////////////////////////////////////////////////////////////////
: v; n& a* m. Q, x8 P4 t. T// 龙贝格求积法( r$ e- s# s+ a: v) E
//
  Q5 K8 M* r1 f+ o$ O, X// 调用时,须覆盖计算函数f(x)值的虚函数double Func(double x)
+ E$ _* J7 z4 t; `& w! [8 t//. m: k- h# X4 u9 C) g5 j$ p( R
// 参数:
, K' G2 f1 f/ k( Z) x// 1. a - Double型变量,积分下限
$ S0 ]# L6 H3 d5 S: C0 ^  e// 2. b - Double型变量,积分上限,要求b&gt;a5 d. y$ S& Z* A  {0 L: F
// 3. eps - Double型变量,积分精度要求  [: t3 a$ v+ b5 G3 ]% T2 _
//( a, S& q1 r0 i. t. @$ Y
// 返回值:double 型,积分值
0 q1 _5 h; b1 z$ I//////////////////////////////////////////////////////////////////////6 o( {1 _, I* H
double Integral_Romberg(double a, double b, double eps /*= 0.000001*/)
  V+ E7 J( ]2 y  _* V{
0 k$ B6 @$ f: }& p( {$ V# }8 q    int m,n,i,k;5 T$ _0 _- G9 C2 \, d$ c# G
    double y[10],h,ep,p,x,s,q;</P>3 e2 m$ h) ?& f& W, [  U: b
<> // 迭代初值
. x- {# U: b4 l& x, ^    h=b-a;
- g4 S3 Z7 @5 b    y[0]=h*(Func(a)+Func(b))/2.0;
7 @) v' x: h& P5 d4 v$ E    m=1;   i. t; z( M4 W
n=1;
5 [3 r$ O( t; i3 t ep=eps+1.0;
0 |7 ~& i, G6 W. _/ i. V   
6 w5 j! [8 M$ `9 t- M% a // 迭代计算3 E" b$ m8 Z$ Y! k5 c8 u
while ((ep&gt;=eps)&amp;&amp;(m&lt;=9))
9 |& u% o2 r* J5 N0 P! J; ?    {
& R/ J1 J) u' U  p=0.0;
( y( F, s) L3 T        for (i=0;i&lt;=n-1;i++)3 K/ n; V# G* z, y. t1 p+ a
        { & |! [" v. ~: ?! ~4 Z/ s1 O# f
   x=a+(i+0.5)*h;; _% S: C# V, @1 X( {, r; r
            p=p+Func(x);
) I& \# Y# b" Y. e; ?0 c7 b        }
& A& J  n. F6 P: ?( Y0 J        # J: w9 E2 N7 r+ S; G2 s
  p=(y[0]+h*p)/2.0;
0 R4 L3 C/ s" a" k9 i        s=1.0;; p! |" o# z- l
        for (k=1;k&lt;=m;k++)
: A# N8 Z; {( o, N  @5 ~        {
/ w. H7 R9 K( L6 ~5 ]: \   s=4.0*s;, z# U* S" E' @4 Y% z$ n5 s7 T
            q=(s*p-y[k-1])/(s-1.0);- l; P) _2 _: |& M: b( r5 e7 ]
            y[k-1]=p; p=q;( E4 j+ G4 H9 W5 J# P$ J& x6 e. r
        }</P>
+ I6 s+ e1 E6 w5 J: G4 `$ T9 `; g<>        ep=fabs(q-y[m-1]);9 f0 K3 q5 Y; f# p" k( q
        m=m+1; / p# r/ t7 X/ A" w5 D
  y[m-1]=q;
: l7 W& Y9 T% f* U8 V* ]0 Q  n=n+n; # X2 |9 y1 m( f$ b# L. ?
  h=h/2.0;9 S/ c& {% \1 j( L; ?+ V4 \
    }
8 t- d4 P- h  E- j    ; K7 X! e. ?8 z: Z# J
return(q);5 F* v* p2 d3 I9 U( U; i
}</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-20 13:31 , Processed in 0.445480 second(s), 52 queries .

回顶部