2019年认证杯SPSSPRO杯数学建模D题(第二阶段)5G时代引发的道路规划革命全过程文档及程序
2019年认证杯SPSSPRO杯数学建模
D题 5G时代引发的道路规划革命
原题再现:
忙着回家或上班的司机们都知道交通堵塞既浪费时间又浪费燃料,甚至有的时候会带来情绪上的巨大影响,引发一系列的交通问题。据报道,每年交通拥堵使得美国市民在路上总共浪费了超过 55 亿小时,以及价值达到 1210亿美元的 29 亿加仑燃料。虽然十字路口和州际公路的匝道处交通十分繁忙,但是大多数乡村公路却鲜有车流,道路占用率只有 5%。
即将到来的 5G(第五代移动通信网络)时代,将有可能解决这个问题,5G的无线传输带宽的峰值理论传输速度可达每秒 10 Gb 以上,这样我们就可以让汽车之间实时共享信息。未来,汽车之间可以交换诸如位置,速度和目的地之类的信息,进而核心控制系统可以基于这些信息,为司机生成个性化指令。通过告诉司机最佳行驶速度、最佳车道或最佳路线,不仅可以消除走走停停的现象,还可以提高交通安全性,如下图所示。

第二阶段问题:
1. 如果车辆之间的互联非常普及,所有车辆都可以自动驾驶,请建立数学模型探讨是否有可能取消路口的红绿灯?这样的通行效率相比有红绿灯时候是否会提高?
2. 在一个平均通过速度为 15 公里每小时的路口,一辆执行任务的消防车想以 40 公里每小时的速度快速通过,控制系统应该如何进行调度?
整体求解过程概述(摘要)
本文针对十字路口发生交通故障时,为尽快疏散堵塞车辆进行分析研究,以题目所给插图进行分析假设,假设故障发生在东西走向。
首先,对南北方向与东西方向的车流量和绿灯时间进行假设分析,列出南北方向与东西方向红绿灯调整系数与各方向上绿灯通行时间之间的关系;由于假设故障发生在东西方向,所以着重研究东西方向上直行车辆与左转车辆的数量,直行通行时间与左转通行时间,从而给出东西方向红绿灯左转与直行调整系数与直行车数量、左转车数量之间的关系[1]。从而根据以上关系计算出南北方向、东西方向中直行与左转的红绿灯时间(绿灯时间规划)[2]。
其次,随着科学技术的发展,网络技术的不断跟新换代,车辆已经可以做到自动接收无线信号,从而自动调整行驶路线与方向。因此,可以通过道路上的车流量情况动态规划红绿灯的开闭时间,从而完善红绿灯时间的规划[3],到达更快疏散堵塞路段的效果。
最后,着重分析十字路口严重堵车时,左转和直行车辆的多少对疏散交通所用时间造成的影响[4]。列出绿灯时间与车身长、车距与速度之间的关系,确定直行绿灯时间与左转绿灯时间的最佳比例,从而在最短时间内使十字路口的离开率大于到达率,以达到最佳疏散效果。
问题二立足于所有车辆均可实现自动驾驶进行研究。首先对原始红绿灯使用过程中存在浪费绿灯时间进行数据统计与分析后可见传统红绿灯在某些时段会存在浪费绿灯时间的情况。取消红绿灯后将十字路口看作服务台,每辆车看作顾客,提出优先级服务公式,并且给出某辆车接受服务时,其它车道车辆是否允许通过十字路口做出规定。从而得到没有红绿灯车辆该如何安全高效地通过十字路口的模型[4]。
在问题二中严格禁止可能会与接受服务车辆发生碰撞的车道内车辆的通行。问题三中研究当消防车以高于其它车辆速度的速度通过十字路口时,其它车道内车辆可能会与之发生碰撞的情况及相关车辆之间可能发生碰撞的情况,分析车辆加速度与减速通过距离之间的关系。为了避免发生碰撞,调度系统应做出相应调整来避开碰撞,因为消防车要与其他车辆错开通过十字路口,且其他车辆之间也可能发生交通事故,需要考虑的因素极多,所以我们通过计算消防车与其他车辆相撞点和其他车辆与其他车辆相撞点来减少需要考虑的因素,从而把复杂的模型简化。只要其他车辆在消防车或其他车辆到达相撞点时,通过变速不同时到达相撞点,就不会发生碰撞,从而既让消防车快速通过,其他车也不耽搁时间,又不发生交通事故。
问题分析:
交通拥堵主要与十字路口行驶车辆的流量、红绿灯时间和交通故障等诸多因素有关。
针对问题 1:主要考虑发生交通故障时,通过调整车辆行驶方向和控制红绿灯时长来解决交通拥堵问题。在十字路口交通高峰期最高峰值是 500 辆/小时,而在此时发生交通故障,有一条路的两车道都停用 30 分钟,在道路恢复正常使用前,主控中心通过网络给车辆发送行驶的调度指令从而改变行驶车辆的行驶方向和自动控制红绿灯时间来将道路通行时间降到最低。因为车身长度和车距对通过红绿灯的时间有一定的影响,所以我们规定车身和车距为一个固定住,从而简化模型,降低车身和车距对交通拥堵的影响。通过计算红绿灯调整系数来确定红绿灯时间的调整方案,根据题中情况要使拥堵处在最短时间内疏散,再进行左转与直行的情况分析,从而得出最短时间疏散的方案。
针对问题 2:红绿灯是每个路口必备的交通指挥系统,也降低了交通事故发生概率,然而在很多各个方向上的车辆数量有较大差异,导致红绿灯时间分配不均匀。使得司机等待时间过长,大大降低了交通效率。对此为解决该问题我们在自动驾驶的前提下,根据不同车辆等待时间与通过路口所需时间长短,来确定各个车辆先后行驶顺序。达到各车辆等待时间大体相同,同时也提高十字路口的通行效率。
针对问题 3:若消防车要以稳定的速度 40km/h 安全通过路口,那么其他车辆必须针对本身位置与消防车位置的不同,来做出不同的速度改变,而速度因加速度改变,所以主要研究方向为其他车辆加速度改变情况。碰撞时要满足两辆车同时到达相撞点,故我们可以算出两辆车相撞时所需加速度,所需位置情况,所需时间,等因素的联系。要使车辆不相撞则不满足该条件即可。
模型假设:
第一阶段:
1. 每辆车通过故障路段所用时间与换道所用时间相同;
2. 各个车辆行驶速度相同;
3. 所有车辆车身长相等;
4. 所有车辆之间的车距都相等。
第二阶段:
1.把车辆当做质点;
2.把单方向中的两条车道看为一条,不考虑往固定行驶时,车辆在两条车道中变
道产生的影响。
论文缩略图:


全部论文请见下方“ 只会建模 QQ名片” 点击QQ名片即可
部分程序代码:(代码和文档not free)
#includeGraph::Graph()
{MAX_INT = 999999;
}void Graph::clear()
{delete[] mat;for(int i=0; i<num;i++){delete[] dist[i];delete[] path[i];}delete[] path;delete[] dist;spath.clear();nodes.clear();
}bool Graph::readFile(QString fileName)
{QFile f(fileName);QFileInfo fileInfo;fileInfo.setFile(fileName);if(fileInfo.suffix()!= "map")return false;if(!f.open(QIODevice::ReadOnly | QIODevice::Text)){qDebug()<<fileName+" : Open failed";return false;}QTextStream inStream(&f);inStream.readLine(); m = inStream.readLine().toInt();n = inStream.readLine().toInt();num = m*n;dist = new int*[num];path = new int*[num];for(int i=0; i<num;i++){dist[i] = new int[num];path[i] = new int[num];}QStringList strList = inStream.readLine().split(QRegularExpression("\\s+"));for(int i=0; i<num; i++){Node newNode;newNode.nodeName =strList[i];newNode.pos = QPoint(i%n,i/n); nodes.push_back(newNode);qDebug()<<newNode.nodeName<<QString("(%1,%2)").arg(newNode.pos.x()).arg(newNode.pos.y());}while(!inStream.atEnd()){QString str = inStream.readLine();if(str == "") continue;QStringList slist = str.split(QRegularExpression("\\s+"));int Id1 = getID(slist[0]);int Id2 = getID(slist[1]);Succeed s1(Id2,slist[2].toInt());Succeed s2(Id1,slist[2].toInt());nodes[Id1].succeeds.push_back(s1);nodes[Id2].succeeds.push_back(s2);}return true;
}void Graph::printGraph()
{for(int i=0; i<nodes.size();i++){qDebug()<<QString("Node%1(%2) :").arg(i).arg(nodes[i].nodeName);for(int k=0; k<nodes[i].succeeds.size();k++){qDebug()<<QString("-- Suc%1(%2) : %3").arg(nodes[i].succeeds[k].id).arg(getName(nodes[i].succeeds[k].id)).arg(nodes[i].succeeds[k].value);}}
}int Graph::getID(QString nodeName)
{for(int i=0; i<nodes.size(); i++){if(nodes[i].nodeName == nodeName)return i;}return -1;
}QString Graph::getName(int id)
{return nodes[id].nodeName;
}void Graph::setNodeObstacle(QPoint p)
{for(int i=0; i < num;i++){if(nodes[i].pos == p){nodes[i].isObstacle = !nodes[i].isObstacle;break;}}
}void Graph::getMat()
{mat = new int[num*num];for(int i=0; i<num; i++){for(int k=0; k<num; k++){mat[i*num+k] =MAX_INT;if(i==k)mat[i*num+k]=0;}}for(int i=0; i<nodes.size();i++){for(int k=0; k<nodes[i].succeeds.size();k++){mat[i*num+nodes[i].succeeds[k].id] = nodes[i].succeeds[k].value;}}
}void Graph::Floyd()
{for(int i=0; i<num;i++) {for(int k=0; k<num;k++){dist[i][k] = mat[i*num+k];path[i][k] = i;}}for(int k=0; k<num;k++) {if(nodes[k].isObstacle) continue;for(int i = 0; i<num; i++){if(nodes[i].isObstacle) continue;for(int j = 0; j<num; j++){if(nodes[j].isObstacle) continue;if(dist[i][k]+dist[k][j] <dist[i][j]) {dist[i][j] = dist[i][k]+dist[k][j];path[i][j] = path[k][j];}}}}}bool Graph::getShortestPath(QString nodeName)
{spath.clear();int k=getID(nodeName); if(dist[0][k] >= MAX_INT) return false;spath.push_back(k);do{spath.push_back(path[0][k]);k = path[0][k];}while(k != path[0][0]);return true;
}
全部论文及程序请见下方“ 只会建模 QQ名片” 点击QQ名片即可
相关文章:
2019年认证杯SPSSPRO杯数学建模D题(第二阶段)5G时代引发的道路规划革命全过程文档及程序
2019年认证杯SPSSPRO杯数学建模 D题 5G时代引发的道路规划革命 原题再现: 忙着回家或上班的司机们都知道交通堵塞既浪费时间又浪费燃料,甚至有的时候会带来情绪上的巨大影响,引发一系列的交通问题。据报道,每年交通拥堵使得美国…...
可视化k8s页面(Kubepi)
Kubepi是一个简单高效的k8s集群图形化管理工具,方便日常管理K8S集群,高效快速的查询日志定位问题的工具 随便在哪个节点部署,我这里在主节点部署 docker pull kubeoperator/kubepi-server docker run --privileged -itd --restartunless-st…...
1434. 数池塘(四方向)-深度优先搜索-DFS
代码: #include<iostream> using namespace std; char a[200][200]; int fx[4]{0,1,0,-1}; int fy[4]{1,0,-1,0}; int k0; int n,m; void dfs(int x,int y){a[x][y].;int tx,ty;for(int i0;i<4;i){txxfx[i];tyyfy[i];if(tx>1&&tx<n&&am…...
Mysql:重点且常用的操作和理论知识整理 ^_^
目录 1 基础的命令操作 2 DDL 数据库定义语言 2.1 数据库操作 2.2 数据表操作 2.2.1 创建数据表 2.2.2 修改和删除数据表 2.2.3 添加外键 3 DML 数据库操作语言 3.1 插入语句(INSERT) 3.2 修改语句(UPDATE) 3.3 删除语句 3.3.1 DELETE命令 3.3.2 TRUNCATE命令 4 …...
小车辅助脚本编写
小车辅助脚本编写 在远程控制中需要启动非常多的 Launch 文件,在终端启动很麻烦,编写一些脚本可以简化操作 robot_client.sh #!/bin/bashecho "开始执行Bash脚本"# 启动zedm roslaunch zed_wrapper zedm.launch & sleep 5# 启动realsen…...
Modern C++ 一个例子学习条件变量
目录 问题程序 施魔法让BUG浮出水面 条件变量注意事项 修改程序 问题程序 今天无意中看到一篇帖子,关于条件变量的,不过仔细看看发现它并达不到原本的目的。 程序如下,读者可以先想想他的本意,以及有没有问题: #…...
ora-12154无法解析指定的连接标识符
用户反映查询的时候报错ora-12154 这个系统只做历史数据查询使用,使用并不平凡,该数据库曾做过一次服务器间的迁移。 用户描述,所有oracle客户端查询该视图都报tns错误,一般ora-12154会发生在连接数据库时,因为tns配…...
rust跟我学三:文件时间属性获得方法
图为RUST吉祥物 大家好,我是get_local_info作者带剑书生,这里用一篇文章讲解get_local_info是怎样获得杀毒软件的病毒库时间的。 首先,先要了解get_local_info是什么? get_local_info是一个获取linux系统信息的rust三方库,并提供一些常用功能,目前版本0.2.4。详细介绍地址…...
解决一个mysql的更新属性长度问题
需求背景: 线上有一个 platform属性,原有长度为 varchar(10),但是突然需要填入一个11位长度的值;而偏偏这个属性在线上100张表中有50张都存在,并且名字各式各样,庆幸都包含 platform;例如 platf…...
[网络安全]DHCP 部署与安全
一 、DHCP作用 (Dynamic HOst Configure Protocol ) 动态IP配置协议 作用:动态自动分配IP地址 二、DHCP相关概念 地址池/作用域: (IP、子网掩码、网关、DNS、周期) 三、DHCP优点 减少工程量 避免IP避免 提高地址利用率 四、DHCP原理 成为DHCP租约过程 步骤: 1.发送 DHC…...
自建ES集群
常用命令 # 重命名文件夹 mv elasticsearch-7.10.2 elasticsearch# 移动文件到文件夹 mv elasticsearch-7.10.2-linux-x86_64.tar.gz middleware-tar/ mv kibana-7.10.2-linux-x86_64.tar.gz middleware-tar/# 创建data文件夹 mkdir /home/admin/elasticsearch/data 自建Ela…...
git rev-parse v406 ‘v4.0.4‘^{} master什么意思?
git rev-parse 是一个 Git 命令,用于解析出 git 对象(如分支、标签、提交等)的完整 SHA-1 哈希值。这个命令对于理解 git 中各种引用的内部表示非常有用。 让我们一步步分析 git rev-parse v406 v4.0.4^{} master 这条命令: v406…...
AI 编程的机会和未来:从 Copilot 到 Code Agent
大模型的快速发展带来了 AI 应用的井喷。统计 GPT 使用情况,编程远超其他成为落地最快、使用率最高的场景。如今,大量程序员已经习惯了在 AI 辅助下进行编程。数据显示,GitHub Copilot 将程序员工作效率提升了 55%,一些实验中 AI …...
git push --set-upstream origin master时超时失败的解决方案
问题描述 提示:这里描述项目中遇到的问题: git push --set-upstream origin master时,超时失败,显示如下错误: connect to host git.acwing.com port 22: Connection timed out fatal: Could not read from remote …...
beego的模块篇 - config自定义文件配置
加载自定义配置到beego.AppConfig中可以配置:Beego框架 app.conf配置参数及环境配置-CSDN博客 1. 文件配置 目前支持解析的文件格式有 ini、json、xml、yaml 安装依赖库: go get github.com/beego/beego/v2/core/config 1.1 ini文件配置使用 配置文…...
YOLOv5-第Y2周:训练自己的数据集
YOLOv5-第Y2周:训练自己的数据集 YOLOv5-第Y2周:训练自己的数据集一、前言二、我的环境三、准备数据集四、运行 split_train_val.py 文件五、生成 train.txt、test.txt、val.txt 文件六、创建ab.yaml文件七、开始使用自己的数据集训练八、总结 YOLOv5-第…...
解决fxml图标无法显示
原文地址:https://www.myjinji.top/articles/2023/10/11/1697033367492.html 代码正确无法显示 <Button fx:id"blockButton" onAction"#handleBlockButtonClick"><graphic><FontIcon iconLiteral"win10-add-shopping-cart…...
React Store及store持久化的使用
1.安装 npm insatll react-redux npm install reduxjs/toolkit npm install redux-persist2. 使用React Toolkit创建counterStore并配置持久化 store/modules/counterStore.ts: import { createSlice } from reduxjs/toolkit// 定义状态类型 interface Action {…...
Hive添加第三方Jar包方式总结
一、在 Hive Shell中加入—add jar hdfs dfs -put HelloUDF-1.0.jar /tmp beeline -u "jdbc:hive2://test.bigdata.com:10000" -n "song" -p "" add jar hdfs:///tmp/HelloUDF-1.0.jar; create function HelloUDF as org.example.HelloUDF USIN…...
Linux用户与文件的关系和文件掩码(umask)的作用
文章目录 1 前言2 Linux用户与文件的关系3 文件掩码(umask)4 总结 1 前言 阅读本篇文章,你将了解Linux的目录结构,用户与文件的关系,以及文件掩码的作用。为了方便大家理解,本文将通过实例进行演示…...
解锁Claude无限潜能:技能生态系统的构建艺术
解锁Claude无限潜能:技能生态系统的构建艺术 【免费下载链接】awesome-claude-skills A curated list of awesome Claude Skills, resources, and tools for customizing Claude AI workflows 项目地址: https://gitcode.com/GitHub_Trending/aw/awesome-claude-s…...
Cursor Pro免费激活终极指南:如何突破试用限制重新获得AI编程体验
Cursor Pro免费激活终极指南:如何突破试用限制重新获得AI编程体验 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reach…...
基于摄像头和网络的火灾监测系统开源项目推荐
推荐的开源项目 基于YOLOv10的火焰烟雾检测系统(最推荐) 特点:支持图像、视频和摄像头实时检测,提供完整的GUI界面(PySide6开发)优势:界面简洁易用,代码结构清晰,适合初学…...
别再写低效循环了:深入理解Qt隐式共享与C++17的std::as_const
别再写低效循环了:深入理解Qt隐式共享与C17的std::as_const 在代码审查中,你是否经常看到这样的写法? const QStringList& list oldList; for (auto& str : list) {// 处理字符串 }这种看似"规范"的写法,实际上…...
Python新手福音:借助快马AI零基础构建你的第一个行情网站
作为一个刚接触Python的新手,想要构建一个行情网站听起来可能有点吓人。但通过InsCode(快马)平台的AI辅助,整个过程变得异常简单。下面我就分享一下自己从零开始搭建第一个行情网站的经历。 数据获取部分 首先需要找到一个免费的金融数据接口。我选择了一…...
Overleaf项目本地化实战:用VS Code插件管理、Git版本控制,再搭配Copilot提效
Overleaf项目本地化实战:用VS Code插件管理、Git版本控制,再搭配Copilot提效 对于经常使用LaTeX撰写学术论文或技术文档的用户来说,Overleaf无疑是一个强大的云端协作平台。然而,当项目规模扩大、需要更精细的版本控制时ÿ…...
AI数字人制作:零门槛创建专属虚拟形象
AI数字人制作:零门槛创建专属虚拟形象 【免费下载链接】Duix-Avatar 🚀 Truly open-source AI avatar(digital human) toolkit for offline video generation and digital human cloning. 项目地址: https://gitcode.com/GitHub_Trending/he/Duix-Avat…...
LFM2.5-1.2B-Thinking-GGUF开源生态初探:与Ollama等工具的对比与集成
LFM2.5-1.2B-Thinking-GGUF开源生态初探:与Ollama等工具的对比与集成 1. 开源大模型本地部署生态概览 近年来,开源大模型本地部署工具呈现百花齐放的局面。从早期的单一模型加载器,发展到如今功能丰富的模型管理生态系统,开发者…...
基于宝塔面板与Docker Compose快速部署Dify最新版实战指南
1. 为什么选择宝塔Docker Compose部署Dify? 最近在帮几个创业团队搭建AI开发环境时,发现很多小伙伴都被复杂的部署流程劝退。传统的手动部署方式需要逐个安装Python、Redis、PostgreSQL等依赖,光是版本兼容问题就能折腾大半天。直到上个月我…...
73:L的程序安全:蓝队的规范防御
作者: HOS(安全风信子) 日期: 2026-03-26 主要来源平台: GitHub 摘要: 程序安全是防御的基石,通过规范的流程、自动化执行和可追溯设计构建可靠的安全防御体系。本文分享程序安全的核心价值、L的程序安全策略、技术实现…...
