#bin #algorithm #packing #bin-packing #pack #fit #offline

pack_it_up

pack_it_up is a simple Rust library that implements various bin packing algorithms

3 releases (1 stable)

1.0.0 Mar 7, 2023
0.1.1 Jan 9, 2023
0.1.0 Jan 7, 2023

#1320 in Algorithms

Download history 87/week @ 2024-09-27 73/week @ 2024-10-04 69/week @ 2024-10-11 42/week @ 2024-10-18 54/week @ 2024-10-25 64/week @ 2024-11-01 75/week @ 2024-11-08 70/week @ 2024-11-15 144/week @ 2024-11-22 79/week @ 2024-11-29 55/week @ 2024-12-06 96/week @ 2024-12-13 26/week @ 2024-12-20 20/week @ 2024-12-27 80/week @ 2025-01-03 125/week @ 2025-01-10

274 downloads per month

MIT license

11KB
174 lines

pack_it_up

Crates.io docs.rs

pack_it_up is a simple Rust library that implements various bin packing algorithms

Current implemented algorithms

  • First-fit
  • First-fit-decreasing

Basic example

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.

Planned features

  • Remaining algorithms
  • Performance optimizations
  • Simple derive for Pack if your struct already has a field called size

No runtime deps