多种智能搜索算法可视化还原 3D 魔方

这篇具有很好参考价值的文章主要介绍了多种智能搜索算法可视化还原 3D 魔方。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、写在前面

许久没有写图形化界面的程序了,最近学习了一些经典的盲目搜索算法与智能搜索算法,正好拿来还原三阶魔方!试试手!

提前声明

我不是专业搞人工智能的,理论或者实现过程有些许错误也很正常,评论区指出即可

先说一下开发环境吧!源码及打包程序的下载链接放在文末!

1.1 开发环境

编程语言:Python 3.12

图形界面库:tkintertools 2.6.21.1(底层为 tkinter)

第三方依赖库:tkintertools 2.6.21.1(就这么一个)

二、程序概览

2.1 代码情况

代码量:1000 行左右

代码大小:34KB

2.2 图片展示

多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
主界面
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
界面设置
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
自定义打乱顺序
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
BFS 宽度优先搜索
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
DFS 深度优先搜索
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
USC 一致代价搜索
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
闵可夫斯基距离 A 算法
多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter
自定义启发函数 A* 算法

2.3 详细功能

左侧是 3D 显示区,鼠标左键旋转,右键平移,滚轮缩放。

右侧是设定区,点击“开始搜索并还原”时会弹出搜索树弹窗,点击“随机打乱”左边的“/”会弹出“自定义打乱顺序”弹窗。

算法对应表:

缩写 BFS DFS UCS A / A* HC REV(测试常用)
说明 宽度优先 深度优先 代价优先 A 或者 A* 算法 爬山法 不是算法,逆序还原

 启发函数对应表:

缩写 CBSV ECLD MHT HM MKWSK /
说明 切比雪夫距离 欧几里得距离 曼哈顿距离 汉明距离 闵可夫斯基距离 h*

自定义顺序说明:

每个项目由三个部分组成:编号,方向,旋向

方向对应表:

缩写 R L U D F B
说明 右(Right) 左(Left) 上(Up) 下(Down) 前(Front) 后(Back)

 旋向有两个:顺时针和逆时针,对应开关的两种状态

三、实现过程分析

3.1 状态表示

三阶魔方一共有 3³ =27 个方块,于是使用 1×27 大小的数组来表示每个方块的位置,给它们编号 0~26,当编号与其数组索引一致时,表示魔方为还原状态。

当然,由于魔方的特性,这 27 个位置中有些并不会改变。比如,当操作不涉及中转的时候,有 1+1×6 = 7 个方块永远不会改变位置,而当操作涉及中转的时候,只有中心处方块不会改变位置。为了方便表示,仍然采用整个 1×27 大小的数组表示状态。

3.2 操作方式

分两种情况:

  • 当不允许三阶魔方中转的时候,操作共有 6×2 = 12 种,即在魔方 6 个面上顺时针旋转 90°或者逆时针旋转 90°。
  • 当允许三阶魔方中转的时候,共有 (6+3)×2 = 18 种,即在第一种情况下加上了三个坐标轴垂直的三个中间面的旋转。

当然,经分析,我认为采用第 1 种情况可能会得到更好结果。

对于第一种情况,魔方将有 1+1×6 = 7 个位置始终固定,使得在完成几乎相同功能的前提下,搜索空间会小一点,且,还原的最终结果只有1个,那就是数组元素与其索引一致。

但反观第二种情况,魔方只有最中间 1 个元素始终固定,在使得搜索空间变大的情况下,还会导致一个程序中不方便处理的问题。因为在这个时候,你会发现,魔方还原的目标状态不只“数组元素与其索引一致”这么一种情况,虽然这可以提高发现目标节点的概率,但搜索空间也变大了,程序实现起来比较麻烦,效率也不见得比第 1 种好。

3.3 启发函数的设计

魔方数据在数组中体现为 1×27,并不方便于直接进行代价的估计,但其在空间上实际是 3×3×3 的,每个方块都有其对应的坐标,于是可以计算每个方块当前位置与目标位置之间的某种差异,并以此作为估计值。

选用的基本启发函数有切比雪夫距离、欧几里得距离、曼哈顿距离和闵可夫斯基距离,同时尝试了一下汉明距离。

不知道什么是切比雪夫距离、欧几里得距离等的朋友,可以去百度一下。

设上述距离对应的启发函数分别为 、、、 和 。

其中闵可夫斯基距离拥有可调节的参数 p,我这里动态地根据问题的规模大小设计其值。而汉明距离并非一个空间上的关系,它是从数组的数据上直接进行考虑的,即目标数组与当前数组的差异。

对于上述的启发函数,并非所有都满足可纳性。由于魔方转动一次只能转动一个面,也就是说,方块只能在一个面上移动,对于方块,分两种情况:

  • 角方块:每次旋转都是沿坐标方向的,对应曼哈顿距离;
  • 边方块:每次旋转都是沿斜直线方向,对应欧几里得距离;
  • 面中心方块:始终没有任何移动,计算时不考虑它。

每个面上角方块与边方块各占一半,故 多种智能搜索算法可视化还原 3D 魔方,开发秘籍:tkinter 桌面应用程序,Python,AI,魔方,智能搜索算法,搜索可视化,tkintertools,tkinter,但是有:

因此有:

已知,对于闵可夫斯基距离,参数 p=1 时,,参数 p=2 时,,参数 p=+∞ 时,,可通过调控其参数 p 来控制其最终效果。

汉明距离并非空间上的距离,属于抽象距离,无法与上面的进行比较。

综上,启发函数为切比雪夫距离、欧几里得距离时,算法为 A* 算法,曼哈顿距离对应的为 A 算法,闵可夫斯基距离是否为 A* 算法与参数 p 有关,汉明距离对应的暂时无法确定。

3.4 算法实现

BFS:用队列实现

DFS:用堆栈实现

UCS:用优先级队列实现,评估函数 F = 代价函数 G

A/A*:用优先级队列实现,评估函数 F = 代价函数 G + 启发函数 H

HC:用优先级队列实现,评估函数 F = 启发函数 H

3.5 结果显示方法

结果采用三种方式进行可视化。

  • 搜索之前的打乱魔方与搜索之后的还原魔方通过 3D 魔方实时演示旋转过程;
  • 搜索过程之中,通过进度条得知总搜索空间的大小以及当前搜索的空间大小,直观显示其百分占比,并实时显示搜索次数,搜索完成后显示还原步骤的数量;
  • 搜索过程中实时展示搜索树,由于此数的每层节点数量是指数级增长的,于是就需要将其对数化后以线性的方式的进行展示,层数越大,颜色越深,搜索完毕后标识出搜索路径。

这里说一下为什么实际搜索的状态空间是 11 的 n 次方,而不是 12 的 n 次方,因为每次操作,虽然有 12 步,但实际我们手动不允许它执行与上次转动相反的操作,因为你顺时针转一下,再逆时针转一下,那不等于没转吗?

别小看这点优化,11⁶ = 1771561,12⁶ = 2985984,仅 6 步,相差多少自己看看。

四、写在后面

4.1 开源图形库

本程序使用的 tkintertools 是我自己一个人开发的图形界面库,基于 tkinter,实现了一些 tkinter 没有的功能,里面还有一个可以称为“微型 3D 引擎”的子模块,上述 3D 效果就是这样实现的,此外还提供了较为强大的动画能力,希望大家能支持一下下!

GitHub repo:GitHub - Xiaokang2022/tkintertools

github.io: Profile - 简介 - tkintertools (xiaokang2022.github.io)

4.2 源代码下载

链接文件包含了源代码,以及已经打包好,可以直接运行的 exe 文件。

源代码及打包程序下载链接:Magic Cube.zip - 蓝奏云

记得给我点赞!收藏!以及在评论区留下你的足迹呀!文章来源地址https://www.toymoban.com/news/detail-841253.html

到了这里,关于多种智能搜索算法可视化还原 3D 魔方的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C#,字符串匹配(模式搜索)KMP算法的源代码与数据可视化

      D.E.Knuth   J.H.Morris KMP 算法(Knuth-Morris-Pratt 算法)是其中一个著名的、传统的字符串匹配算法,效率比较高。 KMP算法由 D.E.Knuth , J.H.Morris 和 V.R.Pratt 在 Brute-Force 算法的基础上提出的模式匹配的改进算法。因此人们称它为“克努特—莫里斯—普拉特算法”,简称KMP算法。K

    2024年01月25日
    浏览(34)
  • 人工智能 - A*算法解决迷宫问题 附源码和可视化显示

    写在最前,先附上可视化后的效果: 迷宫问题可以表述为:一个二维的网格,0 表示点可走,1 表示点 不可以走,点用(x,y)表示,寻找从某一个给定的起始单元格出发, 经由行相邻或列相邻的单元格(可以通过的),最终可以到达目标单元 格的、所走过的单元格序列。在任一

    2024年02月02日
    浏览(39)
  • 智能科学毕设分享(含算法) python大数据房价预测与可视化系统

    # 0 简介 今天学长向大家介绍一个适合作为毕设的项目 毕设分享 python大数据房价预测与可视化系统 项目获取: https://gitee.com/sinonfin/algorithm-sharing 1.需求描述 对于数据挖掘工程师来说,有时候需要抓取地理位置信息,比如统计房子周边基础设施信息,比如医院、公交车站、写

    2024年02月03日
    浏览(29)
  • 判了!国内AI著作权侵权第一案;大模型3D可视化网站也太酷了;RAG从架构到技术细节;AI一年,人间十年;通义千问AI挑战赛;算法可视化网站 | ShowMeAI日报

    👀 日报周刊合集 | 🎡 生产力工具与行业应用大全 | 🧡 点赞关注评论拜托啦! 原告李某使用AI生成涉案图片后发布于小红书平台;被告刘某在百家好发文配图时使用了原告该AI生成的图片,并截掉了署名水印。原告起诉要求被告道歉并进行经济赔偿。 这个案件被称为「 AI生

    2024年02月05日
    浏览(43)
  • C#,人工智能,机器人,路径规划,A*(AStar Algorithm)算法、源代码及计算数据可视化

    Peter Hart  Nils Nilsson  Bertram Raphael  参考: C#,人工智能(AI)机器人路径规划(Path Planning)的ARA*(Anytime Replanning A* Algorithm)算法与源程序 https://blog.csdn.net/beijinghorn/article/details/125464754 A*算法最初由斯坦福研究院(Stanford Institute)的  Peter Hart,Nils Nilsson,Bertram Raphael  发表于

    2024年01月18日
    浏览(46)
  • 可视化工具:将多种数据格式转化为交互式图形展示的利器

    在数据驱动的时代,数据的分析和理解对于决策过程至关重要。然而,不同的数据格式和结构使得数据的解读变得复杂和困难。为了解决这个问题,一种强大的可视化工具应运而生。这个工具具有将多种数据格式(包括 JSON 、 YAML 、 XML 、 CSV 等)转化为交互式图形展示的能力

    2024年02月19日
    浏览(28)
  • Python 3D可视化(一)

    本篇目录: 一、写在前面的话 二、简介 三、环境安装 四、python 3D实例集锦 (1)、圆柱体 (2)、箭头 (3)、球形 (4)、平面 (5)、线型 (6)、立方体 (7)、圆锥体 (8)、六边形 (9)、空心六边形 (10)、茶壶 (11)、兔子 (12)、飞机 五、总结   作者:北宋苏

    2023年04月12日
    浏览(41)
  • 【数据可视化】2D/3D动画

    ◼ CSS3 transform属性允许你旋转,缩放,倾斜或平移给定元素。 ◼ Transform是形变的意思(通常也叫变换),transformer就是变形金刚 ◼ 常见的函数transform function有: ---- 平移:translate(x, y) ---- 缩放:scale(x, y) ---- 旋转:rotate(deg) ---- 倾斜:skew(deg, deg) ◼ 通过上面的几个函数,我们

    2024年02月08日
    浏览(36)
  • QtDataVisualization 数据3D可视化

            Data Visualization的三维显示功能主要由三种三维图形来实现,分别是三维柱状图Q3DBars,三维空间散点Q3DScatter,三维曲面Q3DSurface。这三个类的父类都是QAbstract3DGraph,从QWindow继承而来。         Data Visualization与Qt Charts类似都是基于Qt Graphics View的图形视图结构,所以

    2024年02月14日
    浏览(34)
  • 神经网络的可视化:使用3D可视化和交互式界面来展示模型

    作者:禅与计算机程序设计艺术 作为人工智能领域的从业者,我们常常需要与其他技术人员或者领域内的专家进行交流。在这个过程中,一个关键的问题是如何让复杂的神经网络模型变得易于理解和分析。今天,我们将探讨如何使用3D可视化和交互式界面来展示神经网络模型

    2024年02月14日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包