Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
99 | pmbaty | 1 | /* |
2 | Texel - A UCI chess engine. |
||
3 | Copyright (C) 2013-2014 Peter Ă–sterlund, peterosterlund2@gmail.com |
||
4 | |||
5 | This program is free software: you can redistribute it and/or modify |
||
6 | it under the terms of the GNU General Public License as published by |
||
7 | the Free Software Foundation, either version 3 of the License, or |
||
8 | (at your option) any later version. |
||
9 | |||
10 | This program is distributed in the hope that it will be useful, |
||
11 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
12 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
13 | GNU General Public License for more details. |
||
14 | |||
15 | You should have received a copy of the GNU General Public License |
||
16 | along with this program. If not, see <http://www.gnu.org/licenses/>. |
||
17 | */ |
||
18 | |||
19 | /* |
||
20 | * material.hpp |
||
21 | * |
||
22 | * Created on: May 1, 2013 |
||
23 | * Author: petero |
||
24 | */ |
||
25 | |||
26 | #ifndef MATERIAL_HPP_ |
||
27 | #define MATERIAL_HPP_ |
||
28 | |||
29 | #include "piece.hpp" |
||
30 | |||
31 | /** |
||
32 | * An incrementally updated material identifier. |
||
33 | * For each legal piece configuration, a unique identifier is computed. |
||
34 | */ |
||
35 | class MatId { |
||
36 | public: |
||
37 | static const int WP = 1; |
||
38 | static const int WR = 9; |
||
39 | static const int WN = 91; |
||
40 | static const int WB = 767; |
||
41 | static const int WQ = 5903; |
||
42 | |||
43 | static const int BP = 1 << 16; |
||
44 | static const int BR = 9 << 16; |
||
45 | static const int BN = 91 << 16; |
||
46 | static const int BB = 767 << 16; |
||
47 | static const int BQ = 5903 << 16; |
||
48 | |||
49 | MatId(); |
||
50 | |||
51 | /** Add a piece to the material configuration. */ |
||
52 | void addPiece(int pType); |
||
53 | |||
54 | /** Remove a piece from the material configuration. */ |
||
55 | void removePiece(int pType); |
||
56 | |||
57 | /** Add cnt pieces of tyep ptype to the material configuration. */ |
||
58 | void addPieceCnt(int pType, int cnt); |
||
59 | |||
60 | /** Get the material configuration identifier. */ |
||
61 | int operator()() const; |
||
62 | |||
63 | /** Get ID for black/white mirror position. */ |
||
64 | static int mirror(int id); |
||
65 | |||
66 | private: |
||
67 | int hash; |
||
68 | static const int materialId[Piece::nPieceTypes]; |
||
69 | }; |
||
70 | |||
71 | inline |
||
72 | MatId::MatId() |
||
73 | : hash(0) { |
||
74 | } |
||
75 | |||
76 | inline void |
||
77 | MatId::addPiece(int pType) { |
||
78 | hash += materialId[pType]; |
||
79 | } |
||
80 | |||
81 | inline void |
||
82 | MatId::removePiece(int pType) { |
||
83 | hash -= materialId[pType]; |
||
84 | } |
||
85 | |||
86 | inline void |
||
87 | MatId::addPieceCnt(int pType, int cnt) { |
||
88 | hash += materialId[pType] * cnt; |
||
89 | } |
||
90 | |||
91 | inline int |
||
92 | MatId::operator()() const { |
||
93 | return hash; |
||
94 | } |
||
95 | |||
96 | inline int |
||
97 | MatId::mirror(int h) { |
||
98 | unsigned int ret = h; |
||
99 | return (ret >> 16) | ((ret & 0xffff) << 16); |
||
100 | } |
||
101 | |||
102 | #endif /* MATERIAL_HPP_ */ |