How to program a neural network for chess?

后端 未结 9 569
失恋的感觉
失恋的感觉 2021-01-30 11:18

I want to program a chess engine which learns to make good moves and win against other players. I\'ve already coded a representation of the chess board and a function which outp

相关标签:
9条回答
  • 2021-01-30 12:00

    It is possible, but not trivial by any means.

    https://erikbern.com/2014/11/29/deep-learning-for-chess/

    To train his evaluation function, he utilized a lot of computing power to do so.

    To summarize generally, you could go about it as follows. Your evaluation function is a feedforward NN. Let the matrix computations lead to a scalar output valuing how good the move is. The input vector for the network is the board state represented by all the pieces on the board so say white pawn is 1, white knight is 2... and empty space is 0. An example board state input vector is simply a sequence of 0-12's. This evaluation can be trained using grandmaster games (available at a fics database for example) for many games, minimizing loss between what the current parameters say is the highest valuation and what move the grandmasters made (which should have the highest valuation). This of course assumes that the grandmaster moves are correct and optimal.

    0 讨论(0)
  • 2021-01-30 12:05

    Read blondie24 : http://www.amazon.co.uk/Blondie24-Playing-Kaufmann-Artificial-Intelligence/dp/1558607838.

    It deals with checkers instead of chess but the principles are the same.

    0 讨论(0)
  • 2021-01-30 12:07

    In case somebody randomly finds this page. Given what we know now, what the OP proposes is almost certainly possible. In fact we managed to do it for a game with much larger state space - Go ( https://deepmind.com/research/case-studies/alphago-the-story-so-far ).

    0 讨论(0)
提交回复
热议问题