GFortran, the GNU Fortran compiler, is part of the GNU Compiler Collection (GCC) since 2005 (it was forked from G95 in January 2003), which is licensed under GPLv3+ with GCC Runtime Library Exception. In 2023, GFortran nearly implements all of the Fortran 2008 standard and partially Fortran 2018.
Since 2015 and GCC 5.1, a major version is published every year: the first stable 2022 version was therefore GFortran 12.1. Four subsequent minor versions are then published during the four next years (for example 11.2, 10.3, 9.4 and 8.5). It can be interesting to install several versions, the latest for bleeding edge features and older ones for their robustness. For example, it is not rare to see up to 10% variations in the CPU speed of your program depending on the GCC version, and the latest version is not always the fastest.
You will find here the basic information needed to install GFortran on Linux, macOS, FreeBSD and Windows systems. More details can be found at fortran-lang.
Just install with your package manager the GFortran package, named gfortran in Debian-based distributions (Ubuntu, Mint…) or gcc-fortran in RPM-based distributions (Fedora, Red Hat, CentOS, openSUSE…) and Arch-based (Arch Linux, Manjaro, EndeavourOS…) distributions.
If you use the conda package manager
% conda install conda-forge::gfortranIf you have installed Homebrew, install its GCC package:
% brew install gccIf you have conda, a gfortran package is available for macOS and Linux:
% conda install conda-forge::gfortranJust install the GCC package, for example for the latest GCC 12 release:
# pkg install gcc12There are several ways to install GFortran on Windows.
% conda install conda-forge::gfortranAn easy way is to use the Quickstart Fortran application.
If you use MSYS2, GFortran packages are available for the latest release. For example, for the UCRT64 environment, type:
$ pacman -S mingw-w64-ucrt-x86_64-gcc-fortranThe basic usage of GFortran is
gfortran [options] file...For example, if your project has a module and the main program, just type:
$ gfortran my_module.f90 my_main.f90The default executable is named a.out under Unix-like systems and a.exe under Windows systems.
You can use both GCC options and the GFortran specific options. For example, the default name of the executable can be changed by adding the -o GCC option:
$ gfortran my_module.f90 my_main.f90 -o my_execIn this section, we present only a selection of useful options, as there are hundreds of them!
You can use the GCC debugging options:
-g produces debugging information in the operating system’s native format.-p and -pg generate extra code to write profile information suitable for the analysis program prof (-p) or gprof (-pg).You can use also the Fortran specific options:
-fcheck=all to enable all run-time test (array bounds, memory allocation, pointers…).-ffpe-trap= to enable floating point exception traps ( invalid, zero, overflow, underflow, inexact and denormal),The first three exceptions (‘invalid’, ‘zero’, and ‘overflow’) often indicate serious errors, and unless the program has provisions for dealing with these exceptions, enabling traps for these three exceptions is probably a good idea.-std specifies the standard to which the program is expected to conform, which may be one of f95, f2003, f2008, f2018, f2023, gnu (default), or legacy. For example: -std=f2008 for the Fortran 2008 standard.-Wall enables commonly used warning options.-Wextra enables some warning options for usages of language features which may be problematic.GCC provides the link options -static-libgfortran and -static-libquadmath to force the use of the static versions.
You can use the GCC optimization options:
-O0 (default) reduces compilation time and make debugging produce the expected results.-O1 to reduce code size and execution time, without performing any optimizations that take a great deal of compilation time.-O2 to optimize even more. GCC performs nearly all supported optimizations that do not involve a space-speed tradeoff.-O3 to optimize yet more.-Ofast enables all -O3 optimizations but also optimizations that are not valid for all standard-compliant programs.-Og to optimize debugging experience. It should be the optimization level of choice for the standard edit-compile-debug cycle.-Os to optimize for size. It enables all -O2 optimizations except those that often increase code size.-Oz to optimize aggressively for size rather than speed.GCC offers also machine-specific options starting with -m, especially:
-march=cpu-type generates instructions for the machine type cpu-type. -march=native enables all instruction subsets supported by the local machine. Further details in the GCC doc.-mtune=native produces code optimized for the local machine.Parallel computation is achieved by exploiting different aspects of modern architectures: from vectorization instructions, multi-threading, message passing and offloading to GPU devices. The followings enable handling one or more of these aspects:
The first level of parallelism with vectorization can be achieved by the combination of -O3 and -march=native which enables the compiler to exploit the local machine vector instructions (SSE, AVX, AVX2, AVX512, etc):
$ gfortran -O3 -march=nativeProgrammer-instructed vectorization can be achieved with OpenSIMD (part of OpenMP), for details see this OpenMP API Specification page.
Use the option -fopenmp. You can specify the number of threads using the environment variable OMP_NUM_THREADS, for example in a UNIX-like system type that command before running the executable:
$ export OMP_NUM_THREADS=4You can also spawn threads dynamically at run time in two different ways:
within the directives
use omp_lib
!$omp paralel do num_threads(num_threads)
... parallel code
!$omp end parallel doAs a routine call
use omp_lib
call omp_set_num_threads(num_threads)
!$omp parallel do
... parallel code
!$omp end parallel doOpenACC support was introduced in GCC 5. Depending on the target GPU architecture (Intel, Nvidia, AMD) different offloading backends are available, read here. For Nvidia PTX offloading, you need to install the following backend:
$ sudo apt install gcc-offload-nvptxNow, you can compile your code with the flag -fopenacc and test
!$acc parallel loop
do i = 1,n
... parallel code offloaded to GPU
end doGFortran does not natively support coarrays (Fortran 2008) and the parallel programming features introduced by the 2018 standard. You need to install the OpenCoarrays software.
For example, in an Ubuntu Linux distribution type:
$ sudo apt install libcoarrays-dev libcoarrays-mpich-dev
$ git clone https://github.com/sourceryinstitute/OpenCoarrays.git
$ cd OpenCoarrays
$ ./install.shand accept the installation of the MPICH library (although OpenCoarrays can also work with Open MPI).
You need to define the environment variables in your terminal (you can add it in your ~/.bash_profile):
$ source /home/my_login/OpenCoarrays/prerequisites/installations/opencoarrays/2.9.2/setup.shhere for the 2.9.2 version.
Use the command caf instead of gfortran to compile your program, and cafrun -n to run it with the number of images you want:
$ caf main.f90
$ cafrun -n 4 ./a.out If you want to build OpenMPI locally follow these instructions.
You can also install a pre-built package (linux or WSL):
$ sudo apt-get update
$ sudo apt-get install openmpi-binThen include the header file in your Fortran program/modules:
include 'mpif.h' ! To be included in files calling MPI functions
call MPI_INIT(err) ! should be invoked just once at the beginning of your main program
... code ! N instances of your program with specific communication steps
call MPI_FINALIZE(err) ! should be invoked just once at the end of your main programCompile and run the code:
$ mpif90 main.f90 -o main.exe
$ mpirun -np 4 main.exeThis is a useful link with a concise Hello world for starters.
GFortran is free software developed by volunteer users and any help is welcome.
You can report bugs in the GCC Bugzilla system: first, update your major GFortran version to its latest release, then search if the bug was already reported, then file the bug. You can also use the GFortran mailing list fortran@gcc.gnu.org if you are uncertain on how to handle Bugzilla.
Anyone interested in joining the GFortran developers team should send an email to gfortran@gcc.gnu.org or jvdelisle@gcc.gnu.org to receive an invitation to join the GFortran Mattermost workspace (now hosted by the Oregon State University Open Source Lab), which was created in December 2022 to facilitate chat, patch discussions, mentoring new folks, etc. See also that January 2023 message by Paul Richard Thomas to comp.lang.fortran. And that 2008 message by Tobias Burnus to comp.lang.fortran contains advice that are still pertinent.
See the Quickstart Guide to Hacking Gfortran. The GNU Fortran Compiler Internals documents the internals of GFortran.
You can also contribute to GFortran at the Google Summer of Code: https://gcc.gnu.org/wiki/SummerOfCode.
You can read the GCC sources by cloning that read-only git repository:
$ git clone git://gcc.gnu.org/git/gcc.gitor if you have firewall problems:
$ git clone https://gcc.gnu.org/git/gcc.gitConcerning Fortran, the sub-directories are gcc/fortran, libgfortran, gcc/testsuite/gfortran.dg and gcc/testsuite/gfortran.fortran-torture.
To build GCC, you also need to install the libraries GMP, MPFR and MPC.
Unofficial GFortran 32-bit and 64-bit binary packages based on the current development source code can be found on http://gcc.gnu.org/wiki/GFortranBinaries. For example, to install the latest 64-bit nightly binary in a Linux system, download and install the latest GCC trunk build:
$ cd /tmp
$ wget https://gfortran.meteodat.ch/download/x86_64/nightlies/gcc-trunk.tar.xz
$ cd /opt
$ sudo tar -xJf /tmp/gcc-trunk.tar.xz
$ /opt/gcc-trunk/bin/gfortran --version
GNU Fortran (GCC) 13.0.1 20230227 (experimental) [master r13-6353-g529e03b988]Then set LD_LIBRARY_PATH and PATH: see that GFortran wiki page for details on bash and csh/tcsh. For zsh, this will work for both the x86_64 and i386 versions:
# Determine platform
ARCH=`uname -m`
# GFortran
export PATH=/opt/gcc-trunk/bin:${PATH}
if [[ ${ARCH} == "x86_64" ]]; then
    LIB64="64"
fi
if [ -z "$LD_LIBRARY_PATH" ]; then
  LD_LIBRARY_PATH="/opt/gcc-trunk/lib${LIB64}"
else
  LD_LIBRARY_PATH="/opt/gcc-trunk/lib${LIB64}:$LD_LIBRARY_PATH"
fi
export LD_LIBRARY_PATH