List of Fortran modules which contain utilities for codes. All modules contain a testing unit.
It has been tested with:
- gfortran (14.1.0_2 on macos, 12 on linux)
- ifx/ifort (2023 on linux)
- nagor (7.1 on linux)
To build the library, libQD_gfortran_opt1_lapack1_omp1.a, with the default options (OPt=1, OMP=1, LAPACK=1, INT=4)
make lib
It creates a library with the folowing name: libQD_XXX_optW_lapackX_ompY_intZ.a with XXX, the compiler name (like gfortran), W, X, Y the value O or 1 and Z the value 4 or 8. For instance, the default library is: libQD_gfortran_opt1_lapack1_omp1_int4.a The module file (.mod) are in the OBJ/obj__XXX_optW_lapackX_ompY_intZ directory.
Two options to clean:
make clean
Remove some files, but keep the libraries, libQD_XXX_optW_lapackX_ompY_intZ.a
make cleanall
Remove all files
To test the module, in TESTS directory, run
./run_tests.sh
The tests are running with gfortran and several option combinations:
- OPT=1 or 0: compilation with optimization or without optimization
- OMP=1 or 0: with or without openmp
- LAPACK=1 or 0: with or without blas and lapack libraries
- INT=4 or 8: change the integer kind default compilation option
The file, ALL_Tests.log, contains a summary of all the tests.
To build the library, libQDUtilLib.a, with the Lapack (LAPACK=1)
fpm build
The library is in build/gfortran_xxxx/QDUtilLib directory. To remove Lapack library, the fpm.toml file must be edited.
Two options to clean:
fpm clean
Remove the build directory.
To test the module:
fpm test | grep TESTING | grep Number
To run an example:
fpm run AppQDLib
If you want to use it with fpm, you have to add a dependency in your own the fpm.toml file:
[dependencies]
QDUtilLib = { git = "https://github.com/lauvergn/QDUtilLib" }
If the QDUtil library is build with make, you have to:
- compile your code (such xxx.f90) with the QDUtil module files (.mod files). Those files are in the OBJ/obj_XXX_optW_lapackX_ompY_intZ directory. For instance, with gfortran, OpenMP, lapack and integer kind=4:
gfortan -c xxx.f90 -fopenmp -IOBJ/libQD_gfortran_opt0_omp1_lapack1_int4
- link with libQD_XXX_optW_lapackX_ompY_intZ.a library
gfortran ... libQD_gfortran_opt0_omp1_int4.a -llapack -lblas
This module contains:
- kind definitions from the intrinsinc ISO_FORTRAN_ENV module
- Rkind: default real kind (normaly real64)
- Rk4, Rk8, Rk16 for real32, real64, real128
- Ikind: default integer kind (usualy int32)
- ILkind: default long integer kind (usualy int64)
- Ik4, Ik8 for int32, int64
- Some real (kind=Rkind) numbers : ZERO to TWELVE, HALF, HUNDRED,ONETENTH ..., PI
- Some complexe (kind=Rkind) numbers : EYE (i), CZERO, CONE, CHALF
- out_unit and in_unit: the standard output and input units from the intrinsinc ISO_FORTRAN_ENV module
- print_level: level of printing: 0 minimal, 1 default, 2 large, -1 nothing To change print_level (prtlev is an integer):
CALL set_print_level(prtlev=0)
This module contains functions and subroutines to manipulate character string (character(len=)):
- Functions to change to upper to lowercase or the reverse: TO_lowercase, TO_uppercase
- Functions to convert numbers (integer, real, complex, Frac, logical) in string: TO_string All kinds defined in NumParameters module and logical type are possible For real and comlex convertions, an optional format (Rformat) can be given. It can work with table of dimension 1.
- Function to read a line from a file define with its unit: Read_line
- Function to check is a string is empty: string_IS_empty
- Concatenation (//) between string and integer, real, complex, and logical (and the reverse)
- Examples:
character (len=:), allocatable :: str
str = TO_string(1) ! => "1"
str = TO_string(1.0) ! => "1."
str = TO_string(EYE) ! => "(0.,1.)"
str = TO_string(.FALSE.) ! => "F"
str = TO_string([1,3,-1]) ! => "1 3 -1"
str = 'coucou' // 1. ! => "coucou1."
str = TO_lowercase("AbC") ! => "abc"
str = TO_uppercase("aBc") ! => "ABC"
This module contains functions and subroutines to manipulate fractions. All functions are elemental (except TO_string(frac)). Therefore, one can use those functions with table of fractions.
- A type: Frac_t, which contains the numerator and denominator When the fraction is negative, the numerator has the minus sign. When the denominator is 0, the fraction is simplified as 1/0.
- The operators (+, -, *, /, **, ==, >, <, <=, >=, /=) and the affectation (=) are orverloaded.
- When Frac_t is used for initialization and after numerical operations, the fraction is always reduced (with the Greatest common divisor).
- One can test if a fraction is an integer with: frac_IS_integer(Frac)
- A fraction can be exported to:
- to string: TO_string(frac)
- to real (with the default kind=Rkind): TO_real(frac)
- The affectation can be done as follows:
- Frac2 = Frac_t(3,-6) ! stored as -1/2
- Frac2 = Frac1
- Frac2 = Int1
- Frac2 = '1/4' ! using a string of characters
- where Frac1, Frac2 are fraction, Int1 is an integer
- Examples:
TYPE(Frac_t) :: Frac1, Frac2
TYPE(Frac_t), allocatable :: tab_Frac(:)
Frac1 = '1/-2' ! use the conversion from string to Frac_t
write(*,*) 'Frac1: ',TO_String(Frac1) ! it give "Frac1: -1/2"
Frac2 = -2*Frac1 ! here the result is one and it is simplified
write(*,*) 'Frac2: ',TO_String(Frac2) ! it give "Frac2: 1"
Frac2 = Frac1**3
write(*,*) 'Frac2: ',TO_String(Frac2) ! it give "Frac2: -1/8"
tab_Frac = Frac_t(1,[2,3,4])
write(*,*) 'tab_Frac: ',(TO_String(tab_Frac(i)) // ' ',i=1,size(tab_Frac)) ! it give "tab_Frac: 1/2 1/3 1/4 "
This module contains public subroutines to read and write real and complex (kind=Rkind) vectors and matrices:
- Subroutines to read a matrix from a file: Read_Mat or Read_Vec
All real kinds, all complexe kinds and one integer kind from NumParameters module are possible
Read_Mat(Mat,nio,nbcol,err) or Read_Vec(Vec,nio,nbcol,err)
- Mat or Vec: the matrice or the Vector to be readed. Mat or Vec have to be allocated
- nio: the file unit
- nbcol: the number of columns to be readed per block. If the number of columns of Mat or Vec is larger than nbcol, then several blocks are readed
- err: integer to catch error (err=0 => no error)
- Subroutines to write a matrix to a file or string: Write_Mat or Write_Vec
All real and complexe kinds from NumParameters module are possible. For complex number, it is not possible to write into a string.
Write_Mat(Mat,nio,nbcol,Rformat,info,iprint) or Write_Mat(Mat,string,nbcol,Rformat,info,iprint) or Write_Vec(Vec,nio,nbcol,Rformat,info,iprint) or Write_Vec(Vec,string,nbcol,Rformat,info,iprint)
- Mat or Vec: the matrice or the Vector to be printed. Mat or Vec have to be allocated
- nio: the file unit
- string: a character string with len long enough. It is better an allocatable character length [character (len=:), allocatable :: string]
- nbcol: the number of columns to be printed per block. If the number of columns of Mat or Vec is larger than nbcol, then several blocks are printed
- Rformat: (optional) format for real and complex. If Rformat is not present, then the default formats (RMatIO_format for real and CMatIO_format for complex) are used.
- iprint: (optional) the Mat or Vec are printed if iprint is not present or if iprint=0
- The module contains the two default formats which are public:
- RMatIO_format: (f18.10)
- CMatIO_format: '(',f15.7,',',f15.7,')'
This module contains public functions and subroutines to perform some lienar algebra operations with the default real kind (kind=Rkind). It can use some LAPACK subroutines:
- Function to compute the inverse of a matrix: inv_OF_Mat_TO
- Function to solve a linear system of equation: LinearSys_Solve
- Function to compute the determinant of a matrix: Det_OF
- Function to initialyze a real identity matrix: Identity_Mat
- Gram-Schmidt Orthonormaization (real or complex): Ortho_GramSchmidt
This module contains public subroutines to digonlize a matrix with the default real kind (kind=Rkind). It can use some LAPACK subroutines:
- Subroutine to diagnalize a real matrix: diagonalization