-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCifar_cnn_model.py
More file actions
56 lines (39 loc) · 1.68 KB
/
Cifar_cnn_model.py
File metadata and controls
56 lines (39 loc) · 1.68 KB
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
from tensorflow.keras import layers, models
from tensorflow.keras.datasets import cifar10
import numpy as np
(x_train, y_train), (x_test, y_test) = cifar10.load_data()
x_train, x_test = x_train / 255.0, x_test / 255.0
class_names = [
'airplane', 'automobile', 'bird', 'cat', 'deer',
'dog', 'frog', 'horse', 'ship', 'truck'
]
model = models.Sequential([
layers.Conv2D(32, (3, 3), activation='relu', strides=(1, 1), padding='same', input_shape=(32, 32, 3)),
layers.MaxPooling2D((2, 2)),
layers.Conv2D(64, (3, 3), activation='relu', strides=(1, 1), padding='same'),
layers.MaxPooling2D((2, 2)),
layers.Conv2D(128, (3, 3), activation='relu', strides=(1, 1), padding='valid'),
layers.MaxPooling2D((2, 2)),
layers.Conv2D(256, (2, 2), activation='relu', strides=(1, 1), padding='valid'),
layers.Flatten(),
layers.Dense(256, activation='relu'),
layers.Dropout(0.5),
layers.Dense(128, activation='relu'),
layers.Dense(10, activation='softmax')
])
model.compile(optimizer='adam',
loss='sparse_categorical_crossentropy',
metrics=['accuracy'])
model.fit(x_train, y_train, epochs=20, validation_data=(x_test, y_test))
test_loss, test_acc = model.evaluate(x_test, y_test, verbose=2)
print(f'\nTest accuracy: {test_acc:.4f}')
print(test_loss)
def predict_class(image):
image = np.expand_dims(image, axis=0) # Add batch dimension
predictions = model.predict(image)
predicted_class = np.argmax(predictions[0])
return class_names[predicted_class]
sample_image = x_test[6563]
predicted_label = predict_class(sample_image)
print(f'Predicted label: {predicted_label}')
model.save('cifar10_model.h5')