- #1

- 3

- 0

## Homework Statement

I'm faced with a Shelf Packing problem and am currently conducting some preliminary research as to which algorithms/heuristics are currently yielding the best results. Since the problem is NP hard I do not expect to find the optimal solution in every case, but I was wondering:

1) what are the best algorithms?

2) what are the best heuristic methods?

3) What software exists to conduct some experiments with? Can you just use Maple?

a bit more info about the problem:

You are given a rack which is 1000 mm wide, 2200 mm high and 600 mm deep. Further, you have an unlimited amount of shelves that are 1000 mm wide, 10 mm high and 600 mm deep. Each shelve has a weight limit of 50000 g and shelves can only be placed at positions that are at 50mm from each other (imagine a rack with holes every 50mm, which are possible positions for the shelves). Further, there is a set of rectangular boxes. Each box i, for i=1,…,n has a given length, height, width and weight. The goal is now to place boxes on shelves such that the total packed volume in the rack is maximized. Notice that you can decide on the number of shelves to be used and the position of these shelves in the rack. The following restrictions need to be taken into account: - Each box can be placed at most once - The size and weight capacity of the shelves can not be violated - No overhang of boxes is allowed Boxes can be placed in any orientation and on top of any other box.

How do I best approach this problem? The goal is to minimise the free space in the rack. Any ideas?

## Homework Equations

none

## The Attempt at a Solution

I think there should be some kind of heuristic available that does the following:

1. put 1 box in a random position at the shelf

2. check for all the other boxes for which boxes, the free space within 1 layer is minimised, concidering all constraints.

3. add that box to the shelf and go back to 2 untill the layer is full.

4. check if another box on top of the exisiting layer can be added (given the contraints), if not: go to 1, if so: go to 4.

5. repeat untill raack is full.

Once more the questions:

1) what are the best algorithms?

2) what are the best heuristic methods?

3) What software exists to conduct some experiments with? Can you just use Maple?

Can anyone help me in the right direction?