Skip to main content

Python implementations of simulated annealing variants such as quasi rejection-free and rejection-free simulated annealing to optimize QUBO problems.

Project description

(Quasi) Rejection-Free Simulated Annealing

Python implementations of quasi rejection-free and rejection-free simulated annealing to optimize QUBO problems. A CUDA implementation exists as well. Additionally, the default simulated annealing algorithm is implemented as a reference. This reference implementation makes use of an improved update scheme where only the differences to the last energy state is computed. By using this scheme, the complexity is reduced to O(n * t), where n is the number of bits in the problem and t is the number of time steps.

Usage

The package is available at pypi, so it can be installed with pip install simulated-annealing-variants. The only requirement for the algorithms is numpy and they accept an upper triangular matrix while the example uses qubovert for the QUBO formulation. The algorithm is simply invoked by

from simulated_annealing_variants import simulated_annealing, simulated_annealing_qrf, simulated_annealing_rf
x, energy = simulated_annealing(Q=Q, num_t_values=10000)
x, energy = simulated_annealing_qrf(Q=Q, num_t_values=10000)
x, energy = simulated_annealing_rf(Q=Q, num_t_values=10000)

Algorithm

The implementation uses a parallel computation scheme and has therefore a quadratic speedup compared to standard simulated annealing implementations. The following pseudocode describes the idea and the difference to the standard implementation. For the exact implementation of the parallel computation have a look at the quasi rejection-free or the rejection-free python file.

Procedure RFSimulatedAnnealing
    x = random initial state
    xb = x
    For i in 0:N
        x = FindLocalNeighbour(f, x, T[i])
        If f(x) < f(xb)
            xb = x
        EndIf
    EndFor
    return xb
EndProcedure

Procedure RFFindLocalNeighbour(f, x, t)
    DeltaE = empty vector
    u = empty vector
    For i in 1:length(x)
        DelatE[i] = f(x) - f(flipat(x, i)) # Energy difference for x flipped at bit i
        u[i] = random(0, 1)
    EndFor
    accepted_idx = argmin_i {max(0, DeltaE[i]) + t log( -log(u[i])) }
    return flipat(x, accepted_idx)
EndProcedure

MPI

The MPI version makes use of mpi4py. So, after installing it with pip install mpi4py the parallel version can be run with mpiexec -n 4 python mpi_simulated_annealing.py. Currently, each process computes an individual solution, prints the found energy and sends the corresponding x vector to the root process. The file can be altered to make use of the best solution vector as well as changing the used QUBO problem.

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

simulated_annealing_variants-1.1.8.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

simulated_annealing_variants-1.1.8-py3-none-any.whl (12.4 kB view details)

Uploaded Python 3

File details

Details for the file simulated_annealing_variants-1.1.8.tar.gz.

File metadata

File hashes

Hashes for simulated_annealing_variants-1.1.8.tar.gz
Algorithm Hash digest
SHA256 b64a4e017e951ac4182a4ccd93c63df6a62c89a51fa3205233cc7cede282d335
MD5 95b403baacf51de1c60e405510bae316
BLAKE2b-256 c505014e0827d4ac3d9bd005967ddcdfd8bf3438e3ea986e617d2137786e0c2b

See more details on using hashes here.

File details

Details for the file simulated_annealing_variants-1.1.8-py3-none-any.whl.

File metadata

File hashes

Hashes for simulated_annealing_variants-1.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 2111858ec3e768acdbbe189ae84600698eba44357dc5af8fa77559a0eee4ac69
MD5 8c36101e70a2beb0dc0bec93eb63dc7d
BLAKE2b-256 4114050091b3116aa899c7fce52fc1cea75f50c6098abb3ffd365cdb57880941

See more details on using hashes here.

Supported by

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