24小时热门版块排行榜    

查看: 2206  |  回复: 2
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

li_clifff

银虫 (正式写手)

[求助] 求助一个fortran的均匀分布随机数函数ran2(idum)问题,谢谢

fortran的0,1之间均匀分布随机数程序 ran2(idum),为什么我ran2(6)和ran2(10)的结果都是一样的,都是0.6554, 这个ran2在matlab下类似的函数是什么呢?Matlab里有rand, 还是rand(idum,1) ,这里有个比较有意思的是rand是直接出来一个随机数,而rand(idum,1)是出现一列idum个随机变量;

fortran里面的ran2(idum)运行结果就是一个数,而是,idum=6,和10答案都是0.6554?对fortran的ran2用法还不行, 请大家指点,谢谢。



FUNCTION ran2(idum)

INTEGER, INTENT(OUT)                     :: idum

REAL :: ran2
INTEGER, PARAMETER :: im1=2147483563
INTEGER, PARAMETER :: im2=2147483399
REAL, PARAMETER :: am=1./im1
INTEGER, PARAMETER :: imm1=im1-1
INTEGER, PARAMETER :: ia1=40014
INTEGER, PARAMETER :: ia2=40692
INTEGER, PARAMETER :: iq1=53668
INTEGER, PARAMETER :: iq2=52774
INTEGER, PARAMETER :: ir1=12211
INTEGER, PARAMETER :: ir2=3791
INTEGER, PARAMETER :: ntab=32
INTEGER, PARAMETER :: ndiv=1+imm1/ntab
REAL, PARAMETER :: eps=1.2E-7
REAL, PARAMETER :: rnmx=1.-eps
INTEGER :: idum2,j,k,iv(ntab),iy
SAVE iv,iy,idum2
DATA idum2/123456789/, iv/ntab*0/, iy/0/

IF (idum <= 0) THEN
  idum=MAX(-idum,1)
  idum2=idum
  DO  j=ntab+8,1,-1
    k=idum/iq1
    idum=ia1*(idum-k*iq1)-k*ir1
    IF (idum < 0) idum=idum+im1
    IF (j <= ntab) iv(j)=idum
  END DO
  iy=iv(1)
END IF
k=idum/iq1
idum=ia1*(idum-k*iq1)-k*ir1
IF (idum < 0) idum=idum+im1
k=idum2/iq2
idum2=ia2*(idum2-k*iq2)-k*ir2
IF (idum2 < 0) idum2=idum2+im2
j=1+iy/ndiv
iy=iv(j)-idum2
iv(j)=idum
IF(iy < 1)iy=iy+imm1
ran2=MIN(am*iy,rnmx)

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

绿遍山原

铜虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
给你个mt19937的程序,以前从原始程序改写的
CODE:
module modrandom
  implicit none
  ! Period parameters.
  integer, parameter :: n=624, m=397
  ! Constant vector A.
  integer, parameter :: mata=-1727483681
  ! Most significant w-r bits, note the way to set its value.
  integer, parameter :: umask=-2147483647-1
  ! Least significant r bits.
  integer, parameter :: lmask=2147483647
  ! Tempering parameters.
  integer, parameter :: tmaskb=-1658038656
  integer, parameter :: tmaskc=-272236544
  ! mag01(x)=x*mata for x=0,1.
  integer, parameter :: mag01(0:1)=(/0,mata/)
  ! State vector and index, mti=n+1 means st vector is
  ! not initialized.
  integer, save :: mt(0:n-1)=0, mti=n+1
end module modrandom
subroutine initrand(seed)
  use modrandom
  implicit none
  integer, intent(in) :: seed
  mt(0)=iand(seed,-1)
  do mti=1,n-1
     ! See Knuth's TAOCP vol2 for multiplier.
     mt(mti)=1812433253*ieor(mt(mti-1),ishft(mt(mti-1),-30))+mti
     mt(mti)=iand(mt(mti),-1)
  end do
  mti=mti+1
end subroutine initrand

subroutine genrand(rnd)
  use modrandom
  implicit none
  real(8), intent(out) :: rnd
  integer :: y, kk
  ! Generate N words at once.
  if (mti.gt.n) then
     ! If seed not set, use the default seed 5489.
     if (mti.eq.n+1) call initrand(5489)
     do kk=0,n-m-1
        y=ior(iand(mt(kk),umask),iand(mt(kk+1),lmask))
        mt(kk)=ieor(ieor(mt(kk+m),ishft(y,-1)),mag01(iand(y,1)))
     end do
     do kk=n-m,n-2
        y=ior(iand(mt(kk),umask),iand(mt(kk+1),lmask))
        mt(kk)=ieor(ieor(mt(kk+m-n),ishft(y,-1)),mag01(iand(y,1)))
     end do
     y=ior(iand(mt(n-1),umask),iand(mt(0),lmask))
     mt(n-1)=ieor(ieor(mt(m-1),ishft(y,-1)),mag01(iand(y,1)))
     mti=0
  end if
  ! Tempering
  y=mt(mti)
  mti=mti+1
  y=ieor(y,ishft(y,-11))
  y=ieor(y,iand(ishft(y,7),tmaskb))
  y=ieor(y,iand(ishft(y,15),tmaskc))
  y=ieor(y,ishft(y,-18))
  ! Convert to double in [0, 1] interval
  if (y .lt. 0) then
     rnd=(dble(y)+2.d0**32)/(2.d0**32-1.d0)
  else
     rnd=dble(y)/(2.d0**32-1.d0)
  end if
end subroutine genrand

参考 http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/MT2002/emt19937ar.html
要夢遊,不要催眠。
3楼2012-03-25 08:54:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 3 个回答

snoopyzhao

至尊木虫 (职业作家)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jjdg: 金币+2, 感谢参与 2012-03-25 01:42:32
我其实是不太赞同自己去写随机数发生器的,呵呵……

你自己看一下下面这段程序的输出吧,至少在我这里生成的结果是不一样的。
CODE:
program test
i=6
j=10
x = ran2(i)
y = ran2(j)

write(*,*) x, y

end program test


FUNCTION ran2(idum)

INTEGER, INTENT(inOUT)                     :: idum

REAL :: ran2
INTEGER, PARAMETER :: im1=2147483563
INTEGER, PARAMETER :: im2=2147483399
REAL, PARAMETER :: am=1./im1
INTEGER, PARAMETER :: imm1=im1-1
INTEGER, PARAMETER :: ia1=40014
INTEGER, PARAMETER :: ia2=40692
INTEGER, PARAMETER :: iq1=53668
INTEGER, PARAMETER :: iq2=52774
INTEGER, PARAMETER :: ir1=12211
INTEGER, PARAMETER :: ir2=3791
INTEGER, PARAMETER :: ntab=32
INTEGER, PARAMETER :: ndiv=1+imm1/ntab
REAL, PARAMETER :: eps=1.2E-7
REAL, PARAMETER :: rnmx=1.-eps
INTEGER :: idum2,j,k,iv(ntab),iy
SAVE iv,iy,idum2
DATA idum2/123456789/, iv/ntab*0/, iy/0/

IF (idum <= 0) THEN
  idum=MAX(-idum,1)
  idum2=idum
  DO  j=ntab+8,1,-1
    k=idum/iq1
    idum=ia1*(idum-k*iq1)-k*ir1
    IF (idum < 0) idum=idum+im1
    IF (j <= ntab) iv(j)=idum
  END DO
  iy=iv(1)
END IF
k=idum/iq1
idum=ia1*(idum-k*iq1)-k*ir1
IF (idum < 0) idum=idum+im1
k=idum2/iq2
idum2=ia2*(idum2-k*iq2)-k*ir2
IF (idum2 < 0) idum2=idum2+im2
j=1+iy/ndiv
iy=iv(j)-idum2
iv(j)=idum
IF(iy < 1)iy=iy+imm1
print *, am*iy, rnmx
ran2=MIN(am*iy,rnmx)

RETURN
END FUNCTION ran2

2楼2012-03-25 00:07:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 5lbyq5wrhb 2026-02-07 3/150 2026-02-08 03:05 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 5lbyq5wrhb 2026-02-07 3/150 2026-02-08 02:52 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +3 3rkserf6qr 2026-02-07 3/150 2026-02-08 02:32 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +5 2h7du0nuhk 2026-02-07 5/250 2026-02-08 02:27 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +5 2h7du0nuhk 2026-02-07 5/250 2026-02-08 02:25 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 5/250 2026-02-08 02:12 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 6/300 2026-02-08 02:07 by vs90ilomwc
[教师之家] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 6/300 2026-02-08 02:05 by vs90ilomwc
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:45 by vs90ilomwc
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:32 by vs90ilomwc
[教师之家] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:26 by vs90ilomwc
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全 +4 2h7du0nuhk 2026-02-07 7/350 2026-02-08 01:12 by vs90ilomwc
[教师之家] 有院领导为了换新车,用横向课题经费买了俩车 +7 瞬息宇宙 2026-02-04 7/350 2026-02-07 21:47 by tfang
[有机交流] 酰胺脱乙酰基 10+5 chibby 2026-02-03 12/600 2026-02-07 19:29 by 江东闲人
[基金申请] 有时候真觉得大城市人没有县城人甚至个体户幸福 +9 苏东坡二世 2026-02-04 10/500 2026-02-07 12:37 by 小毛球
[考博] 天津大学招2026.09的博士生,欢迎大家推荐交流(博导是本人) +4 a793625982 2026-02-05 5/250 2026-02-07 10:57 by a793625982
[公派出国] CSC & MSCA 博洛尼亚大学能源材料课题组博士/博士后招生|MSCA经费充足、排名优 +4 雨念 2026-02-01 6/300 2026-02-06 23:32 by MelissaPon
[基金申请] 面上项目申报 +3 Tide man 2026-02-01 3/150 2026-02-05 22:56 by god_tian
[硕博家园] 博士延得我,科研能力直往上蹿 +7 偏振片 2026-02-02 7/350 2026-02-04 17:36 by 陈氏帝国
[教师之家] 遇见不省心的家人很难过 +18 otani 2026-02-03 22/1100 2026-02-04 11:06 by tangmnt
信息提示
请填处理意见