人脸识别(一)合照中的人脸识别:python+ face_recognition

先上照片:(原照+识别后)
图片中包含了7个人,沈叔叔的有点不正常额
沈腾果然没识别出来,TT
代码如下:

import numpy as np
import cv2
import face_recognition
from PIL import Image, ImageDraw, ImageFont

# 计算图片的对应编码
huang_xiao_ming = face_recognition.face_encodings(face_recognition.load_image_file('./pic/huang_xiao_ming.jpg'))[0]
deng_chao = face_recognition.face_encodings(face_recognition.load_image_file('./pic/deng_chao.jpg'))[0]
shen_teng = face_recognition.face_encodings(face_recognition.load_image_file('./pic/shen_teng.jpg'))[0]
biden = face_recognition.face_encodings(face_recognition.load_image_file('./pic/biden.jpeg'))[0]
feng_shao_feng = face_recognition.face_encodings(face_recognition.load_image_file('./pic/feng_shao_feng.jpg'))[0]
zheng_kai = face_recognition.face_encodings(face_recognition.load_image_file('./pic/zheng_kai.jpg'))[0]
li_yi_feng = face_recognition.face_encodings(face_recognition.load_image_file('./pic/li_yi_feng.jpg'))[0]
han_geng = face_recognition.face_encodings(face_recognition.load_image_file('./pic/han_geng.jpg'))[0]
tong_da_wei = face_recognition.face_encodings(face_recognition.load_image_file('./pic/tong_da_wei.jpg'))[0]
tong_li_ya = face_recognition.face_encodings(face_recognition.load_image_file('./pic/tong_li_ya.jpg'))[0]
di_li_re_ba = face_recognition.face_encodings(face_recognition.load_image_file('./pic/di_li_re_ba.jpg'))[0]
yang_mi = face_recognition.face_encodings(face_recognition.load_image_file('./pic/yang_mi.jpg'))[0]

known_encodings = [
    huang_xiao_ming,
    deng_chao,
    shen_teng,
    biden,
    feng_shao_feng,
    zheng_kai,
    li_yi_feng,
    han_geng,
    tong_da_wei,
    tong_li_ya,
    di_li_re_ba,
    yang_mi
]

people_names = [ 'Huang Xiao-ming','Deng Chao','Shen teng','Joe Biden','Feng Shao-feng','zheng_kai','li_yi_feng','han_geng','tong_da_wei','tong_li_ya','di_li_re_ba','yang_mi']
people_names_zh = ['黄晓明','邓超','沈腾','拜登','冯绍峰','郑凯','李易峰','韩庚','佟大为','佟丽娅','迪丽热巴','杨幂']


# 将中文显示在图片上 
def cv2ImgAddText(img, text, left, top, textColor=(0, 255, 0), textSize=20):
    if (isinstance(img, np.ndarray)):  #判断是否OpenCV图片类型
        img = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
    draw = ImageDraw.Draw(img)
    fontText = ImageFont.truetype( 
        "C:/Windows/Fonts/simsun.ttc", textSize, encoding="utf-8")
    draw.text((left, top), text, textColor, font=fontText)
    return cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR)

test_image = face_recognition.load_image_file("./pic/hezhao.jpg")
test_image_encoding = face_recognition.face_encodings(test_image)[0]
test_image_location = face_recognition.face_locations(test_image)

#(A,B,C,D)对应(top,right,bottom,left)
print('图片中检测到',len(test_image_location),'张脸')

saveImg = test_image
for i in range(0,len(test_image_location)):
    top = test_image_location[i][0]
    right = test_image_location[i][1]
    bottom = test_image_location[i][2]
    left = test_image_location[i][3]
    cv2.rectangle(saveImg,(left,bottom),(right,top),(0,255,0),2)
    # 得到差异度列表,值最小的最相似
    face_image =test_image[top:bottom, left:right]
    face_image_encoding = face_recognition.face_encodings(face_image)
    if len(face_image_encoding):
        distance_list = face_recognition.face_distance(known_encodings,face_image_encoding[0])
        idx=np.argmin(distance_list)
        print(min(distance_list),'\t',people_names_zh[idx])
        if min(distance_list)<0.6:
            saveImg = cv2ImgAddText(saveImg, people_names_zh[idx], left+10, top-20, (255, 0, 0), 20)
        else:
            saveImg = cv2ImgAddText(saveImg,'unknown', left+10, top-20, (255, 0, 0), 20)
    else:
       saveImg = cv2ImgAddText(saveImg, 'none', left, top-20, (255, 0, 0), 20) 


# 注意openCV的图片是BGR模式
cv2.imshow('face-compare',cv2.cvtColor(saveImg, cv2.COLOR_RGB2BGR))

cv2.waitKey(0)
cv2.destroyAllWindows()

几点说明:

(1)openCV不支持显示中文,代码中cv2ImgAddText函数用于添加中文显示

(2)openCV打开及显示的图片是BGR格式的,需要做RGB2BGR的转换

(3)人脸相似度可以用 1-min(distance_list)百分数来计算

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值