Files
2024-07-19 13:30:31 +03:00

71 lines
2.0 KiB
Python

import init_utils
import common
# Initialize the environment and get the name
name = init_utils.initialize_environment(__file__)
args = init_utils.get_args()
# Set arguments from command line
max_acc_drop = args.max_acc_drop
device = args.device
from sklearn.model_selection import train_test_split
import torch.nn as nn
import torch.nn.functional as F
import tensorflow as tf
import numpy as np
# Load our Dataset
(X_train, y_train), (X_test, y_test) = tf.keras.datasets.mnist.load_data()
X_train, X_val, y_train, y_val = train_test_split(X_train, y_train, test_size = 0.15)
X_train = np.expand_dims(X_train, axis = 1)
X_test = np.expand_dims(X_test, axis = 1)
X_val = np.expand_dims(X_val, axis = 1)
BATCH_SIZE = 32
epochs = 1
lr = 0.0001
class LeNet5(nn.Module):
def __init__(self):
super(LeNet5, self).__init__()
self.conv1 = nn.Conv2d(in_channels = 1, out_channels = 6, kernel_size = 5, padding = 'same')
self.relu1 = nn.ReLU()
self.avg1 = nn.AvgPool2d(2,2)
self.conv2 = nn.Conv2d(in_channels = 6, out_channels = 16, kernel_size = 5)
self.relu2 = nn.ReLU()
self.avg2 = nn.AvgPool2d(2,2)
self.flatten = nn.Flatten()
self.linear1 = nn.Linear(400, 120)
self.relu3 = nn.ReLU()
self.linear2 = nn.Linear(120, 84)
self.relu4 = nn.ReLU()
self.linear3 = nn.Linear(84, 10)
def forward(self,X):
X = self.relu1(self.conv1(X))
X = self.avg1(X)
X = self.relu2(self.conv2(X))
X = self.avg2(X)
X = self.flatten(X)
X = self.relu3(self.linear1(X))
X = self.relu4(self.linear2(X))
X = self.linear3(X)
return F.log_softmax(X, dim = 1)
net = LeNet5()
common.create_ibex_qnn(net, name, device, X_train, y_train, X_test, y_test,
X_val = X_val, y_val = y_val, BATCH_SIZE = BATCH_SIZE,
epochs = epochs, lr = lr, max_acc_drop = max_acc_drop)