QQ登录

只需要一步,快速开始

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

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

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

3

主题

2

听众

19

积分

升级  14.74%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-4-1 16:34 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>积分的源代码,效率很好的  T4 O/ T' ~0 J; H

2 i( ~5 U1 U" G; D$ J# o; d7 b& H
//////////////////////////////////////////////////////////////////////) g( u, s1 m' k, F
// 龙贝格求积法1 m; C/ E4 s; P" T
//, F/ L8 V. h" q/ o. D" w
// 调用时,须覆盖计算函数f(x)值的虚函数double Func(double x); G4 h1 P2 g; @7 |2 J# x0 C1 P% O
//; M, x! M1 N0 o& ~
// 参数:
6 o* i' P0 \" k// 1. a - Double型变量,积分下限) C: G! x3 i9 l4 e" }
// 2. b - Double型变量,积分上限,要求b&gt;a1 N$ m1 U3 P% h9 [2 @6 d% e
// 3. eps - Double型变量,积分精度要求
' S. i0 X& Q7 ~! d) |//' m! e' R) ]7 k
// 返回值:double 型,积分值
5 |/ s6 H+ O- Z+ [6 q' R//////////////////////////////////////////////////////////////////////
9 P' D- {& n) p, T) v( O# Tdouble Integral_Romberg(double a, double b, double eps /*= 0.000001*/)
% k- P; F% H- N$ A. S; ^{ / h, j& I! k: }4 n6 z
    int m,n,i,k;1 j/ @0 `6 T% n# E5 |/ ?  c- D
    double y[10],h,ep,p,x,s,q;</P>8 }: ?- k" d, X" v# I
<> // 迭代初值& z. k% {9 {6 A0 O
    h=b-a;/ y# S3 x& z2 u6 x6 S5 l
    y[0]=h*(Func(a)+Func(b))/2.0;# A" o+ C! W" e' Z* }+ \0 t
    m=1; ! u4 ?- W$ M: C( z* U- ]: _4 `
n=1;
. r4 R0 r+ b5 V5 F ep=eps+1.0;
. W: o5 |8 K' \* N, X   
! J! b/ v- |/ |1 m // 迭代计算
- [- r2 s8 d( M/ F) k while ((ep&gt;=eps)&amp;&amp;(m&lt;=9))
3 O+ z; f6 W6 J    {
9 h4 n* W* }2 V1 Q  n  p=0.0;
3 ], U0 E; ~$ B/ L2 g- X# i7 _        for (i=0;i&lt;=n-1;i++)1 o+ t' s( g3 `, o2 h
        {
- D' }) E1 ?& j* c2 E# K   x=a+(i+0.5)*h;
: K8 @" T& S& i' E            p=p+Func(x);' Z; @$ n. Y; q" X1 z1 d/ |
        }
9 Q9 \3 b7 o# @& I3 |) q+ |        3 S0 k/ p4 `- e" h" z
  p=(y[0]+h*p)/2.0;
( `, S  d% A$ \        s=1.0;
9 s, |7 ?- l# F9 q7 B/ b+ _        for (k=1;k&lt;=m;k++)
$ `& W$ H8 E0 E0 r1 x        { 6 e. u/ |& j; B. z! Z9 d1 W; ~6 r
   s=4.0*s;
! a, C% |4 B/ B* \" t6 {$ p            q=(s*p-y[k-1])/(s-1.0);. n, l$ J3 U6 h7 v; t
            y[k-1]=p; p=q;
3 p+ Z& x! f8 Y4 A        }</P>
+ N; T2 ^" o6 i) `0 `5 w! q8 ~<>        ep=fabs(q-y[m-1]);
; e* n$ A/ Y5 b        m=m+1; - L2 \) ^$ f- G) Z- W$ B
  y[m-1]=q; ' z, O7 C) O* D  P! V3 t
  n=n+n;
* q! H( b: k  }4 T; j3 X' ]( Y  h=h/2.0;9 _7 X! X5 u5 i
    }3 j! Q0 M) C' u7 `/ f5 ]
    ' {2 F1 [5 e6 Y* e) f% C9 Z
return(q);7 v6 H( b6 {" o5 J. L
}</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-6-12 00:54 , Processed in 0.399643 second(s), 52 queries .

回顶部