Skip to main content

A hyper-heuristic approach on solving the 2D bin packing problem

Project description

hyperpack
https://img.shields.io/badge/License-Apache_2.0-blue.svg https://img.shields.io/badge/python-3.7|3.8|3.9|3.10|3.11-blue.svg https://img.shields.io/badge/maintainer-alkiviadis.aliferis@gmail.com-blue.svg https://img.shields.io/badge/pypi-v1.2.0-blue.svg

Problem description

The hyperpack library is an API for solving instances of the 2D Binpacking problem and also - as of v1.1.0 - strip packing instances!

The library is multiprocessing enabled to minimize execution times and utilizes only pure python, making the package dependency free.

Many different variations can be created and solved, accordind to the instantiation data. The solvable variants can be summarized in the below characteristics: - Any number and sizes of (rectangular) items. - Any number and sizes of (rectangular) bins (containers). - The items can be rotated or not.

The above items’ charascteristics can also be applied to strip packing problems.

The bin/strip packing problem has been used in many sectors of the industry, and mostly where manufacturing or industrial management needs arise.

The theory of this library’s implementation and mechanics can be found in author’s document “A hyper-heuristic for solving variants of the 2D bin packing problem”.

Installation

Install using pip:

pip install hyperpack

Quickstart

A quickstart for testing the library can be made through the generate_problem_data utility function.

>>> from hyperpack import generate_problem_data, HyperPack
>>> problem_data = hyperpack.generate_problem_data(containers_num=2)
Containers number =  2
Containers:
{
    "container-0": {
        "W": 48,
        "L": 53
    },
    "container-1": {
        "W": 53,
        "L": 49
    }
}
Items number =  60
>>> problem = HyperPack(**problem_data)
>>> problem.hypersearch()
>>> problem.create_figure(show=True)
>>> # figure opened in default browser
>>>
>>> # to see parameter explanation do:
>>> help(generate_problem_data)

Defining the problem

Instantiate your problem with proper arguments

>>> from hyperpack import HyperPack
>>> problem = hyperpack.HyperPack(
>>>     containers=containers, # problem parameter
>>>     items=items, # problem parameter
>>>     settings=settings # solver/figure parameters
>>> )

According to the arguments given, the corresponding problem will be instantiated, ready to be solved with provided guidelines. The items and containers (bins) structure:

containers = {
    "container-0-id": {
        "W": int, # > 0 container's width
        "L": int # > 0 container's length
    },
    "container-1-id": {
        "W": int, # > 0 container's width
        "L": int # > 0 container's length
    },
    # ... rest of the containers
    # minimum 1 container must be provided
}

items = {
    "item-0-id": {
        "w": int, # > 0 item's width
        "l": int, # > 0 item's length
    },
    "item-1-id": {
        "w": int, # > 0 item's width
        "l": int, # > 0 item's length
    },
    # ... rest of the items
    # minimum 1 item must be provided
}

See documentation for detailed settings structure.

Usage

Do Local search with default settings:

>>> from hyperpack import HyperPack
>>> problem_data = {
>>>     "containers": containers,
>>>     "items": items,
>>>     "settings": settings
>>> }
>>> problem = HyperPack(**problem_data)
>>> problem.local_search()

After solving has finished, the solution can be found in problem.solution instance attribute.

Alternatively for a deep search and maximum bin utilization in mind:

>>> problem = HyperPack(**problem_data)
>>> problem.hypersearch()

Solution logging

Use the log_solution method to log an already found solution:

>>> problem.log_solution()
Solution Log:
Percent total items stored : 100.0000%
Container: container-0-id 60x30
        [util%] : 100.0000%
Container: container-1-id 60x50
        [util%] : 91.2000%

Remaining items : []

Create a figure

Warning : plotly (5.14.0 or greater) is needed for figure creation and kaleido (0.2.1 or greater) for figure exportation to image. These libraries are not listed as dependencies providing liberty of figure implementation.

>>> problem.create_figure(show=True)

The figure below is opened in default browser:

example_figure

For more information, visit the documentation page.

Future development

Many ideas and concepts can be implemented in this library. The most propable depending on the community’s interest:

  • Augmentation of the objective function to deal with a bigger plethora of problems.

  • Implementation of the strip packing problem.

  • Django integrations.

  • Large Neighborhood Search for big instances of the problem.

  • Other shapes of the container.

  • A dynamic live terminal display.

  • Execution speed optimization.

  • Multiprocessing for the local search alone (combined with Large Neighborhood Search).

  • More detailed figures.

  • Figures with other libraries (matplotlib).

If interested with development with some of these features please contact me.

Theoretical foundations

This packages inner mechanics and theoretical design are based upon this documentation.

Helping

Creating issues wherever bugs are found and giving suggestions for upcoming versions can surely help in maintaining and growing this package.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

hyperpack-1.2.0-py3-none-any.whl (47.0 kB view details)

Uploaded Python 3

File details

Details for the file hyperpack-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: hyperpack-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 47.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for hyperpack-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2be8be4406ddba69acc3515a07d57a9764d94792e04a7fd8de34eb93f322a61b
MD5 ff385a4b3c91a74b2c9502be698b5d88
BLAKE2b-256 70329e3597c99c6e4bd3107d436e6b55b589ab2105574d0b14eb2099c1eefcf5

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