bm产品装箱(重量合规、SKU 优先)
Project description
Cartonizer(装箱求解器)
一个以“重量合规 + SKU尽量不混装”为核心目标的装箱求解器。
目标与约束
- 每箱重量必须满足 12.0 kg ≤ weight ≤ 22.5 kg(可配置)。
- 尽量保证同 SKU 装在一起;默认每箱 SKU 种类 ≤ 3,必要时可放宽。
- 不允许旋转(按固定朝向判断尺寸可放入)。
- 默认只做快速体积与尺寸过滤;可选 3D 校验。
- 方案完成后支持箱型替换(更小体积)与数量整形(每箱 SKU qty 尽量为 5/10 的整数倍)。
输入与输出
输入格式与输出格式详见 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 的箱,其次放入 SKU 种类更少的箱。
- 箱数搜索:从
B_min起尝试B_min+1 / B_min+2。 - 必要时放宽 SKU 限制:若严格限制失败,允许更多 SKU,但仍以少 SKU 为优先。
3) Stage B:修复 underweight(< min_weight)
处理所有低于最小重量的箱:
- 轻箱合并(若合并后重量/体积均不超限)
- 从重箱搬小件到轻箱(保证 donor 仍 ≥ min_weight)
- 跨箱交换(swap)使两箱都落入区间
优先同 SKU,再必要时跨 SKU。
4) 动态箱数与自动降级
若主解失败,会按顺序自动降级尝试:
- 利用率目标:0.8 → 0.75 → 0.70 → 0.60
- 体积阈值:必要时放宽到
fill_rate=0.95 - SKU 限制:必要时允许更多 SKU,但仍尽量少
5) Stage C:箱型替换与数量整形
在满足重量/体积/尺寸的前提下:
- 箱型替换优化:能放下的情况下优先换成体积更小的箱型
- 数量整形:尽量让每箱内每个 SKU 的数量为 5/10 的整数倍(无法满足时保留原值)
6) Stage D:几何可行性校验(可选)
默认仅做“尺寸 + 体积阈值”的快速过滤。
若启用 --geometry-check,使用 py3dbp 做真实 3D 校验。
仅对最终方案进行 3D 验证与可视化输出。
备注
- 当前策略不追求“箱数最少”,而是强调“重量合规 + 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.2.tar.gz.
File metadata
- Download URL: bm_cartonizer-0.1.2.tar.gz
- Upload date:
- Size: 18.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b68355f737a045f5eedb25796137634a466e53afa501c926670ceda320a8899f
|
|
| MD5 |
e7a8fa47634fbe5da6b18a2b3b4ae8aa
|
|
| BLAKE2b-256 |
dfc0cc236c19044c1c3caa94eb5d172bd3ed569fd075a5e5056edfcd222cecc4
|
File details
Details for the file bm_cartonizer-0.1.2-py3-none-any.whl.
File metadata
- Download URL: bm_cartonizer-0.1.2-py3-none-any.whl
- Upload date:
- Size: 19.9 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 |
1837b6cc68dec790029b682697c9fc0705584daa2eec8cdeb0a683f0755957e5
|
|
| MD5 |
4c0ac61db2ec6944e01a9590eaad7e98
|
|
| BLAKE2b-256 |
3f901966de7316182fb0ac06634eaef6160bc72ae5b5c53474388377bf2a70bd
|