实现人脸识别性别之路---制作自己的训练集并读取

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、由于他们是使用线程的方式调用,因此我们需要用到线程


转载于:https://www.cnblogs.com/MyUniverse/p/9505255.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
人脸识别是指利用计算机视觉技术对图像或视频中的人脸进行自动识别和分析的过程。人脸识别技术主要包括特征检测和人脸匹配两个部分。 特征检测是指从图像中提取出与人脸有关的特征信息,包括人脸的轮廓、眼睛、鼻子、嘴巴等特征点。在特征检测过程中,通常会使用Haar特征分类器、HOG特征分类器或者深度学习的卷积神经网络等算法来实现人脸匹配是指将提取出来的人脸特征与数据库中已有的人脸特征进行比对,以判断该人脸是否已经被识别过或者是否为指定人员。常见的人脸匹配算法包括欧氏距离匹配算法、余弦相似度匹配算法、支持向量机(SVM)等。 关于利用C++实现人脸识别的代码,可以参考开源库OpenCV中的示例代码,该库提供了丰富的图像处理和计算机视觉功能,包括人脸检测和识别等。以下是一个简单的基于OpenCV的人脸检测和识别的代码示例: ```c++ #include <opencv2/opencv.hpp> #include <opencv2/face.hpp> using namespace cv; using namespace std; using namespace cv::face; int main(int argc, char** argv) { // 加载人脸检测器和识别器 CascadeClassifier face_cascade; face_cascade.load("haarcascade_frontalface_alt.xml"); Ptr<LBPHFaceRecognizer> recognizer = LBPHFaceRecognizer::create(); // 加载训练好的模型 recognizer->read("model.xml"); // 打开摄像头 VideoCapture cap(0); if (!cap.isOpened()) { cout << "无法打开摄像头!" << endl; return -1; } while (true) { Mat frame; cap >> frame; // 转换成灰度图像并进行直方图均衡化 Mat gray; cvtColor(frame, gray, COLOR_BGR2GRAY); equalizeHist(gray, gray); // 检测人脸 vector<Rect> faces; face_cascade.detectMultiScale(gray, faces, 1.1, 2, 0 | CASCADE_SCALE_IMAGE, Size(30, 30)); // 对每个检测到的人脸进行识别 for (size_t i = 0; i < faces.size(); i++) { Mat face = gray(faces[i]); resize(face, face, Size(92, 112)); // 将人脸图像缩放到指定大小 int label = -1; double confidence = 0.0; recognizer->predict(face, label, confidence); // 在图像中标注出人脸位置和识别结果 rectangle(frame, faces[i], Scalar(255, 0, 0), 2); putText(frame, format("Person %d", label), Point(faces[i].x, faces[i].y - 5), FONT_HERSHEY_PLAIN, 1.0, Scalar(0, 255, 0), 2); } imshow("Face Recognition", frame); if (waitKey(30) == 'q') break; } return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值