Fortran Coder

查看: 16381|回复: 5
打印 上一主题 下一主题

[求助] 我是新手,请问各位大神们,这个子程序是在做的什么循...

[复制链接]

70

帖子

25

主题

0

精华

专家

F 币
263 元
贡献
176 点
跳转到指定楼层
楼主
发表于 2018-5-1 17:13:44 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
[Fortran] 纯文本查看 复制代码
SUBROUTINE multi_to_single(multi_array,simple_array)
USE mytype; USE params
IMPLICIT NONE
INTEGER      :: int_auxil
INTEGER      :: mm_sub, nn_sub
COMPLEX (dp) :: multi_array(-4:1,-4:num_max)
COMPLEX (dp) :: simple_array(1:length_coeff)
!
int_auxil = 1
DO nn_sub = -4, 1  
       DO mm_sub = -4,num_max          
               simple_array(int_auxil)=multi_array(nn_sub,mm_sub)      
               int_auxil = int_auxil+1
       END DO
 END DO
   
!
return
END SUBROUTINE multi_to_single
分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

2022

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1598 元
贡献
689 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

6#
发表于 2018-5-2 08:05:13 | 只看该作者
有很多可能会让程序员有这种想法。比如它有个函数只识别二维输入,但它其他部分的计算都用的一维。
又不想改代码,嫌麻烦,就转一下。

实际上,reshape完全可以代替这俩函数。
这个程序作者为啥这么做?一个原因可能是这代码很老,当时还没有 reshape 函数。二个原因可能是作者对语法函数也不熟悉

70

帖子

25

主题

0

精华

专家

F 币
263 元
贡献
176 点
5#
 楼主| 发表于 2018-5-2 05:37:53 | 只看该作者
li913 发表于 2018-5-1 21:52
二维转为一维存储。直接用reshape函数就是。

是不是多维输入,转一维进行计算,使计算变得简便,算完了再转多维输出,是这样吗?

70

帖子

25

主题

0

精华

专家

F 币
263 元
贡献
176 点
地板
 楼主| 发表于 2018-5-2 00:22:59 | 只看该作者
li913 发表于 2018-5-1 21:52
二维转为一维存储。直接用reshape函数就是。

恩恩,谢谢。我这个子程序下边还有一个一维转二维的子程序,请问这样转来转去是干嘛呢?您看看这两个
[Fortran] 纯文本查看 复制代码
SUBROUTINE multi_to_single(multi_array,simple_array)
USE mytype; USE params
IMPLICIT NONE
INTEGER      :: int_auxil
INTEGER      :: mm_sub, nn_sub
COMPLEX (dp) :: multi_array(-4:1,-4:num_max)
COMPLEX (dp) :: simple_array(1:length_coeff)
!
int_auxil = 1
DO nn_sub = -4, 1  
       DO mm_sub = -4,num_max          
               simple_array(int_auxil)=multi_array(nn_sub,mm_sub)      
               int_auxil = int_auxil+1
       END DO
END DO

!
return
END SUBROUTINE multi_to_single
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
SUBROUTINE single_to_multi(simple_array,multi_array)
USE mytype; USE params
IMPLICIT NONE
INTEGER      :: int_auxil
INTEGER      :: mm_sub, nn_sub
COMPLEX (dp) :: simple_array(1:length_coeff)
COMPLEX (dp) :: multi_array(-4:1,-4:num_max)
!
int_auxil = 1
DO nn_sub = -4, 1
    DO mm_sub = -4,num_max
           multi_array(nn_sub,mm_sub)=simple_array(int_auxil)
               int_auxil = int_auxil+1
     END DO
END DO   
return
END SUBROUTINE single_to_multi


835

帖子

2

主题

0

精华

大宗师

F 币
3926 元
贡献
2334 点
板凳
发表于 2018-5-1 21:52:52 | 只看该作者
二维转为一维存储。直接用reshape函数就是。

70

帖子

25

主题

0

精华

专家

F 币
263 元
贡献
176 点
沙发
 楼主| 发表于 2018-5-1 21:19:58 | 只看该作者
帮忙看一下呀
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-11-24 03:20

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表