/MolFFSim

A C++ implementation of an OFDFT based molecular force field model.

Primary LanguageC++GNU General Public License v3.0GPL-3.0

Static Badge Static Badge Static Badge
Static Badge Static Badge Static Badge
Static Badge Static Badge
Static Badge DOI

MolFFSim

MolFFSim is an open-source program coded in C++ specifically designed for performing point-energy calculations of systems with one or many molecules, as well as optimizing their geometry by minimizing the energy. In the latter, all molecules are treated as rigid objects. The theoretical framework for the calculations in this program is rooted in the Orbital Free Density Functional Theory (OFDFT) approach, as detailed in the following references:

Exact values of gradients and Hessians of interaction energies are obtained using algorithmic differentiation via autodiff. Currently, only forward mode automatic differentiation is supported. All the linear algebra necessary for calculations within this program is handled using Eigen. Parallelization is achieved using OpenMP. All non-linear minimizations problems, related to both kinds of geometry optimizations supported in this program, are handled through libLBFGS.

Compiling and installing

In principle, any C++ compiler that supports C++17 can compile this program. However, thus far, it has been tested only with GCC and Clang compilers. Before proceeding with the compilation and installation, ensure that CMake and OpenMP are installed, along with the C++ libraries Eigen, autodiff and libLBFGS. Detailed instructions on compiling and installing these libraries are available on their respective GitHub/GitLab repositories.

Once these prerequisites are fulfilled, follow these steps to compile and install the program:

cd Downloads
git clone https://github.com/JoseRodriguezRomero/MolFFSim.git
cd MolFFSim
mkdir build && cd build
cmake ..
make && sudo make install

Running a simulation

After installing the program on your computer, conducting a point-energy calculation for a system is straightforward. Simply execute the command MolFFSim <input_file> in a Bash or Z shell.

Input files

To run this program without errors at least the name of an existing input file has to be provided. The name of the input file must always be provided as the first argument. Furthermore, the content of this input file must be formatted according to the rules described in this section. For clarity, two example of valid input files are provided with the source code.

The structure of an input files can be separated in three main parts, that we will now describe.

1. System Configuration

  • n_cores Specifies the number of CPU cores to be used.
  • system_charge Specifies the overall charge of the system.
  • is_periodic Indicates whether the system is periodic or not, with three boolean values representing periodicity along the x, y, and z axes respectively.
  • periodic_box_sizes Specifies the length of the sides of the periodic box (in Ångström), centered at the origin, along the x, y, and z axes.
  • atomic_basis Identifies the collection of basis functions used for atomic representations.
  • xc_coefficients Identifies the collection of exchange-correlation coefficients used.

2. Molecule List

The molecule list contains descriptions of individual molecules in the system. Each molecule is defined by its name followed by its atomic composition and coordinates.

  • BEGIN MOLECULE_LIST Marks the beginning of the molecule list section.
  • BEGIN MOLECULE <molecule_name> Marks the beginning of a molecule with its name.
  • Atomic symbols followed by their x, y, and z coordinates (in Ångström) define each atom within the molecule.
  • END MOLECULE Marks the end of a molecule's description.
  • END MOLECULE_LIST Marks the end of the molecule list section.

3. Molecular System Configuration

This part defines the configuration of the molecular system, including how individual molecules are positioned and whether they are printed or not.

  • BEGIN MOLECULAR_SYSTEM Marks the beginning of the molecular system configuration.
  • Each line describes a molecule within the system, including its name, print status, rotation type, and orientation parameters. For Euler angles the last three arguments describe the rotation angles, and for quaternions the last four arguments describe its w, x, y and z real and complex components. The first three numerical arguments correspond to the distance vector (in Ångström) at which the molecule is displaced.
  • END MOLECULAR_SYSTEM Marks the end of the molecular system configuration.

Point-energy calculations

By default, all calculations performed are point-energy calculations. This means that when invoking the MolFFSim executable in a console with just the input file's name, the calculation type is automatically assumed to be a point-energy calculation. This is equivalent to executing the command:

MolFFSim <input_file> point_energy

The output of this type of calculation provides both the total and interaction energies of the entire system, along with the coordinates and partial charges of the molecules. However, molecules marked with NO_PRINT in the MOLECULAR_SYSTEM section of the input file will be excluded from the output.

Point-energy and atom forces

Caution

This type of calculation is experimental, and with any of the predefined sets of exchange and correlation coefficients, the results obtained lack physical relevance.

By default, the forces acting on every atom in the system are not printed on point-energy calculations. To include them use the following command:

MolFFSim <input_file> point_energy_forces

Geometry optimization of a molecule

Caution

This type of calculation is experimental, and with any of the predefined sets of exchange and correlation coefficients, the results obtained lack physical relevance.

The second type of calculation supported in this program involves optimizing the intramolecular coordinates of a given molecule. For this type of calculation, the entire MOLECULAR_SYSTEM section of the input file can be omitted, and if present, the program simply ignores it. To run this type of calculation, use the following command:

MolFFSim <input_file> molec_geom_optim

In the output of this calculation, the Cartesian coordinates and partial charges of every atom of the molecule are printed. If more than one molecule is specified in the MOLECULE_LIST section of the input file, the optimized geometry of every molecule in the list is printed. The calculation of each molecule is independent of the others, making it embarrassingly parallelizable.

Geometry optimization of a system with two or more molecules

This program also supports system-wide geometry optimization for ensembles containing two or more molecules. In this mode, each molecule in the system is treated as a rigid object, with translations and rotations applied uniformly to their atoms. To initiate this calculation, use the following command:

MolFFSim <input_file> system_geom_optim

The output format of this calculation mirrors that of a point-energy calculation.

By default, all molecules in this calculation are moved and rotated in order to relax the system by minimizing its energy. To prevent a specific molecule from being moved and rotated, add the keyword FREEZE at the end of its row in the input file.

Additionally, for this type of calculations, a backup file is printed approximately every ten seconds, with two backup files generated sequentially. Each backup file is formatted identically to an input file, allowing geometry optimizations to be resumed from either one. This sequential writing ensures a continuous availability of valid backup files, even if the program is interrupted during the backup process.

LBFGS Settings

As previously mentioned, all non-linear optimization problems are managed using libLBFGS. This library allows for the adjustment of various algorithm parameters and the selection of different line search algorithms.

You can specify arbitrary values for these settings in the OPTIMIZER_SETTINGS section of the input file. This section is optional; if omitted, the default values will be used. Refer to input_sample_3.txt for these default settings.

For detailed information about each parameter, consult the libLBFGS documentation.

Automatic differentiation

To model the Mulliken charges of a molecular system, a fictitious self-energy functional is minimized. This functional mirrors the form of the functional used for modeling the system energy. Minimizing this problem simplifies to minimizing a quadratic function, thus solving a system of linear equations. The size of this system scales linearly with the number of atoms in the system.

To derive expressions for the gradient and Hessian, knowledge of the matrix inverse associated with the aforementioned minimization problem is required. Therefore, algorithmic differentiation is used, more specifically forward mode.

For the time being, reverse mode is not supported due to poor performance issues stemming from the system of linear equations that needs to be solve to determine the atomic polarization coefficients.

Atom centered basis functions

The program's core functionality revolves around determining energies and partial charges. These are computed based on the non-interacting ground state eigendensities of each atom in the system. These densities are approximated by a linear combination of s-type Gaussian basis functions centered at the atomic coordinates.

The electronic densities from ab initio calculations utilizing an Effective Core Potential (ECP) basis-set are approximated with three s-type Gaussian basis functions at each atomic site. In contrast, for electronic densities obtained from full electron basis-set calculations, nine basis functions are utilized, except for hydrogen and helium atoms, where only three basis functions suffice. The parameters governing these basis functions depend solely on the argument provided to atomic_basis in the input file.

For further details, please consult ATOMIC_BASIS/README.md.

Exchange and Correlation (XC) coefficients

The energy functional in this program comprises two distinct components:

  • A naïve model component, which relies on the electronic density derived from a Hartree product wave function. This model assumes that electrons "belonging" to different atoms behave independently, albeit contradicting the Pauli exclusion principle.
  • An exchange and correlation component, designed to rectify inaccuracies introduced by the naïve model in both the potential and kinetic energy distributions of the electrons.

Given the spherical symmetry of ground state eigendensities, exact solutions exist for the energy contributions of the naïve model. Moreover, fictitious electronic clouds, easily constructed via successive applications of differential operators, can be unambiguously mapped from non-interacting ground state eigendensities. Exact solutions also exist for integrals resembling a Coulomb potential using these fictitious electronic clouds.

Leveraging this understanding, the exchange and correlation functional is divided into four parts: two for electron-electron and electron-nuclei interactions, where the fictitious electron cloud exhibits spherical symmetry, and another two for electron-electron and electron-nuclei interactions, where the fictitious cloud has cylindrical symmetry. However, to fully parameterize the force field model due to different coefficients used for modeling the Mulliken charges, a total of eight fitting parameters are employed.

For further details, please consult XC_COEFFICIENTS/README.md.

Citing this program

If you find this program useful please consider citing the following sources, that explain the theory behind this program, with the following BibTeX entries:

@article{Romero2024a,
   author = {José Romero and Paulo Limão-Vieira and Kersti Hermansson and Michael Probst},
   doi = {10.1021/acs.jpca.3c06724},
   issn = {1089-5639},
   issue = {6},
   journal = {The Journal of Physical Chemistry A},
   month = {2},
   pages = {1163-1172},
   title = {A Simple Electron-Density Based Force Field Model for High-Energy Interactions between Atoms and Molecules},
   volume = {128},
   year = {2024},
}
@article{Romero2024b,
   author = {José Romero and Paulo Limão-Vieira and Thana Maihom and Kersti Hermansson and Michael Probst},
   doi = {10.1063/5.0210949},
   issn = {0021-9606},
   issue = {23},
   journal = {The Journal of Chemical Physics},
   month = {6},
   title = {A polarizable valence electron density based force field for high-energy interactions between atoms and molecules},
   volume = {160},
   year = {2024},
}