Skip to main content

A tree-based parallel surrogate optimization algorithm for optimizing noisy expensive functions

Project description

ProSRS algorithm

Progressive Stochastic Response Surface (ProSRS) is a parallel surrogate-based optimization algorithm for optimizing noisy expensive functions. This algorithm utilizes a radial basis function (RBF) as the surrogate, and adopts stochastic response surface (SRS) framework to balance exploitation and exploration. Compared to the original parallel SRS work, the novelties of this algorithm include

  • Introducing a new tree-based technique, known as the "zoom strategy", for efficiency improvement.
  • Extending the original work to the noisy setting (i.e., an objective function corrupted with random noise) through the development of a radial basis regression procedure.
  • Introducing weighting to the regression for exploitation enhancement.
  • Implementing a new SRS that combines the two types of candidate points that were originally proposed in the SRS work.

ProSRS algorithm is configured in a master-worker structure, where in each optimization iteration, the algorithm (master) constructs a RBF surrogate using the available evaluations, then proposes new points based on the constructed RBF, and finally distributes the tasks of evaluating these points to parallel processes (workers).

Compared to the popular Bayesian optimization algorithms, ProSRS is able to achieve faster convergence on some difficult benchmark problems, and is orders of magnitude cheaper to run. Moreover, ProSRS enjoys asymptotic convergence gaurantees. The common applications of this algorithm include efficient hyperparamter tuning of machine learning models and characterizing expensive simulation models.

Installation

Python dependencies:

To install prosrs package, type and run the following:

pip install prosrs

Note: The above pip method should work for most users. If a user encounters any installation problems including import errors or warnings, please refer to the Wiki page Installation Troubleshooting for possible solutions.

Getting started

After having installed the required Python packages, users are ready to use ProSRS algorithm for solving optimization problems. The easiest way of getting started is to read the tutorials in the examples directory, where different usages, from the basic level to the advanced level, are demonstrated through code examples. Of course, users are also encouraged to check out the source codes of the algorithm in the prosrs directory.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

prosrs-0.1.1.tar.gz (32.4 kB view details)

Uploaded Source

Built Distribution

prosrs-0.1.1-py3-none-any.whl (36.4 kB view details)

Uploaded Python 3

File details

Details for the file prosrs-0.1.1.tar.gz.

File metadata

  • Download URL: prosrs-0.1.1.tar.gz
  • Upload date:
  • Size: 32.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.1

File hashes

Hashes for prosrs-0.1.1.tar.gz
Algorithm Hash digest
SHA256 cf8a8f8ffb27be371212c7fd16bc18f7afceff9aaae628b1f3e1e1bbf0c4ab53
MD5 f9ef46fb9cfabd62b5f3c90bf0a49112
BLAKE2b-256 0fa3c40956067daea9c1700cdda0279fd0efc87ffdf7151aaba541ea183b0a2e

See more details on using hashes here.

File details

Details for the file prosrs-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: prosrs-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 36.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.20.1 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.7.1

File hashes

Hashes for prosrs-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e98f76ddaab181cd3bc816dc2f617377ebe702dbfab2df1726e21be0cb6d88e7
MD5 de08e237365a77ad5b0c2209d101ef53
BLAKE2b-256 0bea21df802a99f4c454b262f427b84af655f79f1bf1b85349ced0e05a3283fc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page