围棋AI.Sabaki+Leela+Leela Zero+AQ+Ray.2018年2月21日更新

版权声明:本文为博主原创文章,未经博主允许可以随意转载。 https://blog.csdn.net/cfy_openvms/article/details/82803838

前言

随着80年代中日围棋擂台赛的开始,中国大地上兴起了围棋热,于是,从初中一年级开始,围棋成为了我的爱好之一,甚至曾经为之痴迷了七八年(如果不是爱好了围棋,也许我能考上一表大学)。转眼30年过去了,自己的围棋水平基本停滞不前,在弈城围棋网6-7D,偶尔能侥幸赢一次8D。本以为自己终生也就是混迹于这个水平的圈子了,没想到这两年人工智能、大数据的发展,围棋AI竟然将人类打翻在地。得利于开源运动的兴起和传播,感谢众多的开源软件作者,我等升斗小民也能紧跟潮流,尝试一下围棋AI的滋味,俨然自己是职业棋手与围棋AI恶战一番。

相关软件介绍和下载(Windows 10 Pro 64位版本)

1、Sabaki

一个完全使用网页技术(HTML5 + Javascript)开发,由electron封装,界面漂亮的围棋应用程序。作者的中文名字好象叫沈易川。Sabaki好象是日语发音,腾挪(围棋术语)的意思。
官网地址:http://sabaki.yichuanshen.de/
Github地址:https://github.com/SabakiHQ/Sabaki

官方网站截图

Github上Sabaki的页面


下载地址:https://github.com/SabakiHQ/Sabaki/releases/tag/v0.33.3
在官方网站上点击“Download”就会链接到最新版的Sabaki下载地址

2018年2月11日,当下的最新版本是0.33.3


运行下载的“sabaki-v0.33.3-win-x64-setup.exe”文件,按照提示安装即可。
注意:1、最好不要安装在默认的“Program Files”文件夹下,因为随后复制其他工具时会受到权限提示;2、安装文件夹不要有空格,我开始命名文件夹含有空格,结果调用Leela GTP引擎时,报一堆js错误。
Sabaki的Theme(可以定制棋盘棋子的样式)下载地址:https://github.com/SabakiHQ/Sabaki/blob/master/docs/guides/theme-directory.md

2、Leela

2017年2月18日,比利时人工智能开发者Gian-Carlo Pascutto在自己的主页公开了一款围棋人工智能“Leela”,并提供免费下载。这款围棋人工智能据悉接近了职业水准。韩国职业棋手孙根气五段说:“虽然在部分死活问题上存在短板,但棋感和局面的运营接近了职业水准,尤其这款程序在普通个人电脑上运行就可达到上述的水准。”Leela在KGS计算机围棋大赛多次获得冠军(第32、38、42届),2008年在计算机奥林匹克赛上获得过九路围棋银牌和十九路围棋铜牌。现在(2018年2月11日),Leela的水平又有提高,而且衍生出Leela-Zero这一版本。
官网地址:https://www.sjeng.org/leela.html

Leela主页


Leela本身就有图形化界面的对局程序,能够实现人机对弈。Leela还提供GTP(Go Text Protocol,即围棋文本协议)功能的引擎程序。
Leela GTP引擎下载链接:https://www.sjeng.org/dl/Leela0110GTP.zip
在Leela主页选择“Leela 0.11.0 engine only”下载
将下载得到的“Leela0110GTP.zip”文件解压,确认含有“Leela0110GTP.exe”和“Leela0110GTP_OpenCL.exe”两个文件后,在Sabaki的安装文件夹下建立类似下图的文件夹。

“Leela0110GTP”就是解压后得到的文件夹

3、LeelaSabaki

Github地址:https://github.com/SabakiHQ/LeelaSabaki

LeelaSabaki页面

LeelaSabaki下载,选择“Download LeelaSabaki”

LeelaSabaki下载页面


将下载得到的“leelsabaki-v0.3.0-linux-macos-win-x64.7z”文件解压,将解压得到的文件夹复制到Sabaki文件夹下,如下图。

“leelsabaki-v0.3.0”就是解压后的文件夹

4、进入Sabaki设置GTP引擎

首先运行Sabaki应用程序,在窗口的菜单栏中选择“Engines”,选择“Manage Engines...”。

Manage Engines...


在弹出的窗口中,选择“Engines”标签,点击左下的“Add”,分别填入“Engine Name”(引擎名字,随便写)、“Path”(LeelaSabaki的路径和文件名)、“Arguments”(执行参数,还要把Leela GTP的路径和文件名带上)字段。图中下面的是已经填好的样例。完成后点击“Close”。如下图。

填好Engines的样子


LeelaSabaki的正则表达式:leelasabaki [--flat] [--heatmap] [--help] <path-to-leela> [leela-arguments...]
在Sabaki主界面窗口的菜单栏中选择“View”,按照下图勾选。
还要勾选“Show Comments”

View的勾选样例


在Sabaki主界面窗口的菜单栏中选择“Engines”,选择“Attach...”,开始自动对局。如下图。

选择对局引擎,填写对局信息

成功载入引擎,我的显卡是Nvidia GeForce GTX 1050 Ti,准备对局

人机对弈,左边窗口是Leela GTP引擎的信息窗口,右边窗口是棋子树

如果想要围棋AI给你下一手的建议,在引擎设置窗口添加“--heatmap”参数,红色区域越大越浓,表示这个着点的胜率越高

5、后记

从下载软件到学习使用,再到写这个博客文章,前前后后花了5、6小时,希望这篇文章能给更多的棋友和棋童父母以方便,希望围棋AI程序能给更多的棋友和棋童父母以更大的帮助。如有疑问,欢迎留言共同学习。

6、补记.安装AQ引擎

2018年2月12日又试着在Sabaki上安装了一下另一个围棋GTP引擎,Github地址:https://github.com/ymgaq/AQ

AQ的Github页面


在页面中寻找这一段:

注意图中蓝色字:here


点击上图中蓝色的“here”,下载编译好的的AQ程序,链接:https://github.com/ymgaq/AQ/releases

AQ下载链接

上图中,AQ-mini_win.zip是CPU版,不需要显卡支持;AQ_win.zip是显卡版,要求Nvidia显卡的GPU CUDA capability>=3.0。看看Nvidia的显卡GPU CUDA capability吧:

Nvidia主流显卡GPU CUDA capability值

根据自己电脑的配置选择下载文件,解压到Sabaki的文件夹下,运行Sabaki,在窗口的菜单栏中选择“Engines”,选择“Manage Engines...”,点击“Add”,按照自己的文件路径写入,完成后点击“Close”。

添加AQ引擎

设置好AQ引擎了,进入Sabaki试试AI对抗吧。

AQ 2.1.1执黑对Leela 0.1.1.0 GTP

白中盘胜,我电脑的CPU是Intel i7 2600,显卡是Nvidia Geforce GTX 650 Ti,也许是CPU版的AQ弱一些?

7、补记.安装RN(ray)引擎

RN(ray)跟AQ引擎相似的调用方式,下载的文件里面有README.md解释参数的意思。我是在Sabaki里调用的,跟AQ一样的方法,喜欢就试试参数,比如:--thread 4。意思是使用CPU的4线程。
2018年2月18日,飞扬围棋论坛myp0001棋友提供参数参考:--thread 4 --tree-size 262144 --reuse-subtree --const-time 15
RN的Github地址:https://github.com/zakki/Ray

RN的Github页面

RN的Github下载地址:https://github.com/zakki/Ray/releases

RN的Github下载页面

8、补记.安装Leela Zero引擎.配置权重文件

Leela Zero的官方主页:http://zero.sjeng.org/
Leela Zero的Github下载地址:https://github.com/gcp/leela-zero/releases
Leela Zero的权重文件就在官方主页的下方:

Leela Zero的权重文件

Leela Zero的配置方法与Leela相似(其中的参数“-t 6”表示使用CPU的6线程;“-w 20180220.txt”表示调用名字为“20180220.txt”的权重文件;“--noponder”表示对手时间内不思考):

Leela Zero的配置方法

注意:
1、权重文件我是解压缩了的,虽然有说不用解压。
2、权重文件要放在“leelsabaki-v0.3.0”文件夹下,而不是“leela-zero-0.12”文件夹下。因为Sabaki是调用“leelasabaki-win.exe”这个文件,而不是直接调用“leelaz.exe”。
3、可以在DOS窗口,用“leelaz.exe -h”命令查看leelaz的参数说明。

leelaz的参数说明

关于棋子摆放整齐的方法

怀疑自己有轻度强迫症,面对Sabaki棋子排列不整齐的样子难受啊。于是,2018年2月12日在作者的Github上提问了这个问题,下午的时候作者(沈易川?)回复了邮件。解决方法是:菜单栏上点击“File”,再选择“Preferences...”,在弹出的窗口中,把“Fuzzy stone placement”前面的对号去掉。唉,英文不行啊!

选择Preferences...

把“Fuzzy stone placement”前面的对号去掉

猜你喜欢

转载自blog.csdn.net/cfy_openvms/article/details/82803838