import tensorflow as tf
from tensorflow.keras import layers, models
from tensorflow.keras.preprocessing.image import ImageDataGenerator
# Load CIFAR-10 dataset
(X_train, y_train), (X_test, y_test) = tf.keras.datasets.cifar10.load_data()
# Normalize pixel values
X_train, X_test = X_train / 255.0, X_test / 255.0
# Data augmentation
datagen = ImageDataGenerator(
rotation_range=15,
width_shift_range=0.1,
height_shift_range=0.1,
horizontal_flip=True
)
datagen.fit(X_train)
# Build a simple CNN model with dropout
model = models.Sequential([
layers.Conv2D(32, (3, 3), activation='relu', input_shape=(32, 32, 3)),
layers.MaxPooling2D((2, 2)),
layers.Dropout(0.25),
layers.Conv2D(64, (3, 3), activation='relu'),
layers.MaxPooling2D((2, 2)),
layers.Dropout(0.25),
layers.Flatten(),
layers.Dense(64, activation='relu'),
layers.Dropout(0.5),
layers.Dense(10, activation='softmax')
])
model.compile(optimizer='adam',
loss='sparse_categorical_crossentropy',
metrics=['accuracy'])
# Train the model with data augmentation
history = model.fit(datagen.flow(X_train, y_train, batch_size=64),
epochs=30,
validation_data=(X_test, y_test),
verbose=2)
# Evaluate final model
final_train_loss, final_train_acc = model.evaluate(X_train, y_train, verbose=0)
final_val_loss, final_val_acc = model.evaluate(X_test, y_test, verbose=0)
print(f'Training accuracy: {final_train_acc*100:.2f}%')
print(f'Validation accuracy: {final_val_acc*100:.2f}%')