Skip to content

Releases: CyberAgentAILab/cmaes

v0.11.1

13 Aug 07:03
a6e791a
Compare
Choose a tag to compare

What's Changed

Full Changelog: v0.11.0...v0.11.1

PyPI: https://pypi.org/project/cmaes/0.11.1/

v0.11.0

01 Aug 01:05
7513df8
Compare
Choose a tag to compare

Highlights

CatCMA [Hamano+, GECCO2024]

arXiv: https://arxiv.org/pdf/2405.09962

CatCMA is a method for mixed-category optimization problems, which is the problem of simultaneously optimizing continuous and categorical variables. CatCMA employs the joint probability distribution of multivariate Gaussian and categorical distributions as the search distribution.

CatCMA

Usage is like below:

import numpy as np
from cmaes import CatCMA


def sphere_com(x, c):
    dim_co = len(x)
    dim_ca = len(c)
    if dim_co < 2:
        raise ValueError("dimension must be greater one")
    sphere = sum(x * x)
    com = dim_ca - sum(c[:, 0])
    return sphere + com


def rosenbrock_clo(x, c):
    dim_co = len(x)
    dim_ca = len(c)
    if dim_co < 2:
        raise ValueError("dimension must be greater one")
    rosenbrock = sum(100 * (x[:-1] ** 2 - x[1:]) ** 2 + (x[:-1] - 1) ** 2)
    clo = dim_ca - (c[:, 0].argmin() + c[:, 0].prod() * dim_ca)
    return rosenbrock + clo


def mc_proximity(x, c, cat_num):
    dim_co = len(x)
    dim_ca = len(c)
    if dim_co < 2:
        raise ValueError("dimension must be greater one")
    if dim_co != dim_ca:
        raise ValueError(
            "number of dimensions of continuous and categorical variables "
            "must be equal in mc_proximity"
        )

    c_index = np.argmax(c, axis=1) / cat_num
    return sum((x - c_index) ** 2) + sum(c_index)


if __name__ == "__main__":
    cont_dim = 5
    cat_dim = 5
    cat_num = np.array([3, 4, 5, 5, 5])
    # cat_num = 3 * np.ones(cat_dim, dtype=np.int64)
    optimizer = CatCMA(mean=3.0 * np.ones(cont_dim), sigma=1.0, cat_num=cat_num)

    for generation in range(200):
        solutions = []
        for _ in range(optimizer.population_size):
            x, c = optimizer.ask()
            value = mc_proximity(x, c, cat_num)
            if generation % 10 == 0:
                print(f"#{generation} {value}")
            solutions.append(((x, c), value))
        optimizer.tell(solutions)

        if optimizer.should_stop():
            break

What's Changed

New Contributors

Full Changelog: v0.10.0...v0.11.0

v0.10.0

19 Jul 04:11
4ebcdbd
Compare
Choose a tag to compare

What's Changed

Full Changelog: v0.9.1...v0.10.0

v0.9.1

06 Jan 06:06
f7ccf97
Compare
Choose a tag to compare

What's Changed

  • Remove tox.ini by @c-bata in #131
  • Fix a broken link to Optuna's documentation by @c-bata in #132
  • Drop Python 3.6 support. by @c-bata in #130
  • Reuse CMA inside CMAwM by @knshnb in #133
  • Add rng related methods by @knshnb in #135
  • Fix correction of out-of-range continuous params of CMAwM by @knshnb in #134
  • Fix correction of out-of-range discrete params of CMAwM by @knshnb in #136
  • Avoid to use typing.List, typing.Dict, and typing.Tuple. by @c-bata in #139
  • Check feasibility of sampled discrete parameters in CMAwM by @knshnb in #140
  • Refactor CMAwM by @knshnb in #141
  • Add a test case for no discrete spaces. by @c-bata in #143
  • Allow no discrete spaces in CMAwM by @knshnb in #142
  • Remove warnings in CMAwM class by @c-bata in #144
  • Revert handling of infeasible discrete parameters by @knshnb in #145
  • Bump the version up to v0.9.1 by @c-bata in #138

Full Changelog: v0.9.0...v0.9.1

v0.9.0

08 Nov 08:36
8f7a584
Compare
Choose a tag to compare

Highlights

CMA-ES with Margin is now available. It introduces a lower bound on the marginal probability associated with each discrete dimension so that samples can avoid being fixed to a single point. It can be applied to mixed spaces of continuous (float) and discrete (including integer and binary). This algorithm is proposed by Hamano, Saito, @nomuramasahir0 (a maintainer of this library), and Shirakawa, has been nominated as best paper at GECCO'22 ENUM track.

R. Hamano, S. Saito, M. Nomura, S. Shirakawa, CMA-ES with Margin: Lower-Bounding Marginal Probability for Mixed-Integer Black-Box Optimization, GECCO, 2022.

CMA-ES CMA-ESwM
CMA-ES CMA-ESwM

The above figures are taken from EvoConJP/CMA-ES_with_Margin.

Please check out the following examples for the usage.

What's Changed

New Contributors

References

Full Changelog: v0.8.2...v0.9.0

v0.8.2

19 Feb 15:39
Compare
Choose a tag to compare

CHANGES

  • Fix dimensions of Warm starting CMA-ES (#98).

v0.8.1

10 Feb 10:01
Compare
Choose a tag to compare

CHANGES

  • Unset version constraint of numpy.
  • Remove extra_requires for development.

v0.8.0

03 Feb 09:30
Compare
Choose a tag to compare

CHANGES

New features

Warm-starting CMA-ES is now available. It estimates a promising distribution, then generates parameters of the multivariate gaussian distribution used for the initialization of CMA-ES, so that you can exploit optimization results from a similar optimization task. This algorithm is proposed by @nmasahiro, a maintainer of this library, and accepted at AAAI 2021.

Rot Ellipsoid Ellipsoid
rot-ellipsoid quadratic

Link

v0.7.1

02 Feb 06:41
Compare
Choose a tag to compare

CHANGES

  • Support Python 3.9 (#84)
  • Refactor constants definitions (#85)
  • Add tox.ini (#86)
  • Remove numpy from setup_requires (#90)

v0.7.0

20 Oct 05:55
Compare
Choose a tag to compare

CHANGES

New features

Separable CMA-ES is added at #82. It accelerates the search by ignoring the dependency of variables. This is inefficient if there is a strong dependency between variables; however, this technique significantly improves the performance if the dependency can be ignored.

Benchmark
68747470733a2f2f73746f726167652e676f6f676c65617069732e636f6d2f6b75726f62616b6f2d7265706f7274732f43796265724167656e742f636d6165732f7369782d68756d702d63616d656c2d34383231326238303339373266353830656439316335633838343262666631303331623136373336

Dependency

  • Drop Python 3.5 support (#74)

Links