mirror of
https://github.com/aladdinpersson/Machine-Learning-Collection.git
synced 2026-02-22 03:37:57 +00:00
Initial commit
This commit is contained in:
82
ML/TensorFlow/Basics/tutorial15-customizing-modelfit.py
Normal file
82
ML/TensorFlow/Basics/tutorial15-customizing-modelfit.py
Normal file
@@ -0,0 +1,82 @@
|
||||
import os
|
||||
|
||||
os.environ["TF_CPP_MIN_LOG_LEVEL"] = "2"
|
||||
|
||||
import tensorflow as tf
|
||||
from tensorflow import keras
|
||||
from tensorflow.keras import layers
|
||||
from tensorflow.keras.datasets import mnist
|
||||
|
||||
(x_train, y_train), (x_test, y_test) = mnist.load_data()
|
||||
x_train = x_train.reshape(-1, 28, 28, 1).astype("float32") / 255.0
|
||||
x_test = x_test.reshape(-1, 28, 28, 1).astype("float32") / 255.0
|
||||
|
||||
model = keras.Sequential(
|
||||
[
|
||||
layers.Input(shape=(28, 28, 1)),
|
||||
layers.Conv2D(64, (3, 3), padding="same"),
|
||||
layers.ReLU(),
|
||||
layers.Conv2D(128, (3, 3), padding="same"),
|
||||
layers.ReLU(),
|
||||
layers.Flatten(),
|
||||
layers.Dense(10),
|
||||
],
|
||||
name="model",
|
||||
)
|
||||
|
||||
|
||||
class CustomFit(keras.Model):
|
||||
def __init__(self, model):
|
||||
super(CustomFit, self).__init__()
|
||||
self.model = model
|
||||
|
||||
def compile(self, optimizer, loss):
|
||||
super(CustomFit, self).compile()
|
||||
self.optimizer = optimizer
|
||||
self.loss = loss
|
||||
|
||||
def train_step(self, data):
|
||||
x, y = data
|
||||
|
||||
with tf.GradientTape() as tape:
|
||||
# Caclulate predictions
|
||||
y_pred = self.model(x, training=True)
|
||||
|
||||
# Loss
|
||||
loss = self.loss(y, y_pred)
|
||||
|
||||
# Gradients
|
||||
training_vars = self.trainable_variables
|
||||
gradients = tape.gradient(loss, training_vars)
|
||||
|
||||
# Step with optimizer
|
||||
self.optimizer.apply_gradients(zip(gradients, training_vars))
|
||||
acc_metric.update_state(y, y_pred)
|
||||
|
||||
return {"loss": loss, "accuracy": acc_metric.result()}
|
||||
|
||||
def test_step(self, data):
|
||||
# Unpack the data
|
||||
x, y = data
|
||||
|
||||
# Compute predictions
|
||||
y_pred = self.model(x, training=False)
|
||||
|
||||
# Updates the metrics tracking the loss
|
||||
loss = self.loss(y, y_pred)
|
||||
|
||||
# Update the metrics.
|
||||
acc_metric.update_state(y, y_pred)
|
||||
return {"loss": loss, "accuracy": acc_metric.result()}
|
||||
|
||||
|
||||
acc_metric = keras.metrics.SparseCategoricalAccuracy(name="accuracy")
|
||||
|
||||
training = CustomFit(model)
|
||||
training.compile(
|
||||
optimizer=keras.optimizers.Adam(learning_rate=3e-4),
|
||||
loss=keras.losses.SparseCategoricalCrossentropy(from_logits=True),
|
||||
)
|
||||
|
||||
training.fit(x_train, y_train, batch_size=64, epochs=2)
|
||||
training.evaluate(x_test, y_test, batch_size=64)
|
||||
Reference in New Issue
Block a user