Python Conv2D VALUERROR:登录项和标签必须具有相同的形状((无,2)与(无,1))

Python Conv2D VALUERROR:登录项和标签必须具有相同的形状((无,2)与(无,1)),python,machine-learning,deep-learning,conv-neural-network,Python,Machine Learning,Deep Learning,Conv Neural Network,所以我尝试用CNN类型的Tensorflow制作一个faceID,我只给我的数据提供了15张我的脸的图像(这是一个简单的项目),我想让它预测是我的脸还是不是我的脸,比如真是假,问题是我不明白我的代码中的错误是什么。这是 ValueError: logits and labels must have the same shape ((None, 2) vs (None, 1)) 这是我的密码 # Face ID project, using CNN tensorflow from tensorf

所以我尝试用CNN类型的Tensorflow制作一个faceID,我只给我的数据提供了15张我的脸的图像(这是一个简单的项目),我想让它预测是我的脸还是不是我的脸,比如真是假,问题是我不明白我的代码中的错误是什么。这是

ValueError: logits and labels must have the same shape ((None, 2) vs (None, 1))
这是我的密码

# Face ID project, using CNN tensorflow
from tensorflow.keras.preprocessing.image import img_to_array
from tensorflow.keras.optimizers import Adam 
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Dense, Dropout, Flatten, Conv2D, MaxPooling2D, BatchNormalization, Activation
from tensorflow.keras import backend as K
import numpy as np
import cv2  
import glob

# Preparing the data and parameters
epochs = 10
lr = 1e-3
batch_size = 64 
img_dims = (96,96,3)

data = []
labels = []

image_files = glob.glob("C:/Users/berna/Desktop/Programming/AI_ML_DL/Projects/FaceID/Data/*")

for img in image_files:
    image = cv2.imread(img)

    image = cv2.resize(image, (img_dims[0], img_dims[1]))
    image = img_to_array(image)

    data.append(image)

    if img == img:
        label = 1
    else:
        label = 0
    
    labels.append([label])
    

# Preproccesing the data (convert arrays)
data = np.array(data, dtype="float32") / 255.0
labels = np.array(labels)

X = data 
y = labels

def build(width, height, depth, classes):
    model = Sequential()
    inputShape = height, width, depth 
    chanDim = -1

    if K.image_data_format() == "channels_first":
        inputShape = depth, height, width 
        chanDim = 1

    
    # Creating the model
    model.add(Conv2D(32, (3,3), padding="same", input_shape=inputShape))
    model.add(Activation("relu"))
    model.add(BatchNormalization(axis=chanDim))
    model.add(MaxPooling2D(pool_size=(3,3)))
    model.add(Dropout(0.25))

    model.add(Conv2D(64, (3,3), padding="same"))
    model.add(Activation("relu"))
    model.add(BatchNormalization(axis=chanDim))

    model.add(Conv2D(64, (3,3), padding="same"))
    model.add(Activation("relu"))
    model.add(BatchNormalization(axis=chanDim))
    model.add(MaxPooling2D(pool_size=(2,2)))
    model.add(Dropout(0.25))

    model.add(Conv2D(128, (3,3), padding="same"))
    model.add(Activation("relu"))
    model.add(BatchNormalization(axis=chanDim))

    model.add(Conv2D(128, (3,3), padding="same"))
    model.add(Activation("relu"))
    model.add(BatchNormalization(axis=chanDim))
    model.add(MaxPooling2D(pool_size=(2,2)))
    model.add(Dropout(0.25))

    model.add(Flatten())
    model.add(Dense(1024))
    model.add(Activation("relu"))
    model.add(BatchNormalization())
    model.add(Dropout(0.5))

    model.add(Dense(classes))
    model.add(Activation("sigmoid"))

    return model

# Build the model call 
model = build(width=img_dims[0], height=img_dims[1], depth=img_dims[2], classes=2)

# compile the model
opt = Adam(lr=lr, decay=lr/epochs)
model.compile(loss="binary_crossentropy",
            optimizer=opt,
            metrics=['accuracy'])

# fitting the model
H = model.fit(X, y, batch_size=batch_size,
                    epochs=epochs, verbose=1)

model.save('faceid.model')

如@Frightera所述,替换:

model.add(密集(类))
by
model.add(密集(1))
应该可以工作


您的标签是一个整数,但最后一层输出一个2d数组。

它应该是
model。为最后一个密集层添加(密集(1))
。是的!它很管用,谢谢!