-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfizzbuzz.py
113 lines (87 loc) · 2.9 KB
/
fizzbuzz.py
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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
"""
FizzBuzz is the following problem:
For each of the numbers 1 to 100:
* if the number is divisible by 3, print "fizz"
* if the number is divisible by 5, print "buzz"
* if the number is divisible by 15, print "fizzbuzz"
* otherwise, just print the number
"""
import json
from typing import List
import jax.numpy as np
import wandb
from tqdm.autonotebook import tqdm
from lorax.metrics import accuracy
from lorax.train import Experiment, wandb_log, wandb_notes
def fizz_buzz_encode(x: int) -> List[int]:
if x % 15 == 0:
return [0, 0, 0, 1]
elif x % 5 == 0:
return [0, 0, 1, 0]
elif x % 3 == 0:
return [0, 1, 0, 0]
else:
return [1, 0, 0, 0]
def binary_encode(x: int) -> List[int]:
"""
10 digit binary encoding of x
"""
return [x >> i & 1 for i in range(10)]
train_X = np.array([binary_encode(x) for x in range(101, 1024)])
train_Y = np.array([fizz_buzz_encode(x) for x in range(101, 1024)])
test_X = np.array([binary_encode(x) for x in range(1, 101)])
test_y = np.array([fizz_buzz_encode(x) for x in range(1, 101)])
config = {
"experiment_name": "fizzbuzz",
"random_seed": 42,
"loss": "cross_entropy",
"regularization": None,
"optimizer": "adam",
"model_config": {
"kind": "MLP",
"input_dim": 10,
"output_dim": 4,
"hidden_sizes": [50],
"activation": "tanh",
"dropout_keep": None,
},
"learing_rate": 0.001,
"batch_size": 32,
"global_step": 5000,
"log_every": 100,
}
wandb.init(project="colin_net_fizzbuzz", config=config, save_code=True)
config = wandb.config
experiment = Experiment.from_flattened(config)
print(json.dumps(experiment.dict(), indent=4))
update_generator = experiment.train(
train_X=train_X,
train_Y=train_Y,
test_X=test_X,
test_Y=test_y,
iterator_type="batch_iterator",
)
bar = tqdm(total=experiment.global_step)
for update_state in update_generator:
if update_state.step == 1:
markdown = f"{update_state.model.json()}"
wandb_notes(markdown)
if update_state.step % experiment.log_every == 0:
model = update_state.model.to_eval()
predicted = model.predict_proba(train_X)
acc_metric = float(accuracy(train_Y, predicted)) * 100
wandb_log({"train_accuracy": acc_metric}, step=update_state.step)
bar.set_description(f"acc:{acc_metric:.1f}%, loss:{update_state.loss:.5f}")
model = model.to_train()
bar.update()
final_model = update_state.model
# Display Predictions
final_model = final_model.to_eval()
probabilties = final_model.predict_proba(test_X)
for x, (gold, prob) in enumerate(zip(test_y, probabilties)):
actual_idx = np.argmax(gold)
predicted_idx = np.argmax(prob)
labels = [str(x), "fizz", "buzz", "fizzbuzz"]
print(x, labels[predicted_idx], labels[actual_idx])
accuracy_score = float(accuracy(test_y, probabilties))
print("Accuracy: ", accuracy_score)