diff --git a/trainer/src/MacaonTrain.cpp b/trainer/src/MacaonTrain.cpp
index efcab7922027de296531455e131686414582bd0a..20d03eb104f26b0cf8245c931b0e8b1c08ec346b 100644
--- a/trainer/src/MacaonTrain.cpp
+++ b/trainer/src/MacaonTrain.cpp
@@ -82,7 +82,6 @@ int MacaonTrain::main()
   auto nbEpoch = variables["nbEpochs"].as<int>();
   auto batchSize = variables["batchSize"].as<int>();
   auto dynamicOracleInterval = variables["dynamicOracleInterval"].as<int>();
-  bool saveEverything = dynamicOracleInterval > 0;
   auto rarityThreshold = variables["rarityThreshold"].as<float>();
   bool debug = variables.count("debug") == 0 ? false : true;
   bool printAdvancement = !debug && variables.count("silent") == 0 ? true : false;
@@ -145,9 +144,9 @@ int MacaonTrain::main()
       if (buffer != std::fgets(buffer, 1024, f))
         break;
       float devScoreMean = std::stof(util::split(buffer, '\t').back());
-      if (computeDevScore and devScoreMean > bestDevScore)
+      if (computeDevScore and (devScoreMean > bestDevScore or currentEpoch == dynamicOracleInterval))
         bestDevScore = devScoreMean;
-      if (!computeDevScore and devScoreMean < bestDevScore)
+      if (!computeDevScore and (devScoreMean < bestDevScore or currentEpoch == dynamicOracleInterval))
         bestDevScore = devScoreMean;
       currentEpoch++;
     }
@@ -204,7 +203,7 @@ int MacaonTrain::main()
     if (!computeDevScore)
       saved = devScoreMean <= bestDevScore;
 
-    if (saveEverything)
+    if (currentEpoch == dynamicOracleInterval)
       saved = true;
     if (saved)
     {