Skip to content

MachineLearningLifeScience/poli

Folders and files

NameName
Last commit message
Last commit date

Latest commit

9270292 · Mar 10, 2025
Nov 7, 2024
Dec 27, 2023
Feb 2, 2025
Mar 10, 2025
Oct 28, 2024
Jul 29, 2024
Feb 10, 2025
Aug 7, 2024
Nov 1, 2023
Aug 20, 2023
Nov 14, 2024
Oct 1, 2024
Feb 10, 2025
Aug 7, 2024
Jun 17, 2024
Feb 10, 2025
Feb 10, 2025

Repository files navigation

poli 🧪, a library for discrete objective functions

poli base (dev, conda, python 3.9) Link to documentation

poli is a library of discrete objective functions for benchmarking optimization algorithms.

Black boxes

Black box References Tests
Toy continuous functions (e.g. Ackley, Hartmann...) (Al-Roomi 2015), (Surjanovic & Bingham 2013) poli base (dev, conda, python 3.9)
Ehrlich functions (Stanton et al. 2024) poli base (dev, conda, python 3.9)
PMO/GuacaMol benchmark (Brown et al. 2019), (Gao et al. 2022), (Huang et al. 2021) poli tdc (dev, conda, python 3.9)
Dockstring (García-Ortegón et al. 2022) poli dockstring (dev, conda, python 3.9)
Rosetta Energy (Chaudhury et al. 2010) poli rosetta (conda, py3.9)
RaSP (Blaabjerg et al. 2023) poli rasp (conda, py3.9)
FoldX stability and SASA (Schymkowitz et al. 2005) -

Features

  • 🔲 isolation of black box function calls inside conda environments. Don't worry about clashes w. black box requirements, poli will create the relevant conda environments for you.
  • 🗒️ logging each black box call using observers.
  • A numpy interface. Inputs are np.arrays of strings, outputs are np.arrays of floats.
  • SMILES and SELFIES support for small molecule manipulation.

Getting started

To install poli, we recommend creating a fresh conda environment

conda create -n poli-base python=3.9
conda activate poli-base
pip install git+https://github.com/MachineLearningLifeScience/poli.git@dev

To check if everything went well, you can run

$ python -c "from poli import create"

An example: dockstring

Open the minimal example in Colab

In this next example, we estimate the docking score of the example provided in dockstring:

import numpy as np
from poli import objective_factory

problem = objective_factory.create(
    name="dockstring",
    target_name="drd2"
)
f, x0 = problem.black_box, problem.x0
y0 = f(x0)

# x0: [['C' 'C' '1' '=' 'C' '(' 'C', ...]] (i.e. Risperidone's SMILES)
# y0: 11.9
print(x0, y0)

Cite us and other relevant work

If you use certain black boxes, we expect you to cite the relevant work. Check inside the documentation of each black box for the relevant references.

Where can I find the documentation?

The main documentation site is hosted as a GitHub page here: https://machinelearninglifescience.github.io/poli-docs/

Building the documentation locally

If you install the requirements-dev.txt via

pip install -r requirements-dev.txt

then you will have access to sphinx. You should be able to build the documentation by going to the docs folder and building it:

cd docs/
make html

Afterwards, you can enter the build folder and open index.html.