bm产品装箱(重量合规、SKU 优先)
Project description
Cartonizer(装箱求解器)
一个以“重量合规 + SKU尽量不混装”为核心目标的装箱求解器。
目标与约束
- 每箱重量必须满足 12.0 kg ≤ weight ≤ 22.5 kg(可配置)。
- 尽量保证同 SKU 装在一起;仅在修复 underweight 时才跨 SKU 混装。
- 不允许旋转(按固定朝向判断尺寸可放入)。
- 默认只做快速体积与尺寸过滤;可选 3D 校验。
输入与输出
输入格式与输出格式详见 AGENTS.md 的定义,保持稳定以便后续发布 PyPI。
运行命令
在项目根目录执行:
# 安装开发依赖
pip install -e ".[dev]"
# 运行测试
pytest -q
# 运行示例
python -m cartonizer.cli --input examples/order.json
# 可行性验证
python -m cartonizer.cli --input examples/bm_data.json --geometry-check --geometry-viz-dir output
CLI 参数说明
--input: 输入 JSON 路径(必填)。--geometry-check: 对每个箱执行 3D 几何校验(需要安装py3dbp)。--geometry-viz-dir: 输出几何可视化文件的目录(可选)。
打包与发布(PyPI)
1) 构建本地包
python -m build
2) 上传到 PyPI
为避免在命令行或文档中泄露 Token,推荐使用环境变量:
$env:TWINE_USERNAME="__token__"
$env:TWINE_PASSWORD="<你的PyPI Token>"
python -m twine upload dist/*
如需上传到 TestPyPI:
$env:TWINE_USERNAME="__token__"
$env:TWINE_PASSWORD="<你的TestPyPI Token>"
python -m twine upload --repository testpypi dist/*
分箱思路(详细版)
1) 可行性判定(重量区间)
订单总重为 W,箱数 B 需满足:
min_weight * B ≤ W ≤ max_weight * B推导:B_min = ceil(W / max_weight)B_max = floor(W / min_weight)如果B_min > B_max,直接判定 infeasible。
2) Stage A:按 SKU 优先分箱(主解)
按 SKU 逐个处理,尽量形成“纯 SKU”箱:
- 选择箱型(多箱型时)
对该 SKU 的单件物品,筛选可用箱型:- 单件重量 ≤
box.max_weight - 单件体积 ≤
box_volume * fill_rate - 单件尺寸在固定朝向下可放入(不旋转)
- 单件重量 ≤
- 用该箱型进行分割
在重量上限与体积上限的双约束下,把该 SKU 直接分割成多箱(mono‑SKU)。
3) Stage B:修复 underweight(< min_weight)
处理所有低于最小重量的箱,优先不破坏 SKU 聚合:
- 轻箱合并(若合并后重量/体积均不超限)
- 从重箱搬小件到轻箱(保证 donor 仍 ≥ min_weight)
- 跨箱交换(swap)使两箱都落入区间
优先同 SKU,再必要时跨 SKU。
4) Stage C:几何可行性校验(可选)
默认仅做“尺寸 + 体积阈值”的快速过滤。
若启用 --geometry-check,使用 py3dbp 做真实 3D 校验,不可行则直接返回 infeasible。
备注
- 当前策略不追求“箱数最少”,而是强调“重量合规 + SKU 聚合优先”。
- 若需要成本优化、体积利用率二级目标,可在后续版本扩展。
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file bm_cartonizer-0.1.0.tar.gz.
File metadata
- Download URL: bm_cartonizer-0.1.0.tar.gz
- Upload date:
- Size: 12.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d0dd9f664c8c169429d29057168f4aeb092938abebb10a2e895935362677ba7f
|
|
| MD5 |
60a44c23c8aa9fb0fb5403fb1dd54a0e
|
|
| BLAKE2b-256 |
693c60df1c11ae12d4c4d236c50d1c4e6045b77232a1f1d5bcf83d6b52d6ba97
|
File details
Details for the file bm_cartonizer-0.1.0-py3-none-any.whl.
File metadata
- Download URL: bm_cartonizer-0.1.0-py3-none-any.whl
- Upload date:
- Size: 14.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4079d424189289c4fb619082d55f38c609ae9c4c99e3fc6cffd60bcd1dd36823
|
|
| MD5 |
1a4b2734162ee1e0cd38af01bda6dace
|
|
| BLAKE2b-256 |
d1ab65228d13f7b630baa930c0d092066aba5447a66c14aa4c6e2e1cdf23fcbc
|