24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 454  |  回复: 0

panda0927

木虫 (初入文坛)

[交流] 并行的一维fft fortran代码, 速度还行

subroutine cfftserial ( n, x )
   implicit none
   integer (kind = 4) :: n, i
   real (kind = 8)     :: pi, pid
   complex (kind = 8) :: x(n, 2)
   
   pi = acos ( -1.0d0 )
   pid = -pi * 2.0d0
   pid = pid / dble ( n )
!$omp parallel do default(shared) private(i)   
   do i = 0, n-1
      x(i+1, 1) = cmplx ( cos ( pid * dble ( i ) ), sin ( pid * dble ( i ) ), kind = 8 )
      x(i+1, 2) = conjg (  x(i+1, 1) )
   end do
!$omp end parallel do  

   return
end subroutine cfftserial

subroutine ifftserial ( n, x )
   implicit none
   integer (kind = 4) :: n, i, j, k, m, it, is
   integer (kind = 4) :: x(n)
   
   k = 0
   m = 1
   do  
      m = m * 2
      k = k + 1
      if ( n <= m ) exit
   end do
   
!$omp parallel do default(shared) private(it, m, is, i, j)   
   do it = 0, n - 1
      m = it
      is = 0
      do i = 0, k - 1
         j = m / 2
         is = 2 * is + (m - 2 * j)
         m = j
      end do
      x(it + 1) = is + 1
   end do
!$omp end parallel do
   
   return
end subroutine ifftserial

subroutine purefour(n, isign, iserial, cserial, fft)
   implicit none
   integer (kind = 4) :: n, it, is, m, k, i, j, nv, l0, isign
   integer (kind = 4) :: iserial(n)
   real (kind = 8)     :: pi , pid, dn
   complex (kind = 8) :: temp1, temp2, xsi
   complex (kind = 8) :: fft(n), temp(n), cserial(n, 2)
   
   dn = 1.0d0 / dble ( n )
   k = 0
   m = 1
   do  
      m = m * 2
      k = k + 1
      if ( n <= m ) exit
   end do

!$omp parallel default(shared)   

!$omp do private(i)   
   do i = 1, n
      temp(i) = fft(iserial(i))
   end do
!$omp end do

!$omp do private(j, temp2)
   do j = 0, n - 2, 2
      temp2 = temp(j + 1)
      temp(j + 1) = temp2 + temp(j + 2)  
      temp(j + 2) = temp2 - temp(j + 2)
   end do
!$omp end do

!$omp end parallel
   
   if ( isign == 1) then
      is = 1
   else
      is = 2
   end if

   m = n / 2
   nv = 2

   do l0 = k - 2, 0, -1
      m = m / 2
      nv = nv * 2
!$omp parallel do  &
!$omp default(private) &
!$omp shared(m, nv, temp, cserial, is)
      do it = 0, (m - 1) * nv, nv
         do j = 0, (nv / 2) - 1
            i = it + j + 1
            temp2 = cserial(m * j + 1, is) * temp(i + nv / 2)
            temp(i + nv / 2) = temp(i) - temp2
            temp(i) = temp(i) + temp2
         end do
      end do
!$omp end parallel do
   end do
   
   if ( isign == -1 ) then
!$omp parallel do &
!$omp default(shared)  private(i)
      do i = 1, n
         fft(i) = temp(i) * dn
      end do
!$omp end parallel do
   else
!$omp parallel do &
!$omp default(shared)  private(i)
      do i = 1, n
         fft(i) = temp(i)
      end do
!$omp end parallel do
   end if

   return
end subroutine purefour
回复此楼

» 猜你喜欢

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

智能机器人

Robot (super robot)

我们都爱小木虫

相关版块跳转 我要订阅楼主 panda0927 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 专硕085601求调剂 +5 suyifei 2026-04-03 6/300 2026-04-03 12:24 by suyifei
[考研] 266分,一志愿电气工程,本科材料,求材料专业调剂 +9 哇呼哼呼哼 2026-04-02 9/450 2026-04-03 12:05 by 1753564080
[考研] 316求调剂 +14 舟自梗 2026-04-01 18/900 2026-04-03 10:28 by linyelide
[考研] 081200-11408-276学硕求调剂 +6 崔wj 2026-04-02 6/300 2026-04-03 10:19 by 蓝云思雨
[考研] 320求调剂 +4 振—TZ 2026-04-02 4/200 2026-04-03 09:56 by 何曾几何
[考研] 一志愿安徽大学0817化学工程与技术,求调剂 +14 我不是只因 2026-04-02 15/750 2026-04-03 09:49 by 蓝云思雨
[考研] 330分求调剂 +15 qzenlc 2026-03-29 15/750 2026-04-02 21:41 by 百灵童888
[考研] 材料化工340求调剂 +5 jhx777 2026-03-30 5/250 2026-04-02 12:45 by smileboy2006
[考研] 一志愿厦门大学化学工程(专硕)-数二英二406分-求调剂 +5 厦大化工 2026-04-01 5/250 2026-04-02 10:03 by jp9609
[考研] 270调剂 +7 maxjxbsk 2026-04-02 7/350 2026-04-02 09:50 by yulian1987
[考研] 303求调剂 +8 DLkz1314. 2026-03-30 8/400 2026-04-02 09:08 by sanrepian
[考研] 材料调剂 +14 一样YWY 2026-04-01 14/700 2026-04-01 21:07 by lijunpoly
[考研] 材料与化工调剂一志愿大连海事085600,349 +9 吃的不少 2026-03-30 9/450 2026-04-01 11:24 by wangjy2002
[考研] 267求调剂 +13 uiybh 2026-03-31 13/650 2026-04-01 10:25 by 探123
[考研] 0855机械初试280求调剂 +3 kazenotori 2026-03-31 3/150 2026-04-01 10:08 by JourneyLucky
[考研] 080500-315分复试调剂 +9 上岸3821 2026-03-31 9/450 2026-03-31 17:29 by 唐沐儿
[考研] 329求调剂,一志愿西北工业大学,材料工程(085601) +6 小小机灵虫 2026-03-29 12/600 2026-03-31 16:58 by 记事本2026
[考研] 英一数一总分334求调剂 +4 陈阳坤 2026-03-31 4/200 2026-03-31 14:22 by 记事本2026
[考研] 吉大生物学326分求调剂 +3 sunnyupup 2026-03-31 3/150 2026-03-31 09:28 by longlotian
[考研] 材料专硕 085600求调剂 +7 BBQ233 2026-03-30 7/350 2026-03-30 17:44 by oooqiao
信息提示
请填处理意见