Documentation

Last update: June 16, 2024

selectBin

Select the best fitting bin.

The selectBin endpoint requires bin size and item information as input and returns the smallest possible bin in which the items can be packed. A bin is considered to be a match when all provided items can fit in a single bin.


Connectivity

URL https://www.packing-optimizer.com/api/selectBin
Method POST

Headers

Authorization Basic-Auth
API credentials as found on your Account Settings page.
Content-Type application/json

Query string options

Optional
includeItems If false, the individual item information per bin will not be included in the response.
Default: true
Options: true or false
Example: api/selectBin?includeItems=false
responsePrecision Sets the decimal precision of the response body.
Default: 3
Example: api/selectBin?responsePrecision=5
itemDimensionsAfter If rotated, the item dimensions in the response message will be adjusted according to the rotation type.
Default: original
Options: original or rotated
Example: api/selectBin?itemDimensionsAfter=rotated

Request body

Bins

Information about the bin that will be used for packing.

Field Type Description
bins[].type string Type of bin that is used for packing.
Example: pallet
bins[].width numeric Width of the bin.
Example: 1.2
bins[].depth numeric Depth of the bin.
Example: 0.80
bins[].height numeric Height of the bin.
Example: 1.65
bins[].maxWeight numeric Max weight that a single bin can carry.
Example: 1500
bins[].itemLimit numeric Optional Maximum number of items that a bin is allowed to fit.
Default: unlimited
Example: 5
bins[].maxValue numeric Optional Maximum value that a bin is allowed to contain.
Default: unlimited
Example: 1000
bins[].sortMethod string Optional Allows you to control the order in which the items are evaluated for packing.
If weight, the heaviest items are evaluated first. If volume, the biggest items are evaluated first. If optimized, a custom order is used to increase bin utilization.
Default: optimized
Options: weight, volume, or optimized
bins[].gravityStrength numeric Optional Allows you to enforce that a certain bottom surface area percentage of an item must be resting on top of another surface in order to be a valid position. For example, a gravityStrength of 75 would mean that atleast three quarters of an item must be resting on top of another surface. Recommended value is 0 until encountered otherwise.
Default: 0
Options: between 0 and 100
bins[].packingDirection string Optional Sets the packing direction of the bin. For example, boxes on a pallet are usually placed bottom first, stacking upwards when needed. A container with a closed top, however, would be stacked back to front.
Default: bottomUp
Options: bottomUp or backToFront

Items

Information about the items that have to be packed.

Field Type Description
items[].id string id to identify individual items.
Example: ITEM001
items[].width numeric Width of the item.
Example: 0.20
items[].depth numeric Depth of the item.
Example: 0.10
items[].height numeric Height of the item.
Example: 0.65
items[].weight numeric Weight of the item.
Example: 10
items[].value numeric Optional The value of the item.
Default: 0
Example: 10
items[].gravityStrength numeric Optional Same as bin.gravityStrength, item level gravityStrength takes precedence over bin level gravityStrength.
Default: 0
Options: between 0 and 100
items[].allowedRotations string Optional Indicates the way that an item is allowed to rotate while packing.
Default:  012345
Example: 015
Options:
0 No rotation
1 Allowed to rotate around the z-axis by 90°
2 Allowed to rotate around the x-axis by 90°
3 Allowed to rotate around the x-axis by 90° and then around the z-axis by 90°
4 Allowed to rotate around the y-axis by 90°
5 Allowed to rotate around the z-axis by 90° and then around the x-axis by 90°
items[].stackingStyle string Optional Enforce a particular stacking style for this item.
Default:  allowAll
Example: bottomNoItemsOnTop
Options:
allowAll No particular stacking style is being taken into account while placing this item.
bottomNoItemsOnTop The item will be placed at the bottom of the bin and cannot be placed on top of another item. It is not allowed to place any other item (partly) on top of this item. This item will always be the first to be evaluated when packing, meaning that this setting takes precedence over the order determined by bin.sortMethod.
stackByKey The item will either be placed on the ground, or on top of an item with the same stackingKey. This item will always be the first to be evaluated when packing (only bottomNoItemsOnTop items take precedence), meaning that this setting takes precedence over the order determined by bin.sortMethod.
items[].stackingKey string Optional Requires a items[].stackingStyle of stackByKey. Only items with the same stacking key are allowed to be stacked on top of each other.
Default:  None
Example: productTypeA
   
{
    "bins": [{
            "type": "box-large",
            "width": 0.40,
            "depth": 0.40,
            "height": 0.40,
            "maxWeight": 15
        },
        {
            "type": "box-medium",
            "width": 0.30,
            "depth": 0.30,
            "height": 0.30,
            "maxWeight": 10
        },
        {
            "type": "box-small",
            "width": 0.10,
            "depth": 0.07,
            "height": 0.07,
            "maxWeight": 7.5
        }
    ],
    "items": [{
            "id": "i1",
            "width": 0.05,
            "depth": 0.05,
            "height": 0.05,
            "weight": 1
        },
        {
            "id": "i2",
            "width": 0.05,
            "depth": 0.05,
            "height": 0.05,
            "weight": 1
        },
        {
            "id": "i3",
            "width": 0.30,
            "depth": 0.30,
            "height": 0.15,
            "weight": 1
        },
        {
            "id": "i4",
            "width": 0.15,
            "depth": 0.15,
            "height": 0.15,
            "weight": 1
        }
    ]
}

Response body

The packing response body follows a certain hierarchy, this hierarchy can be categorized in 3 sections.

  1. Header information - These details reason across all the bins that have been packed.
  2. Bin information - These details are about a particular bin that has been packed.
  3. Item information - These are details about a particular item. Items are nested inside bins.

Header

Contains header information about the complete packing request.

Field Type Description
requiredNrOfBins numeric The total number of bins it requires to pack all items.
totalVolumeUtil numeric The total volume utilization in percentage points.
totalWeightUtil numeric The total weight utilization in percentage points.
unfittedItems[] array Array of items that did not fit. Items in this array have the same attributes as items in packedBins[].fittedItems[].

PackedBins

Contains information about each bin that has been packed.

Information: The packedBins[] array of a selectBin request will only contain one value, which is the chosen bin. However, if none of the bins were found to fit, the response body will exist of only an empty packedBins array.
Field Type Description
packedBins[] array Contains the bins that have been packed.
packedBins[].id numeric Incrementing counter starting from 1. Generated by Packing Optimizer.
packedBins[].type string The type of bin as provided by the caller in the request body.
packedBins[].width numeric The maximum width of the bin as provided by the caller in the request body.
packedBins[].depth numeric The maximum depth of the bin as provided by the caller in the request body.
packedBins[].height numeric The maximum height of the bin as provided by the caller in the request body.
packedBins[].maxVolume numeric The maximum volume of the bin.
packedBins[].actualVolume numeric Total volume of the items packed in the bin.
packedBins[].actualVolumeUtil numeric actualVolume expressed in percentage points relative to the maxVolume attribute.
packedBins[].maxWeight numeric The maximum weight of the bin as provided by the caller in the request body.
packedBins[].actualWeight numeric Total weight of the items packed in the bin.
packedBins[].actualWeightUtil numeric actualWeight expressed in percentage points relative to the maxWeight attribute.
packedBins[].value numeric Total value of the items packed in the bin.
packedBins[].maxValue numeric The maximum value of the bin as provided by the caller in the request body.
packedBins[].furthestPointWidth numeric The furthest point alongside the x axis that any item is reaching.
packedBins[].furthestPointDepth numeric The furthest point alongside the y axis that any item is reaching.
packedBins[].furthestPointHeight numeric The furthest point alongside the z axis that any item is reaching.
packedBins[].nrOfItems numeric The total number of items packed inside the bin.

FittedItems

Contains information about each item that has been packed in the bin.

Field Type Description
packedBins[].fittedItems[] array Contains the items inside the bin.
packedBins[].fittedItems[].id string Item identifier as provided by the caller in the request body.
packedBins[].fittedItems[].width numeric Width of the item.
packedBins[].fittedItems[].depth numeric Depth of the item.
packedBins[].fittedItems[].height numeric Height of the item.
packedBins[].fittedItems[].weight numeric Weight of the item.
packedBins[].fittedItems[].volume numeric Volume of the item.
packedBins[].fittedItems[].value numeric Value of the item.
packedBins[].fittedItems[].stackingStyle string The stacking style used during packing.
packedBins[].fittedItems[].consolidationKey string Item consolidation key used during packing.
packedBins[].fittedItems[].allowedRotations string Rotations that were allowed during packing.
packedBins[].fittedItems[].xCoordinate numeric X coordinate of the item inside the bin.
packedBins[].fittedItems[].yCoordinate numeric Y coordinate of the item inside the bin.
packedBins[].fittedItems[].zCoordinate numeric Z coordinate of the item inside the bin.
packedBins[].fittedItems[].rotationType numeric Type of rotation that has been used to pack this item.
packedBins[].fittedItems[].rotationTypeDescription string Rotation description.
   
{
    "requiredNrOfBins": 1,
    "totalVolumeUtil": 51.02,
    "totalWeightUtil": 26.667,
    "packedBins": [
        {
            "id": 1,
            "type": "box-small"
            "width": 0.1,
            "depth": 0.07,
            "height": 0.07,
            "maxVolume": 0.00049,
            "actualVolume": 0.00025,
            "actualVolumeUtil": 51.02,
            "maxWeight": 7.5,
            "actualWeight": 2,
            "actualWeightUtil": 26.667,
            "furthestPointWidth": 0.10,
            "furthestPointDepth": 0.05,
            "furthestPointHeight": 0.05,
            "nrOfItems": 2,
            "fittedItems": [
                {
                    "allowedRotations": "012345",
                    "depth": 0.05,
                    "height": 0.05,
                    "id": "i2",
                    "rotationType": 0,
                    "rotationTypeDescription": "No rotation",
                    "stackingStyle": "allowAll",
                    "volume": 0.000125,
                    "weight": 1,
                    "width": 0.05,
                    "xCoordinate": 0,
                    "yCoordinate": 0,
                    "zCoordinate": 0
                },
                {
                    "allowedRotations": "012345",
                    "depth": 0.05,
                    "height": 0.05,
                    "id": "i1",
                    "rotationType": 0,
                    "rotationTypeDescription": "No rotation",
                    "stackingStyle": "allowAll",
                    "volume": 0.000125,
                    "weight": 1,
                    "width": 0.05,
                    "xCoordinate": 0.05,
                    "yCoordinate": 0,
                    "zCoordinate": 0
                }
            ],
        }
    ]
}