Fortran-빠른 가이드

Formula Translating System에서 파생 된 Fortran은 범용 명령형 프로그래밍 언어입니다. 숫자 및 과학 컴퓨팅에 사용됩니다.

Fortran은 원래 1950 년대 IBM이 과학 및 엔지니어링 애플리케이션을 위해 개발했습니다. Fortran은 오랫동안이 프로그래밍 영역을 지배했으며 고성능 컴퓨팅으로 매우 인기를 얻었습니다.

그것은 지원합니다-

  • 수치 분석 및 과학적 계산
  • 구조화 된 프로그래밍
  • 배열 프로그래밍
  • 모듈 식 프로그래밍
  • 일반 프로그래밍
  • 슈퍼 컴퓨터에서 고성능 컴퓨팅
  • 객체 지향 프로그래밍
  • 동시 프로그래밍
  • 컴퓨터 시스템 간의 합리적인 이동성

포트란에 대한 사실

  • Fortran은 1957 년 IBM의 John Backus가 이끄는 팀이 만들었습니다.

  • 처음에는 이름이 모두 대문자로 쓰여졌지만 현재 표준 및 구현에서는 첫 글자 만 대문자로 작성하면됩니다.

  • Fortran은 FORmula TRANslator의 약자입니다.

  • 원래 과학적 계산을 위해 개발되었지만 범용 프로그래밍에 필요한 문자열 및 기타 구조에 대한 지원은 매우 제한적이었습니다.

  • 나중에 확장 및 개발을 통해 이식성이 우수한 고급 프로그래밍 언어로 만들었습니다.

  • 원래 버전 인 Fortran I, II 및 III은 이제 구식으로 간주됩니다.

  • 여전히 사용중인 가장 오래된 버전은 Fortran IV 및 Fortran 66입니다.

  • 오늘날 가장 일반적으로 사용되는 버전은 Fortran 77, Fortran 90 및 Fortran 95입니다.

  • Fortran 77은 고유 한 유형으로 문자열을 추가했습니다.

  • Fortran 90은 다양한 종류의 스레딩과 직접 배열 처리를 추가했습니다.

Windows에서 Fortran 설정

G95는 Windows에서 Fortran을 설정하는 데 사용되는 GNU Fortran 다중 아키텍처 컴파일러입니다. Windows 버전은 Windows에서 MingW를 사용하여 유닉스 환경을 에뮬레이트합니다. 설치 프로그램이이를 처리하고 Windows PATH 변수에 g95를 자동으로 추가합니다.

여기 에서 G95의 안정적인 버전을 얻을 수 있습니다.

G95 사용 방법

설치하는 동안 g95"RECOMMENDED"옵션을 선택하면 PATH 변수에 자동으로 추가됩니다. 즉, 새 명령 프롬프트 창을 열고 "g95"를 입력하여 컴파일러를 불러올 수 있습니다. 시작하려면 아래에서 몇 가지 기본 명령을 찾으십시오.

Sr. 아니요 명령 및 설명
1

g95 –c hello.f90

hello.f90을 hello.o라는 개체 파일로 컴파일합니다.

2

g95 hello.f90

hello.f90을 컴파일하고 연결하여 실행 파일을 생성합니다.

g95 -c h1.f90 h2.f90 h3.f90

여러 소스 파일을 컴파일합니다. 모든 것이 잘되면 객체 파일 h1.o, h2.o 및 h3.o가 생성됩니다.

4

g95 -o hello h1.f90 h2.f90 h3.f90

여러 소스 파일을 컴파일하여 'hello'라는 실행 파일에 함께 연결합니다.

G95 용 명령 줄 옵션

-c Compile only, do not run the linker.
-o Specify the name of the output file, either an object file or the executable.

여러 소스 및 개체 파일을 한 번에 지정할 수 있습니다. Fortran 파일은 ".f", ".F", ".for", ".FOR", ".f90", ".F90", ".f95", ".F95", "로 끝나는 이름으로 표시됩니다. f03 "및".F03 ". 여러 소스 파일을 지정할 수 있습니다. 개체 파일도 지정할 수 있으며 연결되어 실행 파일을 형성합니다.

Fortran 프로그램은 주 프로그램, 모듈 및 외부 하위 프로그램 또는 프로 시저와 같은 프로그램 단위 모음으로 구성됩니다.

각 프로그램은 하나의 주 프로그램을 포함하며 다른 프로그램 단위를 포함하거나 포함하지 않을 수 있습니다. 메인 프로그램의 구문은 다음과 같습니다.

program program_name
implicit none      

! type declaration statements      
! executable statements  

end program program_name

Fortran의 간단한 프로그램

두 개의 숫자를 더하고 결과를 출력하는 프로그램을 작성해 봅시다.

program addNumbers

! This simple program adds two numbers
   implicit none

! Type declarations
   real :: a, b, result

! Executable statements
   a = 12.0
   b = 15.0
   result = a + b
   print *, 'The total is ', result

end program addNumbers

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

The total is 27.0000000

유의하십시오-

  • 모든 Fortran 프로그램은 키워드로 시작합니다. program 키워드로 끝납니다. end program, 그 뒤에 프로그램 이름이옵니다.

  • 그만큼 implicit none문을 사용하면 컴파일러가 모든 변수 유형이 올바르게 선언되었는지 확인할 수 있습니다. 항상 사용해야합니다implicit none 모든 프로그램이 시작될 때.

  • Fortran의 주석은 느낌표 (!)로 시작됩니다. 이후 모든 문자 (문자열 제외)는 컴파일러에서 무시됩니다.

  • 그만큼 print * 명령은 화면에 데이터를 표시합니다.

  • 코드 줄 들여 쓰기는 프로그램을 읽기 쉽게 유지하는 좋은 방법입니다.

  • Fortran은 대문자와 소문자를 모두 허용합니다. Fortran은 문자열 리터럴을 제외하고 대소 문자를 구분하지 않습니다.

기초

그만큼 basic character set 포트란의 포함-

  • 문자 A ... Z 및 a ... z
  • 숫자 0 ... 9
  • 밑줄 (_) 문자
  • 특수 문자 = : + 공백-* / () [],. $ '! "% &; <>?

Tokens기본 문자 집합의 문자로 구성됩니다. 토큰은 키워드, 식별자, 상수, 문자열 리터럴 또는 기호 일 수 있습니다.

프로그램 설명은 토큰으로 구성됩니다.

식별자

식별자는 변수, 프로 시저 또는 기타 사용자 정의 항목을 식별하는 데 사용되는 이름입니다. Fortran의 이름은 다음 규칙을 따라야합니다.

  • 31자를 넘을 수 없습니다.

  • 영숫자 (알파벳의 모든 문자와 0 ~ 9의 숫자)와 밑줄 (_)로 구성되어야합니다.

  • 이름의 첫 번째 문자는 문자 여야합니다.

  • 이름은 대소 문자를 구분하지 않습니다.

키워드

키워드는 언어 전용으로 예약 된 특수 단어입니다. 이러한 예약어는 식별자 또는 이름으로 사용할 수 없습니다.

다음 표는 Fortran 키워드를 나열합니다.

비 I / O 키워드
할당 가능 할당하다 양수인 할당 블록 데이터
요구 케이스 캐릭터 흔한 복잡한
포함 계속하다 주기 데이터 할당 해제
기본 하다 배정 밀도 그밖에 그렇지 않으면
다른 곳에 끝 블록 데이터 끝내다 끝 기능
끝 인터페이스 끝 모듈 프로그램 종료 선택 종료 서브 루틴 종료
끝 유형 어디에서 끝 기입 등가 출구
외부 함수 이동 만약 절대적인
안으로 정수 의지 상호 작용
본질적인 종류 len 논리적 기준 치수
명부 무효화하다 운영자 선택 과목
매개 변수 중지 바늘 은밀한
프로그램 공공의 레알 재귀 결과
반환 저장 케이스 선택 중지 서브 루틴
표적 그때 유형 유형() 사용하다
어디 동안
I / O 관련 키워드
역행 키이 닫기 endfile 체재 문의
열다 인쇄 읽다 되감기 쓰다

Fortran은 5 가지 내장 데이터 유형을 제공하지만 고유 한 데이터 유형도 파생 할 수 있습니다. 5 가지 내장 유형은 다음과 같습니다.

  • 정수 유형
  • 실제 유형
  • 복합 형
  • 논리적 유형
  • 문자 유형

정수 유형

정수 유형은 정수 값만 보유 할 수 있습니다. 다음 예제는 일반적인 4 바이트 정수로 보유 할 수있는 가장 큰 값을 추출합니다.

program testingInt
implicit none

   integer :: largeval
   print *, huge(largeval)
   
end program testingInt

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

2147483647

참고 huge()함수는 특정 정수 데이터 유형이 보유 할 수있는 가장 큰 수를 제공합니다. 다음을 사용하여 바이트 수를 지정할 수도 있습니다.kind지정자. 다음 예제는 이것을 보여줍니다-

program testingInt
implicit none

   !two byte integer
   integer(kind = 2) :: shortval
   
   !four byte integer
   integer(kind = 4) :: longval
   
   !eight byte integer
   integer(kind = 8) :: verylongval
   
   !sixteen byte integer
   integer(kind = 16) :: veryverylongval
   
   !default integer 
   integer :: defval
        
   print *, huge(shortval)
   print *, huge(longval)
   print *, huge(verylongval)
   print *, huge(veryverylongval)
   print *, huge(defval)
   
end program testingInt

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

32767
2147483647
9223372036854775807
170141183460469231731687303715884105727
2147483647

실제 유형

2.0, 3.1415, -100.876 등과 같은 부동 소수점 숫자를 저장합니다.

전통적으로 두 가지 다른 실제 유형이 있습니다. real 유형 및 double precision 유형.

그러나 Fortran 90/95는 다음을 통해 실수 및 정수 데이터 유형의 정밀도를 더 많이 제어합니다. kind 숫자에 관한 장에서 공부할 지정자입니다.

다음 예제는 실제 데이터 유형의 사용을 보여줍니다-

program division   
implicit none  

   ! Define real variables   
   real :: p, q, realRes 
   
   ! Define integer variables  
   integer :: i, j, intRes  
   
   ! Assigning  values   
   p = 2.0 
   q = 3.0    
   i = 2 
   j = 3  
   
   ! floating point division
   realRes = p/q  
   intRes = i/j
   
   print *, realRes
   print *, intRes
   
end program division

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

0.666666687    
0

복합 형

복소수를 저장하는 데 사용됩니다. 복소수에는 실수 부분과 허수 부분의 두 부분이 있습니다. 두 개의 연속 숫자 저장 장치는이 두 부분을 저장합니다.

예를 들어, 복소수 (3.0, -5.0)는 3.0 – 5.0i와 같습니다.

복잡한 유형에 대해서는 숫자 장에서 자세히 설명합니다.

논리적 유형

논리 값은 두 가지뿐입니다. .true..false.

문자 유형

문자 유형은 문자와 문자열을 저장합니다. 문자열의 길이는 len 지정자로 지정할 수 있습니다. 길이를 지정하지 않으면 1입니다.

For example,

character (len = 40) :: name  
name = “Zara Ali”

표현식, name(1:4) 하위 문자열 "Zara"를 제공합니다.

암시 적 타이핑

이전 버전의 Fortran에서는 암시 적 형식 지정이라는 기능이 허용되었습니다. 즉, 사용하기 전에 변수를 선언 할 필요가 없습니다. 변수가 선언되지 않은 경우 이름의 첫 글자가 유형을 결정합니다.

i, j, k, l, m 또는 n으로 시작하는 변수 이름은 정수 변수 용으로 간주되고 나머지는 실제 변수로 간주됩니다. 그러나 좋은 프로그래밍 관행이므로 모든 변수를 선언해야합니다. 이를 위해 당신은 문장으로 프로그램을 시작합니다-

implicit none

이 문은 암시 적 입력을 해제합니다.

변수는 프로그램이 조작 할 수있는 저장 영역에 주어진 이름 일뿐입니다. 각 변수에는 변수 메모리의 크기와 레이아웃을 결정하는 특정 유형이 있어야합니다. 해당 메모리 내에 저장할 수있는 값의 범위 변수에 적용 할 수있는 연산 집합입니다.

변수 이름은 문자, 숫자 및 밑줄 문자로 구성 될 수 있습니다. Fortran의 이름은 다음 규칙을 따라야합니다.

  • 31자를 넘을 수 없습니다.

  • 영숫자 (알파벳의 모든 문자와 0 ~ 9의 숫자)와 밑줄 (_)로 구성되어야합니다.

  • 이름의 첫 번째 문자는 문자 여야합니다.

  • 이름은 대소 문자를 구분하지 않습니다.

이전 장에서 설명한 기본 유형에 따라 다음은 변수 유형입니다.

Sr. 아니요 유형 및 설명
1

Integer

정수 값만 보유 할 수 있습니다.

2

Real

부동 소수점 숫자를 저장합니다.

Complex

복소수를 저장하는 데 사용됩니다.

4

Logical

논리 부울 값을 저장합니다.

5

Character

문자 또는 문자열을 저장합니다.

변수 선언

변수는 유형 선언문에서 프로그램 (또는 서브 프로그램)의 시작 부분에 선언됩니다.

변수 선언 구문은 다음과 같습니다.

type-specifier :: variable_name

예를 들면

integer :: total  	
real :: average 
complex :: cx  
logical :: done 
character(len = 80) :: message ! a string of 80 characters

나중에 이러한 변수에 값을 할당 할 수 있습니다.

total = 20000  
average = 1666.67   
done = .true.   
message = “A big Hello from Tutorials Point” 
cx = (3.0, 5.0) ! cx = 3.0 + 5.0i

내장 함수를 사용할 수도 있습니다. cmplx, 복잡한 변수에 값을 할당하려면-

cx = cmplx (1.0/2.0, -7.0) ! cx = 0.5 – 7.0i 
cx = cmplx (x, y) ! cx = x + yi

다음 예제는 변수 선언, 할당 및 화면 표시를 보여줍니다.

program variableTesting
implicit none

   ! declaring variables
   integer :: total      
   real :: average 
   complex :: cx  
   logical :: done 
   character(len=80) :: message ! a string of 80 characters
   
   !assigning values
   total = 20000  
   average = 1666.67   
   done = .true.   
   message = "A big Hello from Tutorials Point" 
   cx = (3.0, 5.0) ! cx = 3.0 + 5.0i

   Print *, total
   Print *, average
   Print *, cx
   Print *, done
   Print *, message
   
end program variableTesting

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

20000
1666.67004    
(3.00000000, 5.00000000 )
T
A big Hello from Tutorials Point

상수는 프로그램이 실행 중에 변경할 수없는 고정 값을 참조합니다. 이러한 고정 값을literals.

상수는 정수 상수, 부동 상수, 문자 상수, 복합 상수 또는 문자열 리터럴과 같은 기본 데이터 유형 중 하나 일 수 있습니다. 논리 상수는 두 개뿐입니다..true..false.

상수는 정의 후에 값을 수정할 수 없다는 점을 제외하면 일반 변수처럼 처리됩니다.

명명 된 상수 및 리터럴

두 가지 유형의 상수가 있습니다.

  • 리터럴 상수
  • 명명 된 상수

리터럴 상수에는 값이 있지만 이름은 없습니다.

예를 들어, 다음은 리터럴 상수입니다.

유형
정수 상수 01-1300 123456789
실제 상수 0.0 1.0 -1.0 123.456 7.1E + 10 -52.715E-30
복잡한 상수 (0.0, 0.0) (-123.456E + 30, 987.654E-29)
논리 상수 .진실. .그릇된.
문자 상수

"PQR" "a" "123'abc $ % # @!"

"인용문" ""

'PQR' 'a' '123 "abc $ % # @!'

'아포스트로피' ''

명명 된 상수에는 이름과 함께 값이 있습니다.

이름이 지정된 상수는 이름과 유형을 나타내는 변수 유형 선언과 마찬가지로 프로그램 또는 프로 시저의 시작 부분에 선언되어야합니다. 명명 된 상수는 매개 변수 속성으로 선언됩니다. 예를 들면

real, parameter :: pi = 3.1415927

다음 프로그램은 중력 하에서 수직 운동으로 인한 변위를 계산합니다.

program gravitationalDisp

! this program calculates vertical motion under gravity 
implicit none  

   ! gravitational acceleration
   real, parameter :: g = 9.81   
   
   ! variable declaration
   real :: s ! displacement   
   real :: t ! time  
   real :: u ! initial speed  
   
   ! assigning values 
   t = 5.0   
   u = 50  
   
   ! displacement   
   s = u * t - g * (t**2) / 2  
   
   ! output 
   print *, "Time = ", t
   print *, 'Displacement = ',s  
   
end program gravitationalDisp

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

Time = 5.00000000    
Displacement = 127.374992

연산자는 컴파일러에게 특정 수학적 또는 논리적 조작을 수행하도록 지시하는 기호입니다. Fortran은 다음 유형의 연산자를 제공합니다.

  • 산술 연산자
  • 관계 연산자
  • 논리 연산자

이러한 모든 유형의 연산자를 하나씩 살펴 보겠습니다.

산술 연산자

다음 표는 Fortran에서 지원하는 모든 산술 연산자를 보여줍니다. 변수 가정A 5 및 가변 보유 B 3을 잡고-

예시보기

운영자 기술
+ 더하기 연산자, 두 개의 피연산자를 더합니다. A + B는 8을 줄 것입니다
- 빼기 연산자, 첫 번째에서 두 번째 피연산자를 뺍니다. A-B는 2를 줄 것입니다
* 곱하기 연산자, 두 피연산자를 곱합니다. A * B는 15를 줄 것입니다
/ 나누기 연산자, 분자를 분자 해제로 나눕니다. A / B는 1을 줄 것입니다
** 지수 연산자, 한 피연산자를 다른 피연산자로 올립니다. A ** B는 125를 줄 것입니다

관계 연산자

다음 표는 Fortran에서 지원하는 모든 관계 연산자를 보여줍니다. 변수 가정A 10 개와 가변 B 20 개를 보유하면-

예시보기

운영자 동등한 기술
== .eq. 두 피연산자의 값이 같은지 확인하고, 예이면 조건이 참이됩니다. (A == B)는 사실이 아닙니다.
/ = .ne. 두 피연산자의 값이 같은지 확인하고, 값이 같지 않으면 조건이 참이됩니다. (A! = B)는 사실입니다.
> .gt. 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 큰지 확인하고, 그렇다면 조건이 참이됩니다. (A> B)는 사실이 아닙니다.
< .lt. 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작은 지 확인하고, 그렇다면 조건이 참이됩니다. (A <B)는 사실입니다.
> = .ge. 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 크거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. (A> = B)는 사실이 아닙니다.
<= .le. 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. (A <= B)는 참입니다.

논리 연산자

Fortran의 논리 연산자는 논리 값 .true에서만 작동합니다. 및 .false.

다음 표는 Fortran에서 지원하는 모든 논리 연산자를 보여줍니다. 변수 A에 .true가 있다고 가정합니다. 변수 B는 .false를 보유합니다. , 다음-

예시보기

운영자 기술
.과. 논리 AND 연산자라고합니다. 두 피연산자가 모두 0이 아니면 조건이 참이됩니다. (A 및 B)는 거짓입니다.
.또는. 논리 OR 연산자라고합니다. 두 피연산자 중 하나가 0이 아니면 조건이 참이됩니다. (A .or. B)는 사실입니다.
.아니. 논리 NOT 연산자라고합니다. 피연산자의 논리 상태를 반전하는 데 사용합니다. 조건이 참이면 논리 NOT 연산자는 거짓으로 만듭니다. ! (A .and. B)는 사실입니다.
.eqv. 논리적 동등 연산자라고합니다. 두 논리 값의 동등성을 확인하는 데 사용됩니다. (A .eqv. B)는 거짓입니다.
.neqv. 논리적 NON-EQUIVALENT 연산자라고합니다. 두 논리 값의 비 동등성을 확인하는 데 사용됩니다. (A .neqv. B)는 사실입니다.

Fortran의 연산자 우선 순위

연산자 우선 순위는 식의 용어 그룹화를 결정합니다. 이는식이 평가되는 방식에 영향을줍니다. 특정 연산자는 다른 연산자보다 우선 순위가 높습니다. 예를 들어 곱셈 연산자는 더하기 연산자보다 우선 순위가 높습니다.

예를 들어, x = 7 + 3 * 2; 여기서 x는 연산자 *가 +보다 우선 순위가 높기 때문에 20이 아닌 13이 할당됩니다. 따라서 먼저 3 * 2를 곱한 다음 7에 더합니다.

여기에서 우선 순위가 가장 높은 연산자는 테이블 맨 위에 표시되고 가장 낮은 연산자는 맨 아래에 표시됩니다. 식 내에서 우선 순위가 높은 연산자가 먼저 평가됩니다.

예시보기

범주 운영자 연관성
논리 NOT 및 음수 부호 .아니. (-) 좌에서 우로
지수화 ** 좌에서 우로
곱셈 * / 좌에서 우로
첨가물 +- 좌에서 우로
관계형 <<=>> = 좌에서 우로
평등 == / = 좌에서 우로
논리적 AND .과. 좌에서 우로
논리적 OR .또는. 좌에서 우로
할당 = 오른쪽에서 왼쪽으로

의사 결정 구조는 프로그래머가 조건이 참인 경우 실행할 명령문과 함께 프로그램에서 평가하거나 테스트 할 하나 이상의 조건을 지정하고 선택적으로 조건은 거짓으로 결정됩니다.

다음은 대부분의 프로그래밍 언어에서 발견되는 일반적인 의사 결정 구조의 일반적인 형태입니다.

Fortran은 다음 유형의 의사 결정 구조를 제공합니다.

Sr. 아니요 성명 및 설명
1 만약…

안 if… then… end if 문은 논리식과 하나 이상의 문으로 구성됩니다.

2 If ... then ... else 구문

안 if… then 문 뒤에는 선택 사항이 올 수 있습니다. else statement, 논리식이 거짓 일 때 실행됩니다.

if ... else if ... else 문

if 문 구성은 하나 이상의 선택 사항을 가질 수 있습니다. else-if구성. 때if 조건이 실패하면 바로 뒤 따르는 else-if실행됩니다. 때else-if 또한 실패, 그 후속 else-if 문 (있는 경우)이 실행됩니다.

4 중첩 된 if 구문

하나를 사용할 수 있습니다 if 또는 else if 다른 내부의 진술 if 또는 else if 진술 (들).

5 케이스 구성 선택

ㅏ select case 문을 사용하면 변수가 값 목록과 같은지 테스트 할 수 있습니다.

6 중첩 된 선택 케이스 구성

하나를 사용할 수 있습니다 select case 다른 내부의 진술 select case 진술 (들).

코드 블록을 여러 번 실행해야하는 상황이있을 수 있습니다. 일반적으로 명령문은 순차적으로 실행됩니다. 함수의 첫 번째 명령문이 먼저 실행되고 두 번째 명령문이 실행되는 식입니다.

프로그래밍 언어는보다 복잡한 실행 경로를 허용하는 다양한 제어 구조를 제공합니다.

루프 문을 사용하면 문 또는 문 그룹을 여러 번 실행할 수 있으며 다음은 대부분의 프로그래밍 언어에서 루프 문의 일반적인 형식입니다.

Fortran은 루핑 요구 사항을 처리하기 위해 다음 유형의 루프 구조를 제공합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

Sr. 아니요 루프 유형 및 설명
1 루프를하다

이 구조를 사용하면 주어진 조건이 참인 동안 문 또는 일련의 문이 반복적으로 수행 될 수 있습니다.

2 루프 동안 수행

주어진 조건이 참인 동안 명령문 또는 명령문 그룹을 반복합니다. 루프 본문을 실행하기 전에 조건을 테스트합니다.

중첩 된 루프

다른 루프 구조 내에서 하나 이상의 루프 구조를 사용할 수 있습니다.

루프 제어문

루프 제어문은 정상적인 순서에서 실행을 변경합니다. 실행이 범위를 벗어나면 해당 범위에서 생성 된 모든 자동 개체가 삭제됩니다.

Fortran은 다음 제어문을 지원합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

Sr. 아니요 제어문 및 설명
1 출구

exit 문이 실행되면 루프가 종료되고 end do 문 이후 첫 번째 실행 문에서 프로그램 실행이 계속됩니다.

2 주기

주기 명령문이 실행되면 프로그램은 다음 반복이 시작될 때 계속됩니다.

중지

프로그램 실행을 중지하려면 stop 문을 삽입 할 수 있습니다.

Fortran의 숫자는 세 가지 고유 데이터 유형으로 표시됩니다.

  • 정수 유형
  • 실제 유형
  • 복합 형

정수 유형

정수 유형은 정수 값만 보유 할 수 있습니다. 다음 예제는 일반적인 4 바이트 정수에 담을 수있는 가장 큰 값을 추출합니다.

program testingInt
implicit none

   integer :: largeval
   print *, huge(largeval)
   
end program testingInt

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

2147483647

유의하시기 바랍니다 huge()함수는 특정 정수 데이터 유형이 보유 할 수있는 가장 큰 수를 제공합니다. 다음을 사용하여 바이트 수를 지정할 수도 있습니다.kind지정자. 다음 예제는 이것을 보여줍니다-

program testingInt
implicit none

   !two byte integer
   integer(kind = 2) :: shortval
   
   !four byte integer
   integer(kind = 4) :: longval
   
   !eight byte integer
   integer(kind = 8) :: verylongval
   
   !sixteen byte integer
   integer(kind = 16) :: veryverylongval
   
   !default integer 
   integer :: defval
        
   print *, huge(shortval)
   print *, huge(longval)
   print *, huge(verylongval)
   print *, huge(veryverylongval)
   print *, huge(defval)
   
end program testingInt

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

32767
2147483647
9223372036854775807
170141183460469231731687303715884105727
2147483647

실제 유형

2.0, 3.1415, -100.876 등과 같은 부동 소수점 숫자를 저장합니다.

전통적으로 두 가지 다른 real 유형 : 기본 실제 유형 및 double precision 유형.

그러나 Fortran 90/95는 다음을 통해 실수 및 정수 데이터 유형의 정밀도를 더 많이 제어합니다. kind 곧 살펴 보겠습니다.

다음 예제는 실제 데이터 유형의 사용을 보여줍니다-

program division   
implicit none

   ! Define real variables   
   real :: p, q, realRes 
   
   ! Define integer variables  
   integer :: i, j, intRes  
   
   ! Assigning  values   
   p = 2.0 
   q = 3.0    
   i = 2 
   j = 3  
   
   ! floating point division
   realRes = p/q  
   intRes = i/j
   
   print *, realRes
   print *, intRes
   
end program division

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

0.666666687    
0

복합 형

복소수를 저장하는 데 사용됩니다. 복소수는 실수 부분과 허수 부분의 두 부분으로 구성됩니다. 두 개의 연속 숫자 저장 장치는이 두 부분을 저장합니다.

예를 들어, 복소수 (3.0, -5.0)는 3.0 – 5.0i와 같습니다.

일반 기능 cmplx()복소수를 만듭니다. 입력 인수의 유형에 관계없이 실수 및 허수 부분이 단 정밀도 인 결과를 생성합니다.

program createComplex
implicit none

   integer :: i = 10
   real :: x = 5.17
   print *, cmplx(i, x)
   
end program createComplex

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

(10.0000000, 5.17000008)

다음 프로그램은 복소수 산술을 보여줍니다-

program ComplexArithmatic
implicit none

   complex, parameter :: i = (0, 1)   ! sqrt(-1)   
   complex :: x, y, z 
   
   x = (7, 8); 
   y = (5, -7)   
   write(*,*) i * x * y
   
   z = x + y
   print *, "z = x + y = ", z
   
   z = x - y
   print *, "z = x - y = ", z 
   
   z = x * y
   print *, "z = x * y = ", z 
   
   z = x / y
   print *, "z = x / y = ", z 
   
end program ComplexArithmatic

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

(9.00000000, 91.0000000)
z = x + y = (12.0000000, 1.00000000)
z = x - y = (2.00000000, 15.0000000)
z = x * y = (91.0000000, -9.00000000)
z = x / y = (-0.283783793, 1.20270276)

숫자의 범위, 정밀도 및 크기

정수 범위, 정밀도 및 부동 소수점 숫자 크기는 특정 데이터 유형에 할당 된 비트 수에 따라 다릅니다.

다음 표는 정수의 비트 수와 범위를 표시합니다.

비트 수 최대 가치 이유
64 9,223,372,036,854,774,807 (2 ** 63) –1
32 2,147,483,647 (2 ** 31) –1

다음 표는 비트 수, 최소값과 최대 값, 실수의 정밀도를 표시합니다.

비트 수 가장 큰 가치 최소값 정도
64 0.8E + 308 0.5E ~ 308 15 ~ 18 세
32 1.7E + 38 0.3E ~ 38 6-9

다음 예제는 이것을 보여줍니다-

program rangePrecision
implicit none

   real:: x, y, z
   x = 1.5e+40
   y = 3.73e+40
   z = x * y 
   print *, z
   
end program rangePrecision

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

x = 1.5e+40
          1
Error : Real constant overflows its kind at (1)
main.f95:5.12:

y = 3.73e+40
           1
Error : Real constant overflows its kind at (1)

이제 더 작은 수를 사용하겠습니다.

program rangePrecision
implicit none

   real:: x, y, z
   x = 1.5e+20
   y = 3.73e+20
   z = x * y 
   print *, z
   
   z = x/y
   print *, z
   
end program rangePrecision

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Infinity
0.402144760

이제 언더 플로를 살펴 보겠습니다.

program rangePrecision
implicit none

   real:: x, y, z
   x = 1.5e-30
   y = 3.73e-60
   z = x * y 
   print *, z
   
   z = x/y
   print *, z

end program rangePrecision

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

y = 3.73e-60
           1
Warning : Real constant underflows its kind at (1)

Executing the program....
$demo 

0.00000000E+00
Infinity

종류 지정자

과학 프로그래밍에서 작업이 수행되는 하드웨어 플랫폼의 데이터 범위와 정밀도를 알아야하는 경우가 많습니다.

고유 기능 kind() 프로그램을 실행하기 전에 하드웨어의 데이터 표현에 대한 세부 정보를 쿼리 할 수 ​​있습니다.

program kindCheck
implicit none
   
   integer :: i 
   real :: r 
   complex :: cp 
   print *,' Integer ', kind(i) 
   print *,' Real ', kind(r) 
   print *,' Complex ', kind(cp) 
   
end program kindCheck

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Integer 4
Real 4
Complex 4

또한 모든 데이터 유형의 종류를 확인할 수 있습니다.

program checkKind
implicit none

   integer :: i 
   real :: r 
   character :: c 
   logical :: lg 
   complex :: cp 
   
   print *,' Integer ', kind(i) 
   print *,' Real ', kind(r) 
   print *,' Complex ', kind(cp)
   print *,' Character ', kind(c) 
   print *,' Logical ', kind(lg)
   
end program checkKind

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Integer 4
Real 4
Complex 4
Character 1
Logical 4

Fortran 언어는 문자를 단일 문자 또는 연속 문자열로 처리 할 수 ​​있습니다.

문자는 기본 문자 집합, 즉 문자, 10 진수, 밑줄 및 21 개의 특수 문자에서 가져온 기호 일 수 있습니다.

문자 상수는 고정 된 값의 문자열입니다.

내장 데이터 유형 character문자와 문자열을 저장합니다. 문자열의 길이는 다음과 같이 지정할 수 있습니다.len지정자. 길이를 지정하지 않으면 1입니다. 위치로 참조하는 문자열 내에서 개별 문자를 참조 할 수 있습니다. 가장 왼쪽의 문자는 위치 1에 있습니다.

캐릭터 선언

문자 유형 데이터를 선언하는 것은 다른 변수와 동일합니다-

type-specifier :: variable_name

예를 들면

character :: reply, sex

다음과 같은 값을 할당 할 수 있습니다.

reply = ‘N’ 
sex = ‘F’

다음 예제는 문자 데이터 유형의 선언 및 사용을 보여줍니다.

program hello
implicit none

   character(len = 15) :: surname, firstname 
   character(len = 6) :: title 
   character(len = 25)::greetings
   
   title = 'Mr. ' 
   firstname = 'Rowan ' 
   surname = 'Atkinson'
   greetings = 'A big hello from Mr. Bean'
   
   print *, 'Here is ', title, firstname, surname
   print *, greetings
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Here is Mr. Rowan Atkinson       
A big hello from Mr. Bean

문자 연결

연결 연산자 //는 문자를 연결합니다.

다음 예제는 이것을 보여줍니다-

program hello
implicit none

   character(len = 15) :: surname, firstname 
   character(len = 6) :: title 
   character(len = 40):: name
   character(len = 25)::greetings
   
   title = 'Mr. ' 
   firstname = 'Rowan ' 
   surname = 'Atkinson'
   
   name = title//firstname//surname
   greetings = 'A big hello from Mr. Bean'
   
   print *, 'Here is ', name
   print *, greetings
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Here is Mr.Rowan Atkinson       
A big hello from Mr.Bean

일부 캐릭터 기능

다음 표는 설명과 함께 일반적으로 사용되는 문자 기능을 보여줍니다.

Sr. 아니요 기능 및 설명
1

len(string)

문자열의 길이를 반환합니다.

2

index(string,sustring)

다른 문자열에서 하위 문자열의 위치를 ​​찾고, 찾지 못하면 0을 반환합니다.

achar(int)

정수를 문자로 변환합니다.

4

iachar(c)

문자를 정수로 변환합니다.

5

trim(string)

후행 공백이 제거 된 문자열을 리턴합니다.

6

scan(string, chars)

"문자열"을 왼쪽에서 오른쪽으로 (back = .true가 아닌 한) 검색하여 "문자"에 포함 된 문자의 첫 번째 발생을 찾습니다. 해당 문자의 위치를 ​​제공하는 정수를 반환하거나 "chars"에있는 문자가 없으면 0을 반환합니다.

7

verify(string, chars)

"문자열"에서 "문자"에 포함되지 않은 문자의 첫 번째 발생에 대해 왼쪽에서 오른쪽으로 (back = .true가 아닌 경우) 검색합니다. 해당 문자의 위치를 ​​제공하는 정수를 반환하거나 "chars"의 문자 만 찾은 경우 0을 반환합니다.

8

adjustl(string)

"문자열"에 포함 된 문자를 왼쪽 정렬합니다.

9

adjustr(string)

"문자열"에 포함 된 문자를 올바르게 정렬합니다.

10

len_trim(string)

"문자열"의 길이 (len (문자열))에서 후행 공백 수를 뺀 정수를 반환합니다.

11

repeat(string,ncopy)

길이가 "ncopy"에 "string"의 길이를 곱하고 "string"의 "ncopy"연결 사본을 포함하는 문자열을 리턴합니다.

예 1

이 예는 index 기능-

program testingChars
implicit none

   character (80) :: text 
   integer :: i 
   
   text = 'The intrinsic data type character stores characters and   strings.'
   i=index(text,'character') 
   
   if (i /= 0) then
      print *, ' The word character found at position ',i 
      print *, ' in text: ', text 
   end if
   
end program testingChars

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

The word character found at position 25
in text : The intrinsic data type character stores characters and strings.

예 2

이 예제는 trim 기능-

program hello
implicit none

   character(len = 15) :: surname, firstname 
   character(len = 6) :: title 
   character(len = 25)::greetings
   
   title = 'Mr.' 
   firstname = 'Rowan' 
   surname = 'Atkinson'
   
   print *, 'Here is', title, firstname, surname
   print *, 'Here is', trim(title),' ',trim(firstname),' ', trim(surname)
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Here isMr.   Rowan          Atkinson       
 Here isMr. Rowan Atkinson

예제 3

이 예제는 achar 기능-

program testingChars
implicit none

   character:: ch
   integer:: i
   
   do i = 65, 90
      ch = achar(i)
      print*, i, ' ', ch
   end do
   
end program testingChars

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

65  A
66  B
67  C
68  D
69  E
70  F
71  G
72  H
73  I
74  J
75  K
76  L
77  M
78  N
79  O
80  P
81  Q
82  R
83  S
84  T
85  U
86  V
87  W
88  X
89  Y
90  Z

문자의 어휘 순서 확인

다음 함수는 문자의 어휘 순서를 결정합니다-

Sr. 아니요 기능 및 설명
1

lle(char, char)

첫 번째 문자가 어휘 적으로 두 번째 문자보다 작거나 같은지 여부를 비교합니다.

2

lge(char, char)

첫 번째 문자가 어휘 적으로 두 번째 문자보다 크거나 같은지 여부를 비교합니다.

lgt(char, char)

첫 번째 문자가 두 번째 문자보다 어휘 적으로 큰지 여부를 비교합니다.

4

llt(char, char)

첫 번째 문자가 어휘 적으로 두 번째 문자보다 작은 지 여부를 비교합니다.

Example 4

다음 함수는 사용을 보여줍니다-

program testingChars
implicit none

   character:: a, b, c
   a = 'A'
   b = 'a'
   c = 'B'
   
   if(lgt(a,b)) then
      print *, 'A is lexically greater than a'
   else
      print *, 'a is lexically greater than A'
   end if
   
   if(lgt(a,c)) then
      print *, 'A is lexically greater than B'
   else
      print *, 'B is lexically greater than A'
   end if  
   
   if(llt(a,b)) then
      print *, 'A is lexically less than a'
   end if
   
   if(llt(a,c)) then
      print *, 'A is lexically less than B'
   end if
   
end program testingChars

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

a is lexically greater than A
B is lexically greater than A
A is lexically less than a
A is lexically less than B

Fortran 언어는 문자를 단일 문자 또는 연속 문자열로 처리 할 수 ​​있습니다.

문자열은 길이가 한 문자 일 수도 있고 길이가 0 일 수도 있습니다. Fortran에서 문자 상수는 한 쌍의 큰 따옴표 또는 작은 따옴표 사이에 제공됩니다.

내장 데이터 유형 character문자와 문자열을 저장합니다. 문자열의 길이는 다음과 같이 지정할 수 있습니다.len specifier. 길이를 지정하지 않으면 1입니다. 위치로 참조하는 문자열 내에서 개별 문자를 참조 할 수 있습니다. 가장 왼쪽의 문자는 위치 1에 있습니다.

문자열 선언

문자열을 선언하는 것은 다른 변수와 동일합니다-

type-specifier :: variable_name

예를 들면

Character(len = 20) :: firstname, surname

다음과 같은 값을 할당 할 수 있습니다.

character (len = 40) :: name  
name = “Zara Ali”

다음 예제는 문자 데이터 유형의 선언 및 사용을 보여줍니다.

program hello
implicit none

   character(len = 15) :: surname, firstname 
   character(len = 6) :: title 
   character(len = 25)::greetings
   
   title = 'Mr.' 
   firstname = 'Rowan' 
   surname = 'Atkinson'
   greetings = 'A big hello from Mr. Beans'
   
   print *, 'Here is', title, firstname, surname
   print *, greetings
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Here isMr.   Rowan          Atkinson       
A big hello from Mr. Bean

문자열 연결

연결 연산자 //는 문자열을 연결합니다.

다음 예제는 이것을 보여줍니다-

program hello
implicit none

   character(len = 15) :: surname, firstname 
   character(len = 6) :: title 
   character(len = 40):: name
   character(len = 25)::greetings
   
   title = 'Mr.' 
   firstname = 'Rowan' 
   surname = 'Atkinson'
   
   name = title//firstname//surname
   greetings = 'A big hello from Mr. Beans'
   
   print *, 'Here is', name
   print *, greetings
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Here is Mr. Rowan Atkinson       
A big hello from Mr. Bean

부분 문자열 추출

Fortran에서는 문자열을 인덱싱하여 문자열에서 부분 문자열을 추출 할 수 있으며, 한 쌍의 대괄호 안에 부분 문자열의 시작 및 끝 인덱스를 제공합니다. 이를 익스텐트 지정 자라고합니다.

다음 예제는 문자열 'hello world'에서 하위 문자열 'world'를 추출하는 방법을 보여줍니다.

program subString

   character(len = 11)::hello
   hello = "Hello World"
   print*, hello(7:11)
   
end program subString

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

World

다음 예에서는 date_and_time날짜 및 시간 문자열을 제공하는 함수. 익스텐트 지정자를 사용하여 년, 날짜, 월,시, 분 및 초 정보를 개별적으로 추출합니다.

program  datetime
implicit none

   character(len = 8) :: dateinfo ! ccyymmdd
   character(len = 4) :: year, month*2, day*2

   character(len = 10) :: timeinfo ! hhmmss.sss
   character(len = 2)  :: hour, minute, second*6

   call  date_and_time(dateinfo, timeinfo)

   !  let’s break dateinfo into year, month and day.
   !  dateinfo has a form of ccyymmdd, where cc = century, yy = year
   !  mm = month and dd = day

   year  = dateinfo(1:4)
   month = dateinfo(5:6)
   day   = dateinfo(7:8)

   print*, 'Date String:', dateinfo
   print*, 'Year:', year
   print *,'Month:', month
   print *,'Day:', day

   !  let’s break timeinfo into hour, minute and second.
   !  timeinfo has a form of hhmmss.sss, where h = hour, m = minute
   !  and s = second

   hour   = timeinfo(1:2)
   minute = timeinfo(3:4)
   second = timeinfo(5:10)

   print*, 'Time String:', timeinfo
   print*, 'Hour:', hour
   print*, 'Minute:', minute
   print*, 'Second:', second   
   
end program  datetime

위 프로그램을 컴파일하고 실행하면 자세한 날짜와 시간 정보를 제공합니다.

Date String: 20140803
Year: 2014
Month: 08
Day: 03
Time String: 075835.466
Hour: 07
Minute: 58
Second: 35.466

줄 자르기

그만큼 trim 함수는 문자열을 취하고 모든 후미 공백을 제거한 후 입력 문자열을 리턴합니다.

program trimString
implicit none

   character (len = *), parameter :: fname="Susanne", sname="Rizwan"
   character (len = 20) :: fullname 
   
   fullname = fname//" "//sname !concatenating the strings
   
   print*,fullname,", the beautiful dancer from the east!"
   print*,trim(fullname),", the beautiful dancer from the east!"
   
end program trimString

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Susanne Rizwan      , the beautiful dancer from the east!
 Susanne Rizwan, the beautiful dancer from the east!

현의 좌우 조정

함수 adjustl 문자열을 취하고 선행 공백을 제거하고 후행 공백으로 추가하여 리턴합니다.

함수 adjustr 문자열을 가져 와서 후행 공백을 제거하고 선행 공백으로 추가하여 반환합니다.

program hello
implicit none

   character(len = 15) :: surname, firstname 
   character(len = 6) :: title 
   character(len = 40):: name
   character(len = 25):: greetings
   
   title = 'Mr. ' 
   firstname = 'Rowan' 
   surname = 'Atkinson'
   greetings = 'A big hello from Mr. Beans'
   
   name = adjustl(title)//adjustl(firstname)//adjustl(surname)
   print *, 'Here is', name
   print *, greetings
   
   name = adjustr(title)//adjustr(firstname)//adjustr(surname)
   print *, 'Here is', name
   print *, greetings
   
   name = trim(title)//trim(firstname)//trim(surname)
   print *, 'Here is', name
   print *, greetings
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

Here is Mr. Rowan  Atkinson           
A big hello from Mr. Bean
Here is Mr. Rowan Atkinson    
A big hello from Mr. Bean
Here is Mr.RowanAtkinson                        
A big hello from Mr. Bean

문자열에서 하위 문자열 검색

인덱스 함수는 두 개의 문자열을 가져와 두 번째 문자열이 첫 번째 문자열의 하위 문자열인지 확인합니다. 두 번째 인수가 첫 번째 인수의 하위 문자열이면 첫 번째 문자열에서 두 번째 문자열의 시작 인덱스 인 정수를 반환하고, 그렇지 않으면 0을 반환합니다.

program hello
implicit none

   character(len=30) :: myString
   character(len=10) :: testString
   
   myString = 'This is a test'
   testString = 'test'
   
   if(index(myString, testString) == 0)then
      print *, 'test is not found'
   else
      print *, 'test is found at index: ', index(myString, testString)
   end if
   
end program hello

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

test is found at index: 11

배열은 동일한 유형의 요소의 고정 크기 순차 컬렉션을 저장할 수 있습니다. 배열은 데이터 모음을 저장하는 데 사용되지만 배열을 동일한 유형의 변수 모음으로 생각하는 것이 더 유용합니다.

모든 어레이는 연속적인 메모리 위치로 구성됩니다. 가장 낮은 주소는 첫 번째 요소에 해당하고 가장 높은 주소는 마지막 요소에 해당합니다.

숫자 (1) 숫자 (2) 숫자 (3) 숫자 (4)

배열은 1 차원 (벡터), 2 차원 (행렬) 일 수 있으며 Fortran을 사용하면 최대 7 차원 배열을 만들 수 있습니다.

배열 선언

배열은 dimension 속성.

예를 들어, 5 개의 요소를 포함하는 실수의 number라는 1 차원 배열을 선언하려면 다음과 같이 작성합니다.

real, dimension(5) :: numbers

배열의 개별 요소는 첨자를 지정하여 참조됩니다. 배열의 첫 번째 요소에는 1의 첨자가 있습니다. 배열 번호에는 숫자 (1), 숫자 (2), 숫자 (3), 숫자 (4) 및 숫자 (5)의 5 가지 실수 변수가 포함됩니다.

matrix라는 정수의 5 x 5 2 차원 배열을 만들려면 다음과 같이 작성합니다.

integer, dimension (5,5) :: matrix

예를 들어, 명시적인 하한이있는 배열을 선언 할 수도 있습니다.

real, dimension(2:6) :: numbers
integer, dimension (-3:2,0:4) :: matrix

값 할당

다음과 같이 개별 구성원에게 값을 할당 할 수 있습니다.

numbers(1) = 2.0

또는 루프를 사용할 수 있습니다.

do i  =1,5
   numbers(i) = i * 2.0
end do

1 차원 배열 요소는 다음과 같이 배열 생성자라고하는 약식 기호를 사용하여 값을 직접 할당 할 수 있습니다.

numbers = (/1.5, 3.2,4.5,0.9,7.2 /)

please note that there are no spaces allowed between the brackets ‘( ‘and the back slash ‘/’

다음 예는 위에서 설명한 개념을 보여줍니다.

program arrayProg

   real :: numbers(5) !one dimensional integer array
   integer :: matrix(3,3), i , j !two dimensional real array
   
   !assigning some values to the array numbers
   do i=1,5
      numbers(i) = i * 2.0
   end do
   
   !display the values
   do i = 1, 5
      Print *, numbers(i)
   end do
   
   !assigning some values to the array matrix
   do i=1,3
      do j = 1, 3
         matrix(i, j) = i+j
      end do
   end do
   
   !display the values
   do i=1,3
      do j = 1, 3
         Print *, matrix(i,j)
      end do
   end do
   
   !short hand assignment
   numbers = (/1.5, 3.2,4.5,0.9,7.2 /)
   
   !display the values
   do i = 1, 5
      Print *, numbers(i)
   end do
   
end program arrayProg

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

2.00000000    
 4.00000000    
 6.00000000    
 8.00000000    
 10.0000000    
         2
         3
         4
         3
         4
         5
         4
         5
         6
 1.50000000    
 3.20000005    
 4.50000000    
0.899999976    
 7.19999981

일부 어레이 관련 용어

다음 표는 배열 관련 용어를 제공합니다.

기간 의미
계급 배열의 차원 수입니다. 예를 들어, matrix라는 배열의 경우 rank는 2이고 numbers라는 배열의 경우 rank는 1입니다.
범위 차원을 따르는 요소의 수입니다. 예를 들어, 배열 번호의 범위는 5이고 matrix라는 배열의 범위는 두 차원 모두입니다.
모양 배열의 모양은 각 차원의 요소 수 (범위)를 포함하는 1 차원 정수 배열입니다. 예를 들어, 배열 행렬의 경우 모양은 (3, 3)이고 배열 번호는 (5)입니다.
크기 배열에 포함 된 요소의 수입니다. 배열 행렬의 경우 9이고 배열 번호의 경우 5입니다.

절차에 배열 전달

배열을 프로 시저에 인수로 전달할 수 있습니다. 다음 예제는 개념을 보여줍니다-

program arrayToProcedure      
implicit none      

   integer, dimension (5) :: myArray  
   integer :: i
   
   call fillArray (myArray)      
   call printArray(myArray)
   
end program arrayToProcedure


subroutine fillArray (a)      
implicit none      

   integer, dimension (5), intent (out) :: a
   
   ! local variables     
   integer :: i     
   do i = 1, 5         
      a(i) = i      
   end do  
   
end subroutine fillArray 


subroutine printArray(a)

   integer, dimension (5) :: a  
   integer::i
   
   do i = 1, 5
      Print *, a(i)
   end do
   
end subroutine printArray

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

1
2
3
4
5

위의 예에서 서브 루틴 fillArray 및 printArray는 차원 5의 배열에서만 호출 할 수 있습니다. 그러나 모든 크기의 배열에 사용할 수있는 서브 루틴을 작성하려면 다음 기술을 사용하여 다시 작성할 수 있습니다.

program arrayToProcedure      
implicit  none    

   integer, dimension (10) :: myArray  
   integer :: i
   
   interface 
      subroutine fillArray (a)
         integer, dimension(:), intent (out) :: a 
         integer :: i         
      end subroutine fillArray      

      subroutine printArray (a)
         integer, dimension(:) :: a 
         integer :: i         
      end subroutine printArray   
   end interface 
   
   call fillArray (myArray)      
   call printArray(myArray)
   
end program arrayToProcedure


subroutine fillArray (a)      
implicit none      
   integer,dimension (:), intent (out) :: a      
   
   ! local variables     
   integer :: i, arraySize  
   arraySize = size(a)
   
   do i = 1, arraySize         
      a(i) = i      
   end do  
   
end subroutine fillArray 


subroutine printArray(a)
implicit none

   integer,dimension (:) :: a  
   integer::i, arraySize
   arraySize = size(a)
   
   do i = 1, arraySize
     Print *, a(i)
   end do
   
end subroutine printArray

이 프로그램은 size 배열의 크기를 얻는 함수.

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

1
2
3
4
5
6
7
8
9
10

배열 섹션

지금까지 전체 배열을 언급했지만 Fortran은 단일 명령문을 사용하여 여러 요소 또는 배열의 섹션을 쉽게 참조 할 수있는 방법을 제공합니다.

배열 섹션에 액세스하려면 모든 차원에 대해 섹션의 하한 및 상한과 스트라이드 (증가)를 제공해야합니다. 이 표기법을subscript triplet:

array ([lower]:[upper][:stride], ...)

하한 및 상한이 언급되지 않은 경우 기본값은 선언 한 범위로 설정되고 스트라이드 값은 기본적으로 1로 설정됩니다.

다음 예제는 개념을 보여줍니다-

program arraySubsection

   real, dimension(10) :: a, b
   integer:: i, asize, bsize
   
   a(1:7) = 5.0 ! a(1) to a(7) assigned 5.0
   a(8:) = 0.0  ! rest are 0.0 
   b(2:10:2) = 3.9
   b(1:9:2) = 2.5
   
   !display
   asize = size(a)
   bsize = size(b)
   
   do i = 1, asize
      Print *, a(i)
   end do
   
   do i = 1, bsize
      Print *, b(i)
   end do
   
end program arraySubsection

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

5.00000000    
5.00000000    
5.00000000    
5.00000000    
5.00000000    
5.00000000    
5.00000000    
0.00000000E+00
0.00000000E+00
0.00000000E+00
2.50000000    
3.90000010    
2.50000000    
3.90000010    
2.50000000    
3.90000010    
2.50000000    
3.90000010    
2.50000000    
3.90000010

배열 내장 함수

Fortran 90/95는 몇 가지 고유 절차를 제공합니다. 7 가지 카테고리로 나눌 수 있습니다.

  • 벡터 및 행렬 곱셈

  • Reduction

  • Inquiry

  • Construction

  • Reshape

  • Manipulation

  • Location

dynamic array 크기는 컴파일 시간에 알려지지 않았지만 실행 시간에 알려지는 배열입니다.

동적 배열은 속성으로 선언됩니다. allocatable.

예를 들면

real, dimension (:,:), allocatable :: darray

배열의 순위, 즉 차원을 언급해야하지만 이러한 배열에 메모리를 할당하려면 다음을 사용합니다. allocate 함수.

allocate ( darray(s1,s2) )

배열을 사용한 후 프로그램에서 생성 된 메모리는 deallocate 함수

deallocate (darray)

다음 예는 위에서 설명한 개념을 보여줍니다.

program dynamic_array 
implicit none 

   !rank is 2, but size not known   
   real, dimension (:,:), allocatable :: darray    
   integer :: s1, s2     
   integer :: i, j     
   
   print*, "Enter the size of the array:"     
   read*, s1, s2      
   
   ! allocate memory      
   allocate ( darray(s1,s2) )      
   
   do i = 1, s1           
      do j = 1, s2                
         darray(i,j) = i*j               
         print*, "darray(",i,",",j,") = ", darray(i,j)           
      end do      
   end do      
   
   deallocate (darray)  
end program dynamic_array

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

Enter the size of the array: 3,4
darray( 1 , 1 ) = 1.00000000    
darray( 1 , 2 ) = 2.00000000    
darray( 1 , 3 ) = 3.00000000    
darray( 1 , 4 ) = 4.00000000    
darray( 2 , 1 ) = 2.00000000    
darray( 2 , 2 ) = 4.00000000    
darray( 2 , 3 ) = 6.00000000    
darray( 2 , 4 ) = 8.00000000    
darray( 3 , 1 ) = 3.00000000    
darray( 3 , 2 ) = 6.00000000    
darray( 3 , 3 ) = 9.00000000    
darray( 3 , 4 ) = 12.0000000

데이터 진술의 사용

그만큼 data 문은 둘 이상의 배열을 초기화하거나 배열 섹션 초기화에 사용할 수 있습니다.

데이터 문의 구문은-

data variable / list / ...

다음 예제는 개념을 보여줍니다-

program dataStatement
implicit none

   integer :: a(5), b(3,3), c(10),i, j
   data a /7,8,9,10,11/ 
   
   data b(1,:) /1,1,1/ 
   data b(2,:)/2,2,2/ 
   data b(3,:)/3,3,3/ 
   data (c(i),i = 1,10,2) /4,5,6,7,8/ 
   data (c(i),i = 2,10,2)/5*2/
   
   Print *, 'The A array:'
   do j = 1, 5                
      print*, a(j)           
   end do 
   
   Print *, 'The B array:'
   do i = lbound(b,1), ubound(b,1)
      write(*,*) (b(i,j), j = lbound(b,2), ubound(b,2))
   end do

   Print *, 'The C array:' 
   do j = 1, 10                
      print*, c(j)           
   end do      
   
end program dataStatement

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

The A array:
           7
           8
           9
          10
          11
 The B array:
           1           1           1
           2           2           2
           3           3           3
 The C array:
           4
           2
           5
           2
           6
           2
           7
           2
           8
           2

Where 문 사용

그만큼 where문을 사용하면 일부 논리적 조건의 결과에 따라 표현식에서 배열의 일부 요소를 사용할 수 있습니다. 주어진 조건이 참인 경우 요소에서 표현식을 실행할 수 있습니다.

다음 예제는 개념을 보여줍니다-

program whereStatement
implicit none

   integer :: a(3,5), i , j
   
   do i = 1,3
      do j = 1, 5                
         a(i,j) = j-i          
      end do 
   end do
   
   Print *, 'The A array:'
   
   do i = lbound(a,1), ubound(a,1)
      write(*,*) (a(i,j), j = lbound(a,2), ubound(a,2))
   end do
   
   where( a<0 ) 
      a = 1 
   elsewhere
      a = 5
   end where
  
   Print *, 'The A array:'
   do i = lbound(a,1), ubound(a,1)
      write(*,*) (a(i,j), j = lbound(a,2), ubound(a,2))
   end do   
   
end program whereStatement

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

The A array:
           0           1           2           3           4
          -1           0           1           2           3
          -2          -1           0           1           2
 The A array:
           5           5           5           5           5
           1           5           5           5           5
           1           1           5           5           5

Fortran을 사용하면 파생 데이터 유형을 정의 할 수 있습니다. 파생 데이터 유형은 구조라고도하며 다양한 유형의 데이터 개체로 구성 될 수 있습니다.

파생 데이터 유형은 레코드를 나타내는 데 사용됩니다. 예를 들어 도서관에서 책을 추적하고 싶다면 각 책에 대한 다음 속성을 추적 할 수 있습니다.

  • Title
  • Author
  • Subject
  • 도서 ID

파생 데이터 유형 정의

파생 데이터를 정의하려면 type, 유형 및 end type문이 사용됩니다. . type 문은 프로그램에 대해 둘 이상의 멤버를 사용하여 새 데이터 유형을 정의합니다. 유형 문의 형식은 다음과 같습니다.

type type_name      
   declarations
end type

다음은 Book 구조를 선언하는 방법입니다.

type Books
   character(len = 50) :: title
   character(len = 50) :: author
   character(len = 150) :: subject
   integer :: book_id
end type Books

구조 멤버 액세스

파생 된 데이터 유형의 개체를 구조라고합니다.

Books 유형의 구조는 다음과 같은 유형 선언문에서 만들 수 있습니다.

type(Books) :: book1

구조의 구성 요소는 구성 요소 선택기 문자 (%)를 사용하여 액세스 할 수 있습니다.

book1%title = "C Programming"
book1%author = "Nuha Ali"
book1%subject = "C Programming Tutorial"
book1%book_id = 6495407

Note that there are no spaces before and after the % symbol.

다음 프로그램은 위의 개념을 보여줍니다-

program deriveDataType

   !type declaration
   type Books
      character(len = 50) :: title
      character(len = 50) :: author
      character(len = 150) :: subject
      integer :: book_id
   end type Books
   
   !declaring type variables
   type(Books) :: book1 
   type(Books) :: book2 
   
   !accessing the components of the structure
   
   book1%title = "C Programming"
   book1%author = "Nuha Ali"
   book1%subject = "C Programming Tutorial"
   book1%book_id = 6495407 
   
   book2%title = "Telecom Billing"
   book2%author = "Zara Ali"
   book2%subject = "Telecom Billing Tutorial"
   book2%book_id = 6495700
  
   !display book info
   
   Print *, book1%title 
   Print *, book1%author 
   Print *, book1%subject 
   Print *, book1%book_id  
   
   Print *, book2%title 
   Print *, book2%author 
   Print *, book2%subject 
   Print *, book2%book_id  

end program deriveDataType

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

C Programming                                     
 Nuha Ali                                          
 C Programming Tutorial            
   6495407
 Telecom Billing                                   
 Zara Ali                                          
 Telecom Billing Tutorial            
   6495700

구조 배열

또한 파생 된 유형의 배열을 만들 수 있습니다-

type(Books), dimension(2) :: list

배열의 개별 요소는 다음과 같이 액세스 할 수 있습니다.

list(1)%title = "C Programming"
list(1)%author = "Nuha Ali"
list(1)%subject = "C Programming Tutorial"
list(1)%book_id = 6495407

다음 프로그램은 개념을 설명합니다-

program deriveDataType

   !type declaration
   type Books
      character(len = 50) :: title
      character(len = 50) :: author
      character(len = 150) :: subject
      integer :: book_id
   end type Books
   
   !declaring array of books
   type(Books), dimension(2) :: list 
    
   !accessing the components of the structure
   
   list(1)%title = "C Programming"
   list(1)%author = "Nuha Ali"
   list(1)%subject = "C Programming Tutorial"
   list(1)%book_id = 6495407 
   
   list(2)%title = "Telecom Billing"
   list(2)%author = "Zara Ali"
   list(2)%subject = "Telecom Billing Tutorial"
   list(2)%book_id = 6495700
  
   !display book info
   
   Print *, list(1)%title 
   Print *, list(1)%author 
   Print *, list(1)%subject 
   Print *, list(1)%book_id  
   
   Print *, list(1)%title 
   Print *, list(2)%author 
   Print *, list(2)%subject 
   Print *, list(2)%book_id  

end program deriveDataType

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

C Programming                                     
Nuha Ali                                          
C Programming Tutorial               
   6495407
C Programming                                     
Zara Ali                                          
Telecom Billing Tutorial                                      
   6495700

대부분의 프로그래밍 언어에서 포인터 변수는 객체의 메모리 주소를 저장합니다. 그러나 Fortran에서 포인터는 메모리 주소를 저장하는 것보다 더 많은 기능을 가진 데이터 개체입니다. 유형, 순위, 범위 및 메모리 주소와 같은 특정 개체에 대한 자세한 정보가 포함됩니다.

포인터는 할당 또는 포인터 할당을 통해 대상과 연결됩니다.

포인터 변수 선언

포인터 변수는 포인터 속성으로 선언됩니다.

다음 예제는 포인터 변수의 선언을 보여줍니다-

integer, pointer :: p1 ! pointer to integer  
real, pointer, dimension (:) :: pra ! pointer to 1-dim real array  
real, pointer, dimension (:,:) :: pra2 ! pointer to 2-dim real array

포인터는-

  • 동적으로 할당 된 메모리 영역입니다.

  • 포인터와 동일한 유형의 데이터 개체 target 속성.

포인터를위한 공간 할당

그만큼 allocate문을 사용하면 포인터 개체에 공간을 할당 할 수 있습니다. 예를 들면-

program pointerExample
implicit none

   integer, pointer :: p1
   allocate(p1)
   
   p1 = 1
   Print *, p1
   
   p1 = p1 + 4
   Print *, p1
   
end program pointerExample

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

1
5

할당 된 저장 공간을 비워야합니다. deallocate 더 이상 필요하지 않은 경우 사용하지 않고 사용할 수없는 메모리 공간의 누적을 방지합니다.

목표 및 연관

대상은 공간이 따로 설정된 또 다른 일반 변수입니다. 대상 변수는target 속성.

연관 연산자 (=>)를 사용하여 포인터 변수를 대상 변수와 연관시킵니다.

개념을 설명하기 위해 이전 예제를 다시 작성해 보겠습니다.

program pointerExample
implicit none

   integer, pointer :: p1
   integer, target :: t1 
   
   p1=>t1
   p1 = 1
   
   Print *, p1
   Print *, t1
   
   p1 = p1 + 4
   
   Print *, p1
   Print *, t1
   
   t1 = 8
   
   Print *, p1
   Print *, t1
   
end program pointerExample

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

1
1
5
5
8
8

포인터는-

  • Undefined
  • Associated
  • Disassociated

위의 프로그램에서 우리는 associated=> 연산자를 사용하여 대상 t1이있는 포인터 p1. 연결된 함수는 포인터의 연결 상태를 테스트합니다.

그만큼 nullify 문은 대상에서 포인터를 분리합니다.

Nullify는 동일한 대상을 가리키는 포인터가 둘 이상있을 수 있으므로 대상을 비우지 않습니다. 그러나 포인터를 비우면 무효화도 의미합니다.

예 1

다음 예제는 개념을 보여줍니다-

program pointerExample
implicit none

   integer, pointer :: p1
   integer, target :: t1 
   integer, target :: t2
   
   p1=>t1
   p1 = 1
   
   Print *, p1
   Print *, t1
   
   p1 = p1 + 4
   Print *, p1
   Print *, t1
   
   t1 = 8
   Print *, p1
   Print *, t1
   
   nullify(p1)
   Print *, t1
   
   p1=>t2
   Print *, associated(p1)
   Print*, associated(p1, t1)
   Print*, associated(p1, t2)
   
   !what is the value of p1 at present
   Print *, p1
   Print *, t2
   
   p1 = 10
   Print *, p1
   Print *, t2
   
end program pointerExample

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

1
1
5
5
8
8
8
T
F
T
952754640
952754640
10
10

코드를 실행할 때마다 메모리 주소가 달라집니다.

예 2

program pointerExample
implicit none

   integer, pointer :: a, b
   integer, target :: t
   integer :: n
   
   t = 1
   a => t
   t = 2
   b => t
   n = a + b
   
   Print *, a, b, t, n 
   
end program pointerExample

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

2  2  2  4

지금까지 키보드에서 데이터를 읽을 수 있음을 확인했습니다. read * 문을 사용하여 화면에 출력을 표시합니다. print*성명을 각각. 이러한 형태의 입출력은free format I / O, 그리고 list-directed 입출력.

자유 형식의 단순 I / O는 다음과 같은 형식을 갖습니다.

read(*,*) item1, item2, item3...
print *, item1, item2, item3
write(*,*) item1, item2, item3...

그러나 포맷 된 I / O는 데이터 전송에 더 많은 유연성을 제공합니다.

형식화 된 입력 출력

형식화 된 입력 출력에는 다음과 같은 구문이 있습니다.

read fmt, variable_list 
print fmt, variable_list 
write fmt, variable_list

어디,

  • fmt는 형식 사양입니다.

  • variable-list는 키보드에서 읽거나 화면에 쓸 변수 목록입니다.

형식 사양은 형식화 된 데이터가 표시되는 방식을 정의합니다. 목록을 포함하는 문자열로 구성됩니다.edit descriptors 괄호 안에.

edit descriptor 문자와 숫자가 표시되는 정확한 형식 (예 : 너비, 소수점 이하 자릿수 등)을 지정합니다.

예를 들면

Print "(f6.3)", pi

다음 표는 설명자를 설명합니다-

설명자 기술
나는

정수 출력에 사용됩니다. 이는 r, w 및 m의 의미가 아래 표에 나와있는 'rIw.m'형식을 취합니다. 정수 값은 필드에서 바로 정당화됩니다. 필드 너비가 정수를 수용 할만큼 충분히 크지 않으면 필드는 별표로 채워집니다.

"(3i5)"인쇄, i, j, k
에프

실수 출력에 사용됩니다. 이는 r, w 및 d의 의미가 아래 표에 나와있는 'rFw.d'형식을 취합니다. 실제 가치는 그 분야에서 정당화됩니다. 필드 너비가 실수를 수용 할만큼 충분히 크지 않으면 필드는 별표로 채워집니다.

print "(f12.3)", pi
이자형

이것은 지수 표기법의 실제 출력에 사용됩니다. 'E'설명문은 'rEw.d'형식을 취하며 여기서 r, w 및 d의 의미는 아래 표에 나와 있습니다. 실제 가치는 그 분야에서 정당화됩니다. 필드 너비가 실수를 수용 할만큼 충분히 크지 않으면 필드는 별표로 채워집니다.

소수점 세 자리로 실수를 인쇄하려면 필드 너비가 10 이상이어야합니다. 하나는 가수의 부호, 2는 0, 4는 가수, 2는 지수 자체입니다. 일반적으로 w ≥ d + 7.

print "(e10.3)", 123456.0은 '0.123e + 06'을 ​​제공합니다.
ES

이것은 실제 출력 (과학적 표기법)에 사용됩니다. 이는 r, w 및 d의 의미가 아래 표에 나와있는 'rESw.d'형식을 취합니다. 위에서 설명한 'E'설명자는 잘 알려진 전통적인 '과학적 표기법'과 약간 다릅니다. 0.1에서 1.0 범위의 가수를 갖는 E 설명자와 달리 과학적 표기법은 1.0에서 10.0 범위의 가수를 갖는다. 실제 가치는 그 분야에서 정당화됩니다. 필드 너비가 실수를 수용 할만큼 충분히 크지 않으면 필드는 별표로 채워집니다. 여기서도 폭 필드는 식 w ≥ d + 7을 충족해야합니다.

print "(es10.3)", 123456.0은 '1.235e + 05'를 제공합니다.

이것은 문자 출력에 사용됩니다. 이것은 r과 w의 의미가 아래 표에 나와있는 'rAw'형식을 취합니다. 문자 유형은 해당 필드에서 올바르게 정의됩니다. 필드 너비가 문자열을 수용 할만큼 충분히 크지 않으면 필드는 문자열의 첫 번째 'w'문자로 채워집니다.

print "(a10)", str
엑스

이것은 공간 출력에 사용됩니다. 이것은 'nX'형식을 취합니다. 여기서 'n'은 원하는 공간의 수입니다.

print "(5x, a10)", str
/

슬래시 설명자 – 빈 줄을 삽입하는 데 사용됩니다. 이것은 '/'형식을 취하고 다음 데이터 출력이 새 행에 있도록합니다.

print "(/, 5x, a10)", str

다음 기호는 형식 설명자와 함께 사용됩니다-

Sr. 아니요 기호 및 설명
1

c

열 번호

2

d

실제 입력 또는 출력에 대한 소수점 이하 자릿수

m

표시 할 최소 자릿수

4

n

건너 뛸 공백 수

5

r

반복 횟수 – 설명자 또는 설명자 그룹을 사용하는 횟수

6

w

필드 너비 – 입력 또는 출력에 사용할 문자 수

예 1

program printPi

   pi = 3.141592653589793238 
   
   Print "(f6.3)", pi 
   Print "(f10.7)", pi
   Print "(f20.15)", pi 
   Print "(e16.4)", pi/100 
   
end program printPi

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

3.142
3.1415927
3.141592741012573
0.3142E-01

예 2

program printName
implicit none

   character (len = 15) :: first_name
   print *,' Enter your first name.' 
   print *,' Up to 20 characters, please'
   
   read *,first_name 
   print "(1x,a)",first_name
   
end program printName

위 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다. (사용자가 Zara라는 이름을 입력했다고 가정)

Enter your first name.
Up to 20 characters, please
Zara

예제 3

program formattedPrint
implicit none

   real :: c = 1.2786456e-9, d = 0.1234567e3 
   integer :: n = 300789, k = 45, i = 2
   character (len=15) :: str="Tutorials Point"
   
   print "(i6)", k 
   print "(i6.3)", k 
   print "(3i10)", n, k, i 
   print "(i10,i3,i5)", n, k, i 
   print "(a15)",str 
   print "(f12.3)", d
   print "(e12.4)", c 
   print '(/,3x,"n = ",i6, 3x, "d = ",f7.4)', n, d
   
end program formattedPrint

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

45
045
300789 45  2
300789 45  2
Tutorials Point
123.457
0.1279E-08

n = 300789 d = *******

형식 문

format 문을 사용하면 하나의 문에서 문자, 정수 및 실제 출력을 혼합하고 일치시킬 수 있습니다. 다음 예제는 이것을 보여줍니다-

program productDetails 
implicit none 

   character (len = 15) :: name
   integer :: id 
   real :: weight
   name = 'Ardupilot'
   id = 1
   weight = 0.08
   
   print *,' The product details are' 
   
   print 100
   100 format (7x,'Name:', 7x, 'Id:', 1x, 'Weight:')
   
   print 200, name, id, weight 
   200 format(1x, a, 2x, i3, 2x, f5.2) 
   
end program productDetails

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

The product details are
Name:       Id:    Weight:
Ardupilot   1       0.08

Fortran을 사용하면 파일에서 데이터를 읽고 데이터를 파일에 쓸 수 있습니다.

지난 장에서 터미널에서 데이터를 읽고 쓰는 방법을 살펴 보았습니다. 이 장에서는 Fortran에서 제공하는 파일 입력 및 출력 기능을 연구합니다.

하나 이상의 파일을 읽고 쓸 수 있습니다. OPEN, WRITE, READ 및 CLOSE 문을 사용하여이를 수행 할 수 있습니다.

파일 열기 및 닫기

파일을 사용하기 전에 파일을 열어야합니다. 그만큼open명령은 읽기 또는 쓰기를 위해 파일을 여는 데 사용됩니다. 가장 간단한 명령 형식은 다음과 같습니다.

open (unit = number, file = "name").

그러나 공개 진술은 일반적인 형식을 가질 수 있습니다.

open (list-of-specifiers)

다음 표는 가장 일반적으로 사용되는 지정자를 설명합니다.

Sr. 아니요 지정자 및 설명
1

[UNIT=] u

단위 번호 u는 9-99 범위의 숫자가 될 수 있으며 파일을 나타냅니다. 임의의 숫자를 선택할 수 있지만 프로그램의 모든 열린 파일에는 고유 한 번호가 있어야합니다

2

IOSTAT= ios

I / O 상태 식별자이며 정수 변수 여야합니다. open 문이 성공하면 반환 된 ios 값은 0이고 그렇지 않으면 0이 아닌 값입니다.

ERR = err

오류 발생시 컨트롤이 점프하는 레이블입니다.

4

FILE = fname

파일명, 문자열.

5

STATUS = sta

파일의 이전 상태를 보여줍니다. 문자열이며 NEW, OLD 또는 SCRATCH 세 값 중 하나를 가질 수 있습니다. 스크래치 파일은 닫히거나 프로그램이 종료 될 때 생성 및 삭제됩니다.

6

ACCESS = acc

파일 액세스 모드입니다. SEQUENTIAL 또는 DIRECT의 두 값 중 하나를 가질 수 있습니다. 기본값은 SEQUENTIAL입니다.

7

FORM = frm

파일의 형식화 상태를 제공합니다. FORMATTED 또는 UNFORMATTED 두 값 중 하나를 가질 수 있습니다. 기본값은 UNFORMATTED입니다.

8

RECL = rl

직접 액세스 파일의 각 레코드 길이를 지정합니다.

파일이 열린 후 읽기 및 쓰기 명령문으로 액세스됩니다. 완료되면close 성명서.

close 문에는 다음과 같은 구문이 있습니다.

close ([UNIT = ]u[,IOSTAT = ios,ERR = err,STATUS = sta])

괄호 안의 매개 변수는 선택 사항입니다.

Example

이 예제는 파일에 데이터를 쓰기 위해 새 파일을 여는 방법을 보여줍니다.

program outputdata   
implicit none

   real, dimension(100) :: x, y  
   real, dimension(100) :: p, q
   integer :: i  
   
   ! data  
   do i=1,100  
      x(i) = i * 0.1 
      y(i) = sin(x(i)) * (1-cos(x(i)/3.0))  
   end do  
   
   ! output data into a file 
   open(1, file = 'data1.dat', status = 'new')  
   do i=1,100  
      write(1,*) x(i), y(i)   
   end do  
   
   close(1) 
   
end program outputdata

위의 코드가 컴파일되고 실행되면 data1.dat 파일을 만들고 x 및 y 배열 값을 여기에 씁니다. 그런 다음 파일을 닫습니다.

파일 읽기 및 쓰기

read 및 write 문은 각각 파일에서 읽고 쓰는 데 사용됩니다.

그들은 다음과 같은 구문을 가지고 있습니다-

read ([UNIT = ]u, [FMT = ]fmt, IOSTAT = ios, ERR = err, END = s)
write([UNIT = ]u, [FMT = ]fmt, IOSTAT = ios, ERR = err, END = s)

대부분의 지정자는 위의 표에서 이미 논의되었습니다.

END = s 지정자는 프로그램이 파일 끝에 도달 할 때 점프하는 명령문 레이블입니다.

Example

이 예제는 파일 읽기 및 쓰기를 보여줍니다.

이 프로그램에서 우리는 파일을 읽고 마지막 예제 인 data1.dat에서 생성하여 화면에 표시합니다.

program outputdata   
implicit none   

   real, dimension(100) :: x, y  
   real, dimension(100) :: p, q
   integer :: i  
   
   ! data  
   do i = 1,100  
      x(i) = i * 0.1 
      y(i) = sin(x(i)) * (1-cos(x(i)/3.0))  
   end do  
   
   ! output data into a file 
   open(1, file = 'data1.dat', status='new')  
   do i = 1,100  
      write(1,*) x(i), y(i)   
   end do  
   close(1) 

   ! opening the file for reading
   open (2, file = 'data1.dat', status = 'old')

   do i = 1,100  
      read(2,*) p(i), q(i)
   end do 
   
   close(2)
   
   do i = 1,100  
      write(*,*) p(i), q(i)
   end do 
   
end program outputdata

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

0.100000001  5.54589933E-05
0.200000003  4.41325130E-04
0.300000012  1.47636665E-03
0.400000006  3.45637114E-03
0.500000000  6.64328877E-03
0.600000024  1.12552457E-02
0.699999988  1.74576249E-02
0.800000012  2.53552198E-02
0.900000036  3.49861123E-02
1.00000000   4.63171229E-02
1.10000002   5.92407547E-02
1.20000005   7.35742599E-02
1.30000007   8.90605897E-02
1.39999998   0.105371222    
1.50000000   0.122110792    
1.60000002   0.138823599    
1.70000005   0.155002072    
1.80000007   0.170096487    
1.89999998   0.183526158    
2.00000000   0.194692180    
2.10000014   0.202990443    
2.20000005   0.207826138    
2.29999995   0.208628103    
2.40000010   0.204863414    
2.50000000   0.196052119    
2.60000014   0.181780845    
2.70000005   0.161716297    
2.79999995   0.135617107    
2.90000010   0.103344671    
3.00000000   6.48725405E-02
3.10000014   2.02930309E-02
3.20000005  -3.01767997E-02
3.29999995  -8.61928314E-02
3.40000010  -0.147283033    
3.50000000  -0.212848678    
3.60000014  -0.282169819    
3.70000005  -0.354410470    
3.79999995  -0.428629100    
3.90000010  -0.503789663    
4.00000000  -0.578774154    
4.09999990  -0.652400017    
4.20000029  -0.723436713    
4.30000019  -0.790623367    
4.40000010  -0.852691114    
4.50000000  -0.908382416    
4.59999990  -0.956472993    
4.70000029  -0.995793998    
4.80000019  -1.02525222    
4.90000010  -1.04385209    
5.00000000  -1.05071592    
5.09999990  -1.04510069    
5.20000029  -1.02641726    
5.30000019  -0.994243503    
5.40000010  -0.948338211    
5.50000000  -0.888650239    
5.59999990  -0.815326691    
5.70000029  -0.728716135    
5.80000019  -0.629372001    
5.90000010  -0.518047631    
6.00000000  -0.395693362    
6.09999990  -0.263447165    
6.20000029  -0.122622721    
6.30000019   2.53026206E-02
6.40000010   0.178709000    
6.50000000   0.335851669    
6.59999990   0.494883657    
6.70000029   0.653881252    
6.80000019   0.810866773    
6.90000010   0.963840425    
7.00000000   1.11080539    
7.09999990   1.24979746    
7.20000029   1.37891412    
7.30000019   1.49633956    
7.40000010   1.60037732    
7.50000000   1.68947268    
7.59999990   1.76223695    
7.70000029   1.81747139    
7.80000019   1.85418403    
7.90000010   1.87160957    
8.00000000   1.86922085    
8.10000038   1.84674001    
8.19999981   1.80414569    
8.30000019   1.74167395    
8.40000057   1.65982044    
8.50000000   1.55933595    
8.60000038   1.44121361    
8.69999981   1.30668485    
8.80000019   1.15719533    
8.90000057   0.994394958    
9.00000000   0.820112705    
9.10000038   0.636327863    
9.19999981   0.445154816    
9.30000019   0.248800844    
9.40000057   4.95488606E-02
9.50000000  -0.150278628    
9.60000038  -0.348357052    
9.69999981  -0.542378068    
9.80000019  -0.730095863    
9.90000057  -0.909344316    
10.0000000  -1.07807255

procedure잘 정의 된 작업을 수행하고 프로그램에서 호출 할 수있는 명령문 그룹입니다. 정보 (또는 데이터)는 호출 프로그램에 인수로 프로 시저에 전달됩니다.

두 가지 유형의 절차가 있습니다.

  • Functions
  • Subroutines

함수

함수는 단일 수량을 반환하는 절차입니다. 함수는 인수를 수정해서는 안됩니다.

반환 된 수량은 다음과 같이 알려져 있습니다. function value, 함수 이름으로 표시됩니다.

Syntax

함수 구문은 다음과 같습니다.

function name(arg1, arg2, ....)  
   [declarations, including those for the arguments]   
   [executable statements] 
end function [name]

다음 예제는 area_of_circle이라는 함수를 보여줍니다. 반지름이 r 인 원의 면적을 계산합니다.

program calling_func

   real :: a
   a = area_of_circle(2.0) 
   
   Print *, "The area of a circle with radius 2.0 is"
   Print *, a
   
end program calling_func


! this function computes the area of a circle with radius r  
function area_of_circle (r)  

! function result     
implicit none      

   ! dummy arguments        
   real :: area_of_circle   
   
   ! local variables 
   real :: r     
   real :: pi
   
   pi = 4 * atan (1.0)     
   area_of_circle = pi * r**2  
   
end function area_of_circle

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

The area of a circle with radius 2.0 is
   12.5663710

유의하십시오-

  • 지정해야합니다. implicit none 메인 프로그램과 절차 모두에서.

  • 호출 된 함수의 인수 r이 호출됩니다. dummy argument.

결과 옵션

반환 된 값을 함수 이름이 아닌 다른 이름으로 저장하려면 다음을 사용할 수 있습니다. result 선택권.

반환 변수 이름을 다음과 같이 지정할 수 있습니다.

function name(arg1, arg2, ....) result (return_var_name)  
   [declarations, including those for the arguments]   
   [executable statements] 
end function [name]

서브 루틴

서브 루틴은 값을 반환하지 않지만 인수를 수정할 수 있습니다.

Syntax

subroutine name(arg1, arg2, ....)    
   [declarations, including those for the arguments]    
   [executable statements]  
end subroutine [name]

서브 루틴 호출

다음을 사용하여 서브 루틴을 호출해야합니다. call 성명서.

다음 예제는 인수 값을 변경하는 서브 루틴 스왑의 정의 및 사용을 보여줍니다.

program calling_func
implicit none

   real :: a, b
   a = 2.0
   b = 3.0
   
   Print *, "Before calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
   
   call swap(a, b)
   
   Print *, "After calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
   
end program calling_func


subroutine swap(x, y) 
implicit none

   real :: x, y, temp   
   
   temp = x  
   x = y 
   y = temp  
   
end subroutine swap

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Before calling swap
a = 2.00000000    
b = 3.00000000    
After calling swap
a = 3.00000000    
b = 2.00000000

인수의 의도 지정

의도 속성을 사용하면 프로 시저에서 인수가 사용되는 의도를 지정할 수 있습니다. 다음 표는 의도 속성의 값을 제공합니다-

사용 설명
의도 (in) 입력 값으로 사용되며 기능에서 변경되지 않습니다.
의도 (아웃) 출력 값으로 사용되며 덮어 씁니다.
안으로 의도 (inout) 인수가 모두 사용되고 덮어 씁니다.

다음 예제는 개념을 보여줍니다-

program calling_func
implicit none

   real :: x, y, z, disc
   
   x = 1.0
   y = 5.0
   z = 2.0
   
   call intent_example(x, y, z, disc)
   
   Print *, "The value of the discriminant is"
   Print *, disc
   
end program calling_func


subroutine intent_example (a, b, c, d)     
implicit none     

   ! dummy arguments      
   real, intent (in) :: a     
   real, intent (in) :: b      
   real, intent (in) :: c    
   real, intent (out) :: d   
   
   d = b * b - 4.0 * a * c 
   
end subroutine intent_example

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

The value of the discriminant is
   17.0000000

재귀 적 절차

재귀는 프로그래밍 언어가 동일한 함수 내에서 함수를 호출 할 수 있도록 허용 할 때 발생합니다. 이를 함수의 재귀 호출이라고합니다.

프로 시저가 직접 또는 간접적으로 자신을 호출 할 때이를 재귀 프로 시저라고합니다. 이러한 유형의 절차는recursive 선언하기 전에.

함수가 재귀 적으로 사용되면 result 옵션을 사용해야합니다.

다음은 재귀 절차를 사용하여 주어진 숫자에 대한 계승을 계산하는 예입니다.

program calling_func
implicit none

   integer :: i, f
   i = 15
   
   Print *, "The value of factorial 15 is"
   f = myfactorial(15)
   Print *, f
   
end program calling_func

! computes the factorial of n (n!)      
recursive function myfactorial (n) result (fac)  
! function result     
implicit none     

   ! dummy arguments     
   integer :: fac     
   integer, intent (in) :: n     
   
   select case (n)         
      case (0:1)         
         fac = 1         
      case default    
         fac = n * myfactorial (n-1)  
   end select 
   
end function myfactorial

내부 절차

프로 시저가 프로그램 내에 포함 된 경우이를 프로그램의 내부 프로 시저라고합니다. 내부 프로 시저를 포함하는 구문은 다음과 같습니다.

program program_name     
   implicit none         
   ! type declaration statements         
   ! executable statements    
   . . .     
   contains         
   ! internal procedures      
   . . .  
end program program_name

다음 예제는 개념을 보여줍니다-

program mainprog  
implicit none 

   real :: a, b 
   a = 2.0
   b = 3.0
   
   Print *, "Before calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
   
   call swap(a, b)
   
   Print *, "After calling swap"
   Print *, "a = ", a
   Print *, "b = ", b
 
contains   
   subroutine swap(x, y)     
      real :: x, y, temp      
      temp = x 
      x = y  
      y = temp   
   end subroutine swap 
   
end program mainprog

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Before calling swap
a = 2.00000000    
b = 3.00000000    
After calling swap
a = 3.00000000    
b = 2.00000000

모듈은 매우 큰 프로그램을 작성하거나 함수 또는 서브 루틴을 둘 이상의 프로그램에서 사용할 수있는 경우 함수와 서브 루틴을 유지할 수있는 패키지와 같습니다.

모듈은 프로그램을 여러 파일로 분할하는 방법을 제공합니다.

모듈은 다음에 사용됩니다-

  • 서브 프로그램, 데이터 및 인터페이스 블록 패키징.

  • 둘 이상의 루틴에서 사용할 수있는 글로벌 데이터를 정의합니다.

  • 선택한 루틴 내에서 사용할 수있는 변수 선언.

  • 사용을 위해 다른 프로그램이나 서브 루틴으로 모듈 전체를 가져옵니다.

모듈 구문

모듈은 두 부분으로 구성됩니다.

  • 명령문 선언을위한 사양 부분
  • a는 서브 루틴 및 함수 정의에 대한 부분을 포함합니다.

모듈의 일반적인 형태는 다음과 같습니다.

module name     
   [statement declarations]  
   [contains [subroutine and function definitions] ] 
end module [name]

프로그램에 모듈 사용

use 문으로 프로그램이나 서브 루틴에 모듈을 통합 할 수 있습니다.

use name

점에 유의하시기 바랍니다

  • 필요한만큼 모듈을 추가 할 수 있으며, 각 모듈은 별도의 파일에 있으며 별도로 컴파일됩니다.

  • 모듈은 다양한 프로그램에서 사용할 수 있습니다.

  • 모듈은 동일한 프로그램에서 여러 번 사용할 수 있습니다.

  • 모듈 사양 부분에 선언 된 변수는 모듈에 전역 적입니다.

  • 모듈에서 선언 된 변수는 모듈이 사용되는 모든 프로그램 또는 루틴에서 전역 변수가됩니다.

  • use 문은 주 프로그램이나 특정 모듈에서 선언 된 루틴 또는 변수를 사용하는 다른 서브 루틴 또는 모듈에 나타날 수 있습니다.

다음 예제는 개념을 보여줍니다-

module constants  
implicit none 

   real, parameter :: pi = 3.1415926536  
   real, parameter :: e = 2.7182818285 
   
contains      
   subroutine show_consts()          
      print*, "Pi = ", pi          
      print*,  "e = ", e     
   end subroutine show_consts 
   
end module constants 


program module_example     
use constants      
implicit none     

   real :: x, ePowerx, area, radius 
   x = 2.0
   radius = 7.0
   ePowerx = e ** x
   area = pi * radius**2     
   
   call show_consts() 
   
   print*, "e raised to the power of 2.0 = ", ePowerx
   print*, "Area of a circle with radius 7.0 = ", area  
   
end program module_example

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Pi = 3.14159274    
e =  2.71828175    
e raised to the power of 2.0 = 7.38905573    
Area of a circle with radius 7.0 = 153.938049

모듈에서 변수 및 서브 루틴의 접근성

기본적으로 모듈의 모든 변수와 서브 루틴은 모듈 코드를 사용하는 프로그램에서 사용할 수 있습니다. use 성명서.

그러나 다음을 사용하여 모듈 코드의 접근성을 제어 할 수 있습니다. privatepublic속성. 일부 변수 또는 서브 루틴을 개인용으로 선언하면 모듈 외부에서 사용할 수 없습니다.

다음 예제는 개념을 설명합니다-

이전 예에서는 두 개의 모듈 변수가있었습니다. epi. 그들을 비공개로 만들고 출력을 관찰합시다.

module constants  
implicit none 

   real, parameter,private :: pi = 3.1415926536  
   real, parameter, private :: e = 2.7182818285 
   
contains      
   subroutine show_consts()          
      print*, "Pi = ", pi          
      print*, "e = ", e     
   end subroutine show_consts 
   
end module constants 


program module_example     
use constants      
implicit none     

   real :: x, ePowerx, area, radius 
   x = 2.0
   radius = 7.0
   ePowerx = e ** x
   area = pi * radius**2     
   
   call show_consts() 
   
   print*, "e raised to the power of 2.0 = ", ePowerx
   print*, "Area of a circle with radius 7.0 = ", area  
   
end program module_example

위의 프로그램을 컴파일하고 실행하면 다음과 같은 오류 메시지가 나타납니다.

ePowerx = e ** x
   1
Error: Symbol 'e' at (1) has no IMPLICIT type
main.f95:19.13:

   area = pi * radius**2     
   1
Error: Symbol 'pi' at (1) has no IMPLICIT type

이후 epi, 둘 다 private으로 선언되며 module_example 프로그램은 더 이상 이러한 변수에 액세스 할 수 없습니다.

그러나 다른 모듈 서브 루틴이 액세스 할 수 있습니다.

module constants  
implicit none 

   real, parameter,private :: pi = 3.1415926536  
   real, parameter, private :: e = 2.7182818285 
   
contains      
   subroutine show_consts()          
      print*, "Pi = ", pi          
      print*, "e = ", e     
   end subroutine show_consts 
   
   function ePowerx(x)result(ePx) 
   implicit none
      real::x
      real::ePx
      ePx = e ** x
   end function ePowerx
    
   function areaCircle(r)result(a)  
   implicit none
      real::r
      real::a
      a = pi * r**2  
   end function areaCircle
    
end module constants 


program module_example     
use constants      
implicit none     

   call show_consts() 
   
   Print*, "e raised to the power of 2.0 = ", ePowerx(2.0)
   print*, "Area of a circle with radius 7.0 = ", areaCircle(7.0)  
   
end program module_example

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

Pi = 3.14159274    
e = 2.71828175    
e raised to the power of 2.0 = 7.38905573    
Area of a circle with radius 7.0 = 153.938049

내장 함수는 Fortran 언어의 일부로 제공되는 몇 가지 공통적이고 중요한 함수입니다. 배열, 문자 및 문자열 장에서 이러한 함수 중 일부에 대해 이미 논의했습니다.

내장 함수는 다음과 같이 분류 할 수 있습니다.

  • 숫자 함수
  • 수학 함수
  • 숫자 조회 기능
  • 부동 소수점 조작 함수
  • 비트 조작 기능
  • 캐릭터 기능
  • 종류 기능
  • 논리 함수
  • 배열 함수.

배열 장에서 배열 함수에 대해 논의했습니다. 다음 섹션에서는 다른 범주의 모든 기능에 대한 간략한 설명을 제공합니다.

함수 이름 열에서

  • A는 모든 유형의 숫자 ​​변수를 나타냅니다.
  • R은 실수 또는 정수 변수를 나타냅니다.
  • X와 Y는 실제 변수를 나타냅니다.
  • Z는 복잡한 변수를 나타냅니다.
  • W는 실수 또는 복합 변수를 나타냅니다.

숫자 함수

Sr. 아니요 기능 및 설명
1

ABS (A)

A의 절대 값을 반환합니다.

2

AIMAG (Z)

복소수 Z의 허수 부를 반환합니다.

AINT (A [, KIND])

A의 소수 부분을 0으로 자르고 실수 정수를 반환합니다.

4

ANINT (A [, KIND])

실제 값, 가장 가까운 정수 또는 정수를 반환합니다.

5

CEILING (A [, KIND])

숫자 A보다 크거나 같은 최소 정수를 반환합니다.

6

CMPLX (X [, Y, KIND])

실제 변수 X와 Y를 복소수 X + iY로 변환합니다. Y가 없으면 0이 사용됩니다.

7

CONJG (Z)

복소수 Z의 켤레 복소수를 반환합니다.

8

DBLE (A)

A를 배정 밀도 실수로 변환합니다.

9

DIM (X, Y)

X와 Y의 양의 차이를 반환합니다.

10

DPROD (X, Y)

X와 Y의 배정 밀도 실수 곱을 반환합니다.

11

FLOOR (A [, KIND])

숫자 A보다 작거나 같은 가장 큰 정수를 제공합니다.

12

INT (A [, KIND])

숫자 (실수 또는 정수)를 정수로 변환하여 실수 부분을 0으로 자릅니다.

13

MAX (A1, A2 [, A3,...])

인수의 최대 값을 반환하며 모두 동일한 유형입니다.

14

MIN (A1, A2 [, A3,...])

인수의 최소값을 반환하며 모두 동일한 유형입니다.

15

MOD (A, P)

P로 나누면 A의 나머지를 반환하며 두 인수는 모두 동일한 유형 (A-INT (A / P) * P)입니다.

16

MODULO (A, P)

A 모듈로 P를 반환합니다. (A-FLOOR (A / P) * P)

17

NINT (A [, KIND])

숫자 A의 가장 가까운 정수를 반환합니다.

18

REAL (A [, KIND])

실제 유형으로 변환

19

SIGN (A, B)

A의 절대 값에 P의 부호를 곱한 값을 반환합니다. 기본적으로 B의 부호를 A로 전달합니다.

program numericFunctions
implicit none  

   ! define constants  
   ! define variables
   real :: a, b 
   complex :: z
   
   ! values for a, b 
   a = 15.2345
   b = -20.7689
    
   write(*,*) 'abs(a): ',abs(a),' abs(b): ',abs(b)   
   write(*,*) 'aint(a): ',aint(a),' aint(b): ',aint(b) 
   write(*,*) 'ceiling(a): ',ceiling(a),' ceiling(b): ',ceiling(b)   
   write(*,*) 'floor(a): ',floor(a),' floor(b): ',floor(b)  
    
   z = cmplx(a, b)
   write(*,*) 'z: ',z   
   
end program numericFunctions

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

abs(a): 15.2344999   abs(b): 20.7688999    
aint(a): 15.0000000  aint(b): -20.0000000    
ceiling(a): 16  ceiling(b): -20
floor(a): 15  floor(b): -21
z: (15.2344999, -20.7688999)

수학 함수

Sr. 아니요 기능 및 설명
1

ACOS (X)

범위 (0, π)의 역 코사인을 라디안으로 반환합니다.

2

ASIN (X)

범위 (-π / 2, π / 2)의 역 사인을 라디안으로 반환합니다.

ATAN (X)

범위 (-π / 2, π / 2)의 역 탄젠트를 라디안으로 반환합니다.

4

ATAN2 (Y, X)

범위 (-π, π)의 역 탄젠트를 라디안으로 반환합니다.

5

COS (X)

인수의 코사인을 라디안으로 반환합니다.

6

COSH (X)

라디안 단위의 쌍곡선 코사인 인수를 반환합니다.

7

EXP (X)

X의 지수 값을 반환합니다.

8

LOG (X)

X의 자연 로그 값을 반환합니다.

9

LOG10 (X)

X의 공통 로그 (밑수 10) 값을 반환합니다.

10

SIN (X)

인수의 사인을 라디안으로 반환합니다.

11

SINH (X)

인수의 쌍곡 사인을 라디안으로 반환합니다.

12

SQRT (X)

X의 제곱근을 반환합니다.

13

TAN (X)

인수의 탄젠트를 라디안으로 반환합니다.

14

TANH (X)

라디안 단위의 쌍곡선 탄젠트 인수를 반환합니다.

다음 프로그램은 시간 t 이후에 발사체의 수평 및 수직 위치 x와 y를 각각 계산합니다.

여기서 x = ut cos a 및 y = ut sin a-g t2 / 2

program projectileMotion  
implicit none  

   ! define constants  
   real, parameter :: g = 9.8  
   real, parameter :: pi = 3.1415927  
   
   !define variables
   real :: a, t, u, x, y   
   
   !values for a, t, and u 
   a = 45.0
   t = 20.0
   u = 10.0
   
   ! convert angle to radians  
   a = a * pi / 180.0  
   x = u * cos(a) * t   
   y = u * sin(a) * t - 0.5 * g * t * t  
   
   write(*,*) 'x: ',x,'  y: ',y   
   
end program projectileMotion

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

x: 141.421356  y: -1818.57861

숫자 조회 기능

이러한 함수는 정수 및 부동 소수점 산술의 특정 모델에서 작동합니다. 이 함수는 변수 X와 같은 종류의 숫자 속성을 반환하며, 이는 실수 일 수 있고 경우에 따라 정수일 수 있습니다.

Sr. 아니요 기능 및 설명
1

DIGITS (X)

모델의 유효 자릿수를 반환합니다.

2

EPSILON (X)

1에 비해 거의 무시할 수있는 숫자를 반환합니다. 즉, REAL (1.0, KIND (X)) + EPSILON (X)이 REAL (1.0, KIND (X))와 같지 않은 가장 작은 값을 반환합니다.

HUGE (X)

모델의 가장 큰 수를 반환합니다.

4

MAXEXPONENT (X)

모델의 최대 지수를 반환합니다.

5

MINEXPONENT (X)

모델의 최소 지수를 반환합니다.

6

PRECISION (X)

소수 정밀도를 반환합니다.

7

RADIX (X)

모델의 기본을 반환합니다.

8

RANGE (X)

십진수 지수 범위를 반환합니다.

9

TINY (X)

모델의 가장 작은 양수를 반환합니다.

부동 소수점 조작 함수

Sr. 아니요 기능 및 설명
1

EXPONENT (X)

모델 번호의 지수 부분을 반환합니다.

2

FRACTION (X)

숫자의 소수 부분을 반환합니다.

NEAREST (X, S)

주어진 방향에서 가장 가까운 다른 프로세서 번호를 반환합니다.

4

RRSPACING (X)

주어진 숫자에 가까운 모델 번호의 상대적 간격의 역수를 반환합니다.

5

SCALE (X, I)

실수에 밑수를 정수 거듭 제곱으로 곱합니다.

6

SET_EXPONENT (X, I)

숫자의 지수 부분을 반환합니다.

7

SPACING (X)

주어진 숫자에 가까운 모델 번호의 절대 간격을 반환합니다.

비트 조작 기능

Sr. 아니요 기능 및 설명
1

BIT_SIZE (I)

모델의 비트 수를 반환합니다.

2

BTEST (I, POS)

비트 테스트

IAND (I, J)

논리적 AND

4

IBCLR (I, POS)

클리어 비트

5

IBITS (I, POS, LEN)

비트 추출

6

IBSET (I, POS)

비트 설정

7

IEOR (I, J)

독점 OR

8

IOR (I, J)

포함 OR

9

ISHFT (I, SHIFT)

논리적 이동

10

ISHFTC (I, SHIFT [, SIZE])

순환 이동

11

NOT (I)

논리적 보완

캐릭터 기능

Sr. 아니요 기능 및 설명
1

ACHAR (I)

ASCII 배열 순서로 Ith 문자를 반환합니다.

2

ADJUSTL (STRING)

선행 공백을 제거하고 후행 공백을 삽입하여 왼쪽 문자열을 조정합니다.

ADJUSTR (STRING)

후행 공백을 제거하고 선행 공백을 삽입하여 문자열을 오른쪽으로 조정합니다.

4

CHAR (I [, KIND])

기계 별 배열 순서에서 I 번째 문자를 반환합니다.

5

IACHAR (C)

ASCII 배열 순서에서 문자의 위치를 ​​반환합니다.

6

ICHAR (C)

기계 (프로세서) 특정 조합 순서에서 문자의 위치를 ​​리턴합니다.

7

INDEX (STRING, SUBSTRING [, BACK])

STRING 내에서 SUBSTRING의 가장 왼쪽 (BACK이 .TRUE이면 가장 오른쪽) 시작 위치를 반환합니다.

8

LEN (STRING)

문자열의 길이를 반환합니다.

9

LEN_TRIM (STRING)

후행 공백 문자없이 문자열의 길이를 반환합니다.

10

LGE (STRING_A, STRING_B)

어휘 적으로 크거나 같음

11

LGT (STRING_A, STRING_B)

어휘 적으로 큼

12

LLE (STRING_A, STRING_B)

어휘 적으로 작거나 같음

13

LLT (STRING_A, STRING_B)

어휘 적으로 이하

14

REPEAT (STRING, NCOPIES)

반복 된 연결

15

SCAN (STRING, SET [, BACK])

SET에 속하는 STRING의 가장 왼쪽 (BACK이 .TRUE 인 경우 가장 오른쪽) 문자의 인덱스를 반환하고, 속한 것이 없으면 0을 반환합니다.

16

TRIM (STRING)

후행 공백 문자를 제거합니다.

17

VERIFY (STRING, SET [, BACK])

문자열의 문자 집합을 확인합니다.

종류 기능

Sr. 아니요 기능 및 설명
1

KIND (X)

종류 유형 매개 변수 값을 반환합니다.

2

SELECTED_INT_KIND (R)

지정된 지수 범위에 대한 유형 매개 변수의 종류를 반환합니다.

SELECTED_REAL_KIND ([P, R])

정밀도 및 범위가 지정된 실제 종류 매개 변수 값

논리적 기능

Sr. 아니요 기능 및 설명
1

LOGICAL (L [, KIND])

종류 유형 매개 변수가 다른 논리적 유형의 객체 간 변환

이전 버전의 Fortran에는 두 가지 real 유형 : 기본 실제 유형 및 double precision 유형.

그러나 Fortran 90/95는 다음을 통해 실수 및 정수 데이터 유형의 정밀도를 더 많이 제어합니다. kind specifie.

종류 속성

다른 종류의 숫자는 컴퓨터 내부에 다르게 저장됩니다. 그만큼kind속성을 사용하면 숫자가 내부적으로 저장되는 방법을 지정할 수 있습니다. 예를 들면

real, kind = 2 :: a, b, c
real, kind = 4 :: e, f, g
integer, kind = 2 :: i, j, k
integer, kind = 3 :: l, m, n

위 선언에서 실제 변수 e, f 및 g는 실제 변수 a, b 및 c보다 정밀도가 높습니다. 정수 변수 l, m 및 n은 정수 변수 i, j 및 k보다 더 큰 값을 저장할 수 있고 더 많은 숫자를 저장할 수 있습니다. 이것은 기계에 따라 다릅니다.

program kindSpecifier
implicit none

   real(kind = 4) :: a, b, c
   real(kind = 8) :: e, f, g
   integer(kind = 2) :: i, j, k
   integer(kind = 4) :: l, m, n
   integer :: kind_a, kind_i, kind_e, kind_l
   
   kind_a = kind(a)
   kind_i = kind(i)
   kind_e = kind(e)
   kind_l = kind(l)
   
   print *,'default kind for real is', kind_a
   print *,'default kind for int is', kind_i
   print *,'extended kind for real is', kind_e
   print *,'default kind for int is', kind_l
   
end program kindSpecifier

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

default kind for real is 4
default kind for int is 2
extended kind for real is 8
default kind for int is 4

변수의 크기 조회

숫자의 크기를 조사 할 수있는 여러 내장 함수가 있습니다.

예를 들어 bit_size(i)내장 함수는 저장에 사용되는 비트 수를 지정합니다. 실수의 경우precision(x) 내장 함수는 정밀도의 소수 자릿수를 반환하는 반면 range(x) 내장 함수는 지수의 소수 범위를 반환합니다.

program getSize
implicit none

   real (kind = 4) :: a
   real (kind = 8) :: b
   integer (kind = 2) :: i
   integer (kind = 4) :: j

   print *,'precision of real(4) =', precision(a)
   print *,'precision of real(8) =', precision(b)
   
   print *,'range of real(4) =', range(a)
   print *,'range of real(8) =', range(b)
   

   print *,'maximum exponent of real(4) =' , maxexponent(a)
   print *,'maximum exponent of real(8) =' , maxexponent(b)
  
   print *,'minimum exponent of real(4) =' , minexponent(a)
   print *,'minimum exponent of real(8) =' , minexponent(b)
   
   print *,'bits in integer(2) =' , bit_size(i)
   print *,'bits in integer(4) =' , bit_size(j)
   
end program getSize

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

precision of real(4) = 6
precision of real(8) = 15
range of real(4) = 37
range of real(8) = 307
maximum exponent of real(4) = 128
maximum exponent of real(8) = 1024
minimum exponent of real(4) = -125
minimum exponent of real(8) = -1021
bits in integer(2) = 16
bits in integer(4) = 32

종류 가치 획득

Fortran은 정수와 실수의 필요한 정밀도에 대한 종류 값을 얻기 위해 두 가지 추가 내장 함수를 제공합니다.

  • selected_int_kind (r)
  • selected_real_kind ([p, r])

selected_real_kind 함수는 주어진 십진 정밀도 p 및 십진 지수 범위 r에 필요한 종류 유형 매개 변수 값인 정수를 리턴합니다. 십진 정밀도는 유효 자릿수이고 십진 지수 범위는 표현 가능한 최소 및 최대 숫자를 지정합니다. 따라서 범위는 10-r에서 10 + r입니다.

예를 들어 selected_real_kind (p = 10, r = 99)는 소수점 이하 10 자리의 정밀도와 최소 10-99에서 10 + 99의 범위에 필요한 종류 값을 반환합니다.

program getKind
implicit none

   integer:: i
   i = selected_real_kind (p = 10, r = 99) 
   print *,'selected_real_kind (p = 10, r = 99)', i
   
end program getKind

위의 프로그램을 컴파일하고 실행하면 다음 결과가 생성됩니다.

selected_real_kind (p = 10, r = 99) 8

다양한 Fortran 도구와 라이브러리가 있습니다. 일부는 무료이고 일부는 유료 서비스입니다.

다음은 무료 라이브러리입니다.

  • RANDLIB, 난수 및 통계 분포 생성기
  • BLAS
  • EISPACK
  • 사용 가능한 수학 소프트웨어에 대한 GAMS–NIST 가이드
  • NIST의 통계 및 기타 루틴
  • LAPACK
  • LINPACK
  • MINPACK
  • MUDPACK
  • NCAR 수학 라이브러리
  • 수학적 소프트웨어, 논문 및 데이터베이스의 Netlib 모음입니다.
  • ODEPACK
  • 순위 및 순서를위한 루틴 세트 인 ODERPACK.
  • 행렬 지수 계산을위한 Expokit
  • SLATEC
  • SPECFUN
  • STARPAC
  • StatLib 통계 라이브러리
  • TOMS
  • 문자열 정렬 및 병합

다음 라이브러리는 무료가 아닙니다-

  • NAG Fortran 수치 라이브러리
  • Visual Numerics IMSL 라이브러리
  • 수치 레시피

프로그래밍 스타일은 프로그램을 개발하는 동안 몇 가지 규칙을 따르는 것입니다. 이러한 모범 사례는 프로그램에 가독성 및 명확성과 같은 값을 부여합니다.

좋은 프로그램은 다음과 같은 특성을 가져야합니다.

  • Readability
  • 적절한 논리적 구조
  • 자명 한 메모 및 주석

예를 들어 다음과 같은 댓글을 달면 별 도움이되지 않습니다.

! loop from 1 to 10 
do i = 1,10

그러나 이항 계수를 계산하고 nCr에 대해이 루프가 필요한 경우 다음과 같은 주석이 도움이 될 것입니다.

! loop to calculate nCr 
do i = 1,10
  • 다양한 수준의 코드를 명확하게하기 위해 들여 쓰기 된 코드 블록.

  • 0으로 나누기, 음의 실수의 제곱근 또는 음의 실수의 로그와 같은 숫자 오류가 없는지 확인하는 자체 검사 코드입니다.

  • 변수가 불법적이거나 범위를 벗어난 값, 즉 입력 유효성 검사를받지 않도록하는 코드를 포함합니다.

  • 불필요한 곳에 수표를 두지 않으면 실행 속도가 느려집니다. 예를 들면-

real :: x 
x = sin(y) + 1.0

if (x >= 0.0) then
   z = sqrt(x)
end if
  • 적절한 알고리즘을 사용하여 명확하게 작성된 코드.
  • 연속 마커 '&'를 사용하여 긴 표현식 분할.
  • 의미있는 변수 이름 만들기.

디버거 도구는 프로그램의 오류를 검색하는 데 사용됩니다.

디버거 프로그램은 코드를 단계별로 실행하고 프로그램 실행 중에 변수 및 기타 데이터 개체의 값을 검사 할 수 있도록합니다.

소스 코드를로드하고 디버거 내에서 프로그램을 실행해야합니다. 디버거는 다음과 같이 프로그램을 디버그합니다.

  • 중단 점 설정,
  • 소스 코드를 단계별로 살펴보고,
  • 감시 지점 설정.

중단 점은 특히 중요한 코드 줄 다음에 프로그램을 중지해야하는 위치를 지정합니다. 중단 점에서 변수를 확인한 후 프로그램 실행.

디버거 프로그램은 소스 코드를 한 줄씩 확인합니다.

감시 지점은 특히 읽기 또는 쓰기 작업 후에 일부 변수의 값을 확인해야하는 지점입니다.

gdb 디버거

gdb 디버거, GNU 디버거는 Linux 운영 체제와 함께 제공됩니다. X Windows 시스템의 경우 gdb는 그래픽 인터페이스와 함께 제공되며 프로그램 이름은 xxgdb입니다.

다음 표는 gdb에서 몇 가지 명령을 제공합니다-

명령 목적
단절 중단 점 설정
운영 실행 시작
계속 계속 실행
다음 함수 호출을 실행하지 않고 소스 코드의 다음 줄만 실행합니다.
단계 함수 호출의 경우 함수를 한 단계 씩 실행하여 소스 코드의 다음 줄을 실행합니다.

dbx 디버거

Linux 용 다른 디버거 인 dbx 디버거가 있습니다.

다음 표는 dbx에서 몇 가지 명령을 제공합니다-

명령 목적
stop [var] 변수 var의 값이 변경 될 때 중단 점을 설정합니다.
[proc]에서 중지 프로 시저 프로 시저가 입력되면 실행을 중지합니다.
[line]에서 중지 지정된 줄에 중단 점을 설정합니다.
운영 실행을 시작합니다.
계속 실행을 계속합니다.
다음 함수 호출을 실행하지 않고 소스 코드의 다음 줄만 실행합니다.
단계 함수 호출의 경우 함수를 한 단계 씩 실행하여 소스 코드의 다음 줄을 실행합니다.