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 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 人脸识别有趣应用2——自动增大眼睛效果 -> 正文阅读

[人工智能]人脸识别有趣应用2——自动增大眼睛效果

作者:token keyword

前言

人脸识别出五官后,可以增加一些形变的算法,对人脸进行“整形”,比如利用凸面镜的滤镜效果,来使得眼睛增大,起到美颜或者夸张艺术效果,效果如下(下面有点夸张了勿喷,可适当调节滤镜范围):
在这里插入图片描述

原理

整个流程是,利用人脸识别算法库(如face_recognition),识别出人脸的两只眼睛的中心坐标,并利用类似局部“凸透镜效果算法”(详见网上资源),从眼睛中心位置进行逐个像素变形,这里我使用了椭圆型的滤镜(直觉上感觉眼睛接近椭圆用椭圆比较自然点),区别于网上的圆形滤镜,这样就可以通过调节椭圆的大小半径(本篇增加了两个滑块)对眼睛区域进行必要的“椭圆放大”。

Python源码实现

# -*- coding: utf-8 -*-
"""
Created on Tue Apr  5 22:19:08 2022

@author: JAMES FEI 
Copyright (C) 2022 FEI PANFENG, All rights reserved.
THIS SOFTEWARE, INCLUDING DOCUMENTATION,IS PROTECTED BY COPYRIGHT CONTROLLED 
BY FEI PANFENG ALL RIGHTS ARE RESERVED.

"""
import face_recognition
import cv2
import numpy as np
import math

video_capture = cv2.VideoCapture(0)

#img=cv2.imread('55.JPG')

def syd(cx,cy,a,b,i,j):
    """
    计算椭圆半径
    """
    p=np.arctan2((i-cx),-(j-cy))
    if b<=0:
        b=1
    t=np.arctan(np.tan(p)*a/b)
    x=a*np.cos(t)
    y=b*np.sin(t)
    r=np.sqrt(x**2+y**2)
    return r
    
def sydd(img,cx,cy,a,b):
    """
    计算椭圆半径
    """
    for i in range(180):        
        t=2*np.pi/359
        x=int(a*np.cos(t*i)+cx)
        y=int(-b*np.sin(t*i)+cy)
        cv2.circle(img, (x,y), 2, (0,255,0), 1)          
        
    return img


def bigeye(src_img,eye,r=20,R=30):   
    H=src_img.shape[0]#y
    W=src_img.shape[1]#x
    new_img=src_img.copy()
    #print(new_img.shape)              
    center_x=eye[0]
    center_y=eye[1]
    for i in range(W):
        for j in range(H):
            distance=((i-center_x)*(i-center_x)+(j-center_y)*(j-center_y))
            new_dist=math.sqrt(distance)

            if (i-center_x)**2/(R**2)+(j-center_y)**2/(r**2)<1:
                u=int(np.floor(new_dist*(i-center_x)/syd(center_x,center_y,R,r,i,j)+center_x))
                v=int(np.floor(new_dist*(j-center_y)/syd(center_x,center_y,R,r,i,j)+center_y))
                #u=int(int(i-center_x)/2*(new_dist/r)+center_x)
                #v=int(int(i-center_y)/2*(new_dist/r)+center_y)
                if 0<u<W and 0<v<H:
                    new_img[j,i,:]=src_img[v,u,:]              
    new_img=sydd(new_img,int(W/2),int(H/2),R,r)
    return new_img
def nothing(x):
    pass
cv2.namedWindow('bigeye')
cv2.createTrackbar('R', 'bigeye', 10, 100, nothing)
cv2.createTrackbar('r', 'bigeye', 5, 100, nothing)


while True:
    
    
    r = cv2.getTrackbarPos('r', 'bigeye')
    R = cv2.getTrackbarPos('R', 'bigeye')
    if r<=0:
        r=1
    if R<=0:
        R=1
    
    
    #frame=img.copy()
    ret, frame = video_capture.read()

    #small_frame = cv2.resize(frame, (0, 0), fx=1/4, fy=1/4)
    

    rgb_frame = frame[:, :, ::-1]

    face_landmarks_list = face_recognition.face_landmarks(rgb_frame)
    output=frame

    for face_landmarks in face_landmarks_list:

        lef_center_x=0
        lef_center_y=0        
        for point in face_landmarks["left_eye"]:
                lef_center_x+=point[0]
                lef_center_y+=point[1]
        lef_center_x=int(lef_center_x/len(face_landmarks["left_eye"]))
        lef_center_y=int(lef_center_y/len(face_landmarks["left_eye"]))
        #cv2.circle(frame, (lef_center_x,lef_center_y), 30, (0,0,0), -1)  
        
        if lef_center_x and lef_center_y:
            output=bigeye(output,(lef_center_x,lef_center_y),r=r,R=R)  
            
        
        rig_center_x=0
        rig_center_y=0
        
        for point in face_landmarks["right_eye"]:
                rig_center_x+=point[0]
                rig_center_y+=point[1]
        rig_center_x=int(rig_center_x/len(face_landmarks["left_eye"]))
        rig_center_y=int(rig_center_y/len(face_landmarks["left_eye"]))
        
        #cv2.circle(frame, (rig_center_x,rig_center_y), 30, (0,0,0), -1)  
        if rig_center_x and rig_center_y:
            output=bigeye(output,(rig_center_x,rig_center_y),r=r,R=R)  

 
    cv2.imshow('bigeye', output)


    # 按Q退出
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break

video_capture.release()
cv2.destroyAllWindows()
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-04-07 22:41:41  更:2022-04-07 22:45:35 
 
开发: 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/16 14:46:49-

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