added plots

This commit is contained in:
not why 2026-05-25 03:14:54 +03:00
parent 52cba853dd
commit 55ff0515e9

View File

@ -0,0 +1,63 @@
import csv
import statistics
import matplotlib.pyplot as plt
import numpy as np
rows = []
with open("results.csv", encoding="utf-8") as f:
for r in csv.DictReader(f):
rows.append(r)
MAZES = ["small_10x10", "medium_50x50", "large_100x100",
"empty_30x30", "no_exit_20x20", "weighted_40x40"]
STRATS = ["BFS", "DFS", "A*", "Dijkstra"]
MAZE_RU = {
"small_10x10": "10×10",
"medium_50x50": "50×50",
"large_100x100": "100×100",
"empty_30x30": "30×30 пустой",
"no_exit_20x20": "20×20 без выхода",
"weighted_40x40":"40×40 взвешенный",
}
def avg(maze, strat, metric):
vals = [float(r[metric]) for r in rows
if r["maze"] == maze and r["strategy"] == strat]
return statistics.mean(vals) if vals else 0.0
def std(maze, strat, metric):
vals = [float(r[metric]) for r in rows
if r["maze"] == maze and r["strategy"] == strat]
return statistics.stdev(vals) if len(vals) > 1 else 0.0
fig, axes = plt.subplots(1, 3, figsize=(16, 5))
fig.suptitle("Сравнение алгоритмов (среднее, 7 запусков)")
x = np.arange(len(MAZES))
W = 0.18
offsets = np.linspace(-(len(STRATS)-1)/2, (len(STRATS)-1)/2, len(STRATS)) * W
for ax, (metric, ylabel, title) in zip(axes, [
("time_ms", "Время (мс)", "Время выполнения"),
("visited_cells", "Посещено клеток", "Посещённые клетки"),
("path_length", "Длина пути", "Длина найденного пути"),
]):
for i, strat in enumerate(STRATS):
vals = [avg(m, strat, metric) for m in MAZES]
errs = [std(m, strat, metric) for m in MAZES]
ax.bar(x + offsets[i], vals, W * 0.95, label=strat, yerr=errs, capsize=3)
ax.set_title(title)
ax.set_xticks(x)
ax.set_xticklabels([MAZE_RU[m] for m in MAZES], fontsize=7, rotation=15)
ax.set_ylabel(ylabel)
ax.legend(fontsize=8)
ax.yaxis.grid(True, linestyle="--", alpha=0.5)
ax.set_axisbelow(True)
if metric == "time_ms":
ax.set_yscale("log")
plt.tight_layout()
plt.savefig("../../performance_plot.png", dpi=150)
plt.close()