首页/文章/ 详情

Fortran基础编程(入门简介篇)

1年前浏览1349
Fortran是一门上世纪古老的科学计算语言,具有强大的计算能力,虽然没有现在的主流语言热门,但对于想从事有限元二次开发的童鞋来言,是一个不得不跨过去的槛儿,Fortran语言用于自己领域进行开发计算时,往往不需要高深的算法,只需了解简单的语法规则及循环之类结构即可。木木在刚开始学习Fortran时,遇到疑惑会问一问身边的同学有没有用过Fortran,大多数情况是,Fortran?那是啥语言?我......现如今使用的人确实很少,若不是自己对二次开发感兴趣,我也不会去触碰它~

本文先向大家简单介绍一个二分法的fortran程序,然后推荐大家使用一些轻便的编译器,最后推荐一下学习的书籍、论坛。


Fortran程序分为自由格式固定格式,固定格式太太太难看了,阅读起来也很费力,但大多数遗留下来的有限元程序是按照固定格式来编译的(木得办法),自由格式阅读起来就比较友好了,接下来就用自由格式来编写一个二分法程序,固定格式相关的将会在以后的推文中涉及。


































































! 二分法求解module numerical  implicit none  real,parameter :: zero=0.00001contains!   二分法求解程序  real function bisect(A,B,func)  implicit none  real A,B    !输入的值  real C     !用来算(A+B)/2  real FA    !记录F(A)  real FB   !记录F(B)  real FC   !记录F(C)  real,external :: func  !求解的函数!  先求出C,F(C)的值  C=(A+B)/2.0  FC=func(C)!  FC小于zero时,就视F(C)=0,结束循环  do while(abs(fc)>zero)    FA=func(A)    FB=func(B)    if(FA*FC<0) then    !  f(a)*f(c)<0, 以a,c为新的区间      B=C      C=(A+B)/2.0    else    !  不然就是以b,c为新的区间      A=C      C=(A+B)/2.0      end if      !  求出新的f(c)的值      FC=func(c)  end do  bisect = C  return  end function
!  求解用的函数  real function f(x)  implicit none  real x  f=(x+3)*(x-3)  return  end functionend module numerical
program main  use numerical  implicit none  real A,B   !两个猜测值  real ANS   !算出  do while(.true.)    write(*,*) '输入两个猜测值'    read(*,*) A,B    !  f(a)*f(b)<0 的猜测值才是有效的猜测值    if(f(a)*f(b)<0)exit    write(*,*) "不正确的猜测值"  end do  !   调用二分法求根的函数  ANS=bisect(A,B,f)  !   显示结果  write(*,"('x=',F6.3)")ans  stopend program main

本程序采用Module将代码块进行封装,程序中用到的变量、function、subroutine,整理到Module中,用的时候只需要Use一下就可,如行48。程序中一些语法、注意的细节将会在以后专门设立一个Fortran的栏目中进行讲解。


木木最开始用的编译器是VS+IVF,后来发现VS占用系统资源很多,卸载也很麻烦,用起来不顺手,现在我用的是Simply Fortran编译器,小巧轻便(100M左右),很很很好用,Simply Fortran安装包及简单的说明手册在文末获取。界面大致长这个样子:


B站有的教学视频也用的是这个编译器,大家有兴趣可以看一下。还有一个有意思的在线编译FORTRAN网站:http://fortran.jsrun.net/ 。界面大致长介个样子:


接下来就是推荐书籍和论坛了。书籍毫无疑问当然是台湾大学彭国伦先生的《Fortran 95 程序设计》,书里面有自由格式的程序,也有对应固定格式的程序,双管齐下,大家有兴趣可以点击了解一下。国内论坛的话推荐:http://fcode.cn/guide-61-1.html 很不错的Fortran交流论坛,里面有大量的资料,代码,工具免 费 使 用,国外的话,大家都懂得(Github)。


往期精彩内容:

相关文章,在仿真秀官网搜索:

基于Mathematica插值函数的振荡现象

UEL单元开发(1)——二维弹簧单元

基于节点位移的应力强度因子外推法

基于单元应力的应力强度因子外推法

数值计算&Matlab——Lagrange插值

来源:易木木响叮当
二次开发Mathematica
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2023-06-01
最近编辑:1年前
易木木响叮当
硕士 有限元爱好者
获赞 226粉丝 295文章 363课程 2
点赞
收藏
未登录
还没有评论
课程
培训
服务
行家
VIP会员 学习计划 福利任务
下载APP
联系我们
帮助与反馈