24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 495  |  回复: 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的回帖

ycbgyy

木虫 (正式写手)

你的代码是在那个环境里运行的????我也运行一下
3楼2009-03-30 22:44:55
已阅   回复此楼   关注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的回帖

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的回帖

abingchem

木虫 (著名写手)

f77写出来程序真是好看,就是写起来麻烦
冰是从最寒冷的那天开始融化的
5楼2009-04-01 12:30:17
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 329求调剂 +7 星野? 2026-03-26 7/350 2026-03-29 06:43 by 544594351
[考研] 322求调剂 +7 宋明欣 2026-03-27 7/350 2026-03-28 21:27 by sanrepian
[考研] 346求调剂 一志愿070303有机化学 +3 萝卜炖青菜 2026-03-28 3/150 2026-03-28 14:11 by 唐沐儿
[考研] 0703本科郑州大学求调剂 +3 nhj_ 2026-03-25 3/150 2026-03-28 13:24 by Iveryant
[考研] 【求调剂】085601材料工程专硕 | 总分272 | +6 脚滑的守法公民 2026-03-27 6/300 2026-03-28 11:02 by gjlllb
[考研] 一志愿南京航空航天大学材料学硕求调剂 +3 @taotao 2026-03-28 3/150 2026-03-28 10:26 by JourneyLucky
[考研] 求调剂推荐 材料 304 +15 荷包蛋hyj 2026-03-26 15/750 2026-03-28 04:13 by fmesaito
[考研] 275求调剂 +10 jjjjjjjjjjl 2026-03-27 10/500 2026-03-27 23:47 by barnett0632
[考研] 0703化学求调剂,各位老师看看我!!! +5 祁祺祺 2026-03-25 5/250 2026-03-27 21:44 by 东方猪猪
[考研] 化学308分求调剂 +8 你好明天你好 2026-03-23 9/450 2026-03-27 14:01 by 杨光于青云
[考研] 298调剂 +3 jiyingjie123 2026-03-27 3/150 2026-03-27 11:57 by wxiongid
[考研] 333求调剂 +3 question挽风 2026-03-23 3/150 2026-03-27 11:29 by 不吃魚的貓
[考研] 一志愿郑大085600,310分求调剂 +5 李潇可 2026-03-26 5/250 2026-03-27 11:14 by 不吃魚的貓
[考研] 一志愿陕师大生物学071000,298分,求调剂 +5 SYA! 2026-03-23 5/250 2026-03-27 09:29 by 不吃魚的貓
[考研] 一志愿 南京邮电大学 288分 材料考研 求调剂 +3 jl0720 2026-03-26 3/150 2026-03-26 13:39 by zzll406
[考研] 化学调剂一志愿上海交通大学336分-本科上海211 +4 小鱼爱有机 2026-03-25 4/200 2026-03-26 10:19 by aa331100
[考研] 296求调剂 +4 汪!?! 2026-03-25 7/350 2026-03-25 16:41 by 汪!?!
[考研] 302求调剂 +4 锦衣卫藤椒 2026-03-25 4/200 2026-03-25 16:29 by 功夫疯狂
[考研] 材料专硕331求调剂 +4 鲜当牛 2026-03-24 4/200 2026-03-24 15:58 by JourneyLucky
[考研] 333求调剂 +3 ALULU4408 2026-03-23 3/150 2026-03-23 19:04 by macy2011
信息提示
请填处理意见