A Python tool for automating microsolvation and geometry optimization using xTB.
Project description
Complax is a Python tool designed to position solvent molecules (provided as .xyz files) around a user-specified atom of another molecule, also supplied in .xyz format.
It was primarily developed for the microsolvation of small organic molecules, but it can also be applied to other molecular systems, for instance as a starting point for further modeling or optimization studies.
After the stochastic solvent placement, the program performs a geometry optimization using the semiempirical xTB method 1.
Optionally, the user can request an evaluation of the solvation effect in terms of potential energy differences and perform a stochastic sampling to find the most stable solvent configurations.
Installation
Install via PyPI
You can install COMPLAX directly from PyPI using pip:
pip install complax
Installation from GitHub:
Manually cloning the repository:
git clone https://github.com/Fedelau/complax.git
Then adding the location of the Complax directory to the PYTHONPATH environment variable.
Requirements
- Python 3.8 or higher
- External dependencies:
numpyasecoloramatqdmtabulate
Tested with Python 3.11.2
All dependencies can be installed with:
pip install -r requirements.txt
External software
COMPLAX interfaces with the external program xTB, which must be installed and accessible from your system’s PATH. See https://github.com/grimme-lab/xtb for installation instructions.
xTB is developed by the Grimme group and distributed under the Creative Commons Attribution-ShareAlike 4.0 International License (CC BY-SA 4.0).
Quick Start
Example input files are provided in the examples/ folder. (If you installed complax via pip, you can access these files by cloning the repository or downloading them directly from the GitHub examples directory).
This example shows how to position 3 tetrahydrofuran molecules (thf.xyz) around a lithium atom in methyllithium (meli.xyz).
-
First, identify the indices of the atoms to be used:
- Lithium atom in
meli.xyz: 5 - Oxygen atom in
thf.xyz: 2
- Lithium atom in
-
Then run the command:
python3 complax.py meli.xyz thf.xyz -a 5 2 -c 3
- What happens next?
- The program places the molecules avoiding steric clashes.
- Then, a geometry optimization is performed using xTB for each for each incremental number of solvent molecules.
- After optimization, the final geometry is saved in the
/outplaxdirectory namedcomplax_struct_{n}solvent_{s}.xtbopt.xyz, where{n}is the number of solvent molecules and{s}is the structure index.
Commandline Usage
python3 complax.py molecule.xyz solvent.xyz [options]
Mandatory arguments:
-a (MOLECULE ATOM) (SOLVENT ATOM) : Atom numbers of molecule and solvent. Format: (MOLECULE ATOM) (SOLVENT ATOM) using 1-based indexing.
-c INT : Number of solvent copies (solvent.xyz) to be placed around the selected atom of the solute. Default is 1.
Optional arguments:
-t FLOAT : Target distance from MOLECULE ATOM, in Ångstrom. Default is 2.0 Ångstrom.
--alpb SOLVENT : Analytical linearized Poisson-Boltzman (ALPB) model, available solvents on xTB are acetone, acetonitrile, aniline, benzaldehyde, benzene, ch2cl2, chcl3, cs2, dioxane, dmf, dmso, ether, ethylacetate, furane, hexandecane, hexane, methanol, nitromethane, octanol, woctanol, phenol, toluene, thf, water. [2]
--gbsa SOLVENT : The generalized Born solvation model (GBSA) is a simplified version of ALPB. Available solvents are acetone, acetonitrile, benzene (only GFN1-xTB), CH2Cl2, CHCl3, CS2, DMF (only GFN2-xTB), DMSO, ether, H2O, methanol, n-hexane (only GFN2-xTB), THF and toluene. [2]
-p INT : Number of parallel processes. Default=1. During the initial optimization, the program will use the specified number of parallel processes. For subsequent optimizations (one for each solvent configuration), it will automatically launch as many parallel calculations as the number of solvent molecules selected.
--lev LEVEL : Level of theory for the optimization. Default is --gfn2. Other options include --gfn0, --gfn1, --gfnff.
--chrg INT : Molecular charge. Default is 0.
-u, --uhf INT : Number of unpaired electrons. Default is 1.
--maxtries INT : Maximum number of attempts to place each solvent molecule without overlaps. If placement remains difficult, it is likely due to steric hindrance between the molecules. Default is 1000.
--nstruct INT : Number of stochastic, non-overlapping starting structures to generate and optimize. Ideal for exploring the conformational space of the solvated complex.
--keep-best INT : Filters the output to keep only the N lowest-energy optimized structures for each solvent configuration, automatically deleting the less stable ones.
--solvfx : If specified, evaluates the effect of solvation in terms of potential energy differences among systems with an increasing number of solvent molecules.
Tips and Troubleshooting
-
Stochastic Sampling: For complex solvent environments, use
--nstruct 10 --keep-best 3. COMPLAX will generate 10 different random orientations of the solvent cluster, optimize all of them, and retain only the 3 most thermodynamically stable configurations, saving you a massive amount of manual sorting. -
Pre-optimized geometries: The idea is to use an optimized geometry from a DFT calculations. COMPLAX keeps the internal geometry of both solute and solvent constraints, maintaining its original interatomic distances, and finding the best solvent molecules coordination.
-
Visual Check: COMPLAX positions solvent molecules randomly around the selected atom, avoiding overlaps and taking into account only the distance between the chosen atoms. Sometimes the molecules may not be positioned exactly as expected. It is recommended to check the result visually to ensure it is correct.
-
Better luck next time!: If the positioning is not satisfactory, it is worth running the program again to obtain a better configuration.
-
Important: COMPLAX writes output files in the outplax folder. If you want to keep multiple results, move the files out of outplax before running a new calculation, otherwise the previous files will be overwritten and lost.
Authors
Federica Lauria, University of Turin, Torino, Italy
Andrea Maranzana, University of Turin, Torino, Italy
References
[1] C. Bannwarth, E. Caldeweyher, S. Ehlert, A. Hansen, P. Pracht, J. Seibert, S. Spicher, S. Grimme WIREs Comput. Mol. Sci., 2020, 11, e01493. DOI: 10.1002/wcms.1493
[2] S. Ehlert, M. Stahn, S. Spicher, S. Grimme, J. Chem. Theory Comput., 2021, 17, 4250-4261 DOI: 10.1021/acs.jctc.1c00471
License
Complax is licensed under the MIT License.
See the LICENSE file for the full text.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file complax-1.1.0.tar.gz.
File metadata
- Download URL: complax-1.1.0.tar.gz
- Upload date:
- Size: 15.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8ccb02a0eeb9d818100cb6ecf281e3890a6df5120cc72325a8f1f433fcef1f81
|
|
| MD5 |
cd78a8b854b4c83d58f0842e70e059cc
|
|
| BLAKE2b-256 |
596155e8fc68c11f04aec553c1588137c92e5b6ff27fcbc08031b28353db8b98
|
File details
Details for the file complax-1.1.0-py3-none-any.whl.
File metadata
- Download URL: complax-1.1.0-py3-none-any.whl
- Upload date:
- Size: 11.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b3aeb7182debe27f03631f84e7d11d673b81117e9dcd7aa6642812de3fb2566c
|
|
| MD5 |
55056fc464af333cedcb875704cfd909
|
|
| BLAKE2b-256 |
5a21194ab2dcc160861f0c57c2ee9ac5303b62435ea97b182a1877b109308234
|