吴飞教授 人工智能 模型与算法 启发式搜索课件发散分析

本文主要是介绍吴飞教授 人工智能 模型与算法 启发式搜索课件发散分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、文章介绍

本文是针对吴飞教授在MOOC课程 :《人工智能:模型与算法》 2.1节 启发式搜索的课前发散
课程介绍
在课程2.1节 启发式搜索章节中,吴飞教授以如何计算城市地图两点之间最短路径为例,重点讲授了贪婪最佳优先搜索A*搜索算法;但并未使用“笨办法”:遍历查询的方式来解决该需求,对于算法初学者来讲无法直观比较出搜索算法带来的效率提升。故本文目的在于通过遍历查询不借助任何算法,利用python内建数据结构与方法实现任意两点的所有可能路径及开销。

二、信息收集

根据课件,我们可以知晓以下信息:

  1. 城市地图
  2. 相邻城市的实际距离

地图如下:
map_info
将以上信息录入python字典:

city_map = {'Arad':{'Zerind':75,'Sibiu':140,'Timisoara':118},'Zerind':{'Oradea':71},'Oradea':{'Sibiu':151},'Timisoara':{'Lugoj':111},'Lugoj':{'Mehadia':70},'Mehadia':{'Drobeta':75},'Drobeta':{'Craiova':120},'Craiova':{'Pitesti':138},'Sibiu':{'Fagaras':99,'Rimnicu Vilcea':80},'Rimnicu Vilcea':{'Craiova':146,'Pitesti':97},'Fagaras':{'Bucharest':211},'Pitesti':{'Bucharest':101},'Bucharest':{'Giurgiu':90,'Urziceni':85},'Urziceni':{'Hirsova':98,'Vaslui':142},'Hirsova':{'Eforie':86},'Vaslui':{'Iasi':92},'Iasi':{'Neamt':87},   }

问题1: 信息录入我们采取水平分割的录入方式,每个城市只录入下游相邻节点。 以Sibiu为例,其上游城市为AradOradea; 但是并不录入,只录入FagarasRimnicu Vilcea.

三、代码实现

3.1 数据处理

为了解决上述问题1,需要针对收集的城市数据进行处理,输出直观的全邻接信息。

# 统计city_map节点邻接关系
fullmesh_city_map={}      #  用于记录全互联地图# 遍历手工地图信息,正向解析下游城市
for k,v in city_map.items():next_hop={}for _k,_v in v.items():next_hop[_k]=_vif _k in city_map:   # 逆向解析上游城市if _k in fullmesh_city_map:fullmesh_city_map[_k].update({k:_v})else: # fullmesh_city_map[_k] = {k:_v}else:  # 处理边界城市fullmesh_city_map[_k] = {k:_v}if k in fullmesh_city_map:fullmesh_city_map[k].update(next_hop)else:fullmesh_city_map[k]=next_hop# 打印
for k,v in fullmesh_city_map.items():print(k,v)

输出结果如下:

Zerind {‘Arad’: 75, ‘Oradea’: 71}
Sibiu {‘Arad’: 140, ‘Oradea’: 151, ‘Fagaras’: 99, ‘Rimnicu Vilcea’: 80}
Timisoara {‘Arad’: 118, ‘Lugoj’: 111}
Arad {‘Zerind’: 75, ‘Sibiu’: 140, ‘Timisoara’: 118}
Oradea {‘Zerind’: 71, ‘Sibiu’: 151}
Lugoj {‘Timisoara’: 111, ‘Mehadia’: 70}
Mehadia {‘Lugoj’: 70, ‘Drobeta’: 75}
Drobeta {‘Mehadia’: 75, ‘Craiova’: 120}
Craiova {‘Drobeta’: 120, ‘Pitesti’: 138, ‘Rimnicu Vilcea’: 146}
Pitesti {‘Craiova’: 138, ‘Rimnicu Vilcea’: 97, ‘Bucharest’: 101}
Fagaras {‘Sibiu’: 99, ‘Bucharest’: 211}
Rimnicu Vilcea {‘Sibiu’: 80, ‘Craiova’: 146, ‘Pitesti’: 97}
Bucharest {‘Fagaras’: 211, ‘Pitesti’: 101, ‘Giurgiu’: 90, ‘Urziceni’: 85}
Giurgiu {‘Bucharest’: 90}
Urziceni {‘Bucharest’: 85, ‘Hirsova’: 98, ‘Vaslui’: 142}
Hirsova {‘Urziceni’: 98, ‘Eforie’: 86}
Vaslui {‘Urziceni’: 142, ‘Iasi’: 92}
Eforie {‘Hirsova’: 86}
Iasi {‘Vaslui’: 92, ‘Neamt’: 87}
Neamt {‘Iasi’: 87}

根据以上结果,可以发现任意城市都记录了上下游相邻城市。这便于后续代码的实现。

3.2 路径计算

本节代码用于计算任意两个给定城市间的可能路径和代价。因采用遍历的形式,且无任何标志用于判断程序是否已经得出两点之间的全部可能路径,故只能通过夸张的遍历次数来进行覆盖。

需求如下:
计算 城市’Oradea’与’Neamt’之间的可能路径与代价。

代码实现如下:

root = 'Oradea'
start = root
end = 'Neamt'path = []
finnal_path=[]
times = 0
update_pop =[None]while times<100000:    for k,v in fullmesh_city_map[start].items():if update_pop[0] == None:temp_path = [start,k,v]path.append(temp_path)else:if k in update_pop:path.append(update_pop)else:update_pop.insert(-1,k)update_pop[-1] += vpath.append(update_pop)update_pop=[]for i in x_copy:update_pop.append(i)for x in path:if x[-2] == end:_a = []for _x in x:_a.append(_x)if _a not in finnal_path:finnal_path.append(_a)else:passupdate_pop = path.pop(0)x_copy = []for i in update_pop:x_copy.append(i)start = update_pop[-2]    times+=1# 打印结果
path_number = 1
for i in finnal_path:print("线路{}: ".format(path_number),("--->".join(i[0:-1])),"距离 ",i[-1])path_number += 1

经过计算,共有12条可选路径。

四、完整代码

以下代码运行后会出现12条可选路径。大家可自行验证。 自此,大家在学习玩搜索算法后方便感知算法的带来的效率改善情况。

city_map = {'Arad':{'Zerind':75,'Sibiu':140,'Timisoara':118},'Zerind':{'Oradea':71},'Oradea':{'Sibiu':151},'Timisoara':{'Lugoj':111},'Lugoj':{'Mehadia':70},'Mehadia':{'Drobeta':75},'Drobeta':{'Craiova':120},'Craiova':{'Pitesti':138},'Sibiu':{'Fagaras':99,'Rimnicu Vilcea':80},'Rimnicu Vilcea':{'Craiova':146,'Pitesti':97},'Fagaras':{'Bucharest':211},'Pitesti':{'Bucharest':101},'Bucharest':{'Giurgiu':90,'Urziceni':85},'Urziceni':{'Hirsova':98,'Vaslui':142},'Hirsova':{'Eforie':86},'Vaslui':{'Iasi':92},'Iasi':{'Neamt':87},   }# 统计city_map节点邻接关系
fullmesh_city_map={}      #  用于记录全互联地图# 遍历手工地图信息,正向解析下游城市
for k,v in city_map.items():next_hop={}for _k,_v in v.items():next_hop[_k]=_vif _k in city_map:   # 逆向解析上游城市if _k in fullmesh_city_map:fullmesh_city_map[_k].update({k:_v})else: # fullmesh_city_map[_k] = {k:_v}else:  # 处理边界城市fullmesh_city_map[_k] = {k:_v}if k in fullmesh_city_map:fullmesh_city_map[k].update(next_hop)else:fullmesh_city_map[k]=next_hop# 打印
for k,v in fullmesh_city_map.items():print(k,v)root = 'Oradea'
start = root
end = 'Neamt'path = []
finnal_path=[]
times = 0
update_pop =[None]while times<100000:    for k,v in fullmesh_city_map[start].items():if update_pop[0] == None:temp_path = [start,k,v]path.append(temp_path)else:if k in update_pop:path.append(update_pop)else:update_pop.insert(-1,k)update_pop[-1] += vpath.append(update_pop)update_pop=[]for i in x_copy:update_pop.append(i)for x in path:if x[-2] == end:_a = []for _x in x:_a.append(_x)if _a not in finnal_path:finnal_path.append(_a)else:passupdate_pop = path.pop(0)x_copy = []for i in update_pop:x_copy.append(i)start = update_pop[-2]    times+=1# 打印结果
path_number = 1
for i in finnal_path:print("线路{}: ".format(path_number),("--->".join(i[0:-1])),"距离 ",i[-1])path_number += 1

这篇关于吴飞教授 人工智能 模型与算法 启发式搜索课件发散分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/582475

相关文章

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

锐捷和腾达哪个好? 两个品牌路由器对比分析

《锐捷和腾达哪个好?两个品牌路由器对比分析》在选择路由器时,Tenda和锐捷都是备受关注的品牌,各自有独特的产品特点和市场定位,选择哪个品牌的路由器更合适,实际上取决于你的具体需求和使用场景,我们从... 在选购路由器时,锐捷和腾达都是市场上备受关注的品牌,但它们的定位和特点却有所不同。锐捷更偏向企业级和专

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

Spring中Bean有关NullPointerException异常的原因分析

《Spring中Bean有关NullPointerException异常的原因分析》在Spring中使用@Autowired注解注入的bean不能在静态上下文中访问,否则会导致NullPointerE... 目录Spring中Bean有关NullPointerException异常的原因问题描述解决方案总结

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

python-nmap实现python利用nmap进行扫描分析

《python-nmap实现python利用nmap进行扫描分析》Nmap是一个非常用的网络/端口扫描工具,如果想将nmap集成进你的工具里,可以使用python-nmap这个python库,它提供了... 目录前言python-nmap的基本使用PortScanner扫描PortScannerAsync异

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

C# ComboBox下拉框实现搜索方式

《C#ComboBox下拉框实现搜索方式》文章介绍了如何在加载窗口时实现一个功能,并在ComboBox下拉框中添加键盘事件以实现搜索功能,由于数据不方便公开,作者表示理解并希望得到大家的指教... 目录C# ComboBox下拉框实现搜索步骤一步骤二步骤三总结C# ComboBox下拉框实现搜索步骤一这

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行