24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 490  |  回复: 5
当前主题已经存档。
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

jianchaoyv

金虫 (小有名气)

[交流] [求助]一个关于梯形积分的程序

program D3R1
!driver for routine TRAPZD
real,parameter::nmax=15,pio2=1.5707963
external Func,Fint
real::A=0.0,B=pio2
write(*,'(1x,a)') 'integral of Func with 2^(n-1) points'
write(*,'(1x,a,f10.6)')'actual value of integral is',&
               Fint(B)-Fint(A)
write(*,'(1x,t7,a,t16,a)')'n','Approx.integral'
do i=1,nmax
   call TRAPZD(Func,A,B,s,i)
   write(*,'(1x,i6,f20.6)')i,s
end do
end program D3R1
Function Func(x)
    Func=(x**2)*(x**2-2.0)*sin(x)
end function Func
function Fint(x)
!integral of Func
Fint=4.0*x*((x**2)-7.0)*sin(x)-((x**4)-14.0*(x**2)+28.0)*cos(x)
end function Fint



subroutine TRAPZD(Func,A,B,s,n)
integer::n,tnm
integer,parameter::p=selected_real_kind(6,20)
real(p)::del,sum,x
if(n==1)then
  s=0.5*(b-a)*(Func(a)+Func(b))
  else
  tnm=2**(n-1)

  del=(b-a)/tnm
  x=A
  sum=0.0
  do j=2,tnm
    x=x+del
    sum=sum+Func(x)
       
   end do
   s=0.5*(Func(A)+Func(B)+2*sum)*del
end if
end subroutine TRAPZD
运算的结果如下:
integral of Func with 2^(n-1) points
actual value of integral is -0.479158
      n        Approx.integral
      1            0.905772
      2           -0.020945
      3           -0.361461
      4           -0.449584
      5           -0.471756
      6           -0.477307
      7           -0.478697
      8           -0.479042
      9           -0.479126
     10           -0.479146
     11           -0.479151
     12           -0.479152
     13           -0.479153
     14           -0.479411
     15           -0.479676
Press any key to continue
请问n=14,15 时怎么越不接近真实值?
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

至尊木虫 (职业作家)

又看了一下,觉得是数据精度的问题。比如把我给出的那个程序中的 DOUBLE PRECISION 全部换成 REAL 后的结果与 LZ 给出的程序结果是一致的。

所以我觉得问题可能出在 (A-B)/TNM 这一步,因为随着 N 的增加, TNM 会变得很大,而 (A-B)/TNM 则会非常小,由于精度的限制,会造成较大的误差,从而导致最后结果的差异。

所以我建议 LZ 将全部的 REAL 类型的变量换成相当于 fortran 77 中的 DOUBLE PRECISION 或 REAL*8 的精度,应该就不会有问题了。

[ Last edited by snoopyzhao on 2009-4-1 at 17:16 ]
6楼2009-04-01 17:12:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

abingchem

木虫 (著名写手)

★ ★ ★
sunxiao(金币+3,VIP+0):欢迎参与,加分鼓励 3-30 22:39
俺不会Fortran,对你的程序只能看了个大概.循环部分没有问题,至少写成matlab后执行是正确的:
clear;
clc
b=pi/2
a=0
nse=[];
sse=[];

for n=10:20
tnm=2^(n-1)

del=(b-a)/tnm
x=a
s=0.0

for j=2:tnm
   x=x+del;
   s=s+Func(x);
end
s=0.5*(Func(a)+Func(b)+2*s)*del
nse=[nse n];
sse=[sse s];
end
[nse'  sse']
---------------------------------------------
结果是这样的:
10.00000000000000  -0.47915157829510
  11.00000000000000  -0.47915700215368
  12.00000000000000  -0.47915835811872
  13.00000000000000  -0.47915869710992
  14.00000000000000  -0.47915878185820
  15.00000000000000  -0.47915880304466
  16.00000000000000  -0.47915880834252
  17.00000000000000  -0.47915880966840
  18.00000000000000  -0.47915881000004
  19.00000000000000  -0.47915881008306

有点怀疑的是你的变量s是在哪里初始化的,这个值是应该先初始化为零吧.
冰是从最寒冷的那天开始融化的
2楼2009-03-30 19:53:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ycbgyy

木虫 (正式写手)

你的代码是在那个环境里运行的????我也运行一下
3楼2009-03-30 22:44:55
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

至尊木虫 (职业作家)

俺不懂 f90,写了一个 f77 的程序供你参考。我怀疑是数值类型的问题……
CODE:
C234567
      SUBROUTINE TX(FUNC,A,B,N,S)
      IMPLICIT NONE
      INTEGER N, TNM, I
      DOUBLE PRECISION DEL, SUM, X, A, B, S, FUNC
      EXTERNAL FUNC
      IF( N .EQ. 1) THEN
        S = 0.5D0 * (B - A) * (FUNC(A) + FUNC(B))
      ELSE
        TNM = 2**(N - 1)
        DEL = (B - A) / TNM
        X = A
        SUM = 0.0D0
        DO 5 I = 2, TNM
          X = X + DEL
          SUM = SUM + FUNC(X)
5       CONTINUE
        S=0.5D0*(FUNC(A) + FUNC(B) + 2D0 * SUM) * DEL
      ENDIF
      RETURN
      END

      DOUBLE PRECISION FUNCTION FUNC(X)
      IMPLICIT NONE
      DOUBLE PRECISION X
      FUNC = (X**2) * (X**2 - 2.0D0) * SIN(X)
      RETURN
      END

      PROGRAM MAIN
      IMPLICIT NONE
      INTEGER N, I
      DOUBLE PRECISION S, A, B, FUNC
      EXTERNAL FUNC
      A = 0.0D0
      B = 1.5707963D0
      N = 20
      DO 5 I=1,N
        CALL TX(FUNC,A,B,I,S)
        WRITE(*,'(I4,F20.10)') I, S
5     CONTINUE
      END

运行结果:
CODE:
   1        0.9057727803
   2       -0.0209449905
   3       -0.3614613180
   4       -0.4495837621
   5       -0.4717563216
   6       -0.4773076746
   7       -0.4786960160
   8       -0.4790431327
   9       -0.4791299138
  10       -0.4791516092
  11       -0.4791570331
  12       -0.4791583890
  13       -0.4791587280
  14       -0.4791588128
  15       -0.4791588339
  16       -0.4791588392
  17       -0.4791588406
  18       -0.4791588409
  19       -0.4791588410
  20       -0.4791588410

[ Last edited by snoopyzhao on 2009-4-1 at 13:19 ]
4楼2009-04-01 11:54:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 材料学硕333求调剂 +10 北道巷 2026-03-24 10/500 2026-03-28 23:06 by 无际的草原
[考研] 317分 一志愿南理工材料工程 本科湖工大 求调剂 +7 芋泥小铃铛 2026-03-28 7/350 2026-03-28 21:38 by 小木虫tim
[考研] 316求调剂 +7 江辞666 2026-03-26 7/350 2026-03-28 21:28 by sanrepian
[考研] 312,生物学求调剂 +3 小译同学abc 2026-03-28 3/150 2026-03-28 15:32 by 落睿可思
[考研] 339求调剂,想调回江苏 +6 烤麦芽 2026-03-27 8/400 2026-03-28 10:40 by 烤麦芽
[考研] 311求调剂 +3 希望上岸阿小杨 2026-03-23 3/150 2026-03-28 07:57 by 热情沙漠
[考研] 285求调剂 +4 AZMK 2026-03-27 7/350 2026-03-27 20:59 by AZMK
[考研] 266求调剂 +11 阳阳哇塞 2026-03-27 12/600 2026-03-27 17:56 by yu221
[考研] 化学调剂 +4 爱吃番茄的旭 2026-03-24 5/250 2026-03-27 17:50 by kiokin
[考研] 材料与化工085600,总分304,本科有两篇sci参与,求调剂 +10 幸运的酱酱 2026-03-22 12/600 2026-03-27 16:08 by muchong357
[考研] 材料求调剂 +5 .m.. 2026-03-25 5/250 2026-03-27 11:08 by 不吃魚的貓
[硕博家园] 北京林业大学硕导招生广告 +6 kongweilin 2026-03-26 8/400 2026-03-27 10:18 by FF_16
[考研] 324求调剂 +8 hanamiko 2026-03-26 10/500 2026-03-27 08:06 by hypershenger
[考研] 329求调剂 +7 钮恩雪 2026-03-25 7/350 2026-03-27 04:28 by wxiongid
[考研] 材料考研求调剂 +3 Dendel 2026-03-23 6/300 2026-03-26 17:51 by fmesaito
[考研] 总分293求调剂 +6 加一一九 2026-03-25 8/400 2026-03-26 13:30 by yujianx
[考研] 上海电力大学材料防护与新材料重点实验室招收调剂研究生(材料、化学、电化学,环境) +4 我爱学电池 2026-03-23 4/200 2026-03-25 00:59 by 1027_324
[考研] 080500求调剂 +3 zzzzfan 2026-03-24 3/150 2026-03-24 16:38 by barlinike
[考研] 一志愿吉大化学322求调剂 +4 17501029541 2026-03-23 6/300 2026-03-24 10:21 by 戴围脖的小蚊子
[考研] 328求调剂 +4 LHHL66 2026-03-23 4/200 2026-03-23 14:55 by lbsjt
信息提示
请填处理意见