tensorflow1.1/autoencoder人脸识别

环境:tensorflow1.1,python3,matplotlib2.02

#coding:utf-8
"""
python3
tensorflow 1.1
matplotlib 2.02
"""
import tensorflow as tf
import pickle
import numpy as np
import matplotlib.pyplot as plt

#读取数据集
with open('facedataset.pickle','rb') as f:
    (train_data,train_labels),(test_data,test_labels) = pickle.load(f)

learning_rate = 0.01
N_pictures = 3


train_data = train_data.astype(np.float32)
train_data = np.random.permutation(train_data)
test_data = test_data.astype(np.float32)
test_data = np.random.permutation(test_data)

xs = tf.placeholder(tf.float32,[None,57*47])

#构建autoencoder神经网络
encoder0 = tf.layers.dense(xs,512,tf.nn.tanh)
encoder1 = tf.layers.dense(encoder0,128,tf.nn.tanh)
encoder2 = tf.layers.dense(encoder1,64,tf.nn.tanh)
encoder3 = tf.layers.dense(encoder2,10)
decoder0 = tf.layers.dense(encoder3,64,tf.nn.tanh)
decoder1 = tf.layers.dense(decoder0,128,tf.nn.tanh)
decoder2 = tf.layers.dense(decoder1,512,tf.nn.tanh)
decoder3 = tf.layers.dense(decoder2,57*47,tf.nn.sigmoid)

#计算loss
loss = tf.losses.mean_squared_error(labels=xs,predictions=decoder3)
train = tf.train.AdamOptimizer(learning_rate).minimize(loss)

with tf.Session() as sess:
    init = tf.global_variables_initializer()
    sess.run(init)
    #画图plt.subplots
    fig,a = plt.subplots(2,N_pictures,figsize=(6,4))
    #开始交互模式
    plt.ion()
    view_figures = test_data[:N_pictures]
    for i in range(N_pictures):
        #将测试的真实的图显示
        a[0][i].imshow(np.reshape(view_figures[i],(57,47)))
        #清空坐标轴
        a[0][i].set_xticks(())
        a[0][i].set_yticks(())
    for step in range(1000):
        _,encoderd,decodered,c = sess.run([train,encoder3,decoder3,loss],feed_dict={xs:train_data})
        if step % 100 ==0:
            print('= = = = = = > > > > > > step:',int(step/100),'train loss: %.4f'%c)
        #将测试集中真实图片作为预测的图片
        decoder_figures = sess.run(decoder3,feed_dict={xs:view_figures})
        for i in range(N_pictures):
            #清除第二行第i张图片
            a[1][i].clear()
            a[1][i].imshow(np.reshape(decoder_figures[i],(57,47)))
            a[1][i].set_xticks(())
            a[1][i].set_yticks(())
        plt.show()
        plt.pause(1)
        #关闭交互模式
    plt.ioff()

结果

由于使用的数据集太小,训练的效果一般,但也能看到脸的基本轮廓了
开始:
这里写图片描述

训练1000epochs:
这里写图片描述

训练3000epochs:
这里写图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值