[教学]fortran计时间函数

合集下载

fortran语言语法

fortran语言语法

FORTRAN是世界上最早出现的高级编程语言,是工程界最常用的编程语言,它在科学计算中(如航空航天、地质勘探、天气预报和建筑工程等领域)发挥着极其重要的作用。

经过40多年的发展,伴随着FORTRAN语言多次版本的更新及相应开发系统的出现,其功能不断完善,最新版本的开发系统几乎具备了VC、VB的所有特点,如图形界面编程、数据库等。

目前,工科院校开设的计算机编程语言课首选仍然是FORTRAN :<说实话,从科技发展的趋势来说这不是好事。

您可以设想一下,如果需要用鹅毛笔抄写大量的古籍是什么感受!强烈建议阅读《发掘C#特性赋予科学计算项目以威力》1 FORTRAN77四则运算符+ - * / ** (其中**表示乘方)在表达式中按优先级次序由低到高为: +或-→*或/→**→函数→()2 FORTRAN77变量类型隐含约定:I-N规则凡是以字母I,J,K,L,M,N六个字母开头的,即认为是整型变量,其它为实型变量。

用类型说明语句确定变量类型:可以改变I-N规则用IMPLICIT语句将某一字母开头的全部变量指定为所需类型如IMPLICIT REAL (I,J)三种定义的优先级别由低到高顺序为:I-N规则→IMPLICIT语句→类型说明语句,因此,在程序中IMPLICIT语句应放在类型说明语句之前。

数组的说明与使用使用I-N规则时用DIMENSION说明数组,也可在定义变量类型同时说明数组,说明格式为:数组名(下标下界,下标上界),也可省略下标下界,此时默认为1,例:DIMENSION IA(0:9),ND(80:99),W(3,2),NUM(-1:0),A(0:2,0:1,0:3)REAL IA(10),ND(80:99)使用隐含DO循环进行数组输入输出操作:例如WRITE(*,10) ('I=',I,'A=',A(I),I=1,10,2)10FORMAT(1X,5(A2,I2,1X,A2,I4))使用DATA语句给数组赋初值变量表中可出现变量名,数组名,数组元素名,隐含DO循环,但不许出现任何形式的表达式:例如DATA A,B,C/,,DATA A/,B/,C/DATA A,B,C/3*CHARACTER*6 CHN(10)DATA CHN/10*'?????'/INTEGER NUM(1000)DATA (NUM(I),I=1,500)/500*0/,(NUM(I),I=501,1000)/500*1/3 FORTRAN77程序书写规则·程序中的变量名,不分大小写;·变量名称是以字母开头再加上1到5位字母或数字构成,即变更名字串中只有前6位有效;·一行只能写一个语句;·程序的第一个语句固定为PROGRAM 程序名称字符串·某行的第1个字符至第5个字符位为标号区,只能书写语句标号或空着或注释内容;·某行的第1个字符为C或*号时,则表示该行为注释行,其后面的内容为注释内容;·某行的第6个字符位为非空格和非0字符时,则该行为上一行的续行,一个语句最多可有19个续行;·某行的第7至72字符位为语句区,语句区内可以任加空格以求美观;·某行的第73至80字符位为注释区,80字符位以后不能有内容。

FORTRAN简明教程

FORTRAN简明教程

FORTRAN简明教程
一、FORTRAN简介
FORTRAN,指程序设计语言,由IBM在1956年发明,主要用于科学计算、数值运算等。

它将汇编语言中的功能集成在一个简单的命令语句中,
减少了汇编语言的繁琐的编译过程。

它也是目前世界上最古老的计算机程
序设计语言。

FORTRAN由“Formula Translating System”派生而来,主要用于工
程和科学计算,非常适用于此领域的算法及数学公式的应用。

基于这种语言,开发者可以轻松描述数字问题,并同时检测、审核、维护和优化此代码。

二、FORTRAN的优缺点
1、优点
a.FORTRAN是一种很容易上手的程序设计语言,它的语言规范很容易
理解,而且简单易用。

b.FORTRAN支持大量数值操作,所以它在计算机科学和工程领域有广
泛的应用。

c.FORTRAN程序非常高效,它的优化程序可以提高程序运行效率,而
且运算速度很快。

d.FORTRAN支持很多的数据类型,这样可以更有效地操作和管理数据。

2、缺点
a.FORTRAN不支持图形用户界面(GUI),这样用户需要熟悉命令行,才能完成程序的编写。

fortran语言语法

fortran语言语法

FORTRAN是世界上最早出现的高级编程语言,是工程界最常用的编程语言,它在科学计算中(如航空航天、地质勘探、天气预报和建筑工程等领域)发挥着极其重要的作用。

经过40多年的发展,伴随着FORTRAN语言多次版本的更新及相应开发系统的出现,其功能不断完善,最新版本的开发系统几乎具备了VC、VB的所有特点,如图形界面编程、数据库等。

目前,工科院校开设的计算机编程语言课首选仍然是FORTRAN :<说实话,从科技发展的趋势来说这不是好事。

您可以设想一下,如果需要用鹅毛笔抄写大量的古籍是什么感受!强烈建议阅读《》1 FORTRAN77四则运算符+ - * / ** (其中**表示乘方)在表达式中按优先级次序由低到高为:+或-→*或/→**→函数→()2 FORTRAN77变量类型隐含约定:I-N规则凡是以字母I,J,K,L,M,N六个字母开头的,即认为是整型变量,其它为实型变量。

用类型说明语句确定变量类型:可以改变I-N规则用IMPLICIT语句将某一字母开头的全部变量指定为所需类型如IMPLICIT REAL (I,J)三种定义的优先级别由低到高顺序为:I-N规则→IMPLICIT语句→类型说明语句,因此,在程序中IMPLICIT语句应放在类型说明语句之前。

数组的说明与使用使用I-N规则时用DIMENSION说明数组,也可在定义变量类型同时说明数组,说明格式为:数组名(下标下界,下标上界),也可省略下标下界,此时默认为1,例:DIMENSION IA(0:9),ND(80:99),W(3,2),NUM(-1:0),A(0:2,0:1,0:3)REAL IA(10),ND(80:99)使用隐含DO循环进行数组输入输出操作:例如WRITE(*,10) ('I=',I,'A=',A(I),I=1,10,2)10FORMAT(1X,5(A2,I2,1X,A2,I4))使用DATA语句给数组赋初值变量表中可出现变量名,数组名,数组元素名,隐含DO循环,但不许出现任何形式的表达式:例如DATA A,B,C/,,DATA A/,B/,C/DATA A,B,C/3*CHARACTER*6 CHN(10)DATA CHN/10*''/INTEGER NUM(1000)DATA (NUM(I),I=1,500)/500*0/,(NUM(I),I=501,1000)/500*1/3 FORTRAN77程序书写规则•程序中的变量名,不分大小写;•变量名称是以字母开头再加上1到5位字母或数字构成,即变更名字串中只有前6位有效;•一行只能写一个语句;•程序的第一个语句固定为PROGRAM 程序名称字符串•某行的第1个字符至第5个字符位为标号区,只能书写语句标号或空着或注释内容;•某行的第1个字符为C或*号时,则表示该行为注释行,其后面的内容为注释内容;•某行的第6个字符位为非空格和非0字符时,则该行为上一行的续行,一个语句最多可有19个续行;•某行的第7至72字符位为语句区,语句区内可以任加空格以求美观;•某行的第73至80字符位为注释区,80字符位以后不能有内容。

Fortran 函数

Fortran 函数
OUTTEXT
Subroutine
Sends text to the screen at the current position.
PIE, PIE_W
Functions
Draws a pie slice.
POLYGON, POLYGON_W
Functions
Draws a polygon.
POLYLINEQQ
SETFILETIMEQQ
Run-time Function
SETFILETIMEQQ(filename,timedate). Sets modification time for a given file.
SPLITPATHQQ
Run-time Function
SPLITPATHQQ(path,drive,dir,name,ext). Breaks a full path into four components.
File Management: table
Graphics Procedures: table
Note:Programs that use these procedures must access the appropriate library with USE DFLIB.
Name
Procedure TypeGFra bibliotekTFILLMASK
Subroutine
Returns the current fill mask.
GETFONTINFO
Function
Returns the current font characteristics.
GETGTEXTEXTENT
Function
Determines the width of the specified text in the current font.

fortran计时间函数

fortran计时间函数

Fortran 计时函数etime(fortran 77)例:call etime(tarray,t0)…………….Call etime(tarray,t1)print *, … Elapsed time:‟,t1-t0system_clock (fortran 90)cpu_time (fortran 95)例:call cpu_time(t0)…………….call cpu_time(t1)Print *, … Elapsed time:‟, t1-t0函数的具体参数可以参看编译软件Compaq Visual Fortran中的帮助文档和下面这段程序及其运行结果!关于计算程序所耗费的时间函数,具体可以参看帮助文档program systemclockinteger:: ic, crate, cmaxinteger(2) :: ic2, crate2, cmax2integer(4) :: ic4, crate4, cmax4integer::t1,t2call system_clock(t1)call system_clock(count=ic, count_rate=crate, count_max=cmax)call system_clock(count=ic2, count_rate=crate2, count_max=cmax2) call system_clock(count=ic4, count_rate=crate4, count_max=cmax4) call system_clock(t2)print *, t1, t2print *, ic, crate, cmaxprint *, ic2, crate2, cmax2print *, ic4, crate4, cmax4end program systemclock过一会儿再运行一下这段程序,其结果是可见,此台计算机上编译软件Compaq Visual Fortran的默认的integer是integer(4),计数率是10000(每秒计数10000次),最大计数值是2147483647。

[教学]fortran计时间函数

[教学]fortran计时间函数

Fortran,,,,,计时函数etime(fortran,,,,,77),,,,,例:call,,,,,etime(tarray,t0) ,,,,,,,,,,,,,,,,,,,,,,,,,……………. ,,,,,,,,,,,,,,,,,,,,,,,,,Call,,,,,etime(tarray,t1)print,,,,,*,,,,,,…,,,,,Elapsed,,,,,time:‟,t1-t0system_clock,,,,,(fortran,,,,,90)cpu_time,,,,,(fortran,,,,,95)例:call,,,,,cpu_time(t0) ,,,,,,,,,,,,,,,,,,,,,,,,,……………. ,,,,,,,,,,,,,,,,,,,,,,,,,call,,,,,cpu_time(t1)Print,,,,,*,,,,,,…,,,,,Elapsed,,,,,time:‟,,,,,,t1-t0函数的具体参数可以参看编译软件Compaq,,,,,V isual,,,,,Fortran中的帮助文档和下面这段程序及其运行结果!关于计算程序所耗费的时间函数,具体可以,,,,,参看帮助文档,,,,,program,,,,,systemclock,,,,,,,,,,integer::,,,,,,,,,,,,,,,,,,,,,,,,,ic,,,,,,crate,,,,,,cmax,,,,,,,,,,integer(2),,,,,::,,,,,ic2,,,,,,crate2,,,,,,cmax2,,,,,,,,,,integer(4),,,,,::,,,,,ic4,,,,,,crate4,,,,,,cmax4,,,,,,,,,,integer::t1,t2,,,,,,,,,,call,,,,,system_clock(t1),,,,,,,,,,call,,,,,system_clock(count=ic,,,,,,count_rate=crate,,,,,,count_max=cmax) ,,,,,,,,,,call,,,,,system_clock(count=ic2,,,,,,count_rate=crate2,,,,,,count_max=cmax2) ,,,,,,,,,,call,,,,,system_clock(count=ic4,,,,,,count_rate=crate4,,,,,,count_max=cmax4) ,,,,,,,,,,call,,,,,system_clock(t2),,,,,,,,,,print,,,,,*,,,,,,t1,,,,,,t2,,,,,,,,,,print,,,,,*,,,,,,ic,,,,,,crate,,,,,,cmax,,,,,,,,,,print,,,,,*,,,,,,ic2,,,,,,crate2,,,,,,cmax2,,,,,,,,,,print,,,,,*,,,,,,ic4,,,,,,crate4,,,,,,cmax4,,,,,,,,,,end,,,,,program,,,,,systemclock,,,,,过一会儿再运行一下这段程序,其结果是可见,此台计算机上编译软件Compaq,,,,,V isual,,,,,Fortran的默认的integer是integer(4),计数率是10000(每秒计数10000次),最大计数值是2147483647。

Fortran基础教程

Fortran基础教程

2024/8/9
18
3.5 常 量
3.5.2 实型常量
(有二种表示形式)
⒈小数形式
例:15.8,-21.05,14.0 ,14.,.17, 0.0 ,…
⒉指数形式(通常表示较大或较小的数)
例:100000000→1.0E+8
0.0000125→1.25E-05
数字部分
指数部分
2024/8/9
19
3.5 常 量
2024/8/9
31
3.7 Fortran内部函数
注意几点:
⑴函数自变量(参数)必须用括号括起来。
例:sinx+cosx → sin(x)+cos(x)
⑵函数自变量可以是常量、变量或表达式。
例: exp(3.0)
sin (x+cos(x))
⑶有些函数的类型是由自变量的类型确定的。
例:mod(8.0,3.0) →2.0
2024/8/9
24
3.6 变 量
注意几点: ⑴变量名不区分大小写字母。
例:TOTAL,Total,total 代表同一变量 ⑵变量名中的空格不起作用。
例:abc,a bc,ab c,a b c 代表同一变量 ⑶变量名尽量做到“见名知义” AVER、SUM、Imax ⑷允许变量名与语言中具有特定含义的字(“保留字”)
2024/8/9
13
3.4 Fortran程序的编辑与运行
一、Fortran PowerStation 4.0的启动
选“开始”→“程序”→“Fortran PowerStation 4.0”→“Microsoft Developer Studio”。
二、创建项目工作间
选“File”→“New”→“Project Workspace”→“Console Application”,并 输入项目工作间名称(如:aaa)和存放项 目工作间的位置或路径(如:c:\for\) → Create。

采用Fortran编程提取系统时间

采用Fortran编程提取系统时间

采用Fortran编程提取系统时间文一猪编程中我们往往需要提取系统时间,从而确定程序或子程序的运行时间。

我想在这里上有几个目的,比如说要对程序进行优化,当然你得先优化比较费时的子程序,或者你要直接从实际计算上计算出程序的复杂度,简单说就是计算时间同计算量的函数关系。

在这里给出关于采用Fortran95语言编写的提取系统时间程序。

Example1是网上帖子里的程序,不过该程序采用的time程序似乎不是Fortran95的标准程序。

在Example2给出的是自编的采用模块化编程调用cpu_time程序,使用F95的朋友可以很容易地将该程序嵌入到你们的程序中使用。

Mar. 14, 2013program TimeNowcharacter*8 :: nowinteger :: hh,mm,sscall time (now) ! 读系统时间write(*,*) now ! 写出时间字符串! 用字符变量now作为内部文件,从中将时、分、秒作为整数读出read(now,"(I2,1x,I2,1x,I2)") hh,mm,ss ! 字符转换为write(*,*) hh,mm,ss ! 写出时、分、秒的整数值stopend program TimeNow帖子:/club/showtxt.asp?id=70407/post-70559.htmlmodule get_timepublic display_timecontainssubroutine display_time()implicit nonedoubleprecision nowtimecall cpu_time(nowtime)write(*,'(1x,a,1e10.3)') "Now Time is ", nowtime returnend subroutineend moduleprogram test_get_timeuse get_timeimplicit doubleprecision (a-h, o-z), integer (i-n)call display_time()do i = 1,1000000do j = 1,2000x = dlog(1.1d0)enddoenddocall display_time()stop "The end!"end program第2 章Fortran 95 内函数本章列出了f95 编译器可识别的内函数名称。

fortran语言语法

fortran语言语法

FORTRAN是世界上最早出现的高级编程语言,是工程界最常用的编程语言,它在科学计算中(如航空航天、地质勘探、天气预报和建筑工程等领域)发挥着极其重要的作用。

经过40多年的发展,伴随着FORTRAN语言多次版本的更新及相应开发系统的出现,其功能不断完善,最新版本的开发系统几乎具备了VC、VB的所有特点,如图形界面编程、数据库等。

目前,工科院校开设的计算机编程语言课首选仍然是FORTRAN :<说实话,从科技发展的趋势来说这不是好事。

您可以设想一下,如果需要用鹅毛笔抄写大量的古籍是什么感受!强烈建议阅读《发掘C#特性赋予科学计算项目以威力》1 FORTRAN77四则运算符+ - * / ** (其中**表示乘方)在表达式中按优先级次序由低到高为: +或-→*或/→**→函数→()2 FORTRAN77变量类型2.1隐含约定:I-N规则凡是以字母I,J,K,L,M,N六个字母开头的,即认为是整型变量,其它为实型变量。

2.2用类型说明语句确定变量类型:可以改变I-N规则2.3用IMPLICIT语句将某一字母开头的全部变量指定为所需类型如IMPLICIT REAL (I,J)三种定义的优先级别由低到高顺序为:I-N规则→IMPLICIT语句→类型说明语句,因此,在程序中IMPLICIT语句应放在类型说明语句之前。

2.4数组的说明与使用使用I-N规则时用DIMENSION说明数组,也可在定义变量类型同时说明数组,说明格式为:数组名(下标下界,下标上界),也可省略下标下界,此时默认为1,例:DIMENSION IA(0:9),ND(80:99),W(3,2),NUM(-1:0),A(0:2,0:1,0:3)REAL IA(10),ND(80:99)使用隐含DO循环进行数组输入输出操作:例如WRITE(*,10) ('I=',I,'A=',A(I),I=1,10,2)10FORMAT(1X,5(A2,I2,1X,A2,I4))2.5使用DATA语句给数组赋初值变量表中可出现变量名,数组名,数组元素名,隐含DO循环,但不许出现任何形式的表达式:例如DATA A,B,C/-1.0,-1.0,-1.0/DATA A/-1.0/,B/-1.0/,C/-1.0/DATA A,B,C/3*-1.0/CHARACTER*6 CHN(10)DATA CHN/10*''/INTEGER NUM(1000)DATA (NUM(I),I=1,500)/500*0/,(NUM(I),I=501,1000)/500*1/3 FORTRAN77程序书写规则∙程序中的变量名,不分大小写;∙变量名称是以字母开头再加上1到5位字母或数字构成,即变更名字串中只有前6位有效;∙一行只能写一个语句;∙程序的第一个语句固定为PROGRAM 程序名称字符串∙某行的第1个字符至第5个字符位为标号区,只能书写语句标号或空着或注释内容;∙某行的第1个字符为C或*号时,则表示该行为注释行,其后面的内容为注释内容;∙某行的第6个字符位为非空格和非0字符时,则该行为上一行的续行,一个语句最多可有19个续行;∙某行的第7至72字符位为语句区,语句区内可以任加空格以求美观;∙某行的第73至80字符位为注释区,80字符位以后不能有内容。

Fortran基本用法小结

Fortran基本用法小结

Fortran基本用法小结目录:一、说明二、概述三、数据类型及基本输入输出四、流程控制五、循环六、数组七、函数八、文件一、说明本文多数内容是我读彭国伦《Fortran 95 程序设计》的笔记。

只读到第九章,主要是3~9章,都是最基本的用法(原书共16章)。

这里主要摘录了我看书过程中总结的一些Fortran和C不同的地方,主要是语法方面。

希望这份笔记能够给学过C但没有接触过Fortran的同学带去一些帮助。

要想得更清楚些,推荐看一下原书,觉得作者真的写得很好,很清楚;如果有C语言的基础,看完前九应该很快的,花一两天就行了。

觉得如果耐心看完本文,基本功能应该也可以顺利用起来了。

外,由于我之前没有用过Fortran,这次为了赶文档看书又看得很粗浅,大多数东西看过之后都没得及仔细想,只是按着作者的意思去理解。

所以这份笔记还处于纸上谈兵的层次。

如果有不妥的方,希望大家指正。

谢谢!文中蓝色的部分是程序代码,!后面的内容为注释。

二、概述1、名词解释Fortran=For mula Tran slator/Translation一看就知道有什么特色了:可以把接近数学语言的文本翻译成机械语言。

的确,从一开始,IBM设计的时候就是为了方便数值计算和科学数据处理。

设计强大的数组操作就是为了实现这一目标。

ortran奠定了高级语言发展的基础。

现在Fortran在科研和机械方面应用很广。

2、Fortran的主要版本及差别按其发展历史,Fortran编译器的版本其实很多。

现在在广泛使用的是Fortran 77和Fortran90。

ortran 90在Fortran 77基础上添加了不少使用的功能,并且改良了77编程的版面格式,所以编程时推荐使用90。

鉴于很多现成的程序只有77版本,有必要知道77的一些基本常识,至少保证能够看77程序。

以下是77和90的一些格式上的区别。

Fortran 77:固定格式(fixed format),程序代码扩展名:.f 或.for(1)若某行以C,c或*开头,则该行被当成注释;(2)每行前六个字符不能写程序代码,可空着,或者1~5字符以数字表明行代码(用作格式化输入出等);7~72为程序代码编写区;73往后被忽略;(3)太长的话可以续行,所续行的第六个字符必须是"0"以外的任何字符。

Fortran函数大全(1)

Fortran函数大全(1)

Fortran函数大全(1)Fortran库参考SunStudio11SunMicrosystems,文件号码819-4757-102005年11月, 修订版A请将有关本文档的意见和建议提交至:/hwdocs/feedback版权所有#169;2005SunMicrosystems,Inc.,4150NetworkCircle,SantaCla ra,California95054,U.S.A.保留所有权利.美国政府权利-商业用途. 政府用户应遵循SunMicrosystems,Inc.的标准许可协议, 以及FAR (FederalAcquisitionRegulations, 即“联邦政府采购法规”)的适合条款及其补充条款. 必须依据许可证条款使用. 本发行版可能包含由第三方开辟的内容.本产品的某些部份可能是从BerkeleyBSD系统衍生出来的, 并获得了加利福尼亚大学的许可. UNIX是X/OpenCompany,Ltd.在美国和其他国家/地区独家许可的注册商标.Sun、SunMicrosystems、Sun徽标、Java和JavaHelp是SunMicrosystems,Inc.在美国和其他国家/地区的商标或者注册商标. 所有的SPARC商标的使用均已获得许可, 它们是SPARCInternational,Inc.在美国和其他国家/地区的商标或者注册商标. 标有SPARC商标的产品均基于由SunMicrosystems,Inc.开辟的体系结构.本服务手册所介绍的产品以及所包含的信息受美国出口控制法制约, 并应遵守其他国家/地区的进出口法律. 严禁将本产品直接或者间接地用于核设施、导弹、生化武器或者海上核设施, 也不能直接或者间接地出口给核设施、导弹、生化武器或者海上核设施的最终用户. 严禁出口或者转口到美国禁运的国家/地区以及美国禁止出口清单中所包含的实体, 包括但不限于被禁止的个人以及特殊指定的国家/地区的公民. 本文档按“原样”提供, 对于所有明示或者默示的条件、陈述和担保, 包括对适销性、适合性或者非侵权性的默示保证, 均不承担任何责任, 除非此免责声明的适合范围在法律上无效.目录阅读本书之前印刷约定xixiShell提示符支持的平台xiixiiixiii访问SunStudio软件和手册页访问编译器和工具文档访问相关的Solaris文档开辟者资源xviiixixxixxvixviii联系Sun技术支持Sun欢迎您提出意见1. Fortran库例程1.11.21.31–1数据类型注意事项64位环境1–21–1Fortran数学函数1.3.11.3.21.3.3单精度函数1–31–3双精度函数1–6四倍精度函数1–91–111–11iii1.4Fortran库例程参考1.4.1abort:终止和写入核心文件1.4.21.4.31.4.41.4.51.4.61.4.71.4.81.4.91.4.101.4.111.4. 121.4.131.4.141.4.151.4.161.4.171.4.181.4.191.4.201.4.21 1.4.221.4.231.4.241.4.251.4.261.4.271.4.281.4.29access:检查文件权限或者存在性1–11alarm:在指定的时间后调用子例程1–12bit:位函数:and、or、…、bit、setbit、…chdir:更改默认目录chmod:更改文件的模式1–131–161–171–18date:获取以字符串表示的当前日期dtime, etime:经过的执行时间exit:终止进程并设置状态1–201–231–23fdate:以ASCII字符串返回日期和时间flush:刷新逻辑单元的输出1–24fork:创建当前进程的副本1–25fseek,ftell:确定文件的位置以及重新确定文件的位置1–25fseeko64, ftello64:确定大文件的位置以及重新确定大文件的位置1–271–29getarg, iargc:获取命令行参数getc, fgetc:获取下一个字符1–301–32getcwd:获取当前工作目录的路径getenv:获取环境变量的值1–33getfd:获取外部单元编号的文件描述符getfilep:获取外部单元编号的文件指针getlog:获取用户的登录名getpid:获取进程ID1–341–341–361–361–36getuid, getgid:获取进程的用户ID或者组IDhostnm:获取当前主机的名称1–37idate:返回当前日期1–381–38ieee_flags, ieee_handler,sigfpe:IEEE算术index, rindex, lnblnk:子串的索引或者长度. 1–44inmax:返回最大正整数1–45itime:当前时间1–46ivFortran库参考2005年11月1.4.301.4.311.4.321.4.331.4.341.4.35kill:将信号发给进程1–471–47link, symlnk:链接到现有的文件loc:返回对象的地址1–491–491–50long, short:整型对象转换longjmp,isetjmp:返回至isetjmp设置的位置malloc, malloc64, realloc, free:分配/重新分配/释放内存1–521.4.36mvbits:挪移位字段1–561.4.37perror, gerror, ierrno:获取系统错误消息1–571.4.38putc, fputc:将字符写入逻辑单元1–581.4.39qsort, qsort64:对一维数组的元素进行排序1–601.4.40ran:生成一个介于0和1之间的随机数1–621.4.41rand, drand, irand:返回随机值1–631.4.42rename:重命名文件1–641.4.43secnds:获取以秒数表示的系统时间并减去参数1–651.4.44set_io_err_handler, get_io_err_handler:设置并获取I/O错误处理程序1–651.4.45sh:快速执行sh命令1–681.4.46signal:更改信号的操作1–691.4.47sleep:一段时间暂停执行1–701.4.48stat, lstat, fstat:获取文件状态1–701.4.49stat64, lstat64, fstat64:获取文件状态1–731.4.50system:执行系统命令1–731.4.51time, ctime, ltime, gmtime:获取系统时间1–741.4.52ttynam, isatty:获取终端端口的名称1–781.4.53unlink:删除文件1–791.4.54wait:等待进程终止1–802.Fortran95内部函数2–12.1标准Fortran95的通用内部函数2–1v目录2.1.12.1.22.1.32.1.42.1.52.1.62.1.72.1.82.1.92.1.102.1.1 12.1.122.1.132.1.142.1.152.1.162.1.172.1.182.1.192.1.202 .1.212.1.222.1.232.2参数存在查询函数数值函数数学函数字符函数。

fortran getarg函数

fortran getarg函数

fortran getarg函数摘要:1.函数简介2.函数声明3.函数参数4.函数功能5.函数使用示例6.总结正文:【1.函数简介】Fortran 语言是一种高级编程语言,广泛应用于数值计算领域。

在Fortran 中,getarg 函数是一个用于获取命令行参数的函数。

它可以帮助我们在程序运行时从命令行接收参数,并将这些参数的值存储在指定的内存位置。

这对于需要根据用户输入来执行不同操作的程序非常有用。

【2.函数声明】getarg 函数的声明如下:```fortranfunction getarg(index, arg) result(value)implicit noneinteger, intent(in) :: indexcharacter(*), intent(out) :: argcharacter(256), intent(out) :: valueend function getarg```【3.函数参数】getarg 函数有两个参数:- index:一个整数,表示要获取的参数在命令行中的位置。

参数的位置从1 开始计数。

- arg:一个字符串,表示要获取的参数的类型。

例如,如果要获取一个整数参数,可以将arg 设置为"integer"。

【4.函数功能】getarg 函数的功能是根据命令行参数的索引和类型,将对应的参数值存储在value 参数中。

如果指定的参数不存在或为空,函数将返回一个错误信息。

【5.函数使用示例】下面是一个简单的示例,展示如何使用getarg 函数从命令行获取参数:```fortranprogram exampleimplicit noneinteger :: index, valuecharacter(256) :: arg! 设置要获取参数的类型arg = "integer"! 获取参数值call getarg(1, arg, value)! 输出参数值print *, "参数值:", valueend program example```在这个示例中,我们使用getarg 函数从命令行获取第一个参数,并将其值存储在变量value 中。

fortran getarg函数

fortran getarg函数

fortran getarg函数(实用版)目录1.概述2.getarg 函数的作用3.getarg 函数的使用方法4.getarg 函数的返回值5.示例正文1.概述Fortran 是一种高级编程语言,广泛应用于数值计算和科学计算领域。

在 Fortran 中,有一个名为 getarg 的函数,它可以从命令行中获取输入参数。

这对于编写可执行程序非常有用,用户可以通过命令行输入参数来控制程序的行为。

2.getarg 函数的作用getarg 函数用于从命令行中读取输入参数。

在 Fortran 程序中,我们可以使用命令行输入一些参数,这些参数可以用 getarg 函数获取。

getarg 函数将这些参数作为输入,并将它们存储在指定的变量中。

3.getarg 函数的使用方法要使用 getarg 函数,首先需要声明它,然后在程序中调用它。

以下是一个简单的示例:```fortranprogram getarg_exampleimplicit noneinteger :: a, binteger, dimension(2) :: c = (/ 1, 2 /)! 使用 getarg 函数从命令行获取两个整数参数a = getarg(1)b = getarg(2)! 计算并输出两个参数的和与积print *, "a + b =", a + bprint *, "a * b =", a * bend program getarg_example```在这个示例中,我们声明了一个名为 getarg_example 的程序,并在其中使用 getarg 函数从命令行获取两个整数参数。

然后,我们计算并输出这两个参数的和与积。

4.getarg 函数的返回值getarg 函数的返回值是读取到的命令行参数。

在示例中,getarg(1) 表示读取第一个命令行参数,getarg(2) 表示读取第二个命令行参数。

Fortran常用函数

Fortran常用函数

1、RANDOM_NUMBERSyntax ['sintæks] n. 语法CALL RANDOM_NUMBER (harvest结果)Intrinsic Subroutine(固有子程序):Returns a pseudorandom number greater than or equal to zero and less than one from the uniform distribution.返回大于或等于0且小于1,服从均匀分布的随机数2、RNNOA/ DRNNOA (Single/Double precision)Generate pseudorandom numbers from a standard normal distribution using an acceptance/rejection method.产生服从标准正态分布的随机数Usage(用法)CALL RNNOA (NR, R)Arguments(参数)NR— Number of random numbers to generate. (Input) 要产生随机数的个数R— Vector of length NR containing the random standard normal deviates. (Output)输出长度为NR,随机正态分布的向量Comments(注解)The routine RNSET can be used to initialize the seed of the random number generator. The routine RNOPT can be used to select the form of the generator.程序RNSET可以用来初始化随机数发生器的种子ExampleIn this example, RNNOA is used to generate five pseudorandom deviates from a standard normal distribution.INTEGER ISEED, NOUT, NRREAL R(5)EXTERNAL RNNOA, RNSET, UMACHCCALL UMACH (2, NOUT)NR = 5ISEED = 123457CALL RNSET (ISEED)CALL RNNOA (NR, R)WRITE (NOUT,99999) R99999 FORMAT (' Standard normal random deviates: ', 5F8.4)ENDOutputStandard normal random deviates: 2.0516 1.0833 0.0826 1.2777 -1.22603、RESHAPEIntrinsic Function(内部函数)Constructs an array of a specified shape from the elements of another array. 构造规定形式的数组Syntax(语法)result = RESHAPE (source, shape [ , pad][ , order])source(Input) Any type. Array whose elements will be taken in standard Fortran array order (see Remarks), and then placed into a new array.shape(Input) Integer. One-dimensional array that describes the shape of the output array created from elements of source. 描述输出数组的大小的一维数组,The elements of shape are the sizes of the dimensions of the reshaped array in order. If pad is omitted 省略, the total size specified by shape must be less than or equal to source.pad 可选参数(Optional; input) Same type as source. Must be an array. If there are not enough elements in source to fill the result array, elements of pad are added in standardFortran array order. If necessary, extra copies of pad are used to fill the array.order 可选参数(Optional; input) Integer. One-dimensional array. Must be the same length as shape.Permutes the order of dimensions in the result array. The value of order must be a permutation of (1, 2,...n) where n is the size of shape.Return Value(返回值)The result is an array the same data type and kind as source and a shape as defined in shape.ExamplesINTEGER AR1( 2, 5)REAL F(5,3,8)REAL C(8,3,5)AR1 = RESHAPE((/1,2,3,4,5,6/),(/2,5/),(/0,0/),(/2,1/))! returns 1 2 3 4 5! 6 0 0 0 0!! Change Fortran array order to C array orderC = RESHAPE(F, (/8,3,5/), ORDER = (/3, 2, 1/))END4、SUMIntrinsic Function(内部函数)Sums elements of an array or the elements along an optional dimension. The elements summed can be selected by an optional mask.将数组中的元素求和Syntax(语法)result = SUM (array [ , dim] [ , mask])array(Input) Integer, real, or complex. Array whose elements are to be summed.dim 可选参数(Optional; input) Integer. Dimension along which elements are summed.1 ≤dim≤n, where n is the number of dimensions in array.mask 可选参数(Optional; input) Logical. Must be same shape as array. If mask is specified, only elements in array that correspond to .TRUE. elements in mask are summed.Return Value(返回值)Same type and kind as array and equal to the sum of all elements in array or the sum of elements along dimension dim. If mask is specified, only elements that correspondto .TRUE. elements in mask are summed. Returns a scalar if dim is omitted or array is one-dimensional. Otherwise, returns an array one dimension smaller than array.ExamplesINTEGER array (2, 3), i, j(3)array = RESHAPE((/1, 2, 3, 4, 5, 6/), (/2, 3/))! array is 1 3 5! 2 4 6i = SUM((/ 1, 2, 3 /)) ! returns 6j = SUM(array, DIM = 1) ! returns [3 7 11]WRITE(*,*) i, jEND5、SEEDRun-Time Subroutine Changes the starting point of the pseudorandom number generator. 改变随机数发生器的起始点ModuleUSE MSFLIBSyntax(语法)CALL SEED (iseed)iseed(Input) INTEGER(4). Starting point for RANDOM.Remarks(注解)SEED uses iseed to establish the starting point of the pseudorandom number generator.A given seed always produces the same sequence of values from RANDOM.If SEED is not called before the first call to RANDOM, RANDOM always begins with a seed value of one. If a program must have a different pseudorandom sequence each time it runs, pass the constant RND$TIMESEED (defined in MSFLIB.F90) to the SEED routine before the first call to RANDOM.ExampleUSE MSFLIBREAL randCALL SEED(7531)CALL RANDOM(rand)6、RANDOMPurposeRun-Time Subroutine Returns a pseudorandom number greater than or equal to zero and less than one from the uniform distribution. 返回大于或等于0且小于1,服从均匀分布的随机数ModuleUSE MSFLIBSyntaxCALL RANDOM (ranval)ranval(Output) REAL(4). Pseudorandom number, 0 ≤ranval< 1, from the uniformdistribution.RemarksA given seed always produces the same sequence of values from RANDOM.If SEED is not called before the first call to RANDOM, RANDOM begins with a seed value of one. If a program must have a different pseudorandom sequence each time it runs, pass the constant RND$TIMESEED (defined in MSFLIB.F90) to SEED before the first call to RANDOM.All the random procedures (RANDOM, RAN, and RANDOM_NUMBER, and the PortLib functions DRAND, DRANDM, RAND, IRANDM, RAND, and RANDOM) use the same algorithms and thus return the same answers. They are all compatible and can be used interchangeably. (The algorithm used is a “Prime Modulus M Multiplicative Linear Congruential Generator,” a modified version of t he random number generator by Park and Miller in “Random Number Generators: Good Ones Are Hard to Find,” CACM, October 1988, Vol. 31, No. 10.)CompatibilityCONSOLE STANDARD GRAPHICS QUICKWIN GRAPHICS WINDOWS DLL LIBExampleUSE MSFLIBREAL(4) ranCALL SEED(1995)CALL RANDOM(ran)7、FFT2BCompute the inverse Fourier transform of a complex periodic two-dimensional array.计算二维复数数组的逆傅里叶变换Usage(用法)CALL FFT2B (NRCOEF, NCCOEF, COEF, LDCOEF, A, LDA)Arguments(参数)NRCOEF— The number of rows of COEF. (Input) 数组COEF的行数NCCOEF— The number of columns of COEF. (Input) 数组COEF的列数COEF—NRCOEF by NCCOEF complex array containing the Fourier coefficients to be transformed. (Input) NRCOEF行NCCOEF列数组LDCOEF— Leading dimension of COEF exactly as specified in the dimension statement of the calling program. (Input)A—NRCOEF by NCCOEF complex array containing the Inverse Fourier coefficients of COEF. (Output) NRCOEF行NCCOEF列复数数组,包含数组COEF的逆傅里叶系数LDA— Leading dimension of A exactly as specified in the dimension statement of the calling program. (Input)Comments(注解)1.Automatic workspace usage isFFT2B4 * (NRCOEF + NCCOEF) + 32 + 2 *MAX(NRCOEF, NCCOEF) units, orDFFT2B8 * (NRCOEF + NCCOEF ) + 64 + 4 *MAX(NRCOEF, NCCOEF) units.Workspace may be explicitly provided, if desired, by use of F2T2B/DF2T2B. The reference isCALL F2T2B (NRCOEF, NCCOEF, A, LDA, COEF, LDCOEF,WFF1, WFF2, CWK, CPY)The additional arguments are as follows:WFF1— Real array of length 4 *NRCOEF + 15 initialized by FFTCI. The initialization depends on NRCOEF. (Input)WFF2— Real array of length 4 *NCCOEF + 15 initialized by FFTCI. The initialization depends on NCCOEF. (Input)CWK— Complex array of length 1. (Workspace)CPY— Real array of length 2 *MAX(NRCOEF, NCCOEF). (Workspace)2.The routine FFT2B is most efficient when NRCOEF and NCCOEF are the product of small primes.3.The arrays COEF and A may be the same.4.If FFT2D/FFT2B is used repeatedly, with the same values for NRCOEF and NCCOEF, then use FFTCI to fill WFF1(N = NRCOEF) and WFF2(N = NCCOEF). Follow this with repeated calls to F2T2D/F2T2B. This is more efficient than repeated calls toFFT2D/FFT2B.AlgorithmThe routine FFT2B computes the inverse discrete complex Fourier transform of a complex two-dimensional array of size (NRCOEF = N) ⨯ (NCCOEF = M). The method used is a variant of the Cooley-Tukey algorithm , which is most efficient when N and M are both products of small prime factors. If N and M satisfy this condition, then the computational effort is proportional to N M log N M. This considerable savings has historically led people to refer to this algorithm as the "fast Fourier transform" or FFT.Specifically, given an N⨯M array c = COEF, FFT2B returns in aFurthermore, a vector of Euclidean norm S is mapped into a vector of normFinally, note that an unnormalized inverse is implemented in FFT2D. The routine FFT2B is based on the complex FFT in FFTPACK. The package FFTPACK was developed by Paul Swarztrauber at the National Center for Atmospheric Research.ExampleIn this example, we first compute the Fourier transform of the 5 ⨯ 4 arrayfor 1 ≤n≤ 5 and 1 ≤m≤ 4 using the IMSL routine FFT2D. The resultis then inverted by a call to FFT2B. Note that the result is an array a satisfying a = (5)(4)x = 20x. In general, FFT2B is an unnormalized inverse with expansion factor N M.INTEGER LDA, LDCOEF, M, N, NCA, NRACOMPLEX CMPLX, X(5,4), A(5,4), COEF(5,4)CHARACTER TITLE1*26, TITLE2*26, TITLE3*26INTRINSIC CMPLXEXTERNAL FFT2B, FFT2D, WRCRNCTITLE1 = 'The input matrix is below 'TITLE2 = 'After FFT2D 'TITLE3 = 'After FFT2B 'NRA = 5NCA = 4LDA = 5LDCOEF = 5C Fill X with initial dataDO 20 N=1, NRADO 10 M=1, NCAX(N,M) = CMPLX(FLOAT(N+5*M-5),0.0)10 CONTINUE20 CONTINUECCALL WRCRN (TITLE1, NRA, NCA, X, LDA, 0)CCALL FFT2D (NRA, NCA, X, LDA, COEF, LDCOEF)CCALL WRCRN (TITLE2, NRA, NCA, COEF, LDCOEF, 0)CCALL FFT2B (NRA, NCA, COEF, LDCOEF, A, LDA)CCALL WRCRN (TITLE3, NRA, NCA, A, LDA, 0)CENDOutputThe input matrix is below1 2 3 41 ( 1.00, 0.00) ( 6.00, 0.00) ( 11.00, 0.00) ( 16.00, 0.00)2 ( 2.00, 0.00) ( 7.00, 0.00) ( 12.00, 0.00) ( 17.00, 0.00)3 ( 3.00, 0.00) ( 8.00, 0.00) ( 13.00, 0.00) ( 18.00, 0.00)4 ( 4.00, 0.00) ( 9.00, 0.00) ( 14.00, 0.00) ( 19.00, 0.00)5 ( 5.00, 0.00) ( 10.00, 0.00) ( 15.00, 0.00) ( 20.00, 0.00) After FFT2D1 2 3 41 ( 210.0, 0.0) ( -50.0, 50.0) ( -50.0, 0.0) ( -50.0, -50.0)2 ( -10.0, 13.8) ( 0.0, 0.0) ( 0.0, 0.0) ( 0.0, 0.0)3 ( -10.0, 3.2) ( 0.0, 0.0) ( 0.0, 0.0) ( 0.0, 0.0)4 ( -10.0, -3.2) ( 0.0, 0.0) ( 0.0, 0.0) ( 0.0, 0.0)5 ( -10.0, -13.8) ( 0.0, 0.0) ( 0.0, 0.0) ( 0.0, 0.0) After FFT2B1 2 3 41 ( 20.0, 0.0) ( 120.0, 0.0) ( 220.0, 0.0) ( 320.0, 0.0)2 ( 40.0, 0.0) ( 140.0, 0.0) ( 240.0, 0.0) ( 340.0, 0.0)3 ( 60.0, 0.0) ( 160.0, 0.0) ( 260.0, 0.0) ( 360.0, 0.0)4 ( 80.0, 0.0) ( 180.0, 0.0) ( 280.0, 0.0) ( 380.0, 0.0)5 ( 100.0, 0.0) ( 200.0, 0.0) ( 300.0, 0.0) ( 400.0, 0.0)8、TIMEFPurposePortLib Function Returns the number of seconds since the first time it is called, or zero.ModuleUSE PORTLIBSyntaxresult=TIMEF ( )Return ValueREAL(8). Number of seconds that have elapsed since the first time TIMEF( ) was called. The first time called, TIMEF returns 0.0D0.CompatibilityCONSOLE STANDARD GRAPHICS QUICKWIN GRAPHICS WINDOWS DLL LIBExampleUSE PORTLIBINTEGER i, jREAL(8) elapsed_timeelapsed_time = TIMEF() DO i = 1, 100000j = j + 1END DOelapsed_time = TIMEF() PRINT *, elapsed_time END。

采用Fortran编程提取系统时间

采用Fortran编程提取系统时间

采用Fortran编程提取系统时间文一猪编程中我们往往需要提取系统时间,从而确定程序或子程序的运行时间。

我想在这里上有几个目的,比如说要对程序进行优化,当然你得先优化比较费时的子程序,或者你要直接从实际计算上计算出程序的复杂度,简单说就是计算时间同计算量的函数关系。

在这里给出关于采用Fortran95语言编写的提取系统时间程序。

Example1是网上帖子里的程序,不过该程序采用的time程序似乎不是Fortran95的标准程序。

在Example2给出的是自编的采用模块化编程调用cpu_time程序,使用F95的朋友可以很容易地将该程序嵌入到你们的程序中使用。

Mar. 14, 2013program TimeNowcharacter*8 :: nowinteger :: hh,mm,sscall time (now) ! 读系统时间write(*,*) now ! 写出时间字符串! 用字符变量now作为内部文件,从中将时、分、秒作为整数读出read(now,"(I2,1x,I2,1x,I2)") hh,mm,ss ! 字符转换为write(*,*) hh,mm,ss ! 写出时、分、秒的整数值stopend program TimeNow帖子:/club/showtxt.asp?id=70407/post-70559.htmlmodule get_timepublic display_timecontainssubroutine display_time()implicit nonedoubleprecision nowtimecall cpu_time(nowtime)write(*,'(1x,a,1e10.3)') "Now Time is ", nowtime returnend subroutineend moduleprogram test_get_timeuse get_timeimplicit doubleprecision (a-h, o-z), integer (i-n)call display_time()do i = 1,1000000do j = 1,2000x = dlog(1.1d0)enddoenddocall display_time()stop "The end!"end program第2 章Fortran 95 内函数本章列出了f95 编译器可识别的内函数名称。

fortran 函数总结

fortran 函数总结

附录C 部分函数指令表(c). .(注解:本指令表只收集了部分常用指令, 有关全部指令请参照文档文件) + 加- 减* 矩阵乘数组乘 *.1. 通用指令^ 矩阵乘方数组乘方 ^.\ 反斜杠或左除在线帮助/ 斜杠或右除文档中关键词搜寻或.\ 数组除/.缺省变量名以及最新表达式的运算结果等号不等号从内存中清除变量和函数< 小于关闭> 大于退出<= 小于或等于把内存变量存入磁盘>= 大于或等于运行脚本文件逻辑与文件运行中的显示格式逻辑或显示版本逻辑非浮点运算溢出显示模式选择: 冒号列出工作内存中的变量名( ) 园括号文件编辑器[ ] 方括号变量类型{ } 花括号列出基本命令小数点 .设置数据输出格式, 逗号改变当前工作目录; 分号给出环境值注释号创建目录= 赋值符号显示当前工作目录' 引号执行表达式' 复数转置号转置号 '.最新表达式的运算结果2.运算符和特殊算符浮点误差容限, =2 -52≈2.22×10-16虚数单位= √(-1)正无穷大圆周率,π=3.14....3. 编程语言结构中止计算或循环终止最内循环同一起使用将控制转交给外层的或循环同一起使用同一起使用结束,,语句按规定次数重复执行语句条件执行语句可同一起使用暂停模式返回多个条件分支同一起使用不确定次数重复执行语句特定值计算函数特定值计算或多变量计算函数文件头定义全局变量检测变量是否为全局变量显示错误信息显示最近的错误信息按格式把数字转换为串显示警告信息4.基本数学函数反余弦反双曲余弦反余切反双曲余切反余割反双曲余割反正弦反双曲正弦反正切反双曲正切余弦双曲余弦余切双曲余切正弦双曲正弦正切双曲正切指数自然对数10 常用对数2 以2为底的对数平方根绝对值复数共轭复数虚部复数实部向上(正无穷大方向)取整向零方向取整向下(负无穷大方向)取整四舍五入取整符号函数降次排序误差函数补误差函数函数插值函数线性插值函数样条插值函数样条平滑函数样条函数方波函数符号函数将整数转换为双精度浮点数5.基本矩阵函数和操作单位阵全零矩阵全1 矩阵均匀分布随机阵生成随机矩阵线性等分向量对数等分向量矩阵对数运算矩阵元素累计乘矩阵元素累计和矩阵显示矩阵和文字内容确定向量的长度确定矩阵的维数创建对角阵或抽取对角向量找出非零元素1的下标矩阵变维90 矩阵逆时针旋转90度2 据全下标换算出单下标抽取下三角阵抽取上三角阵共轭矩阵伴随矩阵行列式的值矩阵或向量范数矩阵中非零元素个数清空向量或矩阵中的某个元素正交基矩阵秩矩阵迹矩阵条件数逆矩阵条件数矩阵的逆分解或高斯消元法伪逆分解变换求解线性方程方程矩阵特征多项式分解矩阵指数1 矩阵指数的逼近2 用泰勒级数求矩阵指数3 通过特征值和特征向量求矩阵指数计算一般矩阵函数矩阵对数矩阵平方根6. 特性值与奇异值矩阵特征值矩阵束特征值块矩阵, 广义特征向量正则化特征向量特征空间投影奇异值分解奇异值分解近似7. 矩阵元素运算元素累计积元素累计和统计频数直方图最大值平均值中值最小值元素积由大到小排序标准差元素和梯形数值积分求相关系数或方差8. 稀疏矩阵运算稀疏矩阵(只存储非零元素) 2 邻接矩阵转换为稀疏矩阵稀疏矩阵转换为全矩阵将稀疏矩阵转换为稀疏矩阵格式2 稀疏矩阵转换为邻接矩阵稀疏矩阵方式单位阵稀疏矩阵方式随机矩阵稀疏矩阵方式全零阵稀疏矩阵分解稀疏矩阵方程求解稀疏矩阵分解9. 输入输出函数生成屏幕文本记录变量显示文件管理用户键盘输入读已存的变量关闭文件读二进制文件按行读码文件读字符串中单个字打开文件写二进制文件读码文件将变量记录为文件读矩阵变量存变量为二进制文件启动文件按格式存文件对话方式获取文件路径建立参数输入对话框得到文件变量执行文件10. 函数与函数库操作在线定义函数函数编辑器打开函数定义函数或对象在给定目录下建立所有文件的函数库读函数库的文件存储目录路径读函数库中的全部文件在文件中定义一个函数函数库定义函数或对象输入变量个数输出变量个数11. 字符串操作2 将数码转换为字符串字母大小转换清空字符串搜寻相同字符串字符提取2 将字符串转换为数码字符串转换对象, 字符串连接字符字符串的字符位置搜寻字符串中的字符替换12. 日期与时间日期读日期与时间时间计时13. 二维图形函数2d 直角坐标下线性刻度曲线2 维向量场1 由颜色箭头表示的2维向量场2d 等高线图曲线上增加误差范围框线条应用颜色表示的表面画坐标网格线统计频数直方图散点图阵列14. 三维图形函数3d 三维表面3d1 用颜色或灰度表示的三维表面3d 三维中单曲线3d1 三维中多曲线三维表面上的等高线图3d 三维表示的统计频数直方图3d 三维向二维上的投影15. 线条类图形单线条或单多边形多线条或多各多边形正多边形非连接线段单个多边形内填充多个多边形内填充矩形单个矩形内填充多个矩形内填充单个弧线段或弧园多个弧线段或弧园单个弧线段或弧园填充多个弧线段或弧园填充多箭头16. 图形注释, 变换图形中字符框内字符图形标题图形加框并画坐标网格线等尺寸比例显示(原图形窗口不改变)等尺寸比例显示(原图形窗口改变)设置小窗口转换实数为图形象素坐标值设置多个子窗口17. 图形颜色及图形文字应用颜色图交互式选择颜色图增加新色于颜色图线性灰度图热色(红到黄色)颜色图图形显示方式设定读当前图形显示方式设定交互式选择符号和尺寸18. 图形文件及图形文字将图形存储为文件从磁盘中读出图形文件将图形按文件打印或存储为文件2 将图形生成格式文件取消图形窗及其相关内容清空图形窗选择图形驱动器图形驱动器初始化关闭图形图形刷新更改显示范围后的图形刷新关闭图形改变当前图形窗名称19. 控制分析用图形伯德图坐标幅值图坐标(伯德图中的幅值图)奈奎斯特图M-圆图尼库拉斯图-图s 平面图零-极点图z 平面图20. 图形应用中的其它指令图形库指令表等待鼠标在图形上的点击输入由鼠标点击读入图形中的多点位置坐标由鼠标点击读入图形中的当前点位置坐标21. 系统与控制状态空间矩阵可控矩阵线性系统时域响应状态空间的离散时域响应反馈操作符时域响应(离散、采样系统〕2 基于传递函数的频域响应频域响应幅值裕量2 基于状态空间的脉冲响应线性化操作滤波器补偿器补偿器基于状态空间的离散时域响应基于观测器的控制器观测器观测矩阵相位裕量相位与幅值计算极点配置频域响应方程基于传递函数的离散时域响应2 系统矩阵到状态空间变换2 反馈连接的状态空间到状态空间变换2 状态空间到传递函数变换稳定性计算2 传递函数到状态空间变换系统最小方差辨识22. 鲁棒控制被控对象增广操作矩阵近似H∞控制器离散H∞范数h2 H2 范数闭环矩阵H∞控制器H∞范数矩阵奇异值H∞控制器的增益无穷范数矩阵敏感函数23. 动态系统模型2p 基于模型中获得多项式矩阵辨识系统仿真噪声信号发生器常微分方程仿真检测伪随机二进制序列发生器线性拟合24. 系统与控制实例动态系统鱼群人口发展的离散时域模型具有观测器的动态系统相位图生物链模型渔业模型登陆火箭问题吸引子采矿问题可控可观系统3d 三维相位图二维相位图双线性回归方程动态系统动态系统的线性化动态系统的交互初始化25. 非线性工具(优化与仿真〕边界值问题的常微分方程隐式微分方程过零解代数微分方程基于测量数据的参数辨识导数计算非线性函数过零解线性微分方程2d 二维定积分3d 三维定积分不定积分非线性最小二乘法线性规划线性不等矩阵常微分方程离散常微分方程常微分方程根解连续/离散常微分方程非线性优化线性二次型规划半正定规划26. 多项式计算多项式系数多项式矩阵逆多项式阶数分母项有理矩阵求导矩阵行列式值因式分解型多项式计算有理矩阵逆最小公倍数多项式矩阵长除分子项多项式矩阵除2 多项式矩阵到表达式变换2 多项式到字符串变换最小因式余量多项式根多项式化简系统矩阵27. 信号处理椭圆积分完全椭圆积分椭圆函数模拟量低通滤波器滤波器响应倒谱计算1 一型响应2 二型响应多项式卷积相关, 协方差谱估计(应用相关法)离散富立叶变换快速富立叶变换滤波器建模滤波器设计协方差矩阵到矩阵变换变换数字滤波器信号采样率更改滤波器更新最大熵谱估计多维快速富立叶变换频率响应拟合过程滤波器平方根稳态滤波器观测更新线性相位滤波器(维纳)滤波器对称窗函数最小二乘滤波器模拟滤波器1 模拟滤波器28. 音频信号音频信号频域图读* 音频文件写* 音频文件2 将线性信号转换为μ率码信号取* 音频文件音频信号图示2 将μ率码信号转换为线性信号音频信号播放存* 音频文件读* 音频文件写* 音频文件29. 语言与数据转换工具字符串的码2 读格式的文件2 将函数生成码2 将的M 格式文件转换为格式文件取第4版本文件中变量按第4 版本文件格式存变量2 将多项式转换为格式2 将函数转换为格式文件按格式输出对象将子目录下的所有文件转换为文件格式。

fortran erf函数

fortran erf函数

fortran erf函数
Fortran中的erf函数是一个用于计算误差函数的数学函数。

误差函数是一种特殊的函数,通常用于描述随机变量的分布情况,并且可以在统计学、物理学和工程学等领域中得到广泛应用。

在Fortran 中,erf函数的语法为:
erf(x)
其中x是一个实数型变量,表示要计算误差函数的自变量。

erf 函数的返回值也是一个实数型变量,表示误差函数在x处的函数值。

Fortran中的erf函数实现了一种称为“高斯误差函数”的数学函数,它的定义如下:
erf(x) = (2 / √π) ∫[0, x] e^{-t^2} dt
其中e为自然对数的底数,∫表示积分符号,t为积分变量。

高斯误差函数可以用来描述一个均值为0、方差为1的高斯分布内随机变量的分布情况。

在实际应用中,我们通常需要对具有不同均值和方差的随机变量进行误差函数的计算,这时候就需要通过对erf函数进行一些变换和缩放来实现。

总之,Fortran中的erf函数是一种非常重要的数学函数,在科学计算和工程应用中都有广泛的应用。

如果你的工作涉及到这方面的计算和分析,那么学习和掌握erf函数的使用方法将会对你的工作和研究大有帮助。

- 1 -。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
相关文档
最新文档