一文了解经典报童模型的扩展问题

文章目录

  • 1 引言
  • 2 经典报童模型
  • 3 综述文章
  • 4 模型扩展
    • 4.1 扩展目标函数
    • 4.2 增加约束条件
    • 4.3 增加优化变量
    • 4.4 扩展模型参数
    • 4.5 扩展问题场景
  • 5 总结
  • 6 相关阅读

1 引言

时间过的真快呀,已经6月份了。距离上一篇文章发表,已经过去了将近一个月,要不是偶尔还有新关注的提醒,我可能都忘记提醒自己该继续学习和总结了。

看了一眼今年已经发表的文章数量,才5篇,很忧心自己原定的2024学习计划该如何完成。所以,为了对得起朋友们的陪伴和支持,为了保证后续学习计划的顺利推进,后续努力每2周更新一篇,底线是不超过3周更新一篇。

本篇回到不确定优化专题,继续研究报童模型。

此前在随机规划:求解报童问题期望值模型的算法方案中,已经详细研究了经典报童模型的求解方案,推导出了解析最优解。该模型虽然简单,但在实际场景问题中却大有用处,比如最近就在某个业务的技术分享会上,了解到其补货算法用的就是经典报童模型的求解算法。

显然,我们不能满足于经典报童问题的学习,毕竟还有很多更复杂的报童问题需要解决。幸运的是,学界已经针对经典报童问题的很多扩展类型进行了研究,并设计了对应的解决方案;不幸的是,我并没有那么多精力去逐一调研。所以我的研究思路是:先了解清楚有哪些已经被广泛研究的扩展模型,然后基于自己目前遇到的问题、匹配到对应的扩展模型,再详细研究这类扩展模型的求解算法。

本文先把第一项内容搞清楚:当前有哪些已经被广泛研究的基于经典报童模型的扩展问题

2 经典报童模型

在调研扩展问题前,再回顾一下经典报童模型。

经典报童模型可以描述为:报童每天从供应商处采购一定数量的报纸用于当天的销售。已知每份报纸的成本价 c c c,销售价 p p p,需求量 d d d是个不确定参数,通过历史的数据可知其概率分布函数,如果当天卖不完,会按回收价 s s s将未卖完的报纸卖给回收站。

该模型的核心诉求是:确定报童的最佳订购量 x x x,使得报童的净收入 θ ( x ) \theta(x) θ(x)最大化。
其中 θ ( x ) \theta(x) θ(x)的表达式为
θ ( x ) = p ⋅ E [ min ⁡ ( x , d ) ] + s ⋅ E [ max ⁡ ( x − d , 0 ) ] − c x \theta(x)=p·E[\min(x,d)]+s·E[\max(x-d,0)]-cx θ(x)=pE[min(x,d)]+sE[max(xd,0)]cx
第一项是售卖报纸的收益,第二项是回收报纸的收益,第三项是购买报纸的成本。

3 综述文章

在上述经典报童模型的基础上,目前已经衍生出了非常多的新问题。我简单调研了一下相关的综述文章,如下图所示。

早在1999年的时候,国外就有综述文章了,在2010年前后,国内又相继刊发了几篇。需要说明的是:这里国内和国外指的是中国人和外国人,不是指中文和英文。这里面被引用次数最多的是1999年和2011年的两篇文章,文章标题已经标注在图片中,感兴趣的朋友可以自行下载和学习。

4 模型扩展

如果仔细看已有的综述文章,会发现作者的分类扩展标准都不同,比如1999年文章把扩展问题划分成了11种,而2011综述文章则将其划分成了3种。

很多人看论文都会遇到一个问题:文章看了很多,但知识点却难以记忆。所以接下来我将换个角度去梳理这些扩展的报童问题。

首先,从优化模型本身出发,经典报童模型可以理解为:目标函数为最大化 θ ( x ) \theta(x) θ(x);无约束;优化变量数为 x x x;输入参数包括需求量 d d d、成本价 c c c、和回收价 s s s和销售价 p p p。所以第一大类扩展就是分别针对目标函数、约束、优化变量和输入参数进行扩展。

其次,跳出优化模型,在问题的描述上进行扩展,本文将其定义为第二大类扩展:扩展问题场景。

4.1 扩展目标函数

首先看目标函数的扩展。

从最朴素的认知来看,在问题有了不确定性后,收益和风险就是并存的,而且一般来说,收益越高,风险越大。相比只关注收益最大化,更恰当的方案应该是,通过一定的策略,达到收益和风险的平衡。

要实现该目标,可以通过目标函数的扩展来实现。最常用的扩展目标函数是:设定某个预期收益,最大化达到该收益的概率。

更完备的收益和风险平衡的方案,可以去金融投资领域取取经,包括:均值-方差模型、风险估值(Value at Risk ,VaR)、条件风险估值(Conditional Value at Risk, CVaR)。这些模型在报童模型的扩展文献中也已经有很多研究,有兴趣的可以自行调研。

4.2 增加约束条件

然后看报童模型中可以增加哪些约束。

第一种是增加预算约束 B B B,即
c ∗ x ≤ B c*x ≤ B cxB

第二种是增加库存约束或产能约束 W W W,即
x ≤ W x ≤ W xW

除此之外,约束条件这里几乎就没啥可扩展的空间了。

4.3 增加优化变量

从前两节看,如果只是修改了目标函数或者增加了约束条件,好像问题的求解难度也没啥显著变化。

本小节来看一个真正可以增加问题求解难度的扩展方式:增加优化变量。

最常见的增加优化变量的方式是增加报纸类型的数量,即多产品。举个例子,报童可以采购的报纸类型有多种,每一种类型的报纸成本、销售价、需求量和回收价均不同。

当然,如果问题只有这个变化,那么求解复杂度并没有显著增加,因为每一种报纸的最优解计算都是相互独立的,可以分别按照经典报童模型来计算;但是在叠加了约束条件后,例如总预算上限有约束,再想求解就真的变难了。

另一种增加优化变量的方式是引入其他类型的优化变量。此处举个额外引入广告预算变量的例子:报童可以给予报纸一定的广告投入,投入广告后,会改变(大概率是增加)原有的需求,为了最大化收益,就需要在决策订购量的同时,再决策投入的广告预算。

4.4 扩展模型参数

(1)需求量 d d d

上文中广告预算决策的实例,可以说是增加了优化变量,但也可以认为是扩展了需求分布。经典报童模型中,需求分布是个独立于优化变量的函数,但在这个实例中,需求分布函数中还包含了广告预算这个优化变量。

除了需求分布函数变复杂的情况,另一种扩展需求分布的方式是减少对需求分布的认知,例如只知道需求分布的部分信息,如均值、方差等,这类的实例可以参考此前的文章:不确定优化入门:用简单实例讲明白随机规划、鲁棒优化和分布鲁棒优化。

(2)成本价 c c c

以往的成本价 c c c都是固定值,但在很多场景中,如果报童订购量比较大,供应商是愿意给予一定的折扣的,如超过100份报纸打8折等。

(3)回收价 s s s

回收价 s s s的扩展一般也与供应商有关。为了鼓励报童多订购报纸,供应商可能会愿意承诺以原价买回报童未卖掉的报纸,此种情况下,相当于供应商分担了需求不确定性带来的风险。

(4)销售价 p p p

单独针对销售价 p p p的扩展比较少见,通常会结合问题场景的扩展,一并扩展。

4.5 扩展问题场景

问题场景扩展的类型特别多,这里选择几个(不全面)比较常见的类型来描述。

(1)增加频次

先举个增加销售频次的例子,接上此前所说的销售价扩展:假设商品(如服装产品)为一次订货,并用于两个周期(如春、秋)的售卖。第一个周期可以正常售卖,但第二个周期需要决策销售价格(往往是折扣价),目标还是使得总收益达到最大化。

另一个增加频次的方式是:增加订购频次。在允许两次订购的场景中,第二次的成本价往往会高于第一次。

(2)两层报童问题

经典报童问题是仅站在报童视角去分析问题的,但实际上报童和供应商都有提升收益的诉求,他们之间既有合作也有竞争,将他们内部的层次递进关系和决策的相互影响都引入到模型中去,也是一个扩展方向。

(3)供应商不确定性

经典报童问题中,不确定性只存在于需求 d d d中,但供应商处往往也存在不确定性,如供应商的产量具有不确定性、有一部分货品是次品等。

5 总结

综上,基于经典报童模型的扩展问题介绍就到这里了。

本篇文章的文字比较多,此处简单总结一下:

(1)经典报童模型的扩展问题比较多,本文按以下顺序进行了分类:扩展目标函数、增加约束变量、增加决策变量、扩展模型参数和扩展问题场景。

(2)针对自己遇到的问题,可以先找到对应的报童问题类型,然后再借鉴其具体的求解方案。

6 相关阅读

【1】The single-period (news-vendor) problem: literature review and suggestions for future research:https://www.sciencedirect.com/science/article/abs/pii/S0305048399000171

【2】报童模型的研究进展综述:https://www.cnki.com.cn/Article/CJFDTotal-TJJC200817006.htm

【3】报童问题的扩展模型:https://www.cnki.com.cn/Article/CJFDTotal-WHDY200803001.htm

【4】The newsvendor problem: Review and directions for future research:https://www.sciencedirect.com/science/article/abs/pii/S0377221710008040

【5】多产品报童模型的研究综述:https://www.cnki.com.cn/Article/CJFDTotal-LTKJ201503009.htm

【6】A Review of Behavioral Decision Making in the Newsvendor Problem:https://www.journal.oscm-forum.org/journal/journal/download/20180819023347_Paper_3_Vol.11_No._4,2018_Final.pdf

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/846729.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

godot.bk:how to add map to the game

1.项目构建如下,map是我们点击start之后才渲染出来的 mian.tscn --main.gd --background(textureact) --start(button) --button.gd sourceFile map.tscn --tilemap --tileset 2.main.gd:注意main.gd并不定义信号,它只是接收信号而已 extend…

冒泡排序与快速排序

博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:MySQL数据库 关注博主带你了解更多数据结构知识 1.冒泡排序 冒泡排序 private static void swap(int[] arrary,int i,int j){int tmp arrary[i];arrary[i] arrary[j];arrary[j] tmp;public static void bubbl…

Java筑基-面向对象

Java-面向对象 一、类和对象1、类和对象的关系2、创建类3、创建对象4、成员变量与局部变量5、构造器5.1、创建对象的过程5.2、构造器的格式5.3、构造器和方法的区别5.4、构造器的作用5.5、构造器的重载 6、this关键字用法:6.1、this可以修饰属性6.2、this可以修饰方…

【Ubuntu常用命令】终端个人常用命令总结

【Ubuntu常用命令】终端常用命令总结 查看硬盘挂载情况查看内存占用情况移动或重命名文件和目录复制文件或目录conda安装本地文件 查看硬盘挂载情况 mount 命令会列出当前系统上所有已挂载的文件系统。它会显示挂载点、文件系统类型、挂载选项等信息 mount df 命令用于显示文…

【一小时学会Charles抓包详细教程】Charles 抓包相关设置 (7)

🚀 个人主页 极客小俊 ✍🏻 作者简介:程序猿、设计师、技术分享 🐋 希望大家多多支持, 我们一起学习和进步! 🏅 欢迎评论 ❤️点赞💬评论 📂收藏 📂加关注 Charles 抓包相…

数据库(18)——DCL权限控制

MySQL常用权限 权限说明ALL,ALL PRIVILEGES所有权限SELECT查询数据INSERT插入数据UPDATE修改数据DELETE删除数据ALTER修改表DROP删除数据库/表/视图CREATE创建数据库/表 DCL语法 查询权限 SHOW GRANTS FOR 用户名主机名; 查询hello的权限 SHOW GRANTS FOR hellolocalhost; 授…

GCB | 基于36年5个生态系统观测数据发现表层土壤深度提高生态系统的生产力和稳定性

陆地生态系统生产力对全球粮食安全和促进碳固存至关重要,但生产力受到气候变化以及火灾、干旱、洪水、霜冻频率增加和生物多样性减少的压力。了解控制生态系统初级生产力变异的不同因素和机制,为维持生态系统初级生产力和增强生态系统恢复力提供了科学依…

OJ1230进制的转换

答案&#xff1a; #include <bits/stdc.h> using namespace std; using lllong long; const int N10; int a[10]; char ch[]{0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F}; void solve() {int n,m;cin>>n>>m;string str;cin>>str;for(int i0;i<str.size();i)…

字符串操作java

题目&#xff1a; 描述 给定长度为n的只有小写字母的字符串s&#xff0c;进行m次操作&#xff0c;每次将[l,r]范围内所有c1字符改成c2&#xff0c;输出操作完的字符串 输入描述&#xff1a; 第一行两个数n,m 第二行一个字符串s 之后m行&#xff0c;每行两个数l 、r两个字符…

【STL】优先级队列用法介绍及其实现

目录 前言 用法介绍 模拟实现 仿函数 迭代器区间构造 插入 删除 队顶 判空 大小 完整代码 前言 优先级队列&#xff08;priority_queue&#xff09;是一种特殊的队列数据结构&#xff0c;其中每个元素都有一个“优先级”。优先级最高的元素最先出队&#xff0c;而优…

内网域中NTLM中继那些事儿

0x01 初识NTLM协议 基本概念&#xff1a;NTLM(NT LAN Manager)认证是一种早期的Windows网络身份认证协议。它在Windows系统中用于验证用户的身份&#xff0c;并提供对网络资源的访问控制&#xff0c;它是一种基于Challenge/Response的认证机制。 认证流程 NTLM协议Challenge…

Python代码关系图生成,帮助快速熟悉一个项目

一、静态代码关系图 工具1、pyreverse pyreverse 是一个由 Logilab 开发的 Python 工具&#xff0c;它能够自动生成 UML (统一建模语言) 类图&#xff0c;这些类图基于 Python 源代码。pyreverse 可以分析 Python 代码&#xff0c;并从中提取出类、模块、函数、方法和它们之间…

Window下VS2019编译WebRTC通关版

这段时间需要实现这样一个功能&#xff0c;使用WebRTC实现语音通话功能&#xff0c;第一步要做的事情就是编译WebRTC源码&#xff0c;也是很多码友会遇到的问题。 经过我很多天的踩坑终于踩出来一条通往胜利的大路&#xff0c;下面就为大家详细介绍&#xff0c;编译步骤以及踩…

安卓组合控件(底部标签栏、顶部导航栏、增强型列表、升级版翻页)

本章介绍App开发常用的一些组合控件用法&#xff0c;主要包括&#xff1a;如何实现底部标签栏、如何运用顶部导航栏、如何利用循环视图实现3种增强型列表、如何使用二代翻页视图实现更炫的翻页效果。 底部标签栏 本节介绍底部标签栏的两种实现方式&#xff1a;首先说明如何通…

minos 2.3 中断虚拟化——GICv2 管理

首发公号&#xff1a;Rand_cs 该项目来自乐敏大佬&#xff1a;https://github.com/minosproject/minos 硬件肯定需要软件配合&#xff0c;这一节就来实战 GICv2 首先准备好 GICv2 手册&#xff1a;https://developer.arm.com/documentation/ihi0048/bb/?langen&#xff0c;对…

深入剖析Java逻辑运算符,解决日常开发难题

哈喽&#xff0c;各位小伙伴们&#xff0c;你们好呀&#xff0c;我是喵手。运营社区&#xff1a;C站/掘金/腾讯云&#xff1b;欢迎大家常来逛逛 今天我要给大家分享一些自己日常学习到的一些知识点&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相学习&#xff0c;一…

SpringBoot:手动创建应用

Spring提供了在线的Spring Initialzr在线创建Spring Boot项目&#xff0c;为了更好的理解Spring Boot项目&#xff0c;这里我们选择手动创建。 1.新建Web应用 1.1 生成工程 首先要做是创建一个Java项目&#xff0c;这里我们选择使用Maven来支持&#xff0c;使用archetype:ge…

现成方案 - 复刻版类似 Perplexity 与秘塔 AI 的搜索引擎

这里为大家带来一个极具创新性的开源 AI 搜索引擎&#xff0c;其灵感源自 Perplexity。 该搜索引擎主要具备以下功能&#xff1a; 能够接收用户提出的各种问题。借助 Bing 搜索 API 可查找出前 6 个结果并予以展示。会抓取这 6 个链接的文本内容&#xff0c;将其作为重要的上下…

Gavin Wood 访谈|Polkadot 从何而来,又将如何面对 AI 时代?

如果没有宏观经济&#xff0c;加密世界可能无法存在。或许&#xff0c;Satoshi Nakamoto 也永远不会写出那篇开创性的白皮书。区块链技术作为指数时代的核心之一&#xff0c;在宏观经济理论中占有重要地位。传统的经济增长公式是人口增长加生产率增长加债务增长。然而&#xff…

Python 高级数据类型

列表List 定义列表 可以将不同的基本数据类型或者列表装到一个列表里 my_list [1,2,3,4,5] print(my_list) # [1, 2, 3, 4, 5] 直接打印出列表的内容 print(type(my_list)) # <class list>my_list ["1","2","3","4","…