-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathhyper-tune.py
More file actions
63 lines (46 loc) · 2.04 KB
/
hyper-tune.py
File metadata and controls
63 lines (46 loc) · 2.04 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import sys
import matplotlib.pyplot as plt
from nn_from_scratch.dataset import Dataset
from nn_from_scratch.network import Network
from nn_from_scratch.ui.progress import show_progress
def main():
sys.stdout.write("Loading the training dataset. This may take a minute...")
sys.stdout.flush()
dataset = Dataset(split="train")
X, Y = dataset.get_features_and_labels()
sys.stdout.write("\r")
iterations = 2500
learning_rates = [0.5, 0.25, 0.1, 0.05]
total_iterations = iterations * len(learning_rates)
completed_iterations = 0
show_progress(0, 100, f"{completed_iterations} completed iterations from a total of {total_iterations}")
accuracies_report = {}
for learning_rate in learning_rates:
accuracies_report[learning_rate] = {"iterations": [], "accuracies": []}
nn = Network()
for iteration, accuracy in nn.train(X, Y, iterations=iterations, learning_rate=learning_rate):
if (iteration - 1) % 50 == 0 or iteration == iterations:
accuracies_report[learning_rate]["iterations"].append(iteration)
accuracies_report[learning_rate]["accuracies"].append(accuracy)
completed_iterations += 1
show_progress(
100 * completed_iterations / total_iterations,
100,
f"{completed_iterations} completed iterations from a total of {total_iterations}",
)
plot(accuracies_report)
def plot(accuracies_report: dict):
plt.figure(figsize=(10, 6))
for learning_rate in sorted(accuracies_report.keys()):
accuracies = accuracies_report[learning_rate]["accuracies"]
iterations = accuracies_report[learning_rate]["iterations"]
plt.plot(iterations, accuracies, marker="o", label=f"Learning rate = {learning_rate}", linewidth=2, markersize=4)
plt.xlabel("Iteration")
plt.ylabel("Accuracy")
plt.title("Accuracy and Learning Rate")
plt.legend()
plt.grid(True, alpha=0.3)
plt.tight_layout()
plt.show()
if __name__ == "__main__":
main()