【问题标题】:Tensorflow, Keras: In a multi-class classification, accuracy is high, but precision, recall, and f1-score is zero for most classesTensorflow,Keras:在多类分类中,准确率很高,但大多数类的准确率、召回率和 f1-score 为零
【发布时间】:2020-06-29 11:39:33
【问题描述】:

一般说明: 我的代码工作正常,但结果是有线的。我不知道问题出在哪里

  • 网络结构,
  • 或者我将数据提供给网络的方式,
  • 或其他任何东西。

我已经为这个错误苦苦挣扎了好几个星期,到目前为止我已经更改了损失函数、优化器、数据生成器等,但我无法解决它。我很感激任何帮助。 如果以下信息还不够,请告诉我。

研究领域: 我正在使用 tensorflow、keras 进行多类分类。该数据集具有 36 个二进制人类属性。我用的是resnet50,然后对于身体的每个部分(头、上身、下身、鞋子、配饰),我都在网络中添加了一个单独的分支。该网络有 1 个带有 36 个标签的输入图像和 36 个输出节点(36 个具有 sigmoid 激活的 denes 层)。

问题: 问题是 keras 报告的准确度很高,但大多数输出​​的 f1-score 非常低或为零(即使我在编译网络时使用 f1-score 作为指标,用于验证的 f1-socre 也是非常糟糕)。

a训练后,当我在预测模式下使用网络时,对于某些类,它总是返回 1/0。这意味着网络无法学习(即使我使用了加权损失函数或焦点损失函数。)

为什么很奇怪?因为,即使在第一个 epoch 之后,最先进的方法也会报告高 f1 分数(例如 https://github.com/chufengt/iccv19_attribute,我已经在我的 PC 上运行它并在一个 epoch 后得到了很好的结果)。

部分代码:

        print("setup model ...")
        input_image = KL.Input(args.img_input_shape, name= "input_1")
        C1, C2, C3, C4, C5 = resnet_graph(input_image, architecture="resnet50", stage5=False, train_bn=True)
        output_layers = merged_model (input_features=C4)
        model = Model(inputs=input_image, outputs=output_layers, name='SoftBiometrics_Model')

...

        print("model compiling ...")
        OPTIM = optimizers.Adadelta(lr=args.learning_rate, rho=0.95)
        model.compile(optimizer=OPTIM, loss=binary_focal_loss(alpha=.25, gamma=2), metrics=['acc',get_f1])
        plot_model(model, to_file='model.png')

...

        img_datagen = ImageDataGenerator(rotation_range=6, width_shift_range=0.03, height_shift_range=0.03, brightness_range=[0.85,1.15], shear_range=0.06, zoom_range=0.09, horizontal_flip=True, preprocessing_function=preprocess_input_resnet, rescale=1/255.)
        img_datagen_test = ImageDataGenerator(preprocessing_function=preprocess_input_resnet, rescale=1/255.)

        def multiple_outputs(generator, dataframe, batch_size, x_col):
          Gen = generator.flow_from_dataframe(dataframe=dataframe,
                                               directory=None,
                                               x_col = x_col,
                                               y_col = args.Categories,
                                               target_size = (args.img_input_shape[0],args.img_input_shape[1]),
                                               class_mode = "multi_output",
                                               classes=None,
                                               batch_size = batch_size,
                                               shuffle = True)
          while True:
            gnext = Gen.next()
            # return image batch and 36 sets of lables
            labels = gnext[1]
            output_dict = {"{}_output".format(Category): np.array(labels[index]) for index, Category in enumerate(args.Categories)}
            yield {'input_1':gnext[0]}, output_dict

    trainGen = multiple_outputs (generator = img_datagen, dataframe=Train_df_img, batch_size=args.BATCH_SIZE, x_col="Train_Filenames")
    testGen = multiple_outputs (generator = img_datagen_test, dataframe=Test_df_img, batch_size=args.BATCH_SIZE, x_col="Test_Filenames")

    STEP_SIZE_TRAIN = len(Train_df_img["Train_Filenames"]) // args.BATCH_SIZE
    STEP_SIZE_VALID = len(Test_df_img["Test_Filenames"]) // args.BATCH_SIZE

    ...

    print("Fitting the model to the data ...")
            history = model.fit_generator(generator=trainGen,
                                         epochs=args.Number_of_epochs,
                                         steps_per_epoch=STEP_SIZE_TRAIN,
                                         validation_data=testGen,
                                         validation_steps=STEP_SIZE_VALID,
                                         callbacks= [chekpont],
                                         verbose=1)

【问题讨论】:

  • 您的数据集是否不平衡?

标签: tensorflow keras multiclass-classification


【解决方案1】:

您有可能将二进制 f1-score 传递给 compile 函数。这应该可以解决问题 -

pip install tensorflow-addons

...

import tensorflow_addons as tfa 

f1 = tfa.metrics.F1Score(36,'micro' or 'macro')

model.compile(...,metrics=[f1])

您可以阅读更多关于如何计算 f1-micro 和 f1-macro 以及哪些有用的信息here

【讨论】:

    猜你喜欢
    • 2016-04-14
    • 2017-06-21
    • 2016-01-09
    • 2020-04-23
    • 2019-07-28
    • 2016-06-19
    • 2019-02-14
    • 2018-06-02
    • 2018-10-08
    相关资源
    最近更新 更多