X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fmovepick.cpp;h=d4242a300de7620e5f58665cb20c7e5ff0aa102c;hp=dc295e17904b8a0af822b05c507f0eac6e747464;hb=db1b0bfa1d8391281e5e0b1f93564a1e52c41ed2;hpb=20d7197a9be9c03f153c7ceac73857da8416bba4 diff --git a/src/movepick.cpp b/src/movepick.cpp index dc295e17..d4242a30 100644 --- a/src/movepick.cpp +++ b/src/movepick.cpp @@ -66,23 +66,26 @@ namespace { /// move ordering is at the current node. MovePicker::MovePicker(const Position& p, bool pv, Move ttm, - Move mk, Move k1, Move k2, Depth d, EvalInfo* ei) : pos(p) { + const SearchStack& ss, Depth d, EvalInfo* ei) : pos(p) { pvNode = pv; ttMove = ttm; - mateKiller = (mk == ttm)? MOVE_NONE : mk; - killer1 = k1; - killer2 = k2; + mateKiller = (ss.mateKiller == ttm)? MOVE_NONE : ss.mateKiller; + killer1 = ss.killers[0]; + killer2 = ss.killers[1]; depth = d; movesPicked = 0; numOfMoves = 0; numOfBadCaptures = 0; // With EvalInfo we are able to know how many captures are possible before - // generating them. So avoid generating them in case we know are zero. + // generating them. So avoid generating in case we know are zero. Color us = pos.side_to_move(); Color them = opposite_color(us); - bool noAttacks = ei && (ei->attackedBy[us][0] & pos.pieces_of_color(them)) == 0; - bool noCaptures = noAttacks && (pos.ep_square() == SQ_NONE) && !pos.has_pawn_on_7th(us); + bool noCaptures = ei + && (ei->attackedBy[us][0] & pos.pieces_of_color(them)) == 0 + && !ei->mi->specialized_eval_exists() + && (pos.ep_square() == SQ_NONE) + && !pos.has_pawn_on_7th(us); if (p.is_check()) phaseIndex = EvasionsPhaseIndex; @@ -93,7 +96,6 @@ MovePicker::MovePicker(const Position& p, bool pv, Move ttm, else phaseIndex = (noCaptures ? NoMovesPhaseIndex : QsearchWithoutChecksPhaseIndex); - dc = p.discovered_check_candidates(us); pinned = p.pinned_pieces(p.side_to_move()); @@ -145,7 +147,6 @@ Move MovePicker::get_next_move() { case PH_GOOD_CAPTURES: numOfMoves = generate_captures(pos, moves); score_captures(); - capSquares = EmptyBoardBB; movesPicked = 0; break; @@ -269,10 +270,11 @@ void MovePicker::score_noncaptures() { else hs = H.move_ordering_score(pos.piece_on(move_from(m)), m); - // Ensure moves in history are always sorted as first + // Ensure history is always preferred to pst if (hs > 0) hs += 1000; + // pst based scoring moves[i].score = hs + pos.mg_pst_delta(m); } } @@ -291,7 +293,6 @@ void MovePicker::score_evasions() { } else moves[i].score = H.move_ordering_score(pos.piece_on(move_from(m)), m); } - // FIXME try psqt also here } void MovePicker::score_qcaptures() { @@ -383,7 +384,7 @@ Move MovePicker::pick_move_from_list() { while (movesPicked < numOfMoves) { - bestIndex = find_best_index(&capSquares, capSqValues); + bestIndex = find_best_index(); if (bestIndex != -1) // Found a good capture {