【思路代码详解】2023mathorcup大数据复赛B题妈妈杯高校数学建模挑战赛电商零售商家需求预测及库存优化问题

news2024/11/17 13:39:10

2023 年 MathorCup 高校数学建模挑战赛——大数据竞赛
赛道 B复赛:电商零售商家需求预测及库存优化问题

问题一
目标:制定补货计划,基于预测销量。
背景:固定库存盘点周期NRT=1, 提前期LT=3天。
初始条件:所有商品期初库存为5,持有成本及缺货成本与商品价格正相关。
策略:周期性盘点库存策略(s,S)。
数据处理:需结合历史及预测需求量。
任务:提供2023-05-16至2023-05-30期间的补货计划(每天的s和S值)。
目标指标:降低成本,提升服务水平,降低库存周转天数。
问题二
目标:撰写关于电商零售商家需求预测及库存优化问题的总结报告。
内容要求:报告中需要明确团队方案的优缺点。
附件说明
结果表4:库存补货结果表,包含商家编码、商品编码、仓库编码、日期、库存决策变量(s和S)、当天期初库存、当天期末库存、预测需求量和补货量等字段。

总结问题一团队认为可以采用的方法为:基于模拟退火求解规划问题;基于遗传算法求解规划问题;使用库存管理理论,如经济订货量(EOQ)模型;基于机器学习的预测模型;基于修正机器学习的预测模型
团队将选取至少3种方法分别进行求解。

mbd.pub/o/bread/mbd-ZZeckpxs

商品价格数据的Excel文件:
这个数据表包含了商品编号(product_no)和相应的价格(price)。

预测结果表,包含以下信息:
商家编号(seller_no)
商品编号(product_no)
仓库编号(warehouse_no)
日期范围(date),这里显示的是从2023-05-16至2023-05-30的日期范围
预测需求量(forecast_qty)
对原始数据做可视化:

在这里插入图片描述

预测需求量的分布:这个图表显示了预测需求量的分布情况。可以看到需求量的分布范围和集中趋势。
商品价格的分布:这个图表显示了商品价格的分布情况。通过这个图表,我们可以了解商品价格的波动和集中趋势。

在这里插入图片描述

每个商家的预测产品数量:这个图表显示了各个商家的预测产品数量。这有助于了解哪些商家的产品数量较多,可能需要更多关注。
每个仓库的产品数量:这个图表展示了每个仓库中的产品数量。这有助于分析不同仓库的库存分布情况。
最常见的商品价格(前10名):这个图表显示了最常见的商品价格及其出现频率。这可以帮助我们理解价格分布的重点区域。

在这里插入图片描述

价格分布图:这个直方图显示了商品价格的分布情况,并包含一个核密度估计(KDE)曲线,可以帮助理解价格的总体分布趋势。
价格箱线图:这个箱线图提供了商品价格的五数概括(最小值、第一四分位数、中位数、第三四分位数、最大值),以及可能的异常值。
价格密度图:这个密度图展示了价格的概率密度分布,可以帮助更详细地了解价格分布的形状。

补货模型的构建步骤

  1. 数据整合
    将商品价格数据与预测需求数据结合,以便在补货决策中考虑成本。
  2. 确定补货策略
    我们将采用周期性盘点库存策略(s, S)。
    根据商品的预测需求和价格确定每个商品的s和S值。
  3. 考虑库存成本
    考虑持有成本(基于商品价格和库存水平)和缺货成本(当需求不能被满足时)。
    目标是平衡成本和服务水平。
  4. 模型实现
    使用Python来实现这个模型。
    可以考虑使用库存管理理论,如经济订货量(EOQ)模型
    或者基于机器学习的预测模型。
    或者构建规划方程
  5. 模型测试与优化
    测试模型在不同参数下的表现。
    根据成本、库存水平和服务水平进行优化。
  6. 结果输出
    输出2023-05-16至2023-05-30期间的补货计划

结合了预测需求数据和商品价格来计算每个商品的补货点(s值)和目标库存水平(S值)。这里,s和S的计算基于简单的假设
需要考虑了持有成本和缺货成本,这些成本根据商品价格和设定的比率计算得出。
下一步
参数调整:根据具体需求和成本考虑,调整s和S的计算方法。
模型验证:测试模型以确保其准确性和有效性。
优化策略:可能需要进一步优化策略,以更好地适应实际情况。
#初步代码
import pandas as pd
import numpy as np

File paths

forecast_results_file_path = ‘结果表1-预测结果表.xlsx’
product_price_file_path = ‘商品价格数据.xlsx’

Load the forecast results data

forecast_results_data = pd.read_excel(forecast_results_file_path)

Load the product price data

product_price_data = pd.read_excel(product_price_file_path)

Constants and assumptions

initial_inventory = 5 # Initial inventory level for all products
lead_time = 3 # Lead time in days
review_period = 1 # Review period in days
holding_cost_rate = 0.01 # Holding cost rate (percentage of product price)
shortage_cost_rate = 0.02 # Shortage cost rate (percentage of product price)

Merging forecast data with price data

merged_data = forecast_results_data.merge(product_price_data, on=‘product_no’, how=‘left’)

Function to calculate s and S values for each product

def calculate_replenish_points(row):
forecast_demand = row[‘forecast_qty’]
price = row[‘price’]
holding_cost_per_unit = price * holding_cost_rate
shortage_cost_per_unit = price * shortage_cost_rate
return s, S

Apply the function to each row in the dataframe

merged_data[[‘s’, ‘S’]] = merged_data.apply(lambda row: calculate_replenish_points(row), axis=1, result_type=“expand”)

Display the updated dataframe

merged_data.head()

初步预测结果对可视化

在这里插入图片描述

预测数量分布图:这个直方图展示了预测数量的分布情况,并包含一个核密度估计(KDE)曲线,有助于理解预测数量的总体分布趋势。
预测数量箱线图:这个箱线图提供了预测数量的五数概括(最小值、第一四分位数、中位数、第三四分位数、最大值),以及可能的异常值。
预测数量密度图:这个密度图显示了预测数量的概率密度分布,可以更详细地了解预测数量分布的形状。

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

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

相关文章

Qt12.8

使用手动连接,将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中,在自定义的槽函数中调用关闭函数 将登录按钮使用qt5版本的连接到自定义的槽函数中,在槽函数中判断ui界面上输入的账号是否为"admin",密码是否为…

线程池的使用及实现

使用多进程进行并发编程,会频繁的创建销毁进程,效率比较慢,所以引入了线程,线程使用复用资源的方式提高了创建销毁的效率,但是随着创建线程的频率进一步提高,开销仍然无法忽略不计了。 要想办法优化此处线…

防火墙是什么?聊聊部署Web应用防火墙的作用

数字经济时代,也是一个应用爆炸的时代。在享受应用带来的便利同时,当前却出现许多热点威胁,如供应链安全、零日漏洞、数据泄露等,都给现代化应用带来严峻挑战。有了WAF防火墙的帮助,就可以拦截一系列企图通过入侵系统来…

区块链如何影响数字营销的各个方面?

在过去的几年里,由于区块链等新技术和趋势的进步,数字营销领域发生了各种变化和发展。区块链是加密货币爱好者和投资者当前的流行语。然而,它的可能性已经超出了加密货币的世界,今天,来自不同行业的组织正在获得他们的…

目标检测器技术演进简史

引言 目标检测算法的发展已经取得了长足的进步,从早期的计算机视觉方法开始,通过深度学习达到了很高的准确度。在这篇博文中,我们将一起回顾一下这些算法的发展阶段以及现代目标检测系统中使用的主要方法。 我们首先回顾早期传统的目标检测…

服务器端模板注入 (SSTI) 漏洞实战与技巧,网络高级工具透明代理的几种实现方式

服务器端模板注入 (SSTI) 漏洞实战与技巧,网络高级工具透明代理的几种实现方式。 SSTI(Server-Side Template Injection)从名字可以看出即是服务器端模板注入。比如python的flask、php的thinkphp、java的spring等框架一般都采用MVC的模式,用户的输入先进入Controller控制器,…

内网渗透基础

内网 内网指的是内部局域网,常说的LAN(local area network)。常见家庭wifi网络和小型的企业网络,通常内部计算机直接访问路由器设备,路由器设备接入移动电信的光纤实现上网。 内部局域网可以通过交换机/防火墙组成多个…

华清远见嵌入式学习——QT——作业2

作业要求&#xff1a; 代码运行效果图&#xff1a; 登录失败 和 最小化 和 取消登录 登录成功 和 X号退出 代码&#xff1a; ①&#xff1a;头文件 #ifndef LOGIN_H #define LOGIN_H#include <QMainWindow> #include <QLineEdit> //行编辑器类 #include…

《深入理解计算机系统》学习笔记 - 第四课 - 机器级别的程序

Lecture 05 Machine Level Programming I Basics 机器级别的程序 文章目录 Lecture 05 Machine Level Programming I Basics 机器级别的程序intel 处理器的历史和体系结构芯片的构成AMD 公司(Advanced Micro Devices&#xff0c;先进的微型设备) C, 汇编, 机器代码定义汇编/机器…

MDK官网如何下载stm32支持包

网站&#xff1a;https://www.keil.com/demo/eval/arm.htm 1 2 3点这个下载

打造专属小程序,乔拓云模板平台助力商家抢占先机

打造专属小程序&#xff0c;乔拓云模板平台助力商家抢占先机&#xff01;该平台涵盖全行业小程序模板&#xff0c;一键复制即可上线。 想要快速创建高效实用的小程序&#xff0c;乔拓云小程序模板开发平台为您提供了解决方案&#xff01;我们为您提供一系列精心设计的小程序模板…

智汇恒星科技|控乐屋.全宅智能冠军代言来啦, 智慧家居千亿蓝海

随着5G、大数据、云计算、物联网等技术的发展&#xff0c;智能化正覆盖人们生活的方方面面&#xff0c;全屋智能的出现为“一键式”智能家居生活享受提供无限可能。近年来智能家居行业总体规模增长迅速&#xff0c;数据显示&#xff0c;2022年中国智能家居行业市场规模约为6200…

flstudio21破解汉化版2024最新水果编曲使用教程

​ 如果你一直梦想制作自己的音乐(无论是作为一名制作人还是艺术家)&#xff0c;你可能会想你出生在这个时代是你的幸运星。这个水果圈工作室和上一版之间的改进水平确实令人钦佩。这仅仅是FL Studio 21所提供的皮毛。你的音乐项目的选择真的会让你大吃一惊。你以前从未有过这…

vue3移动端脚手架(纯净,集成丰富)

概述 一个纯净的移动端框架 &#xff0c;用到了 Vue3 vuex Vite3 Vant3 sass eslint stylelint htmlhint husky commitlint axios axios-adapter VConsole 自定义全局 loading &#xff0c;自定义函数式 dialog &#xff08;api模仿微信小程序&#xff09;&#x…

选自《洛谷深入浅出进阶篇》——欧拉函数+欧拉定理+扩展欧拉定理

欧拉函数&#xff1a; 欧拉函数定义&#xff1a; 1~n中与n互质的数的个数。 比如 欧拉函数是积性函数&#xff1a;&#xff08;也就是&#xff09;当 n与m互质的时候&#xff1a; 由算术基本定理&#xff0c;我们可以设n&#xff0c;那么我们只要计算出的取值就能求出的取…

【后端学前端学习记录】学习计划

1、个人背景 写了足够久的后端了&#xff0c;常用的语言基本上都接触过&#xff0c;没有在工作中写过前端 一直想做一些前端的工作&#xff0c;但是前端技能不足加上自己审美不行&#xff0c;写出的界面总是很丑 所以一直对前端做不好&#xff0c;也没有真正下手。 2、动机 种…

C# Solidworks二次开发:选择管理器相关的API介绍

今天在讲述主要内容之前&#xff0c;先说一个不太相关的问题。 我之前在其他文章中看到有一些朋友在问为什么获取到的点位数据需要乘以1000进行单位转换&#xff0c;其实原因是这样的&#xff0c;在所有使用的API中如果没有特殊说明&#xff0c;所有的长度单位都是米&#xff…

Langchain-Chatchat大语言模型本地知识库的踩坑、部署、使用

Langchain-Chatchat的部署 Langchain-Chatchat概述实现原理 开发环境准备软件要求硬件要求 部署拉取仓库创建虚拟环境安装全部依赖初始化配置文件初始化知识库模型下载启动项目启动API服务启动Web UI服务使用对话功能知识库管理文件对话搜索引擎问答 异常集合异常1异常2异常3 L…

Linux——web网站服务(一)

一、安装httpd服务器Apache网站服务 1、准备工作 为了避免发送端口冲突&#xff0c;程序冲突等现象&#xff0c;卸载使用rpm方式安装的httpd #使用命令检查是否下载了httpd [rootserver ~]# rpm -qa httpd #如果有则使用 [rootserver ~]# rpm -e httpd --nodeps Apache的配置…

AGI 时代,小红书邀您一起复盘年度 100 件值得学习的好案例

2023 年&#xff0c;由 ChatGPT 引爆新一轮人工智能热潮&#xff0c;开启了由大模型驱动的 AGI 时代。随着 AIGC 的快速崛起&#xff0c;传统的研发模式是否会被 AI 颠覆也成为了巨大的未知数。面对不同规模团队与不同业务场景&#xff0c;企业想要找到可靠、可行、可落地的转型…