当前位置: 首页 > news >正文

python 人脸检测与人脸识别

'''
安装库文件: pip install dlib face_recognition
'''import dlib
import face_recognition
import cv2
from PIL import Image, ImageDraw# 判断运行环境 cpu or gpu
def check_env():print(dlib.DLIB_USE_CUDA)print(dlib.cuda.get_num_devices())# 判断人脸在图片当中的位置
def get_face_location(image_flle):image_fr = face_recognition.load_image_file(image_flle)face_locations = face_recognition.face_locations(image_fr)print(face_locations)# 标记人脸的位置image_cv = cv2.imread(image_flle)for location in face_locations:y0, x1, y1, x0 = locationcv2.rectangle(image_cv,(x0,y0),(x1,y1),(0,0,255),4)cv2.imwrite(image_flle + '.new_image.jpg', image_cv)return face_locations# 提取人脸画面保存到本地
def extract_face(image_file):image_cv = cv2.imread(image_file)face_recognitions = get_face_location(image_file)for i, location in enumerate(face_recognitions):y0,x1,y1,x0 = locationface_image = image_cv[y0:y1,x0:x1]cv2.imwrite(f"{image_file}.face_{i}.jpg",face_image)# 把人脸信息编码为一个128维的向量
def encode_face(image_file):image_fr = face_recognition.load_image_file(image_file)face_recognitions = face_recognition.face_locations(image_fr)face_encodings = face_recognition.face_encodings(image_fr,face_recognitions)return face_encodings[0]# 判断2个人脸是否为同一个人
def compare_face(image_file1, image_file2):face_encoding1 = encode_face(image_file1)face_encoding2 = encode_face(image_file2)ret = face_recognition.compare_faces([face_encoding1],face_encoding2)return ret# 标记人脸局部和标识
def mark_face(image_file):image_fr = face_recognition.load_image_file(image_file)face_marks = face_recognition.face_landmarks(image_fr)image_pil = Image.fromarray(image_fr)image_draw = ImageDraw.Draw(image_pil)for face_mark in face_marks:for facial_feature in face_mark.keys():image_draw.line(face_mark[facial_feature],width=5)image_pil.save(f"{image_file}_face_mark.jpg")# 人脸补扮
def beautify_face(image_file):image_fr = face_recognition.load_image_file(image_file)face_marks = face_recognition.face_landmarks(image_fr)image_pil = Image.fromarray(image_fr)for i, face_mark in enumerate(face_marks):image_draw = ImageDraw.Draw(image_pil)# 眉毛image_draw.polygon(face_mark['left_eyebrow'],fill=(68,54,39,128))image_draw.polygon(face_mark['right_eyebrow'],fill=(68,54,39,128))image_draw.line(face_mark['left_eyebrow'],fill=(68,54,39,150),width=2)image_draw.line(face_mark['right_eyebrow'],fill=(68,54,39,150),width=2)# 嘴唇image_draw.polygon(face_mark['top_lip'],fill=(150,0,0,60))image_draw.polygon(face_mark['bottom_lip'],fill=(150,0,0,60))image_draw.line(face_mark['top_lip'],fill=(150,0,0,20),width=2)image_draw.line(face_mark['bottom_lip'],fill=(150,0,0,20),width=2)# 眼睛image_draw.polygon(face_mark['left_eye'],fill=(255,255,255,20))image_draw.polygon(face_mark['right_eye'],fill=(255,255,255,20))image_draw.line(face_mark['left_eye'] + [face_mark['left_eye'][0]],fill=(0,0,0,50),width=2)image_draw.line(face_mark['right_eye'] + [face_mark['right_eye'][0]],fill=(0,0,0,50),width=2)image_pil.save(f"{image_file}.beautify_face.png")def main():check_env()face_locations = get_face_location('1.webp')print(face_locations)extract_face('3.jpg')face_encodings = encode_face('1.webp.face_0.jpg')print(face_encodings)ret = compare_face('1.webp.face_1.jpg','3.jpg.face_1.jpg')print(ret)mark_face('1.webp')beautify_face('1.webp')if __name__=="__main__":main()
http://www.lryc.cn/news/278503.html

相关文章:

  • RT-Thread: ulog 日志 讲解和使用
  • git ssh key 配置
  • MongoDB聚合:$documents
  • 程序员英语 - 英文会议常用句型
  • UV贴图和展开初学者指南
  • 解密Path环境变量
  • git撤销提交到本地的commit
  • 使用Adobe Acrobat Pro DC给pdf文件填加水印
  • 解决:Unity : Error while downloading Asset Bundle: Couldn‘t move cache data 问题
  • SpringBoot默认配置文件
  • Flink构造宽表实时入库案例介绍
  • 【Kubernetes】K8s 查看 Pod 的状态
  • Linux系统操作命令
  • 大模型学习与实践笔记(五)
  • 100个GEO基因表达芯片或转录组数据处理之GSE126848(003)
  • 1. Presto基础
  • ChatGPT可以帮你做什么?
  • 20240111在ubuntu20.04.6下解压缩RAR格式的压缩包
  • YOLOv5改进 | 检测头篇 | ASFFHead自适应空间特征融合检测头(全网首发)
  • 第十三章 接口测试(笔记)
  • Github搭建图床 github搭建静态资源库 免费CDN加速 github搭建图床使用 jsdelivr CDN免费加速访问
  • Airtest-Selenium实操小课②:刷B站视频
  • Linux chmod命令详解
  • 求幸存数之和 - 华为OD统一考试
  • 【QML COOK】- 008-自定义属性
  • 前端页面优化做的工作
  • Spark六:Spark 底层执行原理SparkContext、DAG、TaskScheduler
  • 关于鸿蒙的笔记整理
  • 【漏洞复现】先锋WEB燃气收费系统文件上传漏洞 1day
  • MYSQL篇--锁机制高频面试题