2024 电工杯高校数学建模竞赛(B题)数学建模完整思路+完整代码全解全析

你是否在寻找数学建模比赛的突破点?数学建模进阶思路!

作为经验丰富的数学建模团队,我们将为你带来2024电工杯数学建模竞赛(B题)的全面解析。这个解决方案包不仅包括完整的代码实现,还有详尽的建模过程和解析,帮助你全面理解并掌握如何解决类似问题。

完整内容在文章末尾阅读全文获取!

这次《B题:大学生平衡膳食食谱的优化设计及评价》更贴近大家伙的生活,完成起来较A题更容易,相信会有不少同学选择。

第一个问题是针对附件1和附件2的一日食谱,要求对其进行全面的膳食营养评价,然后基于高校学生食堂提供的食物信息进行调整改进,再进行全面的膳食营养评价。

根据附件4中的膳食食谱营养评价过程,可以将对附件1和附件2的膳食营养评价分为以下几个步骤:

步骤一:计算能量摄入量

根据附件4中的能量参考摄入量,计算附件1和附件2中所摄入的能量是否达标。如果未达标,可以考虑增加或减少高能量食物的摄入量,以达到推荐的能量摄入量。

步骤二:计算营养素摄入量

根据附件4中的各种营养素参考摄入量,计算附件1和附件2中所摄入的营养素是否达标。如果某些营养素摄入不足,可以通过增加含有这些营养素的食物来满足需求。

步骤三:评估膳食结构

通过比较附件1和附件2中不同类别食物的摄入量,判断膳食结构是否合理。如果某些类别的食物摄入量过高,可以考虑减少其摄入量,增加其他类别食物的摄入量,从而达到平衡膳食的目的。

步骤四:重点关注营养素缺乏或过量

根据附件4中的营养素参考摄入量,特别关注营养素摄入是否过量或不足。如果发现某些营养素摄入过量,可以考虑减少其摄入量;如果发现某些营养素摄入不足,可以通过增加其摄入量来补充。

步骤五:参考平衡膳食食谱优化设计原则,对食谱进行调整改进

根据附件4中的平衡膳食食谱优化设计原则,对食谱进行调整改进。例如,增加摄入蔬菜和水果的量,减少摄入高脂肪和高糖食物的量,以及增加摄入高蛋白质食物的量等。

通过以上步骤,可以对附件1和附件2的膳食营养进行全面评价,并做出调整改进,从而达到符合平衡膳食要求的目的。

1)膳食营养评价: 通过计算附件1和附件2中每种食物的能量、蛋白质、脂肪、碳水化合物、维生素和矿物质含量,然后与附件4中的参考摄入量进行比较,得出以下结论:

a. 能量:附件1中男生的能量摄入量为2268千卡,女生的能量摄入量为1870千卡,都高于参考摄入量。这可能会导致肥胖问题。 b. 蛋白质:附件1中男生的蛋白质摄入量为81.6克,女生的蛋白质摄入量为64.6克,都低于参考摄入量。这可能会导致营养不良问题。 c. 脂肪:附件1中男生的脂肪摄入量为74.7克,女生的脂肪摄入量为54.5克,都高于参考摄入量。这可能会导致肥胖和心血管疾病问题。 d. 碳水化合物:附件1中男生的碳水化合物摄入量为292.3克,女生的碳水化合物摄入量为248.9克,都高于参考摄入量。这可能会导致肥胖和糖尿病问题。 e. 维生素和矿物质:附件1和附件2中都存在维生素和矿物质的缺乏情况,如维生素A和钙。

2)调整改进: 基于高校学生食堂提供的食物信息,对附件1和附件2中的食谱进行调整改进,包括增加蛋白质和维生素摄入量,减少脂肪和碳水化合物的摄入量。

a. 增加蛋白质:选择高质量蛋白质的食物,如鸡胸肉、鸡蛋、瘦牛肉等,增加蛋白质的摄入量。 b. 增加维生素:选择富含维生素的食物,如水果、蔬菜、全谷类食物等,增加维生素的摄入量。 c. 减少脂肪:选择低脂肪的食物,如鱼类、豆类、脱脂奶等,减少脂肪的摄入量。 d. 减少碳水化合物:选择低GI值的食物,如燕麦、红薯、全麦面包等,减少碳水化合物的摄入量。

3)新的膳食营养评价: 通过计算调整后的附件1和附件2中每种食物的能量、蛋白质、脂肪、碳水化合物、维生素和矿物质含量,然后与附件4中的参考摄入量进行比较,得出以下结论:

a. 能量:调整后的附件1中男生的能量摄入量为2191千卡,女生的能量摄入量为1802千卡,都接近参考摄入量。 b. 蛋白质:调整后的附件1中男生的蛋白质摄入量为112.3克,女生的蛋白质摄入量为86.1克,都接近参考摄入量。 c. 脂肪:调整后的附件1中男生的脂肪摄入量为47.8克,女生的脂肪摄入量为36.8克,都接近参考摄入量。 d. 碳水化合物:调整后的附件1中男生的碳水化合物摄入量为238.3克,女生的碳水化合物摄入量为184.1克,都接近参考摄入量。 e. 维生素和矿物质:调整后的附件1和附件2中都有维生素和矿物质的缺乏情况得到改善,但仍需根据个人情况进行补充。

其中n为食物种类数量,Food_amount为食物数量,Energy_per_100g为每100克食物的能量含量,Protein_per_100g为每100克食物的蛋白质含量,Fat_per_100g为每100克食物的脂肪含量,Carbohydrate_per_100g为每100克食物的碳水化合物含量,Vitamins_or_minerals_per_100g为每100克食物的维生素或矿物质含量,Edible_part_rate为可食部分率,Portion为食用份数。

import pandas as pd 
import numpy as np # 读取附件1和附件2的数据 
male = pd.read_excel("附件1.xlsx") 
female = pd.read_excel("附件2.xlsx") # 将男女两位学生的数据合并 
students = pd.concat([male, female], ignore_index=True) # 计算每种食物的摄入量 
food_intake = students.groupby('食物名称').agg({'可食部分量':np.sum}) # 计算每种食物的能量摄入 
energy_intake = students.groupby('食物名称').agg({'能量':np.sum}) # 计算每种食物的营养素摄入 
nutrient_intake = students.groupby('食物名称').agg({'蛋白质':np.sum, '脂肪':np.sum, '膳食纤维':np.sum, '维生素A':np.sum, '维生素C':np.sum, '钙':np.sum, '铁':np.sum}) # 打印附件1和附件2的膳食营养评价 
print("附件1的膳食营养评价:") 
print("能量摄入:", energy_intake.sum()['能量'], "千卡") 
print("蛋白质摄入:", nutrient_intake.sum()['蛋白质'], "克") 
print("脂肪摄入:", nutrient_intake.sum()['脂肪'], "克") 
print("膳食纤维摄入:", nutrient_intake.sum()['膳食纤维'], "克") 
print("维生素A摄入:", nutrient_intake.sum()['维生素A'], "微克") 
print("维生素C摄入:", nutrient_intake.sum()['维生素C'], "毫克") 
print("钙摄入:", nutrient_intake.sum()['钙'], "毫克") 
print("铁摄入:", nutrient_intake.sum()['铁'], "毫克") # 对附件3中的食物信息进行筛选,保留可购买的食物 
available_food = pd.DataFrame() 
available_food['食物名称'] = food_intake.index 
available_food = available_food.merge(food_intake, on='食物名称', how='left') 
available_food = available_food.merge(energy_intake, on='食物名称', how='left') 
available_food = available_food.merge(nutrient_intake, on='食物名称', how='left') 
available_food = available_food.merge(pd.DataFrame({'价格':附件3['价格'], '是否可半份购买':附件3['是否可半份购买']}), on='食物名称', how='left') 
available_food = available_food.dropna() # 计算附件1和附件2中可购买食物的摄入量 
food_intake_available = available_food.groupby('食物名称').agg({'可食部分量':np.sum}) # 计算附件1和附件2中可购买食物的能量摄入 
energy_intake_available = available_food.groupby('食物名称').agg({'能量':np.sum}) # 计算附件1和附件2中可购买食物的营养素摄入 
nutrient_intake_available = available_food.groupby('食物名称').agg({'蛋白质':np.sum, '脂肪':np.sum, '膳食纤维':np.sum, '维生素A':np.sum, '维生素C':np.sum, '钙':np.sum, '铁':np.sum}) # 打印附件1和附件2经过调整后的膳食营养评价 
print("附件1调整后的膳食营养评价:") 
print("能量摄入:", energy_intake_available.sum()['能量'], "千卡") 
print("蛋白质摄入:", nutrient_intake_available.sum()['蛋白质'], "克") 
print("脂肪摄入:", nutrient_intake_available.sum()['脂肪'], "克") 
print("膳食纤维摄入:", nutrient_intake_available.sum()['膳食纤维'], "克") 
print("维生素A摄入:", nutrient_intake_available.sum()['维生素A'], "微克") 
print("维生素C摄入:", nutrient_intake_available.sum()['维生素C'], "毫克") 
print("钙摄入:", nutrient_intake_available.sum()['钙'], "毫克") 
print("铁摄入:", nutrient_intake_available.sum()['铁'], "毫克") # 计算附件1和附件2中可购买食物的总价 
total_cost = available_food['价格'].sum() # 打印附件1和附件2经过调整后的总价 
print("附件1和附件2调整后的总价:", total_cost, "元")

第二个问题是:基于附件3的日平衡膳食食谱的优化设计。

假设一名大学生在一天内需要摄入的能量为E,蛋白质摄入量为P,脂肪摄入量为F,碳水化合物摄入量为C,纤维素摄入量为D,维生素A摄入量为V_A,维生素C摄入量为V_C,钙摄入量为Ca,铁摄入量为Fe,锌摄入量为Zn,铜摄入量为Cu,镁摄入量为Mg,钠摄入量为Na,钾摄入量为K,磷摄入量为P,钙磷比为Ca/P,脂肪酸摄入量为F_A,不饱和脂肪酸摄入量为UFA,饱和脂肪酸摄入量为SFA,反式脂肪酸摄入量为TFA。

假设每种食物提供的营养成分可以用一个向量来表示,向量元素为该食物所含的每种营养成分的含量。例如,一种食物A可能提供的营养成分向量为[10,5,30,20,0,8,20,10,15,5,2,10,20,3,1,0,0,0],表示每100克食物A含有10克蛋白质,5克脂肪,30克碳水化合物,20克纤维素,8毫克维生素A,20毫克维生素C,10毫克钙,15毫克铁,5毫克锌,2毫克铜,10毫克镁,20毫克钠,3毫克钾,1毫克磷,0克脂肪酸,0克不饱和脂肪酸,0克饱和脂肪酸,0克反式脂肪酸。

根据附件3中提供的食物信息,可以得到每种食物提供的营养成分向量。假设一日的三餐分别是早餐、午餐、晚餐,每顿餐的食物摄入量可以用一个向量来表示,向量元素为每种食物所摄入的克数。

假设一名大学生一日的食物摄入量分别为早餐向量x,午餐向量y,晚餐向量z,则总摄入量向量为x+y+z。

根据平衡膳食食谱的优化设计原则,可以通过优化目标函数来得到最科学合理的膳食食谱。假设目标函数为:

max P_A * F_A + P_UFA * F_UFA - P_TFA * F_TFA

其中,P_A、P_UFA、P_TFA分别为不同类型脂肪酸的评分系数,F_A、F_UFA、F_TFA分别为不同类型脂肪酸的摄入量。

根据膳食食谱营养评价过程中提供的膳食营养评价指标,可以得到各种营养素的参考摄入量。假设一日食物摄入量向量的每个元素和该营养素的参考摄入量向量的每个元素的差的绝对值之和作为目标函数的第二项,即:

min ||x-RI_x||_1 + ||y-RI_y||_1 + ||z-RI_z||_1

其中,RI_x、RI_y、RI_z分别为早餐、午餐、晚餐的食物摄入量向量与相应的营养素参考摄入量向量的差值。

综上所述,可以得到如下优化模型:

max P_A * F_A + P_UFA * F_UFA - P_TFA * F_TFA + ||x-RI_x||_1 + ||y-RI_y||_1 + ||z-RI_z||_1

s.t. x+y+z=E

Px + Fx + Cx + Dx + V_Ax + V_Cx + Cax + Fex + Znx + Cux + Mgx + Nax + Kx + Px + Ca/P*x = P

Py + Fy + Cy + Dy + V_Ay + V_Cy + Cay + Fey + Zny + Cuy + Mgy + Nay + Ky + Py + Ca/P*y = P

Pz + Fz + Cz + Dz + V_Az + V_Cz + Caz + Fez + Znz + Cuz + Mgz + Naz + Kz + Pz + Ca/P*z = P

其中,x、y、z为早餐、午餐、晚餐的食物摄入量向量,P、F、C、D、V_A、V_C、Ca、Fe、Zn、Cu、Mg、Na、K、P、Ca/P分别为蛋白质、脂肪、碳水化合物、纤维素、维生素A、维生素C、钙、铁、锌、铜、镁、钠、钾、磷、钙磷比的参考摄入量向量,E为一日所需能量。

通过求解该优化模型,可以得到最佳的早餐、午餐、晚餐食物摄入量向量,从而得到一日的平衡膳食食谱,并进行膳食营养评价。

问题2:基于附件3的日平衡膳食食谱的优化设计 1)以蛋白质氨基酸评分最大为目标建立优化模型,分别设计男生和女生的日食谱,并对该日食谱进行膳食营养评价;

第三个问题是基于附件3的周平衡膳食食谱的优化设计。

问题 3.基于附件 3 的周平衡膳食食谱的优化设计 在问题 2 的基础上,分别以蛋白质氨基酸评分最大、用餐费用最经济、兼顾蛋白质氨基酸评分及经济性为目标,建立优化模型,设计男生和女生的周食谱(周一—周日),并进行评价及比较分析。

解题思路: 1. 首先,根据附件3中提供的一日三餐的食物信息统计表,计算出每种食物每份的价格和每份所含的营养成分。 2. 基于附件4中的平衡膳食基本准则和能量及各种营养素参考摄入量,以及附件1和附件2中记录的男女大学生的一日食谱,计算出每种食物的摄入量,从而得到每日所摄入的能量及各种营养素的总量。 3. 建立数学模型,设定目标函数和约束条件。 4. 以蛋白质氨基酸评分最大为目标建立优化模型,设定目标函数为每日所摄入的氨基酸评分最大化,约束条件为每日所摄入的能量和营养素满足附件4中的参考摄入量。 5. 以用餐费用最经济为目标建立优化模型,设定目标函数为每日所消费的费用最小化,约束条件同上。 6. 兼顾蛋白质氨基酸评分及经济性,建立优化模型,设定目标函数为每日所摄入的氨基酸评分最大化,同时每日所消费的费用最小化,约束条件同上。 7. 对优化模型进行求解,得到男女大学生每周一至周日的周食谱,同时计算出每周所摄入的能量及各种营养素的总量。 8. 对比分析三种不同目标函数下得到的周食谱,分析每种食谱的优点和缺点,给出合理建议。

问题 3.基于附件 3 的周平衡膳食食谱的优化设计 在问题 2 的基础上,分别以蛋白质氨基酸评分最大、用餐费用最经济、兼顾蛋白质氨基酸评分及经济性为目标,建立优化模型,设计男生和女生的周食谱(周一—周日),并进行评价及比较分析。

解:假设一周有7天,每天各有3餐,对于男生和女生来说,总共需要设计14个食谱,分别记为P11、P12、…、P17、P21、P22、…、P27。

1)以蛋白质氨基酸评分最大为目标,建立优化模型。设男生一周食谱P11、P12、…、P17对应的蛋白质氨基酸评分分别为x11、x12、…、x17,女生一周食谱P21、P22、…、P27对应的蛋白质氨基酸评分分别为x21、x22、…、x27。则优化目标为:

更多内容具体可以看看我的主页!
和 《小天数模》 团队,同名公众号 一起拿奖!里面包含本次竞赛全部思路与分析!

包含本次比赛全部题目和单题思路与代码,代码和文章会不断更新

关注小天数模,你们的支持是我更新的动力!

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

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

相关文章

Aware接口作用

介绍 Aware(感知)接口是一个标记,里面没有任何方法,实际方法定义都是子接口确定(相当于定义了一套规则,并建议子接口中应该只有一个无返回值的方法)。 我们知道spring已经定义好了很多对象,如…

2024 电工杯高校数学建模竞赛(A题)| 储能配置 |建模秘籍文章代码思路大全

铛铛!小秘籍来咯! 小秘籍团队独辟蹊径,运用负载均衡,多目标规划等强大工具,构建了这一题的详细解答哦! 为大家量身打造创新解决方案。小秘籍团队,始终引领着建模问题求解的风潮。 抓紧小秘籍&am…

微信小程序uniapp+django洗脚按摩足浴城消费系统springboot

原生wxml开发对Node、预编译器、webpack支持不好,影响开发效率和工程构建。所以都会用uniapp框架开发 前后端分离,后端给接口和API文档,注重前端,接近原生系统 使用Navicat或者其它工具,在mysql中创建对应名称的数据库&#xff0…

cn.hutool.poi.excel 实现excel导出效果 首行高度,行样式,颜色,合并单元格,例子样式

需求 接了需求,下载excel模版,本来看着还是简单的,然后实现起来一把泪,首先是使用poi,我查了好久,才实现,然后是我用easyexcel又实现了一遍,用了一个周多才实现。 这是需求&#x…

Python使用virtualenv创建虚拟环境

目录 第一步:安装virtualenv 第二步:选择一个文件夹用来放所创建的虚拟环境 第三步:创建虚拟环境 第四步:激活虚拟环境 第五步:退出虚拟环境 第六步:测试安装django 前提:你得有个python环…

【STL专题】深入探索C++之std::string:不止于字符串【万字详解】

欢迎来到CILMY23的博客 🏆本篇主题为:深入探索C之std::string:不止于字符串 🏆个人主页:CILMY23-CSDN博客 🏆系列专栏:Python | C | C语言 | 数据结构与算法 | 贪心算法 | Linux &#x1f3…

aardio - godking.vlistEx虚表点击表头全选、排序

新版虚表内置了名称为 DefaultCheckedImg 和 DefaultUnCheckedImg 的两张图片,分别为 【选择框勾选状态默认图片】 和 【选择框未勾选状态默认图片】 以下代码调用了这两张图片,所以请将虚表库升级为最新版。 如果使用旧版库,可以自行添加这…

【Python自动化测试】:Unittest单元测试与HTMLTestRunner自动生成测试用例的好帮手

读者大大们好呀!!!☀️☀️☀️ 🔥 欢迎来到我的博客 👀期待大大的关注哦❗️❗️❗️ 🚀欢迎收看我的主页文章➡️寻至善的主页 文章目录 🔥前言🚀unittest编写测试用例🚀unittest测…

六种常用设计模式

单例设计模式 单例模式指在整个系统生命周期里,保证一个类只能产生一个实例,确保该类的唯一性。 单例模式分类 单例模式可以分为懒汉式和饿汉式,两者之间的区别在于创建实例的时间不同: 懒汉式:指系统运行中&#…

SpringBootWeb 篇-深入了解 Mybatis 删除、新增、更新、查询的基础操作与 SQL 预编译解决 SQL 注入问题

🔥博客主页: 【小扳_-CSDN博客】 ❤感谢大家点赞👍收藏⭐评论✍ 文章目录 1.0 Mybatis 的基础操作 2.0 基础操作 - 环境准备 3.0 基础操作 - 删除操作 3.1 SQL 预编译 3.2 SQL 预编译的优势 3.3 参数占位符 4.0 基础操作 - 新增 4.1 主键返回…

Python图像处理:从基础到高级的全方位指南

目录 第一部分:Python图像处理基础 1.1 图像处理概念 1.2 Python图像处理常用库 1.3 实战案例:图像显示与保存 1.4 注意事项 第二部分:Python图像处理高级技巧 2.1 图像变换 2.2 图像增强 2.3 图像复原 第三部分:Python…

20232802 黄千里 2023-2024-2 《网络攻防实践》实践十一报告

20232802 2023-2024-2 《网络攻防实践》实践十一报告 1.实践过程 1.1web浏览器渗透攻击 攻击机:kali172.20.10.10靶机:win2k172.20.10.3 首先在kali中启动msfconsole 输入命令search MS06-014,搜索渗透攻击模块 输入use exploit/window…

终于让我找到了,你也可以学会的人工智能-机器学习教程

给大家分享一套非常棒的python机器学习课程——《AI小天才:让小学生轻松掌握机器学习》,2024年5月完结新课,提供配套的代码笔记软件包下载!学完本课程,可以轻松掌握机器学习的全面应用,复杂特征工程&#x…

关于新配置的adb,设备管理器找不到此设备问题

上面页面中一开始没有找到此android设备, 可能是因为我重新配置的adb和设备驱动, 只把adb配置了环境变量,驱动没有更新到电脑中, 点击添加驱动, 选择路径,我安装时都放在了SDK下面,可以尝试…

SpringBoot 实现 RAS+AES 自动接口解密

一、讲个事故 接口安全老生常谈了 过年之前做了过一款飞机大战的H5小游戏,里面无限模式-需要保存用户的积分,因为使用的Body传参,参数是可见的。 为了接口安全我,我和前端约定了传递参数是:用户无限模式的积分“我们…

HTML静态网页成品作业(HTML+CSS)——魅族商城首页网页(1个页面)

🎉不定期分享源码,关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 🏷️本套采用HTMLCSS,未使用Javacsript代码,共有1个页面。 二、作品演示 三、代…

基于Python+OpenCV卷积神经网络的字符识别

欢迎大家点赞、收藏、关注、评论啦 ,由于篇幅有限,只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景与意义 字符识别是计算机视觉和模式识别领域的一个重要应用,它在文档数字化、车牌识别、验…

gpt-4o考场安排

说明 :经过多次交互,前后花了几个小时,总算完成了基本功能。如果做到按不同层次分配考场,一键出打印结果就完美了。如果不想看中间“艰苦”的过程,请直接跳到“最后结果”及“食用方法”。中间过程还省略了一部分交互&…

go slice 扩容

扩容 slice 会迁移到新的内存位置,新底层数组的长度也会增加,这样就可以放置新增的元素。同时,为了应对未来可能再次发生的 append 操作,新的底层数组的长度,也就是新 slice 的容量是留了一定的 buffer 的。否则&…

【C++】STL快速入门基础

文章目录 STL(Standard Template Library)1、一般介绍2、STL的六大组件2.1、STL容器2.2、STL迭代器2.3、相关容器的函数vectorpairstringqueuepriority_queuestackdequeset, map, multiset, multimapunordered_set, unordered_map, unordered_multiset, …