Skip to main content

HGDL Optimization

Project description

HGDL

PyPI Documentation Status HGDL CI Codecov PyPI - License DOI

HGDL is an API for HPC distributed constrained function optimization. At the core, the algorithm uses local and global optimization and bump-function-based deflation to provide a growing list of unique optima of a differentiable function. This tackles the common problem of non-uniquness of optimization problems, especially in machine learning.

Usage

The following demonstrates a simple usage of the HGDL API.

import numpy as np
from hgdl.hgdl import HGDL as hgdl
from hgdl.support_functions import *
import dask.distributed as distributed

bounds = np.array([[-500,500],[-500,500]])
#dask_client = distributed.Client("10.0.0.184:8786")
a = hgdl(schwefel, schwefel_gradient, bounds,
        hess = schwefel_hessian,
        global_optimizer = "genetic",
        local_optimizer = "dNewton",
        number_of_optima = 30000,
        args = (1,1), radius = None, num_epochs = 100)

x0 = np.random.uniform(low = bounds[:, 0], high = bounds[:,1],size = (20,2))
a.optimize(x0 = x0)

###the thread is now released, but the work continues in the background

a.get_latest() ##prints the current result whenever queried

a.kill_client() ##stops the execution and returns the result

Credits

Main Developers: Marcus Noack (MarcusNoack@lbl.gov) and David Perryman. Several people from across the DOE national labs have given insights that led to the code in its current form. See AUTHORS for more details on that. HGDL is based on the HGDN algorithm by Noack and Funke.

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

hgdl-2.0.6.tar.gz (35.0 kB view details)

Uploaded Source

Built Distribution

hgdl-2.0.6-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file hgdl-2.0.6.tar.gz.

File metadata

  • Download URL: hgdl-2.0.6.tar.gz
  • Upload date:
  • Size: 35.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.1

File hashes

Hashes for hgdl-2.0.6.tar.gz
Algorithm Hash digest
SHA256 f510ae80155550ed9e5fe4a870c9e376c449469a4d1ff6c0c6df51a4e0cbf00b
MD5 3821b521430c77043b04df1b7226e531
BLAKE2b-256 1bb3dbc7cd91884bd0fb09da19a006938ccf3f21de65af858993bcedb8d69937

See more details on using hashes here.

File details

Details for the file hgdl-2.0.6-py3-none-any.whl.

File metadata

  • Download URL: hgdl-2.0.6-py3-none-any.whl
  • Upload date:
  • Size: 19.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.1

File hashes

Hashes for hgdl-2.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 5c94fddd178ca9a763b1562257cd3d02d71d3e1b445ec1a3d111fb0c641a1027
MD5 8563d7811a524b9fcac420b41ca86961
BLAKE2b-256 b062d268e4aa856eae161d7e2c8aec4ba0d4549a8070b7b061ced4bddd285097

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