2023年第三届长三角高校数学建模竞赛】A 题 快递包裹装箱优化问题 详细数学建模过程

news/2024/11/7 23:54:41/

在这里插入图片描述

1 题目

2022 年,中国一年的包裹已经超过 1000 亿件,占据了全球快递事务量的一半以上。近几年,中国每年新增包裹数量相当于美国整个国家一年的包裹数量, 十年前中国还是物流成本最昂贵的国家,当前中国已经建立起全世界最强大、最先进的快递物流体系。在包裹的打包环节,选取合适的包装耗材非常重要。由于包裹的基数大,因此每个包裹耗材成本的略微降低,也能带来极大的经济效益。图 1 是一些纸箱实物样式,图 2 是某种三维装箱示意图。

在这里插入图片描述

图1 纸箱样式图2 三维装箱示意图

附件 1 的装箱数据中给出了订单数据和耗材数据。根据以上背景,请你们的团队完成以下问题:

问题1: 针对附件1装箱数据中给出的订单数据和耗材数据,对每个订单,分别用箱子或袋子去装,请设计出合适的装载方案,要求使用耗材数量越少越好, 在耗材数量相同时,耗材总体积越小越好。给出每种耗材的使用总数和耗材总体积。

问题2: 针对附件1的数据,现在需要优化耗材的尺寸,请给出耗材尺寸的优化方案。要求优化后耗材的种数不变,只是改变耗材尺寸;对问题1中成功装载的物品,优化后的方案使用的箱子或袋子数尽量减少;总体积不能超过原方案的总体积;在耗材数量相同时,耗材总体积越小越好。给出优化后的每种耗材的具体尺寸、使用总数和耗材总体积。

问题 3: 以上两个问题假设货物与耗材都为刚性的,若货物与耗材存在柔性或者可轻微挤压的属性时,请重新完成问题 1、2。根据实际情况,这里考虑耗材伸展时,长、宽、高都不超过原尺寸的 5%。

提示:

1、需要分别给出箱装(全使用箱子作为耗材)、袋装(全使用袋子作为耗材) 以及两种耗材同时使用的方案。
2、物品长宽高可以任意互换,如case1中第一种物品可看成长170、宽110、高27,也可看成长110、宽170、高27。
3、用袋子装物品时,能够装下的判定标准为同时满足如下两个条件: 袋子长+袋子高≥物品长+物品高;袋子宽+袋子高≥物品宽+物品高。
4、在附件1装箱数据中,case序号相同的看作同一订单,同一订单的物品可以装在同一箱(袋)子里,不同订单的物品一定装在不同箱(袋)子里。
5、对附件1装箱数据中的某订单物品,若耗材无论如何不能装下,则不需要考虑该物品。
6、耗材的重量暂不考虑。
7、表1是订单表示例,表2是耗材信息表,更详细的数据见附件1。

表1 部分订单表(示例)

caseL(长)W(宽)H(高)num
1170110277
1210200301
21051051002
21351101105
3208140185
39090751
411565351
5250190533
6140140482
622580352
7292166871
7320240701
8228148262

表 2 耗材信息表

耗材名称耗材类型重量
普通1号袋250190110
普通2号袋30025018
普通3号袋400330115
普通4号袋450420123
普通1号自营纸箱1651205545
普通2号自营纸箱2001407067
普通3号自营纸箱200150150103
普通4号自营纸箱27020090132
普通5号自营纸箱300200170179

2 思路

2.1 问题一

这个一个目标规划中的三维装箱算法问题。根据附件1.csv文件中的订单数据,可以得到以下信息:

  • 每个订单有多个产品,每个产品的长、宽、高和数量都不同。
  • 每个订单都需要使用一定数量的耗材。
  • 每个耗材包括多种不同的规格和重量。

为了更高效地计算每个订单所需的装箱量,可以使用三维建模软件来模拟不同尺寸和形状的箱子和袋子的使用情况,大概的建模过程如下:

  1. 首先需要将所有的产品按照其长、宽、高进行归一化,使得所有产品的尺寸单位都相同。例如,可以将所有产品的长、宽、高除以一个标准长度(比如170mm),得到归一化后的尺寸。
  2. 然后需要确定每个产品最适合使用的尺寸和形状的箱子或袋子,以及需要使用的数量。这个过程可以根据实际情况进行优化算法,可以考虑以下因素:
  • 箱子或袋子的尺寸是否能够容纳产品?
  • 箱子或袋子的形状是否能够适应产品的形状?
  • 使用单个箱子或袋子时是否能够满足耗材数量要求?
  • 如果使用多个箱子或袋子,则它们的尺寸和形状是否能够最大化地利用空间?
  • 如果使用多个箱子或袋子,则它们之间是否存在重叠部分,导致浪费空间?
  1. 对于每个订单,需要计算出它需要使用的箱子或袋子的总数量和总体积。具体的计算方法取决于选择的优化策略。一般来说,可以考虑以下两种策略:
    • 贪心算法:每次选择能够使耗材数量最少的产品组合,并尝试使用最合适的箱子或袋子来装载它们。如果当前的组合无法满足耗材数量要求,则继续选择其他产品组合,直到找到合适的组合或者已经没有更多的可选项为止。这种策略的优点是速度较快,但可能会出现无法满足耗材数量要求的组合。
    • 动态规划算法:预先计算出所有可能的组合的耗材数量和体积,然后根据实际需求逐步选择合适的组合和箱子或袋子。这种策略的优点是能够确保满足所有的耗材数量要求,但计算量较大。

2.2 问题二

我将附件1拆分为两个csv文件,方面后续的讲解,订单数据.csv和全部耗材数据.csv数据,可以采用以下优化方案来改变耗材尺寸,同时尽量减少使用箱子或袋子的数量,并且总体积不能超过原方案的总体积。对于这个题的建模过程如下。

  1. 确定优化方案的目标和约束条件:减少使用箱子或袋子数、总体积不能超过原方案的总体积、耗材总体积越小越好。
  2. 建立数学模型:定义一个函数 f ( d 2 ) f(d_2) f(d2),表示将所有产品放入尺寸为 d 2 d_2 d2的箱子或袋子中所需的最小空间。
  3. 设计算法:根据上述数学模型,设计算法来计算最优的 d 2 d_2 d2尺寸。具体来说,可以采用贪心算法或者动态规划算法等方法进行计算。
  4. 实现算法:将设计的算法实现到程序中,并调用该程序来计算最优的 d 2 d_2 d2尺寸。
  5. 分析算法性能:对算法进行性能分析,包括时间复杂度、空间复杂度等方面的评估,以确定算法是否满足要求。
  6. 不断优化算法:如果算法性能不够理想,可以对算法进行优化,以提高其效率和准确性。

2.3 问题三

(1)问题一改进

在贪心算法或者动态规划算法的基础上,考虑耗材的柔性属性,将每个产品的尺寸进行归一化后,计算出产品在不同尺寸下能够放入箱子或袋子中的最小体积。如果产品的形状存在柔性或可轻微挤压的属性,那么产品放入尺寸为k的箱子或袋子中时,长、宽、高都不超过 0.5 × k 0.5\times k 0.5×k的限制。

(2)问题二改进

在原有模型的基础上,考虑货物与耗材的柔性属性,即当货物或耗材具有柔性或可轻微挤压的属性时,在计算占用空间时应将长、宽、高都限制在原尺寸的5%以内。对于每个产品,将其长、宽、高分别除以 d 2 d_2 d2,得到三个比例系数 r 1 , r 2 , r 3 r_1, r_2, r_3 r1,r2,r3,然后将它们相乘即可得到占用的空间。

3 建模方案

3.1 问题一

以下是针对每个订单使用贪心算法的三维装箱算法,以减少耗材数量和优化耗材总体积为目标:

  1. 首先,需要将所有产品按照尺寸进行归一化,使得所有产品的尺寸单位都相同。例如,对于长、宽、高分别为170mm、110mm、27mm的产品,可以将其归一化为170mm×110mm×27mm的尺寸。

  2. 然后,需要计算出每个订单需要使用的箱子或袋子的总数量和总体积。具体的计算方法取决于选择的优化策略。

  3. 对于每个订单,可以使用三维贪心算法来进行装箱。具体步骤如下:

。。。略,请下载完整文档
下面是具体的数学公式说明:

d p [ i ] [ j ] [ k ] dp[i][j][k] dp[i][j][k] 表示在前 i i i 个产品中选择尺寸为 j j j 的产品放入尺寸为 k k k 的箱子或袋子的最优解,其中 d p [ i ] [ j ] [ k ] dp[i][j][k] dp[i][j][k] 的定义如下:

。。。略,请下载完整文档

3.2 问题二

针对装箱数据中给出的订单部分数据附件1.csv和全部耗材数据附件2.csv数据,可以使用数学模型来优化耗材尺寸,以达到减少使用箱子或袋子数、总体积不能超过原方案的总体积、耗材总体积越小越好的目标。
假设原方案中每种耗材的尺寸为 d 1 d_1 d1,数量为 n 1 n_1 n1,总体积为 V 1 V_1 V1;优化后方案中每种耗材的尺寸为 d 2 d_2 d2,数量仍为 n 2 n_2 n2,总体积为 V 2 V_2 V2。需要求解以下问题:

。。。略,请下载完整文档
在满足上述条件之一之后,就可以确定最优的

3.3 问题三

(1)改进问题一思路

在贪心算法的基础上,考虑耗材的柔性属性,将每个产品的尺寸进行归一化后,计算出产品在不同尺寸下能够放入箱子或袋子中的最小体积。如果产品的形状存在柔性或可轻微挤压的属性,那么产品放入尺寸为k的箱子或袋子中时,长、宽、高都不超过 0.5 × k 0.5\times k 0.5×k的限制。

具体数学模型如下:

。。。略,请下载完整文档

(2)问题二改进思路

  1. 在原有模型的基础上,考虑货物与耗材的柔性属性,即当货物或耗材具有柔性或可轻微挤压的属性时,在计算占用空间时应将长、宽、高都限制在原尺寸的5%以内。

  2. 对于每个产品,将其长、宽、高分别除以 d 2 d_2 d2,得到三个比例系数 r 1 , r 2 , r 3 r_1, r_2, r_3 r1,r2,r3,然后将它们相乘即可得到占用的空间。具体数学模型如下:
    。。。略,请下载完整文档

4 完整文档获取方式

看我知乎文章的最底部。

zhuanlan.zhihu.com/p/628512849


http://www.ppmy.cn/news/64115.html

相关文章

MySQL基础(十八)MySQL8其它新特性

1. MySQL8新特性概述 MySQL从5.7版本直接跳跃发布了8.0版本,可见这是一个令人兴奋的里程碑版本。MySQL 8版本在功能上做了显著的改进与增强,开发者对MySQL的源代码进行了重构,最突出的一点是MySQL Optimizer优化器进行了改进。不仅在速度上得…

前端CSS学习(二)

1、选择器进阶 1.1 后代选择器:空格 作用:根据HTML标签的嵌套关系,选择父元素后代中满足条件的元素 选择器语法:选择器1 选择器2 { css } 结果:在选择器1所找到标签的后代(儿子、孙子、重孙...)中,找到满足选择器2的…

聊聊Doris向量化执行引擎-过滤操作

聊聊Doris向量化执行引擎-过滤操作 Doris是开源的新一代极速MPP数据库,和StarRocks同源,采用全面向量化技术,充分利用CPU单核资源,将单核执行性能做到极致。本文,我们聊聊过滤操作是如何利用SIMD指令进行向量化操作。 …

Unity开发——如何在协程中进行回调

在Unity开发中,协程是一种实用的异步编程方法,要在协程中进行回调,可以使用委托(delegate)、Action或UnityAction 一、委托(delegate) 下面是一个使用协程和回调的简单示例: // 声明…

Window下载Android源码

Android 10源码下载 想要研究Android 源码的同学可以用此方法进行下载。源码从清华大学开源软件镜像站(https://mirrors.tuna.tsinghua.edu.cn/help/AOSP/)下载。 使用Linux的同学直接参照清华镜像站提供的使用帮助(https://mirrors.tuna.tsinghua.edu…

修改lib64/l.ibc.so6导致系统命令都不能用

问题:想升级libc-2.12.so到libc2.17,拷贝了一个libc2.17到lib64下,然后建立软连接到l.ibc.so6,导致系统除了cd之类的命令,其他都不能使用 报错:relocation error: /usr/lib64/libc.so.6: symbol _dl_start…

肝一肝设计模式【七】-- 代理模式

系列文章目录 肝一肝设计模式【一】-- 单例模式 传送门 肝一肝设计模式【二】-- 工厂模式 传送门 肝一肝设计模式【三】-- 原型模式 传送门 肝一肝设计模式【四】-- 建造者模式 传送门 肝一肝设计模式【五】-- 适配器模式 传送门 肝一肝设计模式【六】-- 装饰器模式 传送门 文…

【shell脚本里的数组】

目录 一、数组的定义方法1、定义数组1.1、使用shell脚本来写出怎么查看这个数组有没有缺少元素1.2、使用shell脚本,来生成数组1.3、元素的切片 二、数组追加元素三、传输和传出1、向函数传入数组的值2、从函数返回数组 一、数组的定义方法 ( 20 10 60…