Operations Research Framework for building metaheuristic algorithms.

# OR-Testbed

OR-testbed is a framework designed to solve combinatorial optimization problems through the use and modeling of metaheuristics. Since metaheuristics are based on certain basic assumptions, they can be adapted for a multitude of different problems.

The contribution of OR-Testbed is to provide the implementation of the basic structure of metaheuristics. In this way, the problems to be solved (and therefore the related structures needed) only need to be modeled once. Then, once each of the functions and parameters of the metaheuristics to be used have been adapted, the problem can be solved with all of them from a centralized point.

In summary, the objective of the framework is to implement the most relevant metaheuristics in the state of the art, as well as the techniques commonly used in literature to improve them. This lets developers and researchers to have a centralized repository of implemented metaheuristics, techniques and potential execution service for all of their problems.

At this moment, the list of implemented metaheuristics is:

• GRASP
• Simulated Annealing
• Tabu Search

To see the development plans at a glance, all relevant information can be found in the roadmap.

## Installing

Since OR-Testbed is coded in pure Python no requirements are needed, just execute:

pip install or-testbed

## Examples and usage

There is no oneliner example, but there is a tutorial in the docs section. Also, check the available examples where some problems and algorithms are implemented and the usual workflow is showed.

## Contributing

All contributions will be greatly appreciated. The main alternatives are to report or correct bugs, suggest changes or functionalities, open issues and, of course, implement new metaheuristics.

### Testing

Run the unit test collection with:

pytest

### Building docs

First, build the docs using Sphinx:

cd docs
make html


Then open build/html/index.html in your browser to view the docs.

### Other resources

Since using OR-Testbed requires both coding and optimization related knowledge, this section will be more focused on the latter:

## Project details

Uploaded source
Uploaded py3