Beginning Fortran Fortran (77) Basics 22 October 2009 *Black text on white background provided for easy printing
Example Code Write a program to read in five values of temperature in Fahrenheit and convert to degrees Celsius OR Kelvin OR both.
Your Typical Program c PROGRAM MYPROGRAM STOP END Program Options Declaration of Variables MAIN CODE
Your Typical Program c PROGRAM MYPROGRAM STOP END Program Options Declaration of Variables MAIN CODE
Program Declaration You declare what kind of Fortran file you are writing on the first line. Syntax: c PROGRAM CONVERTF
Program Declaration You declare what kind of Fortran file you are writing on the first line. Syntax: c PROGRAM CONVERTF Specifies the file as a program Program name – something short but descriptive
Your Typical Program c PROGRAM CONVERTF STOP END Program Options Declaration of Variables MAIN CODE
Options and Variables There are numerous options – you can Google them if you are interested In general, there are two kinds: – You can “include” variables from another *.h file by putting include ‘.h’ in the options section. – You can switch on other options about how the code is run (Google it) – We are going to use implicit none
Options and Variables All variables we are going to use must be accounted for in the declaration section (no implicit variables allowed) – implicit none What do we need? – Temperature in Fahrenheit, Celsius, Kelvin – Logicals (do we want Celsius, Kelvin, both?) – Some integer to loop through all 5 values – Syntax:
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Specify a special parameter – an unchangeable value that can immediately be used (unlike a variable, which can change value)
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Array of 5 REALs for Fahrenheit temps
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Array of 5 REALs for Kelvin temps
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Array of 5 REALs for Celsius temps
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Logical: Do we want to convert to Celsius (TRUE) or not (FALSE)?
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Logical: Do we want to convert to Kelvin (TRUE) or not (FALSE)?
Options and Variables c IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I Integer that counts from 1 to 5 for loop over one-dimensional arrays
Your Typical Program c PROGRAM CONVERTF IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I STOP END MAIN CODE
Main Code We need to do several things: – Read in 5 values of temperature – Determine if we need to convert to Celsius, Kelvin, or both – Output values
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User DOC DOK
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User Read in 5 values of F into array DOC DOK
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User For each of the five temperatures (for-loop): DOC DOK
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User Compute C (we are going to do this no matter what, because we know that the output has to either be C or K or both, and we need C in order to calculate K anyway). DOC DOK
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User Output F to user (this should be done just to make sure that the input was read correctly). DOC DOK
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User If DOC = TRUE, then output C as well. DOC DOK
F F From User FiFi FiFi CiCi CiCi KiKi KiKi To User If DOK = TRUE, then compute K from C and output to user as well. DOC DOK
Main Code F F From User c DO I = 1, NT READ(*,*) F(I) ENDDO
Main Code F F From User c DO I = 1, NT READ(*,*) F(I) ENDDO READ is a Fortran command that is used for input. Syntax: READ(, ) Location (*) = read in from the terminal Format (*) = no particular format
Main Code F F From User c DO I = 1, NT READ(*,*) F(I) ENDDO WRITE(*,*) ‘Convert to C?’ READ(*,*) DOC WRITE(*,*) ‘Convert to K?’ READ(*,*) DOK
Main Code F F From User c DO I = 1, NT READ(*,*) F(I) ENDDO WRITE(*,*) ‘Convert to C?’ READ(*,*) DOC WRITE(*,*) ‘Convert to K?’ READ(*,*) DOK Write to screen with no particular formatting.
Main Code c DO I = 1, NT C(I) = (5./9.)*(F(I)-32.) ENDDO
Main Code c DO I = 1, NT C(I) = (5./9.)*(F(I)-32.) ENDDO For each temperature:
Main Code c DO I = 1, NT C(I) = (5./9.)*(F(I)-32.) ENDDO For each temperature: Compute Celsius temp.
Main Code c IF (DOK.EQV..TRUE.) THEN DO I = 1, NT K(I) = C(I) ENDDO ENDIF
Main Code c IF (DOK.EQV..TRUE.) THEN DO I = 1, NT K(I) = C(I) ENDDO ENDIF Logical trap: If we want to calculate Kelvin:
Main Code c IF (DOK.EQV..TRUE.) THEN DO I = 1, NT K(I) = C(I) ENDDO ENDIF Logical trap: If we want to calculate Kelvin: Loop through temperatures and calculate Kelvin temps. (If DOK =.FALSE., this entire loop is avoided)
Main Code c IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..FALSE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C’ ENDDO ENDIF c IF ((DOC.EQV..FALSE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, K(I), ‘K’ ENDDO ENDIF c IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C ’, K(I), ‘K’ ENDDO ENDIF
Main Code c IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..FALSE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C’ ENDDO ENDIF c IF ((DOC.EQV..FALSE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, K(I), ‘K’ ENDDO ENDIF c IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C ’, K(I), ‘K’ ENDDO ENDIF
c PROGRAM CONVERTF IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I DO I = 1, NT READ(*,*) F(I) ENDDO WRITE(*,*) ‘Convert to C?’ READ(*,*) DOC WRITE(*,*) ‘Convert to K?’ READ(*,*) DOK DO I = 1, NT C(I) = (5./9.)*(F(I)-32.) ENDDO IF (DOK.EQV..TRUE.) THEN DO I = 1, NT K(I) = C(I) ENDDO ENDIF IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..FALSE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C’ ENDDO ENDIF c IF ((DOC.EQV..FALSE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, K(I), ‘K’ ENDDO ENDIF c IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C ’, K(I), ‘K’ ENDDO ENDIF STOP END
Program Start Options/Variable Declaration Main Code Program End c PROGRAM CONVERTF IMPLICIT NONE PARAMETER NT = 5 REAL F(NT) REAL K(NT) REAL C(NT) LOGICAL DOC LOGICAL DOK INTEGER I DO I = 1, NT READ(*,*) F(I) ENDDO WRITE(*,*) ‘Convert to C?’ READ(*,*) DOC WRITE(*,*) ‘Convert to K?’ READ(*,*) DOK DO I = 1, NT C(I) = (5./9.)*(F(I)-32.) ENDDO IF (DOK.EQV..TRUE.) THEN DO I = 1, NT K(I) = C(I) ENDDO ENDIF IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..FALSE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C’ ENDDO ENDIF c IF ((DOC.EQV..FALSE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, K(I), ‘K’ ENDDO ENDIF c IF ((DOC.EQV..TRUE.).AND. (DOK.EQV..TRUE.)) THEN DO I = 1, NT WRITE(*,*) F(I), ‘F = ‘, C(I), ‘C ’, K(I), ‘K’ ENDDO ENDIF STOP END
Compilation Compilation is performed in the terminal: Syntax: -o
Compilation Compilation is performed in the terminal: Syntax: -o Depends on system: f77, g77, pgf77, etc.
Compilation Compilation is performed in the terminal: Syntax: -o We wish to create an object that is an executable file with the following name
Compilation Compilation is performed in the terminal: Syntax: -o Use this *.f file to compile the executable
Compilation Compilation is performed in the terminal: Syntax: -o Also depends on compiler. Some frequent options: Mextend – allows you to go over column 70 in the code Mbounds – if you attempt to reference an array index out of bounds, will notify you Mbyteswapio – some formats require a byte-swap
Compilation Compilation is performed in the terminal: Syntax: -o pgf77 –o CONVERTF.exe CONVERTF.f