From 5c8c2771c1216d01887e4af347c3d488dcb43a53 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaquier=20Aur=C3=A9lien=20Tristan?= Date: Wed, 13 Sep 2023 13:22:59 +0200 Subject: [PATCH 1/2] use generations instead of evaluations in optimisation plot Change-Id: I6b9d73aade75da155ceb4f1437423431847c6d8a --- bluepyemodel/emodel_pipeline/plotting.py | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/bluepyemodel/emodel_pipeline/plotting.py b/bluepyemodel/emodel_pipeline/plotting.py index e7ca955e..9243119a 100644 --- a/bluepyemodel/emodel_pipeline/plotting.py +++ b/bluepyemodel/emodel_pipeline/plotting.py @@ -154,7 +154,7 @@ def optimisation( make_dir(figures_dir) run, _ = read_checkpoint(checkpoint_path) - nevals = numpy.cumsum(run["logbook"].select("nevals")) + ngen = numpy.cumsum(run["logbook"].select("gen")) is_finished_msg = "" if "CMA" in optimiser: is_finished_msg = f"is finished: {not run['CMA_es'].active}" @@ -163,7 +163,6 @@ def optimisation( ( f"min score = {min(run['logbook'].select('min')):.3f}", f"# of generations = {run['generation']}", - f"# of evaluations = {nevals[-1]}", f"evolution algorithm: {optimiser}", is_finished_msg, ) @@ -174,12 +173,12 @@ def optimisation( title = get_title(emodel, iteration, seed) axs[0, 0].set_title(title) - axs[0, 0].plot(nevals, run["logbook"].select("min"), label="Minimum", ls="--", c="gray") + axs[0, 0].plot(ngen, run["logbook"].select("min"), label="Minimum", c="red") - axs[0, 0].plot(nevals, run["logbook"].select("avg"), label="Average", c="gray") + axs[0, 0].plot(ngen, run["logbook"].select("avg"), label="Average", c="black") axs[0, 0].set_yscale("log") - axs[0, 0].set_xlabel("Number of evaluations") + axs[0, 0].set_xlabel("Number of generations") axs[0, 0].set_ylabel("Fitness") axs[0, 0].legend(title=legend_text, loc="upper right", frameon=False) From a94f97627e42261324e4a4f317afea6726700cd5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jaquier=20Aur=C3=A9lien=20Tristan?= Date: Wed, 13 Sep 2023 14:19:32 +0200 Subject: [PATCH 2/2] small fix when getting number of generations in plotting Change-Id: Ibe021a991b20978a215f38f057103c077831a571 --- bluepyemodel/emodel_pipeline/plotting.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bluepyemodel/emodel_pipeline/plotting.py b/bluepyemodel/emodel_pipeline/plotting.py index 9243119a..60cfcf99 100644 --- a/bluepyemodel/emodel_pipeline/plotting.py +++ b/bluepyemodel/emodel_pipeline/plotting.py @@ -154,7 +154,7 @@ def optimisation( make_dir(figures_dir) run, _ = read_checkpoint(checkpoint_path) - ngen = numpy.cumsum(run["logbook"].select("gen")) + ngen = run["logbook"].select("gen") is_finished_msg = "" if "CMA" in optimiser: is_finished_msg = f"is finished: {not run['CMA_es'].active}"