Inspired by my colleague, who is playing the battleship game in FB messenger every night, so I come up with an idea to build such an AI program that can boost our wining rate. :)
如果你有微信的话,欢迎关注我的微信公众号: 猫猫的AI游乐园
会不定期送上有趣的资讯和AI实验互动 :)
-> 2018.04.13 更新: 给这公众号发任意消息可以与这个battleship AI进行对战 -> 2018.04.14 对这个project的中文简介: https://mp.weixin.qq.com/s/QBMsbrj6bJzXJjU_kRVw-A
References:
- Simple battleship tensorflow tutoriale http://efavdb.com/battleship/
- AlphaZero Algorithm for Gomoku, tensorflow version written by me :), where I reuse the network layer here. https://github.com/Kelvin-Zhong/AlphaZero_Gomoku/blob/master/policy_value_net_tensorflow.py
Demo: (5x5 board with two 1x2 ships, left is AI board, right is random-play board
You can see that the AI learn to hit the dialog line which can maximize its hitting rate.
Develop Enviroment:
- Python 3.6
- Tensorflow 1.7.0
How to train the model ?
-> python3 Train.py
I want to play against the AI ?
-> python3 HumanPlay.py
I want to deploy the AI program to my server so my friends can play against my AI ?
-> You can take a look at HumanPlayForServer.py
, it will store the game state into pickle in local directory, so anyone can play the game via different request.
-> Board size: 5 x 5
-> Ships: A. 1x2, B. 1x2
You can change whatever you want by changing the GameConfig.py
file.
-> I tried two structures:
- Two dense connected layers
- 3 layer CNN (similar to the CNN I built for Gomoku on the second reference) As a result, I use the latter one, which is slightly better than the first one, though it takes longer time to train. You can find and play with the two network structure by simply changing
-> I just simply reuse the rewarding function from the first reference. LOL
- For the 5x5 board setup, it takes me half an hour for self-playing 10000 games, and the avg #move stablized at 14, compared to 20 at the beginning.
- For the 10x10 board setup, still training...
-> One of my colleague ask if we can build a good algorithm simply based on DFS but not Deep Learning ?
Hmm, I still need to think about it, would like to hear you guys' thoughts. (looks like a good interview question for me to ask the candidates)
-> The training time GPU/CPU are similar (based on 5x5 board setup), but sometimes CPU will stuck on computation, not sure why, so eventually I train the network on my AWS GPU instance.