Skip to content

Latest commit

 

History

History
60 lines (42 loc) · 2.21 KB

README.md

File metadata and controls

60 lines (42 loc) · 2.21 KB

Summary

OpenPSO is an efficient, modular and multicore-aware framework for experimenting with different PSO approaches. The package is implemented in C99, and transparently parallelized with OpenMP. OpenPSO is composed of three modules:

  1. A PSO algorithm library, with the capability of performing parallel function evaluations.
  2. A library of benchmarking functions.
  3. A command-line tool for directly experimenting with the different PSO algorithms and benchmarking functions.

The library components can be interfaced with other programs and programming languages, making OpenPSO a flexible and adaptable framework for PSO research.

Building

OpenPSO has been tested with GCC and Clang on Windows and Linux. OpenMP support depends on the compiler version, but OpenPSO will work regardless (albeit slower without OpenMP support).

OpenPSO uses the CMake build system, which is able to generate projects for different targets, e.g. regular Makefiles, XCode or Eclipse.

A Dev-C++ project file is included for convenience. This project will only generate the command-line tool. It will not generate the library components for interfacing with third-party applications. Unfortunately, due to a bug in Dev-C++, the editor crashes when opening the project. To avoid this, disable "Enable code completion" in Tools=>Editor Options=>Completion before opening the project.

Experimenting

The openpsocli tool uses the following syntax:

openpsocli [INPUT_FILE [SEED]]

If no input file is given, the tool defaults to input.ini. The input file defines the PSO parameters and number of runs to perform. An example input file is available here.

By default, the number of threads used is the same as the number of available processors. However, this default can be overridden by setting the OMP_NUM_THREADS environment to a specific value.

Reference

If you use this software please cite the following reference:

License

Mozilla Public License 2.0