pack_it_up 1.1.0

pack_it_up is a simple Rust library that implements various bin packing algorithms
Documentation
  • Coverage
  • 63.64%
    21 out of 33 items documented1 out of 23 items with examples
  • Size
  • Source code size: 30.84 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 657.53 kB This is the summed size of all files generated by rustdoc for all configured targets
  • Ø build duration
  • this release: 10s Average build duration of successful builds.
  • all releases: 9s Average build duration of successful builds in releases after 2024-10-23.
  • Links
  • stevenliebregt/pack_it_up
    2 1 2
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • stevenliebregt

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
  • Next-fit

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