3D Bin Packing
This is a GUI 3D bin packing problem solver written in go and typescript using:
- wails - a gui framework that makes it possible to write desktop applications using Go and web technologies
- vite - next generation frontend tooling
- react - a declarative js library for building gui
- mui (material-ui) - a react components library
- zustand - a minimalistic state management library
- three.js - a general purpose 3D library
- react-three/fiber - a react renderer for three.js
The following algorithms are available to use:
- A custom implementation of B-Cell Algorithm
- Genetic algorithms based on different evolution models: Darwin and de Vries
How to build
Prerequisites
- go 1.18
- node 15+
- wails v2 beta36+:
go install github.com/wailsapp/wails/v2/cmd/wails@latest
- you might need to install some additional packages/dependencies:
- Fedora 36 requires webkit2gtk3-devel package to successfully build the application:
sudo dnf install -y webkit2gtk3-devel
- Check official wails v2 installation guide if you use other Linux distro | MacOS | Windows
Build command
wails generate module && wails build
Development
wails generate
to generate wailsjs runtime and go/ts bindings
wails dev
to run the app in development mode (with hot reload)
wails dev -browser
to run the app in development mode in a browser
Research
Optimal parameters
The research of both algorithms was done on a randomly generated task of size 47 (1 container and 47 blocks)
For this task the best solution is 0.773552 (there is no solution where the container is fully filled)
BCA |
GA |
data:image/s3,"s3://crabby-images/0a3e0/0a3e0da50271414299b25cefd88999168fa0b896" alt="optimal_ci_for_bca" |
data:image/s3,"s3://crabby-images/582c7/582c7bf18a306d24fdc65ea9c8a81fab1e546681" alt="optimal_mp_for_ga" |
Comparison
Comparison of speed and efficiency was also done out using randomly generated tasks of different sizes
(except for the first task of size 10, which has 1.0 solution)
Speed |
Efficiency |
data:image/s3,"s3://crabby-images/d7728/d7728f6b96109499cfb22dfb6b647a6f065af4ac" alt="time_comparison" |
data:image/s3,"s3://crabby-images/19dc7/19dc71cf7505081f485613bc543b9cda8aa27a8f" alt="obj_fun_comparison" |
Demo
https://user-images.githubusercontent.com/58259700/180448623-d1d14059-a22b-482a-98ec-4bf44358c297.mp4