- The source codes are main.py experiment.py config.py solvers.py
- The experiment.py : Three classes of Receptors, Proteins, and Configs are saved in the experiment.py file. In order to save the file name and path for the receptor and ligand directory, so that when calling vina to score, provide the file path parameter.
- The config.py : if you don't have the config files about where is the pocket of the receptor.You need to use cavity to compute the pocket files,this function may helpful for you.
- The solvers.py : The class rUCB is a implementation of the algorithm which we proposed.
- The file called vina can only execute in linux. if you want to execute on macos, you should download the corresponding version and repace it. Also you maybe need gave the vina execute permission use
chmod u+x vina
- To run main.py, you should prepare ligands and receptor files and the same name config files as receptor files. Place them in the path of ./conf,./ligand,./receptor,the symbol './' represents the current directory. And delete the existing file which were as examples before.
- My running example
python main.py -m 20 -T 56958
(select the first 20 ligands and the total docking time is 56958)- if you want to change the coefficient of the formula rUCB you can delete the line 66 in solvers.py and
python main.py -m 20 -T 56958 -u <float>
- After excecuting the codes, five results file will be created.
- rUCB_process.csv records the docking process and predicted Ka (calculated from scores).
- rUCB_initialization.txt records every ligand was docked once.
- rUCB_loop.txt records every ligand was docked times during loop.
- rUCB_order.txt records ligands docking sequence.
- rUCB_result.txt records every ligand's <Ka>.
- Reference: Bin Chong, Yingguang Yang, Zi-Le Wang, Han Xing and Zhirong Liu,Reinforcement Learning to Boost Molecular Docking upon Protein Conformational Ensemble.
846468230/Variant-UCB-algorithm
Reinforcement Learning to Boost Molecular Docking upon Protein Conformational Ensemble.
Python