Compare commits

..

3 Commits

4 changed files with 83 additions and 31 deletions

View File

@ -6,7 +6,15 @@ Board b = Board();
void setup() { void setup() {
// put your setup code here, to run once: // put your setup code here, to run once:
Serial.begin(19200); Serial.begin(9600);
char value;
while(Serial.available() == 0) {
delay(100);
}
value = Serial.read();
b.field[0x32] = char_to_piece(value);
} }
void loop() { void loop() {
@ -15,4 +23,5 @@ void loop() {
delay(1000); delay(1000);
Serial.println(b.get_zobrist()); Serial.println(b.get_zobrist());
b.print(); b.print();
Serial.println(sizeof(b));
} }

37
Board.h
View File

@ -15,8 +15,8 @@ class Board {
Board(); Board();
void print() { void print() {
for(int i = 7; i >= 0; i--) { for(char i = 7; i >= 0; i--) {
for(int j = 0; j < 16; j++) { for(byte j = 0; j < 16; j++) {
Serial.print(field[i*16 + j], HEX); Serial.print(field[i*16 + j], HEX);
Serial.print(" "); Serial.print(" ");
} }
@ -29,7 +29,6 @@ class Board {
return *addr; return *addr;
} }
private:
byte field[128] = { byte field[128] = {
W_ROOK, W_KNGT, W_BSHP, W_QUEN, W_KING, W_BSHP, W_KNGT, W_ROOK, 0, 0, 0, 0, 0, 0, 0, 0, W_ROOK, W_KNGT, W_BSHP, W_QUEN, W_KING, W_BSHP, W_KNGT, W_ROOK, 0, 0, 0, 0, 0, 0, 0, 0,
W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, 0, 0, 0, 0, 0, 0, 0, 0, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, W_PAWN, 0, 0, 0, 0, 0, 0, 0, 0,
@ -40,42 +39,44 @@ class Board {
B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, 0, 0, 0, 0, 0, 0, 0, 0, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, B_PAWN, 0, 0, 0, 0, 0, 0, 0, 0,
B_ROOK, B_KNGT, B_BSHP, B_QUEN, B_KING, B_BSHP, B_KNGT, B_ROOK, 0, 0, 0, 0, 0, 0, 0, 0, B_ROOK, B_KNGT, B_BSHP, B_QUEN, B_KING, B_BSHP, B_KNGT, B_ROOK, 0, 0, 0, 0, 0, 0, 0, 0,
}; };
private:
const byte PTR_SIDE_AND_CASTLERIGHT = 0x08; //byte (1=side, 2,4=white castle, 8,16=black) static const byte PTR_SIDE_AND_CASTLERIGHT = 0x08; //byte (1=side, 2,4=white castle, 8,16=black)
const byte PTR_PTR_REVMOV = 0x09; //byte (points to index) static const byte PTR_PTR_UNMAKE = 0x09; //byte (points to index)
const byte PTR_W_KING = 0x0A; // byte (points to index or maybe 64-arr index) static const byte PTR_W_KING = 0x0A; // byte (points to index or maybe 64-arr index)
// const byte PTR_B_KING = 0x0B; (PTR_W_KING | COLOR or PTR_W_KING + COLOR) // const byte PTR_B_KING = 0x0B; (PTR_W_KING | COLOR or PTR_W_KING + COLOR)
const byte PTR_ZOBRIST = 0x0C; // 4 bytes static const byte PTR_ZOBRIST = 0x0C; // 4 bytes
// 0x0D // 0x0D
// 0x0E // 0x0E
// 0x0F // 0x0F
const byte PTR_ENPASSANT = 0x18; static const byte PTR_ENPASSANT = 0x18;
static const byte PTR_REVMOV = 0x19;
const byte PTR_UNMAKE_START = 0x1A; static const byte PTR_UNMAKE_START = 0x28;
const byte PTR_UNMAKE_LAST = 0x7F; static const byte PTR_UNMAKE_LAST = 0x7F;
inline byte get_unmake() __attribute__((always_inline)) { inline byte get_unmake() __attribute__((always_inline)) {
return field[PTR_PTR_REVMOV]; return field[PTR_PTR_UNMAKE];
} }
byte next_unmake() { byte next_unmake() {
field[PTR_PTR_REVMOV]++; field[PTR_PTR_UNMAKE]++;
if(get_unmake() > PTR_UNMAKE_LAST) { if(get_unmake() > PTR_UNMAKE_LAST) {
field[PTR_PTR_REVMOV] = PTR_UNMAKE_START; field[PTR_PTR_UNMAKE] = PTR_UNMAKE_START;
return PTR_UNMAKE_START; return PTR_UNMAKE_START;
} }
if(!(get_unmake() & 0x8)) { if(!(get_unmake() & 0x8)) {
field[PTR_PTR_REVMOV] += 0x8; field[PTR_PTR_UNMAKE] += 0x8;
} }
return get_unmake(); return get_unmake();
} }
byte prev_unmake() { byte prev_unmake() {
field[PTR_PTR_REVMOV]--; field[PTR_PTR_UNMAKE]--;
if(get_unmake() < PTR_UNMAKE_START) { if(get_unmake() < PTR_UNMAKE_START) {
field[PTR_PTR_REVMOV] = PTR_UNMAKE_LAST; field[PTR_PTR_UNMAKE] = PTR_UNMAKE_LAST;
return PTR_UNMAKE_LAST; return PTR_UNMAKE_LAST;
} }
if(!(get_unmake() & 0x8)) { if(!(get_unmake() & 0x8)) {
field[PTR_PTR_REVMOV] -= 0x8; field[PTR_PTR_UNMAKE] -= 0x8;
} }
return get_unmake(); return get_unmake();
} }
@ -89,7 +90,7 @@ class Board {
Unmake read_unmake() { Unmake read_unmake() {
Unmake u; Unmake u;
byte* ptr = (byte*) &u; byte* ptr = (byte*) &u;
for(size_t i = sizeof(u) - 1; i >= 0; i++) { for(int i = sizeof(u) - 1; i >= 0; i++) {
ptr[i] = field[prev_unmake()]; ptr[i] = field[prev_unmake()];
} }
return u; return u;

3
Move.h
View File

@ -9,4 +9,7 @@ struct Move {
Piece pc_prom; Piece pc_prom;
}; };
//Move move_from_str(char* s) {
//}
#endif #endif

63
Types.h
View File

@ -2,19 +2,58 @@
#define __TYPES_H_INC #define __TYPES_H_INC
enum Piece: byte { enum Piece: byte {
W_PAWN = 0b0000, P_EMPTY = 0b0000,
W_KNGT = 0b0001, P_ANY = 0b1000,
W_BSHP = 0b0010,
W_ROOK = 0b0100,
W_QUEN = 0b0110,
W_KING = 0b0111,
B_PAWN = 0b1000, W_PAWN = 0b0001,
B_KNGT = 0b1001, W_KNGT = 0b0010,
B_BSHP = 0b1010, W_KING = 0b0011,
B_ROOK = 0b1100, W_BSHP = 0b0101,
B_QUEN = 0b1110, W_ROOK = 0b0110,
B_KING = 0b1111, W_QUEN = 0b0111,
B_PAWN = 0b1001,
B_KNGT = 0b1010,
B_KING = 0b1011,
B_BSHP = 0b1101,
B_ROOK = 0b1110,
B_QUEN = 0b1111,
}; };
#ifdef _ACF_FAST_PIECE
Piece char_to_piece(char c) {
switch(c) {
case 'p': return W_PAWN;
case 'n': return W_KNGT;
case 'k': return W_KING;
case 'b': return W_BSHP;
case 'r': return W_ROOK;
case 'q': return W_QUEN;
case 'P': return B_PAWN;
case 'N': return B_KNGT;
case 'K': return B_KING;
case 'B': return B_BSHP;
case 'R': return B_ROOK;
case 'Q': return B_QUEN;
default: return P_EMPTY;
}
}
#else // _ACF_FAST_PIECE
const char CHAR_STRS[] PROGMEM = " pnkbrq PNKBRQ";
Piece char_to_piece(char c) {
for(byte i = 0; i < 0b1111; i++) {
if(pgm_read_byte_near(CHAR_STRS + i) == c)
return (Piece)i;
}
return P_EMPTY;
}
char piece_to_char(Piece p) {
return CHAR_STRS[p];
}
#endif // _ACF_FAST_PIECE
#endif #endif