3
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

生成AIのハードルを下げたい!Advent Calendar 2023

Day 12

【世界初?】ChatGPTと合法手の範囲で将棋をするための工夫まとめ

Last updated at Posted at 2023-12-11

はじめに

本記事では、ChatGPTと将棋をするための工夫を紹介します。ChatGPTと将棋をしようとしたところ、初手で合法ではない手を返してきました。

image.png

かなり調べたのですが、ChatGPTと合法手の範囲で将棋をできたという事例は見つかりませんでした。
※ChatGPTが合法ではない手、つまり反則をしてしまうという事例はたくさん出てきました。

そこで、ChatGPTに色々な工夫を施し、なんとかルール通りに対局ができるGPTsを作成しました。
※不具合は多いです

また、盤面を毎回表示することで盤面を見ながら対局ができるようにしました。

自己紹介

  • 1人アドカレで生成AIについての記事を25件執筆しようとしているデータサイエンティストです。
  • NishikaのChatGPTコンペで2位になったことがあります。
  • 将棋はアマチュア三段、チェスはルールを知っているくらいの実力です。
  • 推しの将棋棋士は、永瀬拓矢先生、羽生善治先生です。推しの女流棋士は、西山朋佳先生、香川愛生先生です。

工夫①:将棋ライブラリの利用

まず、最初の工夫は、将棋ライブラリの利用です。Pythonには将棋用のライブラリがいくつか用意されています。Code interpreterを用いることでライブラリを使用します。
python-shogi を用いることで、盤面の崩壊や合法ではない手を指すことは少なくなりました。

Code interpreterで既存のライブラリ(pandasなど)以外を使用する方法は、からあげさんのツイートを参考にしました。

python-shogi以外にもcshogiという将棋ライブラリがあります。最初こちらから試したのですが、CコンパイラをCode interpreter内で用意する方法がわからず断念しました。

工夫②:Instructionsのチューニング

InstructionsによってChatGPTをカスタマイズすることができます。

例えば、下記のようにInstructionsに記入することで、ChatGPTの挙動をソフトにコントロールすることができます。
Instructions例
image.png

Instructions(完全版)
ユーザーとは日本語でやり取りしてください。
「へぼ将棋」は、将棋の学習とプレイをサポートするために設計されたGPTです。このGPTは、「python-shogi」というPythonライブラリを使用してゲームの局面を分析し、初心者に優しい手を提案します。各やり取りで、どちらの番かを明確にし、将棋盤を表示します。また、公式の将棋ルールに従い、追加のガイドラインと戦略については、日本大使館(アメリカ)の「Shogi Cheat Sheet」を参考にします。
「へぼ将棋」は、将棋に関係のない話題への参加を避け、将棋のルールや戦略を正確に表現します。ゲームに関する誤情報を避けます。
GPTのやり取りは教育的で魅力的であり、初心者が将棋の基本を理解するのを手助けすることを目指します。動きや戦略をシンプルでアクセスしやすい方法で説明します。GPTはフレンドリーで、励まし、新しいプレイヤーに対して忍耐強く接します。
GPTは、将棋の専門用語を適切に使用し、初心者に合わせて言語の複雑さを調整することができます。

**最初に振り駒を行い、プレイヤーとGPTのどちらが先手かを決めます。もしくは、ユーザーの希望に合わせます。**
**まず、「python-shogi-master.zip」を解凍し、ライブラリとして使用します。**
**KIF形式で盤面を表示してください。**
**毎ターン、どちらの手番かを表示します。**
**毎ターン、盤面を表示します。**
**GPTの手はGPTが考え、人間の手は人間が考えます。**
**ユーザーの入力が、USI形式ではない場合でも、うまく解釈してください。例えば、`76歩`は`7g7f`と等価です。**


GPTsのInstructionsはGPTs Builderの自動生成とユーザーの入力などが混ざって汚くなりがちです。
下記のようにInstructionsのプロンプトをリファクタリングすることができます。

`下記のプロンプトをリファクタリングしてください。`

~~~Instructions~~~

ユーザーの入力が、USI形式ではない場合でも、うまく解釈してください。というプロンプトをInstructionsに入れることで、ユーザーにとって馴染み深い記法(26歩など)をChatGPTが扱いやすい記法(2g2fなど)に自動的に変換できます。ただし、不安定になるので、チェススタイルの符号(7g7f、2d2c+、S*5cなど)を用いることを推奨とします。

image.png

工夫③:Knowledgeの利用

GPTsのKnowledgeには下記の2つを与えました。

  1. Shogi-Cheat-Sheet.pdf:在アメリカ合衆国日本国大使館が共有している将棋のルールブック
  2. python-shogi-master.zip:先述のpython-shogiライブラリをzipにしたもの

image.png

完成した合法手の範囲で将棋をすることができるChatGPT

「将棋ライブラリの利用」「Instructionsのチューニング」「Knowledgeの利用」以上3つの工夫を行うことで、辛うじてChatGPTと将棋をすることができるようになりました!
※不具合がとても多いです

【棋譜の一例】

【GPTs】

image.png

参考にしたもの

3
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?