pack_it_up is a simple Rust library that implements various bin packing algorithms
- First-fit
- First-fit-decreasing
use pack_it_up::offline::first_fit_decreasing::first_fit_decreasing;
struct MyItem {
some_content: i32,
size: usize,
}
impl Pack for MyItem {
fn size(&self) -> usize {
self.size
}
}
fn main() {
let my_items = vec![
MyItem { some_content: 1, size: 1, },
MyItem { some_content: 2, size: 2, },
MyItem { some_content: 3, size: 19, },
MyItem { some_content: 4, size: 17, },
MyItem { some_content: 5, size: 1, },
];
let mut bins = first_fit_decreasing(20, my_items);
}
The above will result in 2 full bins, one with sizes 19 and 1, and the other with sizes 17, 2 and 1.
- Remaining algorithms
- Performance optimizations
- Simple derive for Pack if your struct already has a field called size