python卷积神经网络人脸识别_用keras小试CNN卷积神经网络应用于人脸识别

使用Python的Keras库构建一个简单的卷积神经网络(CNN),在Olivetti Faces数据集上进行人脸识别,训练25个周期后,检测准确率达到95%。文章介绍了数据预处理、网络模型构建、训练和评估过程。
摘要由CSDN通过智能技术生成

Keras是一个简约,高度模块化的神经网络库。采用Python / Theano开发。

使用Keras如果你需要一个深度学习库:

可以很容易和快速实现原型(通过总模块化,极简主义,和可扩展性)

同时支持卷积网络(vision)和复发性的网络(序列数据)。以及两者的组合。

无缝地运行在CPU和GPU上。

keras的资源库网址为https://github.com/fchollet/keras

本文使用keras尝试配置了一个CNN(仿造http://blog.csdn.net/u012162613/article/details/43277187,用的图片资源也是来自于此),程序更简洁,检测正确率可以达到95%。下面是测试的代码:

'''Train a simple convnet on the part olivetti faces dataset.

Run on GPU: THEANO_FLAGS=mode=FAST_RUN,device=gpu,floatX=float32 python mnist_cnn.py

Get to 95% test accuracy after 25 epochs (there is still a lot of margin for parameter tuning).

'''

from __future__ import print_function

import numpy

numpy.random.seed(1337) # for reproducibility

from PIL import Image

from keras.models import Sequential

from keras.layers.core import Dense, Dropout, Activation, Flatten

from keras.layers.convolutional import Convolution2D, MaxPooling2D

from keras.optimizers import SGD

from keras.utils import np_utils

# There are 40 different classes

nb_classes = 40

nb_epoch = 40

batch_size = 40

# input image dimensions

img_rows, img_cols = 57, 47

# number of convolutional filters to use

nb_filters1, nb_filters2 = 5, 10

# size of pooling area for max pooling

nb_pool = 2

# convolution kernel size

nb_conv = 3

def load_data(dataset_path):

img = Image.open(dataset_path)

img_ndarray = numpy.asarray(img, dtype='float64')/256

#400pictures,size:57*47=2679

faces=numpy.empty((400,2679))

for row in range(20):

for column in range(20):

faces[row*20+column]=numpy.ndarray.flatten(img_ndarray [row*57:(row+1)*57,column*47:(column+1)*47])

label=numpy.empty(400)

for i in range(40):

label[i*10:i*10+10]=i

label=label.astype(numpy.int)

#train:320,valid:40,test:40

train_data=numpy.empty((320,2679))

train_label=numpy.empty(320)

valid_data=numpy.empty((40,2679))

valid_label=numpy.empty(40)

test_data=numpy.empty((40,2679))

test_label=numpy.empty(40)

for i in range(40):

train_data[i*8:i*8+8]=faces[i*10:i*10+8]

train_label[i*8:i*8+8]=label[i*10:i*10+8]

valid_data[i]=faces[i*10+8]

valid_label[i]=label[i*10+8]

test_data[i]=faces[i*10+9]

test_label[i]=label[i*10+9]

rval = [(train_data, train_label), (valid_data, valid_label),

(test_data, test_label)]

return rval

def Net_model(lr=0.005,decay=1e-6,momentum=0.9):

model = Sequential()

model.add(Convolution2D(nb_filters1, nb_conv, nb_conv,

border_mode='valid',

input_shape=(1, img_rows, img_cols)))

model.add(Activation('tanh'))

model.add(MaxPooling2D(pool_size=(nb_pool, nb_pool)))

model.add(Convolution2D(nb_filters2, nb_conv, nb_conv))

model.add(Activation('tanh'))

model.add(MaxPooling2D(pool_size=(nb_pool, nb_pool)))

#model.add(Dropout(0.25))

model.add(Flatten())

model.add(Dense(1000)) #Full connection

model.add(Activation('tanh'))

#model.add(Dropout(0.5))

model.add(Dense(nb_classes))

model.add(Activation('softmax'))

sgd = SGD(lr=lr, decay=decay, momentum=momentum, nesterov=True)

model.compile(loss='categorical_crossentropy', optimizer=sgd)

return model

def train_model(model,X_train,Y_train,X_val,Y_val):

model.fit(X_train, Y_train, batch_size=batch_size, nb_epoch=nb_epoch,

show_accuracy=True, verbose=1, validation_data=(X_val, Y_val))

model.save_weights('model_weights.h5',overwrite=True)

return model

def test_model(model,X,Y):

model.load_weights('model_weights.h5')

score = model.evaluate(X, Y, show_accuracy=True, verbose=0)

print('Test score:', score[0])

print('Test accuracy:', score[1])

return score

if __name__ == '__main__':

# the data, shuffled and split between tran and test sets

(X_train, y_train), (X_val, y_val),(X_test, y_test) = load_data('olivettifaces.gif')

X_train = X_train.reshape(X_train.shape[0], 1, img_rows, img_cols)

X_val = X_val.reshape(X_val.shape[0], 1, img_rows, img_cols)

X_test = X_test.reshape(X_test.shape[0], 1, img_rows, img_cols)

print('X_train shape:', X_train.shape)

print(X_train.shape[0], 'train samples')

print(X_val.shape[0], 'validate samples')

print(X_test.shape[0], 'test samples')

# convert class vectors to binary class matrices

Y_train = np_utils.to_categorical(y_train, nb_classes)

Y_val = np_utils.to_categorical(y_val, nb_classes)

Y_test = np_utils.to_categorical(y_test, nb_classes)

model=Net_model()

#train_model(model,X_train,Y_train,X_val,Y_val)

#score=test_model(model,X_test,Y_test)

model.load_weights('model_weights.h5')

classes=model.predict_classes(X_test,verbose=0)

test_accuracy = numpy.mean(numpy.equal(y_test,classes))

print("accuarcy:",test_accuracy)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个基于PythonKeras框架实现的CNN卷积神经网络人脸识别代码示例: ```python # 导入必要的库 import numpy as np from keras.models import Sequential from keras.layers import Dense, Dropout, Flatten from keras.layers import Conv2D, MaxPooling2D from keras.utils import np_utils from keras.datasets import mnist from keras import backend as K from keras.preprocessing.image import ImageDataGenerator from keras.preprocessing import image # 定义数据集相关参数 batch_size = 128 num_classes = 2 epochs = 10 img_rows, img_cols = 28, 28 input_shape = (img_rows, img_cols, 3) # 加载数据集 train_datagen = ImageDataGenerator( rescale=1./255, shear_range=0.2, zoom_range=0.2, horizontal_flip=True) test_datagen = ImageDataGenerator(rescale=1./255) train_generator = train_datagen.flow_from_directory( 'train', target_size=(img_rows, img_cols), batch_size=batch_size, class_mode='categorical') validation_generator = test_datagen.flow_from_directory( 'test', target_size=(img_rows, img_cols), batch_size=batch_size, class_mode='categorical') # 构建CNN模型 model = Sequential() model.add(Conv2D(32, kernel_size=(3, 3), activation='relu', input_shape=input_shape)) model.add(Conv2D(64, (3, 3), activation='relu')) model.add(MaxPooling2D(pool_size=(2, 2))) model.add(Dropout(0.25)) model.add(Flatten()) model.add(Dense(128, activation='relu')) model.add(Dropout(0.5)) model.add(Dense(num_classes, activation='softmax')) # 编译模型 model.compile(loss='categorical_crossentropy', optimizer='adam', metrics=['accuracy']) # 训练模型 model.fit_generator( train_generator, steps_per_epoch=2000 // batch_size, epochs=epochs, validation_data=validation_generator, validation_steps=800 // batch_size) # 预测新图像 img_path = 'test/cat/cat.1.jpg' img = image.load_img(img_path, target_size=(img_rows, img_cols)) x = image.img_to_array(img) x = np.expand_dims(x, axis=0) preds = model.predict_classes(x) print('预测结果:', preds[0]) ``` 这是一个简单的人脸识别例子,其中使用了一个2层的CNN卷积神经网络模型,并且使用Keras提供的ImageDataGenerator来加载和处理数据集。你可以将此代码作为一个起点,并进行修改以满足你的具体需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值