【人工智能】—_深度优先搜索、代价一致搜索、深度有限搜索、迭代深度优先搜索、图搜索

news2025/1/16 1:00:54

【人工智能】无信息搜索—BFS 、代价一致、DFS、深度受限、迭代深入深度优先、图搜索

什么是搜索

  • 搜索问题是指既不能通过数学建模解决,又没有其他算法可以套用或者非遍历所有情况才能得出正确结果。这时就需要采用搜索算法来解决问题。搜索就是一种通过穷举所有解的状态,来求得题目所要求的解或者最优解的方法。
  • 搜索的基本概念:
    1. 状态:对某一系统在某一时刻的数学描述。
    2. 动作:从当前时刻状态转移到下一时刻所处状态的操作。
    3. 状态转移:对某一时刻的状态进行动作后所达到的状态。
    4. 路径:一个状态序列,该序列被一系列动作所连接。
    5. 目标测试:评估当前状态是否是所求解的目标状态。

树搜索算法

  • 基本思想:通过扩展已探索状态的后继,离线模拟探索状态空间
    在这里插入图片描述
  • 以下图举例在这里插入图片描述
  • 根据给定的初始状态初始化搜索树在这里插入图片描述
  • 根据策略strategy决定扩展哪个叶子结点,直到达到目标状态
    在这里插入图片描述在这里插入图片描述

搜索策略

  • 通过选择节点扩展的顺序来定义搜索策略
  • 根据以下维度评估策略:
    • 完整性(完备性): 如果存在,它是否总能找到解决方案?
    • 时间复杂性(时间复杂度): 生成的节点数
    • 空间复杂性(空间复杂度) : 内存中的最大节点数
    • 最优性(最优性): 它总是找到成本最低的解决方案吗?
  • 时间和空间复杂性是根据
    • b: maximum branching factor of the search tree搜索树的最大分支因子—分支因子
    • d: depth of the least-cost solution—最浅的目标节点的深度
    • m: maximum depth of the state space状态空间的最大深度(可以是 ∞ ∞ )—最大深度

无信息搜索

不一致的搜索策略只使用问题定义中可用的信息

  • Breadth-first search 广度优先搜索
  • Uniform-cost search 代价一致搜索
  • Depth-first search 深度优先搜索
  • Depth-limited search 深度受限搜索
  • Iterative deepening search 迭代深度优先搜索

Breadth-first search

在这里插入图片描述
  • 扩展最浅的未扩展节点

  • 实施:边缘结点是一个FIFO队列,即,新来的后继放在末尾

  • 时间复杂度 :BFS算法的时间复杂度可以通过BFS中遍历的节点数来获得,直到最浅的节点。其中 d= 最浅解的深度,b是每个状态的节点。在这里插入图片描述

  • 空间复杂度: O ( b d + 1 ) O(b ^{d+1}) O(bd+1)(keeps every node in memory)

  • 完整性:BFS完成,这意味着如果最浅的目标节点处于某个有限的深度,那么BFS将找到解决方案。

  • 最优性:如果路径成本是节点深度的非递减函数,则BFS是最优的。

  • 空间是个大问题;可以轻松地以100MB/秒的速度生成节点,因此24小时=8640GB。

Uniform-cost search

  • 一致代价搜索(Uniform Cost Search),优先扩展拥有最小路径消耗函数g(n)的结点,和最佳优先搜索(Best-first Search)在代码实现上一致,即最佳优先搜索的评价函数f(n)等于g(n)时,最佳优先搜索即为一致代价搜索。
  • 一致代价搜索是用于遍历加权树或图的搜索算法。
  • 当每个边缘有不同的成本时,该算法开始起作用
  • 一致代价搜索的主要目标是找到具有最低累积成本的目标节点的路径。一致代价搜索根据路径成本从根节点扩展节点。
  • 它可用于解决需要最优成本的任何图/树。一致代价搜索算法由优先级队列实现。它最优先考虑最低累积成本。
  • 如果所有边的路径成本相同,则一致代价搜索等效于宽度优先搜索算法
  • 完整性:是,如果每一步代价 ≥ ε ≥ε ε
  • 时间复杂性: O ( b c e i l i n g ( C ∗ / ε ) O(bceiling(C*/ ε) O(bceiling(C/ε) C ∗ C* C是最佳解决方案的成本, g ≤ g≤ g最优解代价的节点数
  • 空间复杂度: O ( b c e i l i n g ( C ∗ / ε ) O(bceiling(C*/ ε) O(bceiling(C/ε) g ≤ g≤ g最优解代价的节点数
  • 最优解:节点按 g(n) 的递增顺序扩展

Depth-first search

  • DFS的核心是沿着树的深度遍历树的结点,尽可能深的探索树的分支,当结点v的所有边都已经被探索后,将回溯到发现v的那条边的起始结点。这一过程一直进行到已发现初始结点可以到达的所有结点为止,如果还有未被发现的结点,则从中选择一个作为初始结点重复上述过程,直到所有结点都被访问为止。
  • DFS的基本原则可以归纳为:按照某种条件一直往前探索,如果在过程中失败,比如死路(全部探索完但是仍没有解)则返回,另选一条道路继续,直到到达目标结点为止。
  • 深度优先搜索扩展搜索树中深度最深的结点。
  • 它既不是完备的也不是最优的,但它具有线性的空间复杂度。
  • 总是扩展在队列frontier中level最深的结点。深度优先搜索的其中一个variant是回溯搜索(Backtracking Search),可以实现更小内存开销。
  • 完整性:DFS搜索算法在有限状态空间内完成,因为它将扩展有限搜索树中的每个节点。
  • 时间复杂度:DFS的时间复杂度将等同于算法遍历的节点。它的公式如下:
    在这里插入图片描述
    其中,m = 任何节点的最大深度,这可能远大于d(Shallowest解算深度)
  • 空间复杂度:DFS算法只需要存储来自根节点的单个路径,因此DFS的空间复杂度等于边缘集的大小,即O(bm)。
  • 最优解:DFS搜索算法不是最优的,因为它可能产生大量步骤或高成本以到达目标节点。

depth-limited search

  • 深度受限搜索(Depth-limited Search),是在深度优先搜索基础上,设置搜索深度限制。因为当搜索状态空间很大的时候,深度优先搜索DFS会非常尴尬,所以可以通过设置搜索深度界限来避免。
  • 深度有限搜索算法类似于具有预定限制的深度优先搜索。深度限制搜索可以解决深度优先搜索中无限路径的缺点。在该算法中,深度限制的节点将被视为没有后继节点
  • 可以使用两个失败条件终止深度限制搜索
    • 标准故障值:表示问题没有任何解决方案。
    • 截止故障值:它在给定的深度限制内没有定义问题的解决方案。
  • 完整性:如果解决方案高于深度限制,则DLS搜索算法完成。
  • 时间复杂度:DLS算法的时间复杂度为O(bℓ)。
  • 空间复杂度:DLS算法的空间复杂度为O(b×l)。
  • 最优解:深度限制搜索可以看作是DFS的一个特例,即使ℓ> d也不是最优的。

Iterative deepening search

  • 由Depth-limited search演化而成,每轮增加深度限制
  • 迭代加深的深度优先搜索(Iterative deepening depth-first Search),逐步增大限制搜索的深度,直到返回目标结点。
  • 迭代加深的深度优先搜索是DFS和BFS算法的组合。此搜索算法找出最佳深度限制,并通过逐渐增加限制直到找到目标为止。迭代加深(Iterative deepening)搜索,实质上就是限定下界的深度优先搜索。即首先允许深度优先搜索K层搜索树,若没有发现可行解,再将K+1后重复以上步骤搜索,直到搜索到可行解。
  • 在迭代加深搜索的算法中,连续的深度优先搜索被引入,每一个深度约束逐次加1,直到搜索到目标为止。
  • 迭代加深搜索算法就是仿广度优先搜索的深度优先搜索。既能满足深度优先搜索的线性存储要求,又能保证发现一个最小深度的目标结点。
  • 从实际应用来看,迭代加深搜索的效果比较好,并不比广度优先搜索慢很多,但是空间复杂度却与深度优先搜索相同,比广度优先搜索小很多,在一些层次遍历的题目中,迭代加深不失为一种好方法!
  • 该算法执行深度优先搜索直到某个“深度限制”,并且在每次迭代之后它不断增加深度限制,直到找到目标节点。
  • 此搜索算法结合了广度优先搜索的快速搜索和深度优先搜索的内存效率的优势。当搜索空间很大并且目标节点的深度未知时,迭代搜索算法对于无知搜索是有用的。
  • 示例,以下树结构显示迭代加深深度优先搜索。IDDFS算法执行各种迭代,直到找到目标节点。算法执行的迭代如下在这里插入图片描述
  • 第1次迭代——-> A
    第2次迭代——> A,B,C
    第3次迭代———> A,B,D,E,C,F,G
    第4次迭代———> A,B,D,H,I,E,C,F,K,G
    在第四次迭代中,算法将找到目标节点。
  • 完整性:如果分支因子是有限的,则该算法是完整的。
  • 时间复杂性:假设b是分支因子,深度是d,那么最坏情况时间复杂度是O(bd)。
  • 空间复杂性:IDDFS的空间复杂度为O(bd)。
  • 最优解:如果路径成本是节点深度的非递减函数,则IDDFS算法是最佳的。

图搜索

  • 检测不到重复状态可能会将线性问题变成指数问题!在这里插入图片描述

  • 避免探索冗余路径的方法是牢记曾经走过的路。

  • 为了做到这一点,我们给TREE-SEARCH搜索树算法增加一个参数–这个数据结构称为探索集(也被称为 closed 表),用它记录每个已扩展过的结点。

  • 新生成的结点若与已经生成的某个结点相匹配的话–即是在探索集中或是边缘集中-那么它将被丢弃而不是被加入边缘集中。

  • 新算法叫 GRAPH-SEARCH,图搜索

小结

在这里插入图片描述

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

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

相关文章

【分布式搜索引擎es】

文章目录 数据搜索DSL实现查询文档搜索结果处理 RestClient实现 elasticsearch最擅长的是 搜索和 数据分析。 数据搜索 DSL实现 查询文档 常见的查询类型包括: 查询所有:查询出所有数据,一般测试用。例如:match_all全文检索…

Power BI 连接 MySQL 数据库

Power Query 或 Power BI 只提供了对 SQL Server 的直接连接,而不支持其它数据库的直连。所以第一次连接 MySQL 数据库时,就出现下面的错误信。 这就需要我们自己去安装一个连接器组件。https://downloads.mysql.com/archives/c-net/ 错误解决方案 我一…

【已解决+吐槽】pip install cn2an报错 Cannot uninstall ‘ruamel_yaml‘

我需要用cn2an模块将中文的数字转化为阿拉伯数字,但在安装cn2an的过程中出现了以下报错: 于是乎,我跟着CSDN上诸如此类的教程开始跟nodejs死磕,折腾了大半天,以下是各种尝试。这不是重点,我主要是吐槽&…

Spring MVC 五 - Spring MVC的配置和DispatcherServlet初始化过程

今天的内容是SpringMVC的初始化过程,其实也就是DispatcherServilet的初始化过程。 Special Bean Types DispatcherServlet委托如下一些特殊的bean来处理请求、并渲染正确的返回。这些特殊的bean是Spring MVC框架管理的bean、按照Spring框架的约定处理相关请求&…

传送带下料口堵塞识别检测算法 yolov5

传送带下料口堵塞识别检测算法通过python基于yolov5网络深度学习框架模型,下料口堵塞识别检测算法能够准确判断下料口是否出现堵塞现象,一旦发现下料口堵塞,算法会立即抓拍发出告警信号。Python是一种由Guido van Rossum开发的通用编程语言&a…

《信息系统项目管理师教程(第4版)》第17章 采购管理、合同管理 知识点整理,xmind思维导图

已上传采购管理xmind思维导图,需要的同学可以直接下载哦。 一、规划采购管理 二、实施采购 三、控制采购 四、合同管理 4.1 合同类型 4.2 合同管理过程 签订履行变更档案,合同档案管理是整个合同管理的基础,要求采用电脑打印文本&#xff…

在k8s中用label控制Pod部署到指定的node上

案例-标注k8s-node1是配置了SSD的节点 kubectl label node k8s-node1 disktypessd 查看标记 测试 将pod部署到disktypessd的节点上(这里设置了k8s-node1为ssd) 部署后查看结果-副本全都运行在了k8s-node1上—符合预期 删除标记 kubectl label node k8…

yolov8机器视觉-工业质检

使用训练好的模型进行预测 yolo predict taskdetect model训练好的模型路径 source测试图片文件夹路径 showTrue效果展示 切换模型进行训练(yolov8s) 修改main.py训练参数文件 使用云gpu进行训练,很方便:点击链接转至在线云gpu…

2020年下半年系统架构设计师上午真题及答案解析

1.按照我国著作权法的权利保护期,( )受到永久保护。 A.发表权 B.修改权 C.复制权 D.发行权 2.假设某计算机的字长为32位,该计算机文件管理系统磁盘空间管理采用位示图记录磁盘的使用情况,若磁盘的容量为3…

python节假日库holidays——查询国家节假日

节假日—计算某天是否为节假日 参考学习: ​ Python holidays模块 ​ Python实现节假日查询 ​ Python怎么获取节假日信息 pip install holidaysimport holidayscn_holidays holidays.CountryHoliday(CN) print(cn_holidays)from datetime import dateif date(…

攻防世界-php_rce

原题 解题思路 thinkPHP.0有漏洞,ThinkPHP5.x rec 漏洞分析与复现。本题就是利用漏洞查找。格式是: ?sindex/\think\app/invokefunction&functioncall_user_func_array&vars[0]system&vars[1][]命令。 ls查看文件没什么东西,r…

简单使用_matlab生成数据帧

文章目录 生成数据帧参考 生成数据帧 代码如下,代码很简单,有几点要注意, 较高版本的MATLAB中支持0x的写法使用bitand进行位运算使用strcat函数进行字符串拼接时,如果需要插入空格,要使用双引号 cmd_ay(1) 0x33; …

【Linux】fork函数的基础知识

文章目录 前言一、fork的返回值二、常见问题 1.为什么fork要给子进程返回0,给父进程返回子进程pid?2.一个函数返回两次值怎么理解? 3.一个变量怎么会有不同的内容? 4.fork函数干了什么? 前言 fork初识: …

基于OFDM的水下图像传输通信系统matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 function [rx_img] func_TR(tx_img, num_path, pathdelays, pathgains, snr) rng(default); …

matlab的基本使用

matlab的基本使用,可以参考如下的教程:matlab教程 本文针对基本内容进行记录。 matlab简介 MATLAB是美国MathWorks公司出品的商业数学软件,用于数据分析、无线通信、深度学习、图像处理与计算机视觉、信号处理、量化金融与风险管理、机器人&…

微信小程序的乐跑运动健身计划设计与实现

基于乐跑运动的设计基于现有的安卓手机上运行,可以实现管理员服务端;首页、个人中心、课程名称管理、用户管理、音乐分类管理、音乐库存管理、课程视频管理、运动记录管理、运动计划管理、运动提醒管理、系统管理等功能。方便用户微信端;首页…

LinkedHashMap实现LRU缓存cache机制,Kotlin

LinkedHashMap实现LRU缓存cache机制,Kotlin LinkedHashMap的accessOrdertrue后,访问LinkedHashMap里面存储的元素,LinkedHashMap就会把该元素移动到最尾部。利用这一点,可以设置一个缓存的上限值,当存入的缓存数理超过…

基于人工兔算法优化的BP神经网络(预测应用) - 附代码

基于人工兔算法优化的BP神经网络(预测应用) - 附代码 文章目录 基于人工兔算法优化的BP神经网络(预测应用) - 附代码1.数据介绍2.人工兔优化BP神经网络2.1 BP神经网络参数设置2.2 人工兔算法应用 4.测试结果:5.Matlab代…

【Unity3D】UI Toolkit容器

1 前言 UI Toolkit简介 中介绍了 UI Builder、样式属性、UQuery,本文将介绍 UI Toolkit 中的容器,主要包含 VisualElement、ScrollView、ListView、UI Toolkit,官方介绍详见→UXML elements reference。 2 VisualElement(空容器&…

【C++】 C++11(右值引用,移动语义,bind,包装器,lambda,线程库)

文章目录 1. C11简介2. 统一的列表初始化2.1 {}初始化2.2 std::initializer_list 3. 声明3.1 auto3.2 decltype3.3 auto与decltype区别3.4 nullptr 4. 右值引用和移动语义4.1 左值引用和右值引用4.2 左值引用与右值引用比较4.3 右值引用使用场景和意义4.…