QQ登录

只需要一步,快速开始

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

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

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

3

主题

2

听众

19

积分

升级  14.74%

该用户从未签到

新人进步奖

跳转到指定楼层
1#
发表于 2005-4-1 16:34 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>积分的源代码,效率很好的3 R% Z4 c( x% [
7 J1 _6 q2 a/ x
3 p  T- Z+ a  H* @" }
//////////////////////////////////////////////////////////////////////
7 G! |) t' J+ b6 y1 c5 w// 龙贝格求积法
, n  ?! f- f8 ?2 A2 j* s/ H//
4 X3 ^" R1 g2 J// 调用时,须覆盖计算函数f(x)值的虚函数double Func(double x)
& ]2 }) {7 e; O//) c; B* Q6 @1 F; A7 |
// 参数:
# H  `& U5 z5 v6 j: f( S: I// 1. a - Double型变量,积分下限  b6 A: W- ?$ _% u
// 2. b - Double型变量,积分上限,要求b&gt;a/ Q9 {2 Q3 h# L3 X2 H
// 3. eps - Double型变量,积分精度要求
+ f4 `) d+ m" a0 N7 x0 P. X  i9 k+ y//3 c. J1 }9 `1 f" R) L' W" V0 |4 T
// 返回值:double 型,积分值8 F  L. a1 Z( l& _( o! v5 |. _
//////////////////////////////////////////////////////////////////////4 W" X" K3 k1 i5 {( R( \
double Integral_Romberg(double a, double b, double eps /*= 0.000001*/)7 u' }6 N3 n! e. k
{
7 z, ?. K* m: d  T5 c    int m,n,i,k;& b7 y$ s3 @( Y7 |
    double y[10],h,ep,p,x,s,q;</P>
  s/ T* m0 A, D8 L<> // 迭代初值% Z9 j# _* C# q& A5 Z. l9 A
    h=b-a;
( W3 G' e7 Y7 t, f5 B; s    y[0]=h*(Func(a)+Func(b))/2.0;
6 p7 Q  s& |  \2 X+ j% q$ p    m=1; ) p- l% F2 U6 X9 C  J; m
n=1; $ \* ^0 S, l, n6 J6 m, g, [
ep=eps+1.0;, J) @" U/ R5 O- n
    : ~1 M+ g7 g/ D9 [! s6 d. w
// 迭代计算9 f! Q5 Y9 S9 M
while ((ep&gt;=eps)&amp;&amp;(m&lt;=9))+ k7 ^/ Q% L+ b
    { * n8 t, n7 W: d9 {. s: x
  p=0.0;
: J8 Z, Y9 _+ [6 c        for (i=0;i&lt;=n-1;i++)- B- Z! d6 p! o# G7 y$ P* ]3 b& d
        { 3 L( ]  ^) E5 a! ]4 i$ i' a
   x=a+(i+0.5)*h;1 S, t& z( x! }# Y2 V
            p=p+Func(x);
; K% |4 t  t. ~6 e8 |! v# d- Y" s        }
1 k* l, t( B, q. ~! i        & j& k* A& f" W* r" @% h
  p=(y[0]+h*p)/2.0;7 h* n7 ?8 N6 h3 z7 R
        s=1.0;
$ g9 f, t1 \) d8 X  c8 p0 H$ z/ Y! J        for (k=1;k&lt;=m;k++)
2 ]) E& z' E& G0 Y/ Z        {
- j' q8 ~  L+ d/ I5 ~   s=4.0*s;3 A  e* d  c  g) e0 S2 k: e" r
            q=(s*p-y[k-1])/(s-1.0);5 L5 r" @* c& A' _, N2 O- J0 i
            y[k-1]=p; p=q;- _' [- f# v# u0 C7 j
        }</P>
5 E% b9 l. X1 q" r. @<>        ep=fabs(q-y[m-1]);
# \: h0 ^: _6 T% O2 P. x        m=m+1;
" B; f) d: J# B5 l+ M* P, K% s8 \9 [  y[m-1]=q;
1 k8 A6 r5 q: _' L2 M* K  n=n+n; " m( W" J1 S% B- J! V) H
  h=h/2.0;
' i  Y- o6 y7 e: r" L# m3 E    }
, b! p. M# Y$ H& }3 _2 C   
6 P, ^' J: \- y# F: |. k$ o return(q);& A) b7 F7 u  ~6 Q/ W) I% w0 F* X% n
}</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:42 , Processed in 0.392723 second(s), 52 queries .

回顶部