zoukankan      html  css  js  c++  java
  • 实现人脸识别性别之路---制作自己的训练集并读取

    import tensorflow as tf
    import os
    import cv2

    def handle_data(photo_path):
    #制作数据集
    writer = tf.python_io.TFRecordWriter("data_photo.tfrecords")
    cast = {"boy"}
    for index,name in enumerate(cast):
    # print(index,name)
    for i in os.listdir(photo_path):
    image_path = os.path.join(photo_path,i)
    # print(image_path)
    imag = cv2.imread(image_path)
    # print(imag)
    image = cv2.resize(imag, (128,128), interpolation=cv2.INTER_CUBIC)
    # print(image)
    dr_image = image.tobytes()
    # print(dr_image)
    exmple = tf.train.Example(features = tf.train.Features(feature = {
    "label":tf.train.Feature(int64_list = tf.train.Int64List(value = [index])),
    "img_raw": tf.train.Feature(bytes_list = tf.train.BytesList(value = [dr_image])), }))
    writer.write(exmple.SerializeToString())

    writer.close()

    def put_fileinfo_queue(data_path):
      #将文件放进队列中
    file_queue = tf.train.string_input_producer([data_path])

    reader = tf.TFRecordReader()
    key,value = reader.read(file_queue)
    features = tf.parse_single_example(value,features={"label":tf.FixedLenFeature([],tf.int64),
    "img_raw":tf.FixedLenFeature([],tf.string)})#这个要和之前的一样才能更好的读取数据
    img = tf.decode_raw([features["img_raw"]],tf.uint8)#要与存入数据的时候,一致
    img = tf.cast(img,tf.float32)#然后我们可以转化为tf.float32
    img = tf.reshape(img,[128,128,3])#图片是三通道的
    lebal = tf.cast(features["label"],tf.int32)

    return img,lebal

    def batch_size(img,label):
    #将图片的信息分批化
    image,label=tf.train.shuffle_batch([img,label],batch_size=2,capacity=3,min_after_dequeue=2)
    return image,label

    init = tf.global_variables_initializer()
    if __name__=="__main__":
    photo_path="E:\temporary"
    handle_data(photo_path)
    file = os.listdir("E:\da")
    for i in file:
    filepath = os.path.join("E:\da",i)
    img,label = put_fileinfo_queue(filepath)
    image,label = batch_size(img,label)
    with tf.Session()as sess:
    sess.run(init)
    coord = tf.train.Coordinator()
    threads = tf.train.start_queue_runners(coord=coord)
    for i in range(3):
    print(sess.run([image,label]))
    coord.request_stop()
    coord.join()
    代码的思路:
    图片分批处理的方式:
    (1)、制作数据集(文件扩展名为:tfrecord)
    1、通过tf.python_io.TFRecordWriter(地址)返回一个作者对象
    2、读取图片地址
    3、通过地址将文件信息读取出来
    4、重新设置一下图片的大小
    5、将文件信息转化为二进制
    6、将所有关于图片的东西转化为一个例子
    7、将例子序列化
    8、将例子写入文件
    9、让作者休息
    (2)、将数据集放入队列中
    1、创建能读取文件内容的对象
    2、调用对象中的阅读函数
    3、使用阅读函数返回的value值
    4、调用能返回字典(包含文件信息,名字)对象
    5、将read读取的二进制转化了
    6、这里注意再转码时候,要与之前的类型要一样,因此decode_raw函 数的第二参数是:tf.uint8.
    7、记住转化为我们之前的图片的形式,即为三通道的图片
    8、转化图片信息的张量
    9、转化标签类型
    10、调用将文件并且与文件相对应的标签分批处理
    11、由于他们是使用线程的方式调用,因此我们需要用到线程


  • 相关阅读:
    数据库高级链表查询,重点可以多看看
    数据库多表查询,一对一关系,一对多关系,多对多关系
    Django基础
    前端之JavaScript
    前端之Jquery
    CF888E Maximum Subsequence-折半搜索
    HNOI2010 平面图判定
    CEOI 2011Traffic
    LuoguP1710 地铁涨价
    Luogu2059 卡牌游戏-概率DP
  • 原文地址:https://www.cnblogs.com/MyUniverse/p/9505255.html
Copyright © 2011-2022 走看看