与本文配套的示范程序是“象棋小巫师”0.3版,程序清单是: (1) XQWL03.CPP——C++源程序; (2) XQWLIGHT.RC——资源描述文件; (3) RESOURCE.H——资源符号定义文件; (4) RES目录——图标、图片、声音等资源。 在阅读本章前,建议读者先阅读象棋百科全书网计算机博弈专栏的以下几篇译文:   (1) 国际象棋程序设计(四):基本搜索方法(François Dominic Laramée);   (2) 国际象棋程序设计(六):局面评估函数(François Dominic Laramée);   (3) 基本搜索方法——简介(一)(David Eppstein);   (4) 基本搜索方法——简介(二)(David Eppstein);   (5) 基本搜索方法——最小-最大搜索(Bruce Moreland);   (6) 基本搜索方法——Alpha-Beta搜索(Bruce Moreland);   (7) 基本搜索方法——迭代加深(Bruce Moreland);   (8) 高级搜索方法——简介(二)(David Eppstein);   (9) 其他策略——胜利局面(David Eppstein);   (10) 局面评估函数——简介(一)(David Eppstein)。 4.1 局面评价函数 根据国际象棋程序的经验,局面评价函数中最关键的因素是子力价值(后9车5象马3兵1)。这个经验同样也适合于中国象棋,并且适当调整就可以得到更好的效果——子力价值是跟它的绝对位置相关的。最明显的例子是中国象棋中的兵(卒),过河前我们给它很低的分数,过河后分数大涨,越接近九宫分数就越高,九宫中心甚至接近一个马或炮的值。 如此一来,每个兵种就都会有一个与绝对位置相关的价值数组,因此我们的程序里有一个常量数组 cucvlPiecePos[7][256],它是从开源的象棋程序 ElephantEye 中照搬过来的。 现在要开始进行局面评价了,我们是不是应该这样做:

vlEvaluate = 0; // 相对于红方来说的局面评价值
for (sq = 0; sq < 256; sq ++) {
 pc = ucpcSquares[sq];
 if (IS_RED(pc)) {
  vlEvaluate += cucvlPiecePos[PIECE_TYPE(pc)][sq];
 } else if (IS_BLACK(pc)) {
  vlEvaluate -= cucvlPiecePos[PIECE_TYPE(pc)][SQUARE_FLIP(sq)];
 }
}

这样做太浪费时间了,因为根本没有必要每次都把棋盘扫描一遍。在我们的程序里,每走一步棋都会调用两到三次 AddPiece (放一枚棋子)和 DelPiece (取走一枚棋子),可以趁这个机会更新 vlEvaluate(将上面代码中红色的部分放到 AddPiece 和 DelPiece 中)。 对于象棋小巫师来说,这样的局面评价函数已经足够好了。 4.2 Alpha-Beta搜索复杂吗? 我们可以很容易地写出一个Alpha-Beta搜索函数:

int AlphaBeta(int vlAlpha, int vlBeta, int nDepth) {
if (nDepth == 0) {
return 局面评价函数;
}
生成全部走法;
排序全部走法;
for (每个生成的走法) {
走这个走法;
int vl = -AlphaBeta(-vlBeta, -vlAlpha, nDepth - 1);
撤消这个走法; 
if (vl >= vlBeta) {
return vlBeta;
}
if (vl > vlAlpha) {
vlAlpha = vl;
}
}
return vlAlpha;
}

但是,这样的程序根本走不出棋来,因为它返回的是一个分数而不是一个走法。另外,我们还发现几个问题: (1) 排序的依据是什么? (2) 是不是每个生成的走法都可以走? (3) 如果什么走法都走不出来,那么返回vlAlpha合理吗? 针对以上几个问题,我们对程序做如下改进: (0) 如果函数在根节点处被调用,就把最佳走法作为电脑要走的棋; (1) 国际象棋程序的经验证明,历史表是很好的走法排序依据; (2) 由于我们的走法生成器并没有考虑自杀(被将军)的情况,因此走完一步后要检查是否被将军了,被将军时应立即退回来; (3) 如果没有走出过任何走法,说明当前局面是杀棋或困毙局面,应该返回杀棋的分数。 下面是改进过的程序,改进的地方用红色标出:

int AlphaBeta(int vlAlpha, int vlBeta, int nDepth) {
if (nDepth == 0) {
return 局面评价函数;
}
生成全部走法;
 按历史表排序全部走法;
for (每个生成的走法) {
走这个走法;
  if (被将军) {
   撤消这个走法;
  } else {
int vl = -AlphaBeta(-vlBeta, -vlAlpha, nDepth - 1);
撤消这个走法; 
if (vl >= vlBeta) {
    将这个走法记录到历史表中;
return vlBeta;
}
if (vl > vlAlpha) {
    设置最佳走法;
vlAlpha = vl;
}
  }
}
 if (没有走过任何走法) {
  return 杀棋的分数;
 }
 将最佳走法记录到历史表中;
 if (根节点) {
  最佳走法就是电脑要走的棋;
 }
return vlAlpha;
}

4.3 杀棋的分数 遇到将死或困毙的局面时,应该返回 nDistance - INFINITY,这样程序就能找到最短的搜索路线。nDistance 是当前节点距离根节点的步数,每走一个走法,nDistance 就增加1,每撤消一个走法,nDistance 就减少1。 如果程序中使用了置换表,这个问题将变得更加复杂,我们以后再讨论。 4.4 历史表 国际象棋程序的经验证明,历史表是很好的走法排序依据。那么,什么样的走法要记录到历史表中去呢?象棋小巫师选择了以下两类走法: A. 产生Beta截断的走法; B. 不能产生Beta截断,但它是所有PV走法(vl > vlAlpha)中最好的走法。 象棋小巫师的历史表是一个大小为65536的数组,正好能将走法的数值(mv)作为指标,因此根据走法取得历史表的值非常容易,即nHistoryTable[mv]。那么,一个走法记录到历史表,究竟该给 nHistoryTable 中的这个元素加多少分的值呢?我们仍旧沿用国际的经验——深度的平方。所以,更新历史表的代码非常简单:

nHistoryTable[mv] += nDepth * nDepth;

4.5 迭代加深和时间控制 迭代加深具有一石多鸟的功效,目前最明显的供效是充分发挥历史表的作用——浅一层搜索结束后,历史表中积累了大量非常宝贵的数据,这将大幅度减少深一层搜索的时间。 在迭代加深的基础上实现时间控制,这将是非常简单的:

for (i = 1; i < MAX_DEPTH; i ++) {
AlphaBeta(-INFINITY, INFINITY, i);
if (超过最短搜索时间) {
break;
}
}

当然,我们还可以加入其他结束迭代加深的条件,例如当程序算出了杀棋(分值接近INFINITY或-INFINITY)时,就没有必要进行更深的搜索了。

  象棋小巫师示范程序(0.1~0.6)下载:http://www.elephantbase.net/download/xqwlight_win32.7z

  CSDN下载频道:http://d.download.csdn.net/source/407014

电脑象棋循序渐进(四):最初级的人工智能相关推荐

  1. 电脑象棋循序渐进(三):让电脑掌握象棋规则

    与本文配套的示范程序是"象棋小巫师"0.2版,程序清单是: (1) XQWL02.CPP--C++源程序: (2) XQWLIGHT.RC--资源描述文件: (3) RESOURC ...

  2. 计算机中国象棋书籍,[建议]中国的象棋永远不能被没有“思维”的电脑所代替(就目前的电脑象棋软件...

    [建议]中国的象棋永远不能被没有"思维"的电脑所代替(就目前的电脑象棋软件有感而发) 先自我介绍一下,本人来自上海,师从原江苏省棋队教练言穆江大师,现年28岁,无任何值得自傲的成绩 ...

  3. 第四次产业革命源于人工智能(趋势解读20k字)

    第四次产业革命源于人工智能(趋势解读20k字) 秦陇纪10汇编 目录 A. 第四次产业革命:始于人工智能(6.7k字) B. 人工智能将带来第四次产业革命(3.3k字) C. 人工智能2.0时代序幕开 ...

  4. 第四次产业革命源于人工智能(趋势解读22k字秦陇纪10汇编)

    目录 A. 第四次产业革命:始于人工智能(6.7k字) B. 人工智能将带来第四次产业革命(3.3k字) C. 人工智能2.0时代序幕开启书(6.5k字) D. 第四次产业革命之人工智能常识.机遇和挑 ...

  5. AI公开课:18.05.05 施尧耘(阿里云量子技术CS)—清华AI第四讲之《人工智能与量子计算》Quantum课堂笔记——带你了解量子计算

    AI公开课:18.05.05 施尧耘(阿里云量子技术CS)-清华AI第四讲之<人工智能与量子计算>Quantum课堂笔记--带你了解量子计算 导读 清华大学"人工智能前沿与产业趋 ...

  6. 第四次产业革命源于人工智能(趋势…

    第四次产业革命源于人工智能(趋势解读20k字) 秦陇纪10汇编 第四次产业革命源于人工智能(趋势解读20k字),附"数据简化DataSimp"技术描述.学会及社区1k字.欢迎关注. ...

  7. 计算机图片怎么截图快捷键,电脑截图快捷键四种截屏方式,笔记本电脑如何截屏截图?...

    电脑截图快捷键四种截屏方式,笔记本电脑如何截屏截图? 网际百科资讯    知识宝库    2020-3-18    43955    0评论 电脑截图快捷键四种截屏方式,笔记本电脑如何截屏截图?给你推 ...

  8. 第四次工业革命,人工智能革命真的来了

    近两年,全球IT巨头纷纷布局人工智能领域:谷歌相继收购DeepMind.Kaggle为代表的人工智能公司.IBM打造Watson平台.百度进军无人汽车.阿里联合杭州市政府打造"城市数据大脑& ...

  9. 关于电脑CPU双核四线程

    最近想学习下Java的线程,然而对于CPU双核四线程一直不是很明白.双核是不是CPU在同一时间片上能够运行两个进程呢?答案是否定的!下面是我设备管理器显示的cpu信息以及解释,如果有错误的地方希望热心 ...

最新文章

  1. LUA C 交互 cocos
  2. 简单分析一下socket中的bind
  3. android如何实现支付宝,(Android集成支付宝支付)react-native实现支付宝支付
  4. 设计模式总结一波点点
  5. CentOS6.7安装mysql5.7
  6. HTML相对路径(Relative Path)和绝对路径(Absolute Path)
  7. Collections集合工具类的方法_sort(List,Comparator)
  8. 【原】Python基础-函数
  9. 2021年河南高考成绩排名查询一分一段表,2018河南高考一分一段统计表,查排名必备!...
  10. 基于深度学习模型WideDeep的推荐
  11. SCUT - 243 - 宝华复习 - 二分 - 桶计数
  12. mysql 主从同步不一致_为什么mysql会经常出现主从同步不一致的情况
  13. IDEA设置注释配置时获取不到参数的解决办法
  14. 超快语义分割 | PP-LiteSeg集速度快、精度高、易部署等优点于一身,必会模型!!!...
  15. 接口自动化测试框架搭建(7、连接数据库提交sql方法以及打印日志方法封装)--python+HTMLTestRunnerCN+request+unittest+mock+db
  16. flash插件java_[Java教程]SWFObject Flash 增强插件
  17. 5G协议栈用户面模块
  18. 设计模式---002适配模式(转载自我的老师 Alley-巷子)
  19. 2008、2012、2013海康威视嵌入式校招笔试整理
  20. C网络编程项目 图书借阅系统(一)

热门文章

  1. 局域网内网怎么设置无线路由器?
  2. 论文查重后怎么修改?
  3. BBC高清纪录片大全【值得收藏】
  4. 2021-2027全球与中国海上甚高频电台市场现状及未来发展趋势
  5. 办完户口档案的事了,下一步呢。。。
  6. 使用tasklist将任务管理器的进程导出
  7. win10代理服务器拒接连接
  8. 网络安全工程师(白帽子)前景分析+学习成长路线,超多思维导图从零到整,看完这篇就够了。
  9. 【ESP 保姆级教程】玩转巴法云篇④ —— TCP创客云,同步时间,OLED时钟
  10. 怎么在电脑上使用计算机,一招教你如何在电脑上使用手机APP软件?