当前位置: 首页 > news >正文

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时代引发的道路规划革命 原题再现&#xff1a; 忙着回家或上班的司机们都知道交通堵塞既浪费时间又浪费燃料&#xff0c;甚至有的时候会带来情绪上的巨大影响&#xff0c;引发一系列的交通问题。据报道&#xff0c;每年交通拥堵使得美国…...

可视化k8s页面(Kubepi)

Kubepi是一个简单高效的k8s集群图形化管理工具&#xff0c;方便日常管理K8S集群&#xff0c;高效快速的查询日志定位问题的工具 随便在哪个节点部署&#xff0c;我这里在主节点部署 docker pull kubeoperator/kubepi-server docker run --privileged -itd --restartunless-st…...

1434. 数池塘(四方向)-深度优先搜索-DFS

代码&#xff1a; #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 文件&#xff0c;在终端启动很麻烦&#xff0c;编写一些脚本可以简化操作 robot_client.sh #!/bin/bashecho "开始执行Bash脚本"# 启动zedm roslaunch zed_wrapper zedm.launch & sleep 5# 启动realsen…...

Modern C++ 一个例子学习条件变量

目录 问题程序 施魔法让BUG浮出水面 条件变量注意事项 修改程序 问题程序 今天无意中看到一篇帖子&#xff0c;关于条件变量的&#xff0c;不过仔细看看发现它并达不到原本的目的。 程序如下&#xff0c;读者可以先想想他的本意&#xff0c;以及有没有问题&#xff1a; #…...

ora-12154无法解析指定的连接标识符

用户反映查询的时候报错ora-12154 这个系统只做历史数据查询使用&#xff0c;使用并不平凡&#xff0c;该数据库曾做过一次服务器间的迁移。 用户描述&#xff0c;所有oracle客户端查询该视图都报tns错误&#xff0c;一般ora-12154会发生在连接数据库时&#xff0c;因为tns配…...

rust跟我学三:文件时间属性获得方法

图为RUST吉祥物 大家好,我是get_local_info作者带剑书生,这里用一篇文章讲解get_local_info是怎样获得杀毒软件的病毒库时间的。 首先,先要了解get_local_info是什么? get_local_info是一个获取linux系统信息的rust三方库,并提供一些常用功能,目前版本0.2.4。详细介绍地址…...

解决一个mysql的更新属性长度问题

需求背景&#xff1a; 线上有一个 platform属性&#xff0c;原有长度为 varchar(10)&#xff0c;但是突然需要填入一个11位长度的值&#xff1b;而偏偏这个属性在线上100张表中有50张都存在&#xff0c;并且名字各式各样&#xff0c;庆幸都包含 platform&#xff1b;例如 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 命令&#xff0c;用于解析出 git 对象&#xff08;如分支、标签、提交等&#xff09;的完整 SHA-1 哈希值。这个命令对于理解 git 中各种引用的内部表示非常有用。 让我们一步步分析 git rev-parse v406 v4.0.4^{} master 这条命令&#xff1a; v406…...

AI 编程的机会和未来:从 Copilot 到 Code Agent

大模型的快速发展带来了 AI 应用的井喷。统计 GPT 使用情况&#xff0c;编程远超其他成为落地最快、使用率最高的场景。如今&#xff0c;大量程序员已经习惯了在 AI 辅助下进行编程。数据显示&#xff0c;GitHub Copilot 将程序员工作效率提升了 55%&#xff0c;一些实验中 AI …...

git push --set-upstream origin master时超时失败的解决方案

问题描述 提示&#xff1a;这里描述项目中遇到的问题&#xff1a; git push --set-upstream origin master时&#xff0c;超时失败&#xff0c;显示如下错误&#xff1a; connect to host git.acwing.com port 22: Connection timed out fatal: Could not read from remote …...

beego的模块篇 - config自定义文件配置

加载自定义配置到beego.AppConfig中可以配置&#xff1a;Beego框架 app.conf配置参数及环境配置-CSDN博客 1. 文件配置 目前支持解析的文件格式有 ini、json、xml、yaml 安装依赖库&#xff1a; go get github.com/beego/beego/v2/core/config 1.1 ini文件配置使用 配置文…...

YOLOv5-第Y2周:训练自己的数据集

YOLOv5-第Y2周&#xff1a;训练自己的数据集 YOLOv5-第Y2周&#xff1a;训练自己的数据集一、前言二、我的环境三、准备数据集四、运行 split_train_val.py 文件五、生成 train.txt、test.txt、val.txt 文件六、创建ab.yaml文件七、开始使用自己的数据集训练八、总结 YOLOv5-第…...

解决fxml图标无法显示

原文地址&#xff1a;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&#xff1a; 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 文件掩码&#xff08;umask&#xff09;4 总结 1 前言 阅读本篇文章&#xff0c;你将了解Linux的目录结构&#xff0c;用户与文件的关系&#xff0c;以及文件掩码的作用。为了方便大家理解&#xff0c;本文将通过实例进行演示&#xf…...

JS -- 正则表达式教程

1 概念 ECMAScript 通过 RegExp 类型支持正则表达式。 2 写法 2.1 类似 Perl 的简写语法&#xff1a; let pattern /a/g let pattern2 /a/i2.2 构造函数创建&#xff1a; let pattern new RegExp(a, g) let pattern new RegExp(a, i)上面两种是等价的正则表达式 3 修…...

详细介绍IP 地址、网络号和主机号、ABC三类、ip地址可分配问题、子网掩码、子网划分

1、 IP 地址: 网络之间互连的协议&#xff0c;是由4个字节(32位二进制)组成的逻辑上的地址。 将32位二进制进行分组&#xff0c;分成4组&#xff0c;每组8位(1个字节)。【ip地址通常使用十进制表示】ip地址分成四组之后&#xff0c;在逻辑上&#xff0c;分成网络号和主机号 2…...

滚动菜单+图片ListView

目录 Fruit.java FruitAdapter MainActivity activity_main.xml fruit.xml 整体结构 Fruit.java public class Fruit {private String name;private int imageId;public Fruit(String name, int imageId) {this.name name;this.imageId imageId;}public String getNam…...

【4k】4k的webrtc播放示例

目录 使用带研发角色的账号&#xff0c;在app端设置下分辨率 &#xff1a; 4k 点播 ffplay播放看下详细的参数 使用带研发角色的账号&#xff0c;在app端设置下分辨率 &#xff1a; 4k 点播 ffplay播放看下详细的参数...

PMIC 基础知识浅析(四)

PMIC 后端研究现状&#xff1a; 现今针对便携式移动平台的电源管理芯片仍以传统分离型 PMIC为主。 根据后端设计的特点&#xff0c;传统分离型 PMIC 又可分三大类。 控制芯片与开关 MOSFET 分离型&#xff0c;MOSFET 外置于PCB上&#xff0c;芯片仅提供智能控制功能。 此类IC…...

gin+gorm增删改查目录框架

从网上找资料,发现,很多都是直接的结构 路由&#xff0c;后端的controller层&#xff0c;还有model层&#xff0c;都是放在了同一个main.go文件中&#xff0c;如果写项目的话&#xff0c;还得自己去拆文件&#xff0c;拆代码&#xff0c;经过查询和自己总结&#xff0c;下面放…...

python进阶(二)导入import 机制 | 导入import 用法 工作原理全解析

文章目录 1. 整体概念基本介绍1.1 包package1.2 模块 module 2 基本语法2.1 import直接使用2.2 from 及其用法3.1 as的用法 3 工作原理3.1 搜寻3.2 执行3.3 避免导入模块代码执行 参考《Python应该如何导入&#xff08;import&#xff09;模块及包》梳理 1. 整体概念基本介绍 …...

极客时间-《罗剑锋的 C++ 实战笔记》文章笔记 + 个人思考

极客时间-《罗剑锋的 C 实战笔记》文章笔记 个人思考 语言特性06 | auto/decltype&#xff1a;为什么要有自动类型推导&#xff1f; 语言特性 06 | auto/decltype&#xff1a;为什么要有自动类型推导&#xff1f; auto 在C 11 引入。 为什么说C是静态强类型语言&#xff1f…...

Pytorch 对比TensorFlow 学习:Day 17-18: 循环神经网络(RNN)和LSTM

Day 17-18: 循环神经网络&#xff08;RNN&#xff09;和LSTM 在这两天的学习中&#xff0c;我专注于理解循环神经网络&#xff08;RNN&#xff09;和长短期记忆网络&#xff08;LSTM&#xff09;的基本概念&#xff0c;并学习了它们在处理序列数据时的应用。 1.RNN和LSTM基础…...

Java基础 - 07 Set之Set,AbstractSet

上边几篇&#xff0c;我们对java的List集合进行相关介绍&#xff0c;了解了关于List集合下的相关实现类的方法或者接口。 自本篇开始&#xff0c;将围绕java的Set进行介绍&#xff0c;也是对我java知识的巩固吧&#xff0c;处理业务越多&#xff0c;发现自己对基础知识的薄弱&…...