Eu sunt încercarea de a construi un CNN pentru a clasifica fructe. Am fost confruntă cu pierderi mari valori și încerc să-l reducă pe cât de mult pot, dar nu sunt sigur cum de a îmbunătăți modelul meu în continuare.
Aici este codul meu:
model96 = tf.keras.Sequential()
#Architecture
model96.add(tf.keras.layers.Conv2D(filters = 32,
kernel_size = (3, 3),
activation = "relu",
input_shape = (96, 96, 3)))
model96.add(tf.keras.layers.Conv2D(filters = 32,
kernel_size = (3, 3),
activation = "relu"))
model96.add(tf.keras.layers.MaxPooling2D(pool_size=(2, 2)))
model96.add(tf.keras.layers.Dropout(rate=0.25))
model96.add(tf.keras.layers.Flatten())
model96.add(tf.keras.layers.Dense(units=128, activation='relu'))
model96.add(tf.keras.layers.Dropout(rate=0.5))
#output layer
model96.add(tf.keras.layers.Dense(units=4, activation='softmax'))
#Loss function
model96.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy'])
#Train model
hist96 = model96.fit(x=x_train96_norm, y=y_train, epochs=100)
#Test and Evaluate
print("Performance with test data:")
loss96, accuracy96 = model96.evaluate(x=x_test96_norm, y=y_test)
print('loss =', loss96)
print('accuracy =', accuracy96)
În timpul antrenamentului, în final pierderea de valoare a fost 0.0153 și finale valoare de precizie a fost 0.9958, cu toate acestea, în timpul testului, modelul de marcat: loss = 1.0462701320648193
și accuracy = 0.8666666746139526