Python游戏开发实例之graphics实现AI五子棋


Posted in Python onNovember 01, 2021

前言

利用Python+graphics模块实现AI五子棋。
让我们愉快地开始吧~~~

效果展示

Python游戏开发实例之graphics实现AI五子棋

源码

import sys
import cfg

from modules.misc.Buttons import *
from modules.ai.playWithAI import *
from modules.online.playOnline import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *

'''游戏开始界面'''
class gameStartUI(QWidget):
	def __init__(self, parent=None, **kwargs):
		super(gameStartUI, self).__init__(parent)
		self.setFixedSize(760, 650)
		self.setWindowTitle('五子棋-微信号: ilove-python')
		self.setWindowIcon(QIcon(cfg.ICON_FILEPATH))
		# 背景图片
		palette = QPalette()
		palette.setBrush(self.backgroundRole(), QBrush(QPixmap(cfg.BACKGROUND_IMAGEPATHS.get('bg_start'))))
		self.setPalette(palette)
		# 按钮
		# --人机对战
		self.ai_button = PushButton(cfg.BUTTON_IMAGEPATHS.get('ai'), self)
		self.ai_button.move(250, 200)
		self.ai_button.show()
		self.ai_button.click_signal.connect(self.playWithAI)
		# --联机对战
		self.online_button = PushButton(cfg.BUTTON_IMAGEPATHS.get('online'), self)
		self.online_button.move(250, 350)
		self.online_button.show()
		self.online_button.click_signal.connect(self.playOnline)
	'''人机对战'''
	def playWithAI(self):
		self.close()
		self.gaming_ui = playWithAIUI(cfg)
		self.gaming_ui.exit_signal.connect(lambda: sys.exit())
		self.gaming_ui.back_signal.connect(self.show)
		self.gaming_ui.show()
	'''联机对战'''
	def playOnline(self):
		self.close()
		self.gaming_ui = playOnlineUI(cfg, self)
		self.gaming_ui.show()


'''run'''
if __name__ == '__main__':
	app = QApplication(sys.argv)
	handle = gameStartUI()
	font = QFont()
	font.setPointSize(12)
	handle.setFont(font)
	handle.show()
	sys.exit(app.exec_())

开发工具

Python版本: 3.6.4

相关模块:

graphics模块。

环境搭建

安装Python并添加到环境变量即可。

注:
graphics模块在相关文件中已经提供,就是一个py文件,直接放在当前路径或者放到python安装文件夹下的site-packages文件夹内均可。

原理简介

对于五子棋这样的博弈类AI,很自然的想法就是让计算机把当前所有可能的情况都尝试一遍,找到最优的落子点。这里有两个问题:

(1)如何把所有可能的情况都尝试一遍;

(2)如何定量判断某落子点的优劣。

对于第一个问题,其实就是所谓的博弈树搜索,对于第二个问题,其实就是所谓的选择评估函数。评估函数的选取直接决定了AI算法的优劣,其形式也千变万化。可以说,每个评估函数就是一个选手,对不同的棋型每个选手自然有不同的看法和应对措施,当然他们的棋力也就因此各不相同了。

但博弈树搜索就比较固定了,其核心思想无非是让计算机考虑当前局势下之后N步所有可能的情况,其中奇数步(因为现在轮到AI下)要让AI方的得分最大,偶数步要让AI方的得分最小(因为对手也就是人类,也可以选择最优策略)。

当然这样的搜索其计算量是极大的,这时候就需要剪枝来减少计算量。例如下图:

Python游戏开发实例之graphics实现AI五子棋

其中A代表AI方,P代表人类方。AI方搜索最大值,人类方搜索最小值。因此Layer3的A1向下搜索的最终结果为4,Layer3的A2向下搜索,先搜索Layer4的P3,获得的分值为6,考虑到Layer2的P1向下搜索时取Layer3的A1和A2中的较小值,而Layer3的A2搜索完Layer4的P3时,其值就已经必大于Layer3的A1了,就没有搜索下去的必要了,因此Layer3到Layer4的路径3就可以剪掉了

上述搜索策略其实质就是:

minimax算法+alpha-beta剪枝算法。

了解了上述原理之后,就可以自己写代码实现了。当然实际实现过程中,我做了一些简化,但万变不离其宗,其核心思想都是一样的。

 

到此这篇关于Python游戏开发实例之graphics实现AI五子棋的文章就介绍到这了,更多相关Python AI五子棋内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python实现获取域名所用服务器的真实IP
Oct 25 Python
Python中的连接符(+、+=)示例详解
Jan 13 Python
python pandas.DataFrame选取、修改数据最好用.loc,.iloc,.ix实现
Jun 11 Python
Python第三方Window模块文件的几种安装方法
Nov 22 Python
Python合并同一个文件夹下所有PDF文件的方法
Mar 11 Python
Django页面数据的缓存与使用的具体方法
Apr 23 Python
使用Python3内置文档高效学习以及官方中文文档
May 19 Python
PyCharm+Qt Designer+PyUIC安装配置教程详解
Jun 13 Python
详解python中的time和datetime的常用方法
Jul 08 Python
Python3 执行Linux Bash命令的方法
Jul 12 Python
django 做 migrate 时 表已存在的处理方法
Aug 31 Python
使用 PyTorch 实现 MLP 并在 MNIST 数据集上验证方式
Jan 08 Python
Python Django获取URL中的数据详解
Nov 01 #Python
python编程项目中线上问题排查与解决
Nov 01 #Python
python实现层次聚类的方法
Python list列表删除元素的4种方法
Nov 01 #Python
Python面向对象编程之类的概念
Nov 01 #Python
python代码实现扫码关注公众号登录的实战
python编程实现清理微信重复缓存文件
Nov 01 #Python
You might like
PHP编码规范-php coding standard
2007/03/16 PHP
php中json_decode()和json_encode()的使用方法
2012/06/04 PHP
PHP 无限级分类
2017/05/04 PHP
通过源码解析Laravel的依赖注入
2018/01/22 PHP
PHP const定义常量及global定义全局常量实例解析
2020/05/28 PHP
JavaScript面向对象编程
2008/03/02 Javascript
JavaScript中继承的一些示例方法与属性参考
2010/08/07 Javascript
如何让div span等元素能响应键盘事件操作指南
2012/11/13 Javascript
js导入导出excel(实例代码)
2013/11/25 Javascript
JavaScript字符串对象toLowerCase方法入门实例(用于把字母转换为小写)
2014/10/17 Javascript
5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例
2015/01/29 Javascript
javascript实现鼠标放上后下边对应内容变换的效果
2015/08/06 Javascript
Bootstrap中文本框的宽度变窄并且加入一副验证码图片的实现方法
2016/06/23 Javascript
全面了解构造函数继承关键apply call
2016/07/26 Javascript
基于Vue2的移动端开发环境搭建详解
2016/11/03 Javascript
Webpack打包慢问题的完美解决方法
2017/03/16 Javascript
Angular.Js中ng-include指令的使用与实现
2017/05/07 Javascript
Angular限制input框输入金额(是小数的话只保留两位小数点)
2017/07/13 Javascript
JavaScript实现移动端页面按手机屏幕分辨率自动缩放的最强代码
2017/08/18 Javascript
vue几个常用跨域处理方式介绍
2018/02/07 Javascript
React Form组件的实现封装杂谈
2018/05/07 Javascript
微信小程序实现星级评分和展示
2018/07/05 Javascript
vue实现商城秒杀倒计时功能
2019/12/12 Javascript
jquery实现有过渡效果的tab切换
2020/07/17 jQuery
node使用async_hooks模块进行请求追踪
2021/01/28 Javascript
Jacobi迭代算法的Python实现详解
2019/06/29 Python
python3.7简单的爬虫实例详解
2019/07/08 Python
PyTorch里面的torch.nn.Parameter()详解
2020/01/03 Python
大专应届生个人简历的自我评价
2013/10/15 职场文书
一名老师的自我评价
2014/02/07 职场文书
软件项目开发计划书
2014/05/01 职场文书
精神文明建设标语
2014/06/16 职场文书
行政执法队伍作风整顿剖析材料
2014/10/11 职场文书
机关干部作风建设剖析材料
2014/10/23 职场文书
2014年新农村建设工作总结
2014/12/01 职场文书
先进个人事迹材料
2014/12/29 职场文书