cifar10图像分类--卷积神经网络

链接:https://pan.baidu.com/s/1Nxty7ntGSUUA18oa_-ORSQ
提取码:in9m
cifar10数据集百度云链接

从本地加载图片

import os
import numpy as np
import pickle as p

def load_CIFAR_batch(filename):
    with open(filename,'rb')as f:
        data_dict = p.load(f,encoding='bytes')
        images = data_dict[b'data']
        labels =data_dict[b'labels']
        
        images = images.reshape(10000,3,32,32)
        images = images.transpose(0,2,3,1)
        labels = np.array(labels)
        return images,labels

def load_CIFAR_data(data_dir):
    images_train=[]
    labels_train=[]
    for i in range(5):
        f = os.path.join(data_dir,'data_batch_%d'%(i+1))
        print('loading',f)
        images_batch,label_batch = load_CIFAR_batch(f)
        
        images_train.append(images_batch)
        labels_train.append(label_batch)
        
        Xtrain = np.concatenate(images_train)
        Ytrain = np.concatenate(labels_train)
        del images_batch,label_batch
    Xtest,Ytest = load_CIFAR_batch(os.path.join(data_dir,'test_batch'))
    print('finished loadding CIFAR-10 data')
    return Xtrain,Ytrain,Xtest,Ytest
data_dir = 'D:\cat_dog\cifar-10-python\cifar-10-batches-py'
train_images, train_labels
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
卷积神经网络(Convolutional Neural Network,CNN)是一种在图像识别、自然语言处理等领域广泛应用的深度学习模型。在cifar-10图像分类任务中,我们可以使用CNN来实现高效准确的图像分类。 首先,我们需要准备cifar-10数据集。该数据集包含了10个类别的60000张32x32像素的彩色图像,其中50000张用于训练,10000张用于测试。我们可以使用Python的Keras库来加载数据集。 然后,我们可以定义一个CNN模型来对图像进行分类。该模型通常由多个卷积层和池化层组成。卷积层用于提取图像的特征,池化层用于减小特征图的大小。在最后一层之后,我们可以添加一个全连接层和一个softmax层来输出每个类别的概率分布。 下面是一个简单的CNN模型实现: ```python from keras.models import Sequential from keras.layers import Conv2D, MaxPooling2D, Flatten, Dense model = Sequential() # 第一层卷积层 model.add(Conv2D(32, (3, 3), activation='relu', input_shape=(32, 32, 3))) # 第一层池化层 model.add(MaxPooling2D(pool_size=(2, 2))) # 第二层卷积层 model.add(Conv2D(64, (3, 3), activation='relu')) # 第二层池化层 model.add(MaxPooling2D(pool_size=(2, 2))) # 第三层卷积层 model.add(Conv2D(64, (3, 3), activation='relu')) # 全连接层 model.add(Flatten()) model.add(Dense(64, activation='relu')) model.add(Dense(10, activation='softmax')) ``` 接下来,我们可以编译模型并训练数据集: ```python model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy']) model.fit(x_train, y_train, epochs=10, batch_size=64, validation_data=(x_test, y_test)) ``` 在训练完成后,我们可以使用测试集对模型进行评估: ```python loss, accuracy = model.evaluate(x_test, y_test) print('Test loss:', loss) print('Test accuracy:', accuracy) ``` 通过调整CNN的架构和超参数,我们可以进一步提高模型的准确率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值