forked from iree-org/iree-turbine
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmlp_eager_simple.py
98 lines (79 loc) · 2.61 KB
/
mlp_eager_simple.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
# Copyright 2023 Nod Labs, Inc
#
# Licensed under the Apache License v2.0 with LLVM Exceptions.
# See https://llvm.org/LICENSE.txt for license information.
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
import logging
import unittest
import torch
from torch import nn
from torch.utils.data import DataLoader
import torchvision.transforms as transforms
import torchvision.datasets as datasets
torch._dynamo.config.dynamic_shapes = (
False # TODO: https://github.com/nod-ai/SHARK-ModelDev/issues/93
)
class MNISTDataLoader:
def __init__(self, batch_size, shuffle=True):
self.batch_size = batch_size
self.shuffle = shuffle
transform = transforms.Compose(
[transforms.ToTensor(), transforms.Normalize((0.5,), (0.5,))]
)
self.mnist_trainset = datasets.MNIST(
root="../data", train=True, download=True, transform=transform
)
self.mnist_testset = datasets.MNIST(
root="../data", train=False, download=True, transform=transform
)
def get_train_loader(self):
return DataLoader(
dataset=self.mnist_trainset,
batch_size=self.batch_size,
shuffle=self.shuffle,
)
def get_test_loader(self):
return DataLoader(
dataset=self.mnist_testset,
batch_size=self.batch_size,
shuffle=False,
drop_last=True,
)
class MLP(nn.Module):
def __init__(self):
super().__init__()
self.layer0 = nn.Linear(28, 28, bias=True)
self.layer1 = nn.Linear(28, 14, bias=True)
self.layer2 = nn.Linear(14, 7, bias=True)
self.layer3 = nn.Linear(7, 7, bias=True)
def forward(self, x: torch.Tensor):
x = self.layer0(x)
x = torch.sigmoid(x)
x = self.layer1(x)
x = torch.sigmoid(x)
x = self.layer2(x)
x = torch.sigmoid(x)
x = self.layer3(x)
return x
def infer_iteration(model, images):
outputs = model(images)
return outputs
def infer():
# Example Parameters
config = {
"batch_size": 64,
"learning_rate": 0.001,
"num_epochs": 10,
}
custom_data_loader = MNISTDataLoader(config["batch_size"])
test_loader = custom_data_loader.get_test_loader()
model = MLP()
test_opt = torch.compile(infer_iteration, backend="turbine_cpu")
for i, (images, labels) in enumerate(test_loader):
test_opt(model, images)
class ModelTests(unittest.TestCase):
def testMNISTEagerSimple(self):
infer()
if __name__ == "__main__":
logging.basicConfig(level=logging.DEBUG)
unittest.main()