Skip to content

Generate Kinetic Energy Operators (KEO) with curvilinear coordinates (z-matrix, polyspherical ...)

License

Notifications You must be signed in to change notification settings

lauvergn/Tnum-Tana

Repository files navigation

Tnum-Tana

Tnum-Tana is a Fortran library which deals with kinetic energy operators (KEO) and coordinates transformations. Maore precisely, this library enables one to compute :

  • the KEO or the metric tensor (covariant, g, or contravariant, G, components) using curvilinear coordinates for a molecular system of any size, without build in limitation.
  • Coordinates transformations from curvilinear coordinates to Cartesian coordinates or the reverse (when possible).
  1. The Tnum code enables to calculate numerically and exactly the KEO, g and G. With respect to similar approaches or codes, it is highly flexible in terms coordinates. One can add several coordinates transformations (no limitation) between the coordinates used for the dynamics (Qdyn or Qact) and the Cartesian coordinates (body-fixed). The exactness is guaranteed by the automatic differentiation procedures used for all coordinate transformations (except one or two).
  2. The Tana code enables to compute the analitical expression of the KEO and G with polysherical coordinates. It has no limitation in terms of the molecular size of the number of dregrees of freedom.

Tnum and Tana share the same imput file.

1) Installation

1a) Installation with a makefile

The installation is simple with a makefile. However, we do not have an fully automatic procedure (like configure ...). The program uses some Fortran 2003 features. Therefore, the compilers gfortran or ifort need to be recent.

For instance, main executables can be built:

# Main Tnum/Tana executable:
make Tnum
# Example of Fortran driver:
make Tnum_FDriver
# another smplier example of Fortran driver (cartesian to curvilinear transformation):
make X2Q
# Example of c driver:
make Tnum_cDriver
# Special main Tnum/Tana executable for MCTDH:
make Tnum_MCTDH
# Special main Tnum/Tana executable for MidasCpp:
make Tnum_MidasCpp

If one to build the TnumTana library:

make lib

Furthermore, one can add options:

make FC=ifort OMP=0 OPT=0 LAPACK=0 INT=4
  # FC=ifort to change the compiller to ifort
  # OMP=0/1 to turn off/on the OpenMP fortran flag.
  # OPT=0/1 to turn off/on the fortran optimization.
  # LAPACK=0/1 to turn off/on the lapack use
  # INT=4/8 to change the default integer

The library, libTnum-Tana_dnSVM_XXX_oppY_ompZ_lapackW_intV.a is created in the main directory. Remarks :

  • XXX is the compiller (gfortran, ifort ...)
  • Y is 0 or 1 (opt0 / opt1: compiler optimization)
  • Z is 0 or 1 (omp0 / omp1: whitout/with OpenMP)
  • W is 0 or 1 (lapack0 / lapack1: whitout/with lapack)
  • V is 4 or 8 (int4 / int8)

If needed, the .mod files are in the obj/obj_XXX_oppY_ompZ_lapackW_intV directory.

1b) Installation with fpm

fpm is a Fortran Package Manager (see https://fpm.fortran-lang.org). If it is not done yet, the external library directory links (in Ext_lib directory) need to be set by:

make fpm

Then to build

fpm build

To run some tests:

fpm run cDriver --< TESTS/exa_TnumDriver/dat_driver0
fpm run cDriver --< TESTS/exa_TnumDriver/dat_driver1

fpm run X2Q --< TESTS/exa_TnumDriver/dat_driver0
fpm run X2Q --< TESTS/exa_TnumDriver/dat_driver1

fpm run FDriver -- -i TESTS/exa_TnumDriver/dat_driver0
fpm run FDriver -- -i TESTS/exa_TnumDriver/dat_driver1

fpm run Tnum90          --< TESTS/exa_TnumDriver/dat_driver0
fpm run Tnum90_MidasCpp --< TESTS/exa_TnumDriver/dat_driver0
fpm run Tnum90_MCTDH    --< TESTS/exa_TnumDriver/dat_driver0

2) Documentation

See Tnum-Tana Wiki (uncomplete)

About

Generate Kinetic Energy Operators (KEO) with curvilinear coordinates (z-matrix, polyspherical ...)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published