Molecule Energy Estimator (RuCode 5.0)
This project started off from me participating in the RuCode 5.0 hackathon and then led me to write a research report on the topic. Initially, the problem and data were provided by Artificial Intelligence Research Institute.
The chemical and physical properties of a molecule are determined not only by its structural formula, but also by its conformation – positions of atoms in 3d space. An important task when working with molecules is the estimation of their energies. Currently avaliable approxiamtion methods, such as DFT, have high accuracy but are computationally expensive.
One proven approach for predicting conformational energies and other chemical and physical properties is the use of GNNs (Graphed Neural Networks) [Schrödinger network, Directional Message Passing for Molecular Graphs].
In this competition, you need to learn how to predict energy from a three-dimensional representation of a molecule. You will be given a set of conformations for a subsample of molecules from the MOSES dataset. For some of the conformations, the energy value will also be given.
Solution
The idea of the initial solution was as follows:
- Energy has two parts: kinetic and potential energy. The kinetic energy will be assumed to be zero because there is no data on molecule is moving. The potential energy is the sum of the potential energies of all the bonds in the molecule. Or, in other words, the potential energy is the sum of function of these two atoms and the distance between them.
-
Energy of a bond is defined in small ranges. So, I made an assumption that it is constant for any two types of atoms.
-
To determine if there is a bond, I checked if the distance between two atoms is smaller than the longest bond length possible.
-
Now, the number of each bond can be passed to a neural network to determine the energy of the molecule. The assumption is that, the neural network will determine the energy of each bond and use that to predict the energy of the molecule.
This is the solution I used in the competition and got to the top 7th place. You can listen to my solution on the livestream (only in russian).
After the competition, I did deeper research into the problem and found that the problem is not simple. The problem is that the energy of a bond is not a constant. Actually, bonds has multiple descrete energy levels, which are determined by the distance between two atoms.
So, I used another way of determining the bond energy level with a constraint satisfaction solver. I proposed new task to my team and they we solved it. Passing the bond energy levels to the neural network gave better results.