修改predict实现acc计算

该博客介绍了一个使用EfficientNet_B0模型进行图像分类的Python代码实现。它加载预训练权重,对指定目录下的图像进行预测,并计算No-Anomaly类别的准确率。代码包括数据预处理、模型创建、权重加载和预测过程。
import os
import json

import torch
from PIL import Image
from torchvision import transforms
import matplotlib.pyplot as plt

from model import efficientnet_b0 as create_model


def main():
    device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")

    img_size = {"B0": 224,
                "B1": 240,
                "B2": 260,
                "B3": 300,
                "B4": 380,
                "B5": 456,
                "B6": 528,
                "B7": 600}
    num_model = "B0"

    data_transform = transforms.Compose(
        [transforms.Resize(img_size[num_model]),
         transforms.CenterCrop(img_size[num_model]),
         transforms.ToTensor(),
         transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225])])
    # 建立循环,将目标目录下的图片路径取出
    # 需要改动的有两个部分,输入文件夹的路径、预测结果与文件夹对应结果的对比
    path = r'C:\Users\sun\Desktop\b_classification\classification-pytorch-main\color_datasets\train\No-Anomaly'
    # 获取该路径下所有图片
    filelist = os.listdir(path)
    a = 1
    for files in filelist:
    # load image
        img_path = os.path.join(path, files)
        assert os.path.exists(img_path), "file: '{}' dose not exist.".format(img_path)
        img = Image.open(img_path)
        plt.imshow(img)
        # [N, C, H, W]
        img = data_transform(img)
        # expand batch dimension
        img = torch.unsqueeze(img, dim=0)

        # read class_indict
        json_path = './class_indices.json'
        assert os.path.exists(json_path), "file: '{}' dose not exist.".format(json_path)

        json_file = open(json_path, "r")
        class_indict = json.load(json_file)

        # create model
        model = create_model(num_classes=5).to(device)
        # load model weights
        model_weight_path = "./weights/model-29.pth"
        model.load_state_dict(torch.load(model_weight_path, map_location=device))
        model.eval()
        with torch.no_grad():
            # predict class
            output = torch.squeeze(model(img.to(device))).cpu()
            predict = torch.softmax(output, dim=0)
            predict_cla = torch.argmax(predict).numpy()
            if predict_cla == "No-Anomaly":
                a = a + 1
            else:
                a = a
    # 这里的result就是该路径下的图片得到的准确率
    result = a / 2000
    print(result)

        # print_res = "class: {}   prob: {:.3}".format(class_indict[str(predict_cla)],
        #                                              predict[predict_cla].numpy())

        # 不需要展示运行结果所以该部分注释掉
        # plt.title(print_res)
        # for i in range(len(predict)):
        #     print("class: {:10}   prob: {:.3}".format(class_indict[str(i)],
        #                                               predict[i].numpy()))
        # plt.show()


if __name__ == '__main__':
    main()
参考提供的引用内容,虽未直接提及SSD模型训练输出准确率(acc)的具体内容,但可从类似训练后测试模型准确率的代码示例(引用[2])中获得一定思路。以下是一个可能的分析和示例。 在训练模型完成后,可以通过对测试集进行测试来输出准确率。引用[2]中给出了一个使用Keras框架测试模型准确率的示例代码,将其思路迁移到SSD模型上,可能的步骤如下: 首先,需要准备验证数据集,并对其进行预处理,例如对图像进行归一化处理。然后,使用模型对验证数据集进行预测,得到预测标签。最后,将预测标签与真实标签进行对比,计算准确率。 以下是一个类似的伪代码示例: ```python from tensorflow.keras.preprocessing.image import ImageDataGenerator from tensorflow.keras.models import load_model from sklearn.metrics import accuracy_score # 准备验证数据 def valid_data(valid_data_dir='./data/val'): valid_datagen = ImageDataGenerator(rescale=1. / 255) valid_generator = valid_datagen.flow_from_directory( valid_data_dir, target_size=(224, 224), batch_size=16, class_mode='categorical', ) return valid_generator # 获取验证数据生成器 valid_generator = valid_data() # 加载SSD模型(这里假设模型已经保存为ssd_model.h5) model = load_model('ssd_model.h5') # 进行预测 predictions = model.predict_generator(valid_generator, verbose=1) # 获取预测标签 predict_label = predictions.argmax(axis=-1) # 获取真实标签 true_label = valid_generator.classes # 计算准确率 acc = accuracy_score(true_label, predict_label) # 输出准确率 print(acc, end='\n\n') ``` 需要注意的是,以上代码是基于引用[2]的示例进行的修改,实际应用中可能需要根据SSD模型的具体情况进行调整,例如模型的输入尺寸、数据格式等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值