IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 用opencv的人脸识别来分辨明星似乎不太灵光 -> 正文阅读

[人工智能]用opencv的人脸识别来分辨明星似乎不太灵光


前言

学习opencv, 用网上找到的男女明星照骗试了下opencv的3种人脸识别机制, 似乎都不太行。


一、opencv 人脸识别函数

  • 有3个识别器:
recognizer_eigenface = cv2.face.EigenFaceRecognizer_create()
recognizer_fisher = cv2.face.FisherFaceRecognizer_create()
recognizer_LBPH = cv2.face.LBPHFaceRecognizer_create()
  • 使用方法是一样的,都要先准备好训练集来训练,训练后再预测
  • 注意安装标准版的opencv-python是不行的,要安装opencv-contrib-python才行。

二、从素材准备到预测

  1. 下载图片
    男女明星各一组,每组2人,每人各9张。图片找小冰要的,度娘也一样。
  2. 图片规整化
    训练时要求图片尺寸统一,而下载来的图片大大小小,所以要统一到同一尺寸. 用简单粗暴的方法,查出所有图片的最小尺寸,然后将所有照片调到此尺寸。不能变形,不足的方向补黑边。
def unifyImg(strSource):
    #read all images and get the smallest size
    x_min = 9999
    y_min = 9999
    img_Bingbing = list()
    img_file_list = os.listdir(strSource)
    for i in range(0,len(img_file_list)):
        strFileName = os.path.join(strSource,img_file_list[i]) 
        if os.path.isfile(strFileName):
            img = cv2.imread(strFileName)
            if img is None:
                print('Failed when read file %s'%strFileName)
                continue
            
            # record size
            if img.shape[0] < y_min:
                y_min = img.shape[0]
            if img.shape[1] < x_min:
                x_min = img.shape[1]
                
            #store img and its name
            img_Bingbing.append([img,img_file_list[i]])

    #Resize images  
    frontFaceCascade = cv2.CascadeClassifier(r'.\Lib\site-packages\cv2\data\haarcascade_frontalface_default.xml')
    profileFaceCascade = cv2.CascadeClassifier(r'.\Lib\site-packages\cv2\data\haarcascade_profileface.xml')
    
    for i in range(0,len(img_Bingbing)):
        img = img_Bingbing[i][0]

        #check if face is identified in the image
        frontFaces = frontFaceCascade.detectMultiScale(img)
        profileFaces = profileFaceCascade.detectMultiScale(img)
        if len(frontFaces) == 0:
            if len(profileFaces) == 0:
                print("no face detected on img: %s, deleted."%img_Bingbing[i][1])
                continue
            else:
                x = profileFaces[0][0]
                y = profileFaces[0][1]
                w = profileFaces[0][2]
                h = profileFaces[0][3]
        else:
            x = frontFaces[0][0]
            y = frontFaces[0][1]
            w = frontFaces[0][2]
            h = frontFaces[0][3]
        
        img_new = img[y:y+h,x:x+w]
        cv2.imwrite(strSource + "\\Face_only\\" + img_Bingbing[i][1],img_new)

        # 98% make sure the output image size is smaller than the min_x or min_y
        rate_x = x_min / img.shape[1] * 0.98
        rate_y = y_min / img.shape[0] * 0.98 
        rate = min(rate_x, rate_y)
        
        img_new = cv2.resize(img, None, fx = rate, fy = rate)
        if len(img_new.shape) == 2:
            # grey
            img_template = np.zeros((y_min, x_min),np.uint8) 
        else:
            img_template = np.zeros((y_min, x_min, 3),np.uint8) 
        
        h = img_new.shape[0]
        w = img_new.shape[1]
          
        img_template[0:h,0:w] = img_new
        
        cv2.imwrite(strSource + "\\Unified\\" + img_Bingbing[i][1],img_template)

strSource = r'C:\Waley\Personal\Learning\Python\Image\TryFaceIdentify'
unifyImg(strSource)
  1. 挑一部分统一好尺寸的图片整合进一个列表,用来训练
src = list()
lables = list()
# LiYiFeng
for i in range(0,6):
    img = cv2.imread(strSource + "\\unified\\LYF_" + str(i+1) + ".jpg",cv2.IMREAD_GRAYSCALE)
    if img is None:
        print("Fail to read images")
        sys.exit(0)
    else:
        src.append(img)
        lables.append(0)
#YiYangQianXi
for i in range(0,6):
    img = cv2.imread(strSource + "\\unified\\YYQX_" + str(i+1) + ".jpg",cv2.IMREAD_GRAYSCALE)
    if img is None:
        print("Fail to read images")
        sys.exit(0)
    else:
        src.append(img)
        lables.append(1)              
names = {"0":"LiYiFeng","1":"YiYangQianXi"}

#train recognizer
recognizer_eigenface.train(src,np.array(lables))
recognizer_fisher.train(src, np.array(lables))
recognizer_LBPH.train(src, np.array(lables))
  1. 识别
for i in range(7,10):
    img = cv2.imread(strSource + "\\unified\\LYF_" + str(i) + '.jpg',cv2.IMREAD_GRAYSCALE)
    print("LYF %d : "%i)
    lable, confidence = recognizer_eigenface.predict(img)
    print("predicted by Eigenface: %s, confidence is: %d"%(names[str(lable)],confidence))
    lable, confidence = recognizer_fisher.predict(img)
    print("predicted by Fisher: %s, confidence is: %d"%(names[str(lable)],confidence))
    lable, confidence = recognizer_LBPH.predict(img)
    print("predicted by LBPH: %s, confidence is: %d"%(names[str(lable)],confidence))

print("\n\n")

for i in range(7,10):
    img = cv2.imread(strSource + "\\unified\\YYQX_" + str(i) + '.jpg',cv2.IMREAD_GRAYSCALE)
    print("YYQX %d : "%i)
    lable, confidence = recognizer_eigenface.predict(img)
    print("predicted by Eigenface: %s, confidence is: %d"%(names[str(lable)],confidence))
    lable, confidence = recognizer_fisher.predict(img)
    print("predicted by Fisher: %s, confidence is: %d"%(names[str(lable)],confidence))
    lable, confidence = recognizer_LBPH.predict(img)
    print("predicted by LBPH: %s, confidence is: %d"%(names[str(lable)],confidence))

  1. 以上可以合并为一个函数,方便换人试验:
def trainAndPredict(strSource, strName1, strName2):
    # prepare training dataset
    src = list()
    lables = list()
    for i in range(0,6):
        img = cv2.imread(strSource + "\\unified\\" + strName1 + '_' + str(i+1) + ".jpg",cv2.IMREAD_GRAYSCALE)
        if img is None:
            print("Fail to read images")
            sys.exit(0)
        else:
            src.append(img)
            lables.append(0)
            
    for i in range(0,6):
        img = cv2.imread(strSource + "\\unified\\" + strName2 + '_' +  str(i+1) + ".jpg",cv2.IMREAD_GRAYSCALE)
        if img is None:
            print("Fail to read images")
            sys.exit(0)
        else:
            src.append(img)
            lables.append(1)              
    names = {"0":strName1,"1":strName2}
    #set up creator
    recognizer_eigenface = cv2.face.EigenFaceRecognizer_create()
    recognizer_fisher = cv2.face.FisherFaceRecognizer_create()
    recognizer_LBPH = cv2.face.LBPHFaceRecognizer_create()
    
    #train recognizer
    recognizer_eigenface.train(src,np.array(lables))
    recognizer_fisher.train(src, np.array(lables))
    recognizer_LBPH.train(src, np.array(lables))
    
    for i in range(7,10):
        img = cv2.imread(strSource + "\\unified\\" + strName1 + '_' +  str(i) + '.jpg',cv2.IMREAD_GRAYSCALE)
        print("%s %d : "%(strName1,i))
        lable, confidence = recognizer_eigenface.predict(img)
        print("predicted by Eigenface: %s, confidence is: %d"%(names[str(lable)],confidence))
        lable, confidence = recognizer_fisher.predict(img)
        print("predicted by Fisher: %s, confidence is: %d"%(names[str(lable)],confidence))
        lable, confidence = recognizer_LBPH.predict(img)
        print("predicted by LBPH: %s, confidence is: %d"%(names[str(lable)],confidence))
    
    print("\n\n")
    
    for i in range(7,10):
        img = cv2.imread(strSource + "\\unified\\" + strName2 + '_' +  str(i) + '.jpg',cv2.IMREAD_GRAYSCALE)
        print("%s %d : "%(strName2,i))
        lable, confidence = recognizer_eigenface.predict(img)
        print("predicted by Eigenface: %s, confidence is: %d"%(names[str(lable)],confidence))
        lable, confidence = recognizer_fisher.predict(img)
        print("predicted by Fisher: %s, confidence is: %d"%(names[str(lable)],confidence))
        lable, confidence = recognizer_LBPH.predict(img)
        print("predicted by LBPH: %s, confidence is: %d"%(names[str(lable)],confidence))

#strSource = r'C:\Waley\Personal\Learning\Python\Image\TryFaceIdentify'
#strName1 = 'LYF'
#strName2 = 'YYQX'

strSource = r'C:\Waley\Personal\Learning\Python\Image\FaceIdentify'
strName1 = 'LiBingbing'
strName2 = 'YangMi'
trainAndPredict(strSource, strName1, strName2)
  1. 结果让人意外
    对于两位男明星,简直没有任何识别率。在这里插入图片描述
    在这里插入图片描述
    这两位明星都不太熟悉,会不会是网站也是AI标的,标错了呢?哈哈。

换了两位女明星试验,效果似乎还行:
在这里插入图片描述
在这里插入图片描述

三、意外的发现

  • 发现这张图片opencv 检测不出来脸部,正面侧面都不行。等继续研究为什么。
    在这里插入图片描述
  • 发现这张图片opencv识别出来的脸部是错误的
    在这里插入图片描述
    识别出来的脸是肘部,
    在这里插入图片描述

原因待进一步研究。

四、结论

将opencv 的人脸识别用于生产环境估计是不行的。下一步准备用同样的这些图片训练下TensorFlow试试

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-02-06 13:50:16  更:2022-02-06 13:52:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:07:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码