X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fevaluate.cpp;h=c396e0f757569bbf1674c3fb44bd2b303b1c40d0;hb=58054fd0fa6294510fc8cf76b0ba9673d5094c10;hp=0fb9abdf2404ff3a6edc775238c885e1b129f604;hpb=6ad4f485d37556f5e09baae5a939f44ac5b51c84;p=stockfish diff --git a/src/evaluate.cpp b/src/evaluate.cpp index 0fb9abdf..c396e0f7 100644 --- a/src/evaluate.cpp +++ b/src/evaluate.cpp @@ -114,6 +114,26 @@ namespace Eval { } } + void NNUE::export_net(const std::optional& filename) { + std::string actualFilename; + if (filename.has_value()) { + actualFilename = filename.value(); + } else { + if (eval_file_loaded != EvalFileDefaultName) { + sync_cout << "Failed to export a net. A non-embedded net can only be saved if the filename is specified." << sync_endl; + return; + } + actualFilename = EvalFileDefaultName; + } + + ofstream stream(actualFilename, std::ios_base::binary); + if (save_eval(stream)) { + sync_cout << "Network saved successfully to " << actualFilename << "." << sync_endl; + } else { + sync_cout << "Failed to export a net." << sync_endl; + } + } + /// NNUE::verify() verifies that the last net used was loaded successfully void NNUE::verify() { @@ -1117,7 +1137,7 @@ Value Eval::evaluate(const Position& pos) { bool lowPieceEndgame = pos.non_pawn_material() == BishopValueMg || (pos.non_pawn_material() < 2 * RookValueMg && pos.count() < 2); - v = classical || lowPieceEndgame ? Evaluation(pos).value() + v = classical || lowPieceEndgame ? Evaluation(pos).value() : adjusted_NNUE(); // If the classical eval is small and imbalance large, use NNUE nevertheless.