forked from ripred/MicroChess
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgame.h
142 lines (106 loc) · 4.1 KB
/
game.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/**
* game.h
*
* the MicroChess project: https://github.com/ripred/MicroChess
*
* header file for MicroChess
*
*/
#ifndef GAME_INCL
#define GAME_INCL
#include "Arduino.h"
#include <stdint.h>
#include "board.h"
#include "stats.h"
#include "options.h"
extern board_t board;
////////////////////////////////////////////////////////////////////////////////////////
// board spot by column and row
struct point_t
{
public:
index_t x : NUM_BITS_PT,
y : NUM_BITS_PT;
point_t() {}
point_t(index_t X, index_t Y) : x(X), y(Y) {}
}; // point_t
////////////////////////////////////////////////////////////////////////////////////////
// the state of a game
class game_t
{
public:
// The game options
static options_t options;
// The locations of the pieces on the board
point_t pieces[MAX_PIECES];
uint8_t piece_count;
uint8_t
wking : 6, // the location of the white king
last_was_pawn_promotion : 1, // True when last move promoted a Pawn to a Queen
white_king_in_check : 1, // The check state of the white king
bking : 6, // the location of the black king
black_king_in_check : 1, // The check state of the black king
last_was_en_passant : 1, // True when last move was an en-passaant capture
state : 3, // the current state of the game
last_was_castle : 1, // True when last move was a castling of a king and a rook
ply : 3, // the current ply level
supply_valid : 1, // True when the supplied move has been validated
book_supplied : 1, // True when the current move was supplied by an opening book move
user_supplied : 1, // True when the current move was supplied by the user via serial
timeout1 : 1, // True when last move timed out - this version used only duing ply 0 and 1
timeout2 : 1, // True when last move timed out - this version used during all plies
turn : 1; // Whose turn it is: 0 := Black, 1 := White
// The last 'MAX_REPS * 2 - 1' moves are kept to recognize 'MAX_REPS' move repetition
struct history_t {
index_t from : 6,
to : 6;
} history[MAX_REPS * 2 - 1];
uint8_t hist_count;
// The pieces that have been taken
struct {
uint8_t piece : 6;
} taken_by_white[16];
struct {
uint8_t piece : 6;
} taken_by_black[16];
uint8_t white_taken_count;
uint8_t black_taken_count;
// The statistics of the game
stat_t stats;
// The last move made
move_t last_move;
// Increasing move number
uint8_t move_num;
// The alpha and beta boundaries of our search envelope
long alpha;
long beta;
// The supplied move if book_supplied := True or user_supplied != True
move_t supplied;
// static, pre-computed tables for bonus values
static long const center_bonus[8][7][2] PROGMEM;
static long const material_bonus[7][2] PROGMEM;
#ifdef ENA_MEM_STATS
// The amount of free memory at critical junctions and ply levels
struct {
uint16_t mem : 12;
} freemem[8];
uint16_t lowest_mem;
index_t lowest_mem_ply;
#endif
public:
// Constructor
game_t();
// Inititialize the contents based off of the move value
void init();
// Sort the pieces by side
void sort_pieces(Color const side);
// Shuffle the pieces of the side at the top of the pieces[] list
void shuffle_pieces(index_t const shuffle_count);
// Set the pieces[] array based off of the board contents
void set_pieces_from_board(board_t &board);
// Check the integrity of the game.pieces[] array compared to the board contents
Bool compare_pieces_to_board(board_t &board) const;
// Find the game.pieces[] array index for the given board location
index_t find_piece(index_t const index) const;
}; // game_t
#endif // GAME_INCL