2014年亚太杯APMCM数学建模大赛A题无人机创造安全环境求解全过程文档及程序

2014年亚太杯APMCM数学建模大赛

A题 无人机创造安全环境

原题再现

  20 国集团,又称 G20,是一个国际经济合作论坛。2016 年第 11 届 20 国集团峰会将在中国召开,这是继 APEC 后中国将举办的另一个大型峰会。此类大型峰会,举办城市甚至举办地周围的城市都会采取严格的措施来为峰会提供保障,尤其是安全领域。举办地地方政府都将投入大量的人力、物力和财力来维持社会秩序以及应对突发事件。
  无人机作为一种高科技产品,逐渐被用于国防和安保领域。现在假设我国政府决定第 11 届 G20 峰会在上海市杨浦区举办,并打算采用无人机对整个杨浦区进行监视。目前的无人机对复杂的外部环境比较鲁棒,能够持续飞行 4 个小时,并且当你策略改变时,无人机携带的复杂控制器可以被立即重新初始化。当地政府要求你们团队完成以下任务:
  计划 1:杨浦区所有的地方都不能脱离监控状态超过 15 分钟,请问至少需要多少架无人机才能达到这一目标?
  计划 2:对于杨浦区而言,有些地点由于其人流量比较大,是相对比较重要的,比如五角场的万达广场、复旦大学周边道路。这样的区域至少每 5 分钟被监测一次,而有些人流量较小的地方,可以多于 20 分钟被监测一次。请问你至少需要多少无人机来满足上述的条件?
  计划 3:假设所有的区域都是同等重要的,都应该保持有规律地监测,但是由于发生故障,30%的无人机无法使用了。此时,你的监测计划可以提供多大的监测范围?

整体求解过程概述(摘要)

  本文根据杨浦区无人机监控的三个规划要求,对无人机轨迹和监控区域进行了优化设计。该方案建立了基于遗传算法的无人机最优路径模型、无人机监控区域规划模型和模拟退火算法,然后将两个模型相结合,进行分析求解。
  为了规划a,本文首先分析了无人机摄影测量系统的具体参数,得出无人机监测面积为0.6849km2。同时,通过对图像的处理,将问题简化为满足无人机监控飞行路径节点和路径约束的问题。根据方案a,发现该问题属于全局最优搜索问题。因此,本文引入并使用遗传算法来解决这个问题。基于遗传算法,建立了无人机最优路径模型。然后借助MATLAB计算出无人机的最短飞行路径长度为209.0776km,通过物理运动学公式将无人机的数量转换为至少需要9架,这满足了杨浦地区从监测状态到各地不超过15分钟的条件。
  本文提取了杨浦区2012年能够反映街道交通统计年鉴数据的人口密度进行聚类分析。根据聚类结果、街道和人口密度,将本文划分为大人口密度、中等人口密度和小人口密度三级区域。接下来为每一级设计有针对性的区域无人机监控解决方案。同时,分析了该问题属于局部最优搜索。因此,本文选择了一种启发式随机搜索算法——模拟退火算法。并建立了基于模拟退火算法的无人机区域规划监控模型。最后,本文计算出每一级区域需要无人机的数量分别为6架、4架和1架,可以得出这样的结论:在人口容量为约束条件下,杨浦区监测区所有区域都需要无人机。
  根据方案c,在分析问题后,问题的解决方案基于方案a、b的核心。首先,根据计划a所需的无人机数量,本文计算出计划c只有6次无人机行动。利用基于遗传算法的无人机最优路径模型,计算出无人机在15分钟内的最大监测面积为28.66km2,这是基于监测面积的最大范围。根据杨浦区实际地形图的基本地形,初始化六条规则。然后利用基于模拟退火算法的无人机监测区域规划模型,得到6个无人机监测区位置图及相应的总监测范围最大面积占杨浦区总面积的66.94%。

模型假设:

  (1) 假设无论杨浦贫困人口的地区分布在每一条街上,每一条街的人口密度都是一样的

  (2) 无人机飞行轨迹的二维无限平面图形区域接近人员流动水平的实际需要监控区域的范围;

  (3) 无人机时刻监测范围的区域差距可以忽略不计。

问题分析:

  本文基于通用无人机监测上海杨浦区11日在G20峰会上设定的三种场景,结合通用无人机摄影测量系统系数和杨浦区面积、边界等实际情况,初步分析了飞机数量和无人机对杨浦区每架飞机所需飞行时间的全面监控,可能为进一步深入研究和分析各种方案提供了逻辑依据。
  基本思路

  (1) 视觉摄像机焦距与面积的关系

  视觉相机焦距与视角之间存在一定的关系。传统尺寸的35mm胶片相机,35mm是胶片的宽度(包括穿孔部分),35mm胶片的感光面积为36x24mm,转换为数码相机,对角线长度越近为43.2mm,表面的CCD/CMOS标尺在数码单反相机中越大,很多都接近35mm胶片感光CCD/CMOS尺寸。

  (2) 航空摄影高度的确定

  显示相机焦距与面积的关系,航空摄影确定飞行高度的地面分辨率航空摄影(GSD)取决于飞行高度,公式为:
在这里插入图片描述
  3) 本文在50毫米的无人机摄影测量系统中选择了相机镜头,因为无人机摄影图像要用来制作成1:2000比例的地图数字产品(DEM、DOM、DLG),地面分辨率的航空图像(GSD)应该是20厘米,结合上述理论,通过数值计算得到相应的GSD飞行高度为1100m。无人机监测范围半径:
在这里插入图片描述
  方案1的分析方法
  根据材料信息,目前无人机在复杂的外部环境中也持续了四个小时的飞行,由于以上对无人机摄影测量系统的参数选择、分析和计算,监控过程将监控获取的图像转化为数字产品,是镜头焦距为50毫米的无人机在实际监测中的飞行高度h=1100米,监测面积为0.6849平方公里,已知在上海杨浦区的区域面积为60.61平方公里,略估算一架无人机在飞行初期完成一个杨浦区所需的时间为1小时37。614分钟,初步估计所需的无人机数量为8架或9架。进一步分析问题,在所有与杨浦区交会的前提下,不从监测状态出发超过15分钟,至少配备一架无人机,以确保第十一届二十国集团峰会的顺利召开,本文将问题转化为优化每架无人机的飞行路径,采用局部最优全局最优的原则,即:,通过运用遗传算法(ga)计算得出无人机监测整个杨浦区所有区域的最短路径,通过路径长度和无人机飞行速度之间的运动学公式转换原理,得出无人机数量至少需要

  方案2分析方法
  根据总体人口分布不均的特点,十一届二十国集团峰会期间,杨浦区周边交通点位的位置和环境发生了变化,对存在安全隐患的溪流所在地人口较为稀少,必须对溪流所在地进行更多的安全监控。11日G20峰会在安全监测计划2中要求对相对较大区域的交通至少每5分钟进行一次监测,对相对较小区域的交通一次可监测20分钟以上,有针对性地加强区域安全监测可以有效保障11日G20峰会的顺利召开。方案2不同于方案1,加入交通是无人机路径规划的一个可变约束条件,监测区域人口在一般人口密度下可以反应交通状况,本文首先对杨浦区各街道的人口密度进行聚类分析,杨浦区根据人口密度分为三个层次,最大人口密度控制的无人机至少每5分钟监测一次,人口密度较大的区域控制无人机距离监测状态不到15分钟,而人口密度较小的区域控制无人人机监测一次可以超过20分钟;在第一个方案的基础上进行了无人机最优控制路径轨迹的研究,以二维平面图为初始化图形,分析、研究并利用模拟退火算法的核心思想,在满足不同分段的人口流动水平的前提下,监测时间间隔,通过初始化图形来填充每个流量级别的区域,得出交通密度区域所需的无人机数量,最后将每个区域的数量相加,即得到至少需要规划的无人机的数量

  方案3的分析方法
  将所有区域识别为同等重要区域,所有区域距离监测状态不超过15分钟,处理方案1的处理问题相同,差异是由于故障,导致30%的无人机已经无法使用,是根据无人机所需数量计划1计算,只提供6架无人机监视杨浦区;6无人机如何使监控区域最大,处理逻辑与方案2类似,基于无人机15分钟即可监控最大区域,基于杨浦区地图形状,初始化6个形状,在优化的基础上仍然使用模拟退火算法,将六个基本图形之间的重叠面积尽可能小,并定位到杨浦区中心,最后计算出六个基本形状覆盖面积的大小,杨浦区的总面积只有70%的无人机监测可以提供最大的监测范围。

模型的建立与求解整体论文缩略图

在这里插入图片描述
在这里插入图片描述

全部论文及程序请见下方“ 只会建模 QQ名片” 点击QQ名片即可

程序代码:

部分程序如下:
G=G.*1.5;
jin=[1 2 3 5 44 51 61 63 62 57 38 31];
bj=zeros(1,63);
while(1)
s=0;
for i=1:1:63
 if bj(i)>0
 continue;
 else
 s=i;
 fprintf('%d',s);
 bj(s)=1;
 break;
 end
end
if s==0
 break;
end
time=0;
while (1)
 min=99;
 minx=0;
 for i=1:1:63
 if G(s,i)~=0 && G(s,i)*(1+bj(i))<min && i~=s
 min=G(s,i)*(1+bj(i));
 minx=i;
 end
 end
 if time+G(s,minx)<7.5
 fprintf('->%d',minx);
 bj(minx)=bj(minx)+1;
 time=time+G(s,minx);
 s=minx;
 else
break;
 end
end
fprintf('\n');
end
x=zeros(1,4);
for i=1:1:63
 switch T(i)
 case 5
 a(1,x(1)+1)=i;
 x(1)=x(1)+1;
 case 12
 a(2,x(2)+1)=i;
 x(2)=x(2)+1;
 case 18
 a(3,x(3)+1)=i;
 x(3)=x(3)+1;
 case 25
 a(4,x(4)+1)=i;
 x(4)=x(4)+1;
 end
end
bj=zeros(1,63);
n=size(G,1);
for i=1:1:n
 for j=1:1:n
 if i~=j && G(i,j)==0
 G(i,j)=inf;
 end
 if G(i,j)==1.571*1.5
 % G(i,j)=inf;
 end
end
end
D=G;
for i=1:1:n
 for j=1:1:n
 R(i,j)=j;
 end 
end 
for k=1:n
for i=1:n 
 for j=1:n
 if D(i,k)+D(k,j)<D(i,j)
 D(i,j)=D(i,k)+D(k,j);
 R(i,j)=R(i,k);
 end 
 end 
 end 
end 
while(1)
 for i=1:1:4
 s=0;
 for j=1:1:x(i)
 if bj(a(i,j))==0
 s=a(i,j);
 bj(a(i,j))=bj(a(i,j))+1;
 t=i;
 fprintf('%d',s);
 break;
 end
 end
 if s~=0
 break;
 end
 end
 if s==0
 break;
 end
 time=0;
 tt=T(s)/2;
 if t==1
 min=inf;
 minx=0;
 for j=1:1:x(i)
 if time+D(s,a(i,j))<tt && bj(a(i,j))==0 && 
D(s,a(i,j))<min && a(i,j)~=s
 min=D(s,a(i,j));
minx=a(i,j);
 end
 if minx~=0
 break;
else
 continue;
 end
 end
 if minx~=0
 time=time+D(s,minx);
 ttt=s;
 while (ttt~=minx)
 fprintf('-->%d',R(ttt,minx));
 ttt=R(ttt,minx);
 bj(ttt)=bj(ttt)+1;
 end 
 s=minx;
 end
 end
 q=0;
 while time<tt
 min=inf;
 minx=0;
 for i=1:1:63
 if G(s,i)~=inf && T(i)+(25*bj(i))<min && i~=s && 
q*bj(i)<1
 min=T(i)+(25*bj(i));
 minx=i;
 end 
 end
 if minx==0
 break;
 end
 if time+G(s,minx)<tt
 if bj(minx)~=0
 q=1;
 end
 fprintf('->%d',minx);
 bj(minx)=bj(minx)+1;
 time=time+G(s,minx);
 s=minx;
 else
 break;
 end
 end 
 fprintf(' \n');
end
sum(bj)
全部论文及程序请见下方“ 只会建模 QQ名片” 点击QQ名片即可

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

L4级自动驾驶前装量产车型来了,小马智行与丰田联合打造

11月5日&#xff0c;小马智行与丰田汽车联合发布的首款纯电自动驾驶出租车&#xff08;Robotaxi&#xff09;概念车在第六届进博会亮相&#xff0c;该车型基于广汽丰田生产的bZ4X纯电车辆平台打造&#xff0c;将搭载小马智行研发的第七代L4级自动驾驶乘用车软硬件系统。 今年8月…

SpringBoot整合JUnit

1.创建新项目 说明&#xff1a;创建springboot_04_junit项目&#xff0c;选择对应的版本。 2.接口类 说明&#xff1a;新建BookDao接口。 package com.forever.dao;public interface BookDao {public void save(); }3.实现类 说明&#xff1a; 新建BookDaoImpl实现类。 pa…

餐饮加盟信息展示预约小程序的内容如何

餐饮业规模持续增加&#xff0c;相关从业者逐渐增多&#xff0c;对中等规模以上的餐饮品牌来说&#xff0c;当有一定规模后除了开多家直营店外&#xff0c;还会开放招商加盟&#xff0c;扩展品牌、提升营收等。 由于餐饮加盟属于准属性业务&#xff0c;因此传统线下方式不太适…

HomeAssistant添加HACS插件并实现公网控制米家,HomeKit等智能家居

HomeAssistant添加HACS插件并实现公网控制米家&#xff0c;HomeKit等智能家居 文章目录 HomeAssistant添加HACS插件并实现公网控制米家&#xff0c;HomeKit等智能家居基本条件一、下载HACS源码二、添加HACS集成三、绑定米家设备 ​ 上文介绍了如何实现群晖Docker部署HomeAssist…

3.27每日一题(常系数线性非齐次方程的特解)

常系数非齐次线性方程的特解如何假设&#xff08;两种&#xff09;形式&#xff1a; 1、题目中 e 的 x 次幂以及 1&#xff0c;都是第一种&#xff1a;1可以看成为e的0次幂 注&#xff1a;题目给的多项式是特殊的形式&#xff0c;我们要设为一般的形式的多项式 2、题目中sin…

【MySQL基本功系列】第一篇 先熟悉MySQL的运行逻辑

​ 我将推出一系列关于MySQL的博客文章&#xff0c;涵盖了从入门到深入底层的原理。这些文章将包括MySQL的运行逻辑、InnoDB存储引擎、SQL优化、undo log、bin log等多个方面的知识。希望这些文章能为你提供宝贵的信息和洞见&#xff0c;并帮助你更好地理解和应用MySQL。同时&a…

gma 1.x 气候气象指数计算源代码(分享)

本模块的主要内建子模块如下&#xff1a; 如何获得完整代码&#xff1a; 回复博主 或者 留言/私信 。 注意&#xff1a;本代码完全开源&#xff0c;可随意修改使用。 但如果您的成果使用或参考了本段代码&#xff0c;给予一定的引用说明&#xff08;非强制&#xff09;&#xf…

客户案例 | 思腾合力助力深度图灵生成式AI应用平台建设

近年来&#xff0c;娱乐行业发展迅猛&#xff0c;市场容量不断扩大。从娱乐产业发展来看&#xff0c;用户对于娱乐内容和体验的需求不断攀升&#xff0c;如何将生成式AI更好的应用于照片修复、创意摄影、漫画创作、图片生成等场景中是对娱乐行业各科技公司的挑战和考验&#xf…

Kubernetes 的四个网络挑战

Kubernetes 的主要职责之一是在应用程序之间共享节点。由于这些应用程序需要相互通信并与外部世界通信&#xff0c;因此网络是一个基本的需求。 Kubernetes 托管的分布式应用程序架构 来自 Kubernetes 集群外部的请求通常通过负责将它们代理到适当服务的路由器或 API 网关进行…

Python笔记——linux/ubuntu下安装mamba,安装bob.learn库

Python笔记——linux/ubuntu下安装mamba&#xff0c;安装bob.learn库 一、安装/卸载anaconda二、安装mamba1. 命令行安装&#xff08;大坑&#xff0c;不推荐&#xff09;2. 命令行下载guihub上的安装包并安装&#xff08;推荐&#xff09;3. 网站下载安装包并安装&#xff08;…

STM32创建工程步骤

以创建led工程为例&#xff1a; 新建一个led文件夹 新建一个以led命名的工程&#xff08;用keil_uVision5&#xff09;并添加三个组。 Library文件夹里放置库函数文件。 User&#xff1a; 点亮led灯的程序&#xff1b; 直接给寄存器赋值 调用库函数。 #include "stm…

VSCode 连接不上 debian 的问题

之前一台笔记本上安装了 debian12&#xff0c;当时用 vscode 是可以连接上的&#xff0c;但今天连接突然就失败了&#xff0c;失败信息是这样的&#xff1a; 查看失败信息 因为 debian 是自动获取 ip 地址的&#xff0c;以前能连接上时&#xff0c;ip 地址是 104&#xff0c;然…

bin.zip和bin.tar.gz以及src.zip和src.tar.gz以及rpm和dmg的区别

下载JDK时Java Downloads | Oracle会有很多文件&#xff0c;时间长了容易混淆&#xff0c;在此记录一下。 如上面三张图所示: bin代表二进制文件&#xff0c;是编译后的文件&#xff0c;而src是源码。.tar.gz是linux的压缩包&#xff0c;.zip是windows的压缩包 所以: bin.ta…

分页存储管理、分段存储管理、段页式存储管理、两级页表

目录: 分页存储管理 基本地址存储机构 具有快表的地址存储机构 两级页表 分段存储管理 段页式管理方式 分页存储管理(重点) 首先回顾,逻辑地址和物理地址. 为什么要引入分页存储管理? 把物理地址下,离散的各个小片都利用起来,也就是在逻辑地址中看似是连续存储的,实际上对应…

halcon快速傅里叶变换

说明 低频特征是灰度变化不明显&#xff0c;例如图像整体轮廓&#xff0c;高频特征是图像灰度变化剧烈&#xff0c;如图像边缘和噪声。一个重要的经验结论&#xff1a;低频代表图像整体轮廓&#xff0c;高频代表了图像噪声&#xff0c;中频代表图像边缘、纹理等细节。 傅里叶变…

Ps:色彩范围

Ps菜单&#xff1a;选择/色彩范围 Select/Color Range 色彩范围 Color Range是一个功能强大选择命令&#xff0c;不仅可以基于颜色进行选择&#xff0c;而且可以基于影调进行选择。不仅可以用来检测人脸选择肤色&#xff0c;也可用来选择超出印刷色域范围的区域。 在图层蒙版的…

Apex的addError()显示的消息中实现换行

直接用‘<br/>’是无效的&#xff0c;因为addError默认不转义HTML符号&#xff0c;如果需要转义&#xff0c;应该将第二个参数escape设置为false。不过即使设置了也只对classic页面生效&#xff0c;lightning页面还是无法转义。 官方文档&#xff1a; 参考资料&#xf…

稀土/铜催化剂电催化CO2制C2+或CH4

在电化学CO2还原反应&#xff08;CO2RR&#xff09;中&#xff0c;合理调控反应途径以生成所需产物是最重要的挑战之一。基于此&#xff0c;中国科学院化学研究所韩布兴院士和朱庆宫研究员等人报道了一系列稀土-铜混合相催化剂&#xff0c;通过调整催化剂的组成和结构&#xff…

Linux环境变量

Linux环境变量 &#x1f4df;作者主页&#xff1a;慢热的陕西人 &#x1f334;专栏链接&#xff1a;Linux &#x1f4e3;欢迎各位大佬&#x1f44d;点赞&#x1f525;关注&#x1f693;收藏&#xff0c;&#x1f349;留言 本博客主要内容讲解了环境变量&#xff0c;什么是环境变…

OpenCV检测圆(Python版本)

文章目录 示例代码示例结果调参 示例代码 import cv2 import numpy as np# 加载图像 image_path DistanceComparison/test_image/1.png image cv2.imread(image_path, cv2.IMREAD_COLOR)# 将图像转换为灰度 gray cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 使用高斯模糊消除…