- // Doubled pawn penalty by file
- const Score Doubled[FILE_NB] = {
- S(13, 43), S(20, 48), S(23, 48), S(23, 48),
- S(23, 48), S(23, 48), S(20, 48), S(13, 43) };
-
- // Isolated pawn penalty by opposed flag and file
- const Score Isolated[2][FILE_NB] = {
- { S(37, 45), S(54, 52), S(60, 52), S(60, 52),
- S(60, 52), S(60, 52), S(54, 52), S(37, 45) },
- { S(25, 30), S(36, 35), S(40, 35), S(40, 35),
- S(40, 35), S(40, 35), S(36, 35), S(25, 30) } };
-
- // Backward pawn penalty by opposed flag and file
- const Score Backward[2][FILE_NB] = {
- { S(30, 42), S(43, 46), S(49, 46), S(49, 46),
- S(49, 46), S(49, 46), S(43, 46), S(30, 42) },
- { S(20, 28), S(29, 31), S(33, 31), S(33, 31),
- S(33, 31), S(33, 31), S(29, 31), S(20, 28) } };
-
- // Connected pawn bonus by opposed, phalanx flags and rank
- Score Connected[2][2][RANK_NB];
-
- // Levers bonus by rank
- const Score Lever[RANK_NB] = {
- S( 0, 0), S( 0, 0), S(0, 0), S(0, 0),
- S(20,20), S(40,40), S(0, 0), S(0, 0) };
-
- // Unsupported pawn penalty
- const Score UnsupportedPawnPenalty = S(20, 10);
-
- // Weakness of our pawn shelter in front of the king by [distance from edge][rank]
- const Value ShelterWeakness[][RANK_NB] = {
- { V(101), V(10), V(24), V(68), V(90), V( 95), V(102) },
- { V(105), V( 1), V(30), V(76), V(95), V(100), V(105) },
- { V( 99), V( 0), V(32), V(72), V(92), V(101), V(100) },
- { V( 94), V( 1), V(31), V(68), V(89), V( 98), V(106) } };
-
- // Danger of enemy pawns moving toward our king by [type][distance from edge][rank]
- const Value StormDanger[][4][RANK_NB] = {
- { { V( 0), V( 61), V( 128), V(47), V(27) },
- { V( 0), V( 66), V( 131), V(49), V(27) },
- { V( 0), V( 62), V( 126), V(52), V(23) },
- { V( 0), V( 63), V( 128), V(52), V(26) } },
- { { V(25), V( 33), V( 95), V(39), V(21) },
- { V(24), V( 33), V( 97), V(42), V(22) },
- { V(24), V( 33), V( 93), V(35), V(23) },
- { V(26), V( 27), V( 96), V(37), V(22) } },
- { { V( 0), V( 0), V( 80), V(14), V( 8) },
- { V( 0), V( 0), V( 163), V(28), V(12) },
- { V( 0), V( 0), V( 163), V(25), V(15) },
- { V( 0), V( 0), V( 161), V(24), V(14) } },
- { { V( 0), V(-300), V(-300), V(54), V(23) },
- { V( 0), V( 67), V( 128), V(46), V(24) },
- { V( 0), V( 64), V( 130), V(50), V(29) },
- { V( 0), V( 63), V( 127), V(51), V(24) } } };
-
- // Max bonus for king safety. Corresponds to start position with all the pawns
- // in front of the king and no enemy pawn on the horizon.
- const Value MaxSafetyBonus = V(261);
+ // Pawn penalties
+ constexpr Score Backward = S( 9, 24);
+ constexpr Score BlockedStorm = S(82, 82);
+ constexpr Score Doubled = S(11, 56);
+ constexpr Score Isolated = S( 5, 15);
+ constexpr Score WeakLever = S( 0, 56);
+ constexpr Score WeakUnopposed = S(13, 27);
+
+ // Connected pawn bonus
+ constexpr int Connected[RANK_NB] = { 0, 7, 8, 12, 29, 48, 86 };
+
+ // Strength of pawn shelter for our king by [distance from edge][rank].
+ // RANK_1 = 0 is used for files where we have no pawn, or pawn is behind our king.
+ constexpr Value ShelterStrength[int(FILE_NB) / 2][RANK_NB] = {
+ { V( -6), V( 81), V( 93), V( 58), V( 39), V( 18), V( 25) },
+ { V(-43), V( 61), V( 35), V(-49), V(-29), V(-11), V( -63) },
+ { V(-10), V( 75), V( 23), V( -2), V( 32), V( 3), V( -45) },
+ { V(-39), V(-13), V(-29), V(-52), V(-48), V(-67), V(-166) }
+ };
+
+ // Danger of enemy pawns moving toward our king by [distance from edge][rank].
+ // RANK_1 = 0 is used for files where the enemy has no pawn, or their pawn
+ // is behind our king. Note that UnblockedStorm[0][1-2] accommodate opponent pawn
+ // on edge, likely blocked by our king.
+ constexpr Value UnblockedStorm[int(FILE_NB) / 2][RANK_NB] = {
+ { V( 85), V(-289), V(-166), V(97), V(50), V( 45), V( 50) },
+ { V( 46), V( -25), V( 122), V(45), V(37), V(-10), V( 20) },
+ { V( -6), V( 51), V( 168), V(34), V(-2), V(-22), V(-14) },
+ { V(-15), V( -11), V( 101), V( 4), V(11), V(-15), V(-29) }
+ };