百度AI---人臉識別案例


一.人臉分析

import requests, base64


def get_access_token():
    url = 'https://aip.baidubce.com/oauth/2.0/token'
    data = {
        'grant_type': 'client_credentials',  # 固定值
        'client_id': 'API Key',  # 在開放平台注冊后所建應用的API Key
        'client_secret': 'Secret Key'  # 所建應用的Secret Key
    }
    res = requests.post(url, data=data)
    res = res.json()
    access_token = res['access_token']
    return access_token


def get_json(img):
    access_token=get_access_token()
    request_url = "https://aip.baidubce.com/rest/2.0/face/v3/detect"
    file = open(img, 'rb')  # 二進制讀取圖片
    base64_data = base64.b64encode(file.read())  # 將圖片進行base64編碼
    base64_code = base64_data.decode()
    params = {
        'image': base64_code,
        'image_type': 'BASE64',
        'face_field': 'age,beauty,expression,face_shape,gender,glasses,landmark,landmark150,quality,eye_status,emotion,face_type,mask,spoofing'
    }
    request_url = request_url + "?access_token=" + access_token
    headers = {'Content-Type': 'application/json'}
    response = requests.post(request_url, data=params, headers=headers)
    if response:
        return response.json()

if __name__ == '__main__':
    img = './img/狗狗.jpg'
    json_data=get_json(img)

返回結果說明

必選 類型 說明
face_num int 檢測到的圖片中的人臉數量
face_list array 人臉信息列表,具體包含的參數參考下面的列表。
+face_token string 人臉圖片的唯一標識 (人臉檢測face_token有效期為60min)
+location array 人臉在圖片中的位置
++left double 人臉區域離左邊界的距離
++top double 人臉區域離上邊界的距離
++width double 人臉區域的寬度
++height double 人臉區域的高度
++rotation int64 人臉框相對於豎直方向的順時針旋轉角,[-180,180]
+face_probability double 人臉置信度,范圍【0~1】,代表這是一張人臉的概率,0最小、1最大。其中返回0或1時,數據類型為Integer
+angle array 人臉旋轉角度參數
++yaw double 三維旋轉之左右旋轉角[-90(左), 90(右)]
++pitch double 三維旋轉之俯仰角度[-90(上), 90(下)]
++roll double 平面內旋轉角[-180(逆時針), 180(順時針)]
+age double 年齡 ,當face_field包含age時返回
+beauty int64 美丑打分,范圍0-100,越大表示越美。當face_fields包含beauty時返回
+expression array 表情,當 face_field包含expression時返回
++type string none:不笑;smile:微笑;laugh:大笑
++probability double 表情置信度,范圍【0~1】,0最小、1最大。
+face_shape array 臉型,當face_field包含face_shape時返回
++type double square: 正方形 triangle:三角形 oval: 橢圓 heart: 心形 round: 圓形
++probability double 置信度,范圍【0~1】,代表這是人臉形狀判斷正確的概率,0最小、1最大。
+gender array 性別,face_field包含gender時返回
++type string male:男性 female:女性
++probability double 性別置信度,范圍【0~1】,0代表概率最小、1代表最大。
+glasses array 是否帶眼鏡,face_field包含glasses時返回
++type string none:無眼鏡,common:普通眼鏡,sun:墨鏡
++probability double 眼鏡置信度,范圍【0~1】,0代表概率最小、1代表最大。
+eye_status array 雙眼狀態(睜開/閉合) face_field包含eye_status時返回
++left_eye double 左眼狀態 [0,1]取值,越接近0閉合的可能性越大
++right_eye double 右眼狀態 [0,1]取值,越接近0閉合的可能性越大
+emotion array 情緒 face_field包含emotion時返回
++type string angry:憤怒 disgust:厭惡 fear:恐懼 happy:高興 sad:傷心 surprise:驚訝 neutral:無表情 pouty: 撅嘴 grimace:鬼臉
++probability double 情緒置信度,范圍0~1
+face_type array 真實人臉/卡通人臉 face_field包含face_type時返回
++type string human: 真實人臉 cartoon: 卡通人臉
++probability double 人臉類型判斷正確的置信度,范圍【0~1】,0代表概率最小、1代表最大。
+mask array 口罩識別 face_field包含mask時返回
++type int 沒戴口罩/戴口罩 取值0或1 0代表沒戴口罩 1 代表戴口罩
++probability double 置信度,范圍0~1
+landmark array 4個關鍵點位置,左眼中心、右眼中心、鼻尖、嘴中心。face_field包含landmark時返回
+landmark72 array 72個特征點位置 face_field包含landmark72時返回
+landmark150 array 150個特征點位置 face_field包含landmark150時返回
+quality array 人臉質量信息。face_field包含quality時返回
++occlusion array 人臉各部分遮擋的概率,范圍[0~1],0表示完整,1表示不完整
+++left_eye double 左眼遮擋比例,[0-1] ,1表示完全遮擋
+++right_eye double 右眼遮擋比例,[0-1] , 1表示完全遮擋
+++nose double 鼻子遮擋比例,[0-1] , 1表示完全遮擋
+++mouth double 嘴巴遮擋比例,[0-1] , 1表示完全遮擋
+++left_cheek double 左臉頰遮擋比例,[0-1] , 1表示完全遮擋
+++right_cheek double 右臉頰遮擋比例,[0-1] , 1表示完全遮擋
+++chin double 下巴遮擋比例,,[0-1] , 1表示完全遮擋
++blur double 人臉模糊程度,范圍[0~1],0表示清晰,1表示模糊
++illumination double 取值范圍在[0~255], 表示臉部區域的光照程度 越大表示光照越好
++completeness int64 人臉完整度,0或1, 0為人臉溢出圖像邊界,1為人臉都在圖像邊界內
+spoofing double 判斷圖片是否為合成圖

 

二、人臉對比

import requests, base64


def get_access_token():
    url = 'https://aip.baidubce.com/oauth/2.0/token'
    data = {
        'grant_type': 'client_credentials',  # 固定值
        'client_id': 'API Key',  # 在開放平台注冊后所建應用的API Key
        'client_secret': 'Secret Key'  # 所建應用的Secret Key
    }
    res = requests.post(url, data=data)
    res = res.json()
    access_token = res['access_token']
    return access_token

# 根據圖片名讀取圖片,並轉換成base64
def read_img(img):
    with open(img, 'rb') as f:
        base64_data = base64.b64encode(f.read())
        base64_code = base64_data.decode()
    return base64_code

def get_json(img1,img2):
    request_url = "https://aip.baidubce.com/rest/2.0/face/v3/match"
    params = [
        {
            "image": img1,
            "image_type": "BASE64",
            "face_type": "LIVE",
            "quality_control": "LOW",
            "liveness_control": "HIGH"
        },
        {
            "image": img2,
            "image_type": "BASE64",
            "face_type": "LIVE",
            "quality_control": "LOW",
            "liveness_control": "HIGH"
        }
    ]
    access_token = get_access_token()
    request_url = request_url + "?access_token=" + access_token
    headers = {'content-type': 'application/json'}
    response = requests.post(request_url, json=params, headers=headers)
    if response:
        return response.json()


if __name__ == '__main__':
    img1 = read_img('img/mm2.jpeg')
    img2 = read_img('img/mjl.jpg')
    json_data=get_json(img1,img2)
    print(json_data)
    if json_data['error_msg'] == 'SUCCESS':
        score = json_data['result']['score']

        if score > 80:
            print("照片相似度為:" + str(score) + "基本確定是本人")
        else:
            print("照片相似度為:" + str(score) + "基本確定不是本人")
        print(score)
    else:
        print('錯誤信息:', json_data['error_msg'])

返回結果說明

參數名 必選 類型 說明
score float 人臉相似度得分,推薦閾值80分
face_list array 人臉信息列表
+face_token string 人臉的唯一標志

三、人臉融合

import requests
import base64
import json



# 獲取token
def get_access_token():
    url = 'https://aip.baidubce.com/oauth/2.0/token'
    data = {
        'grant_type': 'client_credentials',  # 固定值
        'client_id': 'API Key',  # 在開放平台注冊后所建應用的API Key
        'client_secret': 'Secret Key'  # 所建應用的Secret Key
    }
    res = requests.post(url, data=data)
    res = res.json()
    access_token = res['access_token']
    return access_token


# 根據圖片名讀取圖片,並轉換成base64
def read_photo(name):
    with open(name, 'rb') as f:
        base64_data = base64.b64encode(f.read())
        base64_code = base64_data.decode()
    return base64_code


# 調用百度的接口,實現融合圖片
def face_fusion(template, target):
    access_token = get_access_token()
    url = 'https://aip.baidubce.com/rest/2.0/face/v1/merge'
    request_url = url + '?access_token=' + access_token
    params = {
        "image_template": {
            "image": template,
            "image_type": "BASE64",
            "quality_control": "NONE"
        },
        "image_target": {
            "image": target,
            "image_type": "BASE64",
            "quality_control": "NONE"
        },
        "merge_degree": "NORMAL"
    }
    params = json.dumps(params)
    headers = {'content-type': 'application/json'}
    result = requests.post(request_url, data=params, headers=headers).json()
    if result['error_code'] == 0:
        res = result["result"]["merge_image"]
        down_photo(res)
    else:
        print(str(result['error_code'])+result['error_msg'])

# 下載融合后圖片
def down_photo(data):
    imagedata = base64.b64decode(data)
    file = open('./result.jpg', "wb")
    file.write(imagedata)

# 主程序
if __name__ == '__main__':
    template = read_photo('img/狗狗.jpg')
    target = read_photo('img/毛毛.jpeg')
    face_fusion(template, target)

返回結果說明

字段 類型 說明
merge_image string 融合圖的BASE64值

四、人像動漫化

import requests, base64


# 百度AI開放平台鑒權函數
def get_access_token():
    url = 'https://aip.baidubce.com/oauth/2.0/token'
    data = {
        'grant_type': 'client_credentials',  # 固定值
        'client_id': 'API Key',  # 在開放平台注冊后所建應用的API Key
        'client_secret': 'Secret Key'  # 所建應用的Secret Key
    }
    res = requests.post(url, data=data)
    res = res.json()
    access_token = res['access_token']
    return access_token


def image_process(img_before, img_after, how_to_deal):
    # 函數的三個參數,一個是轉化前的文件名,一個是轉化后的文件名,均在同一目錄下,第三個是圖像處理能力選擇
    request_url = 'https://aip.baidubce.com/rest/2.0/image-process/v1/' + how_to_deal
    if how_to_deal == 'style_trans':  # 判斷如果是 圖像風格化,需要額外添加一個風格配置
        others = 'cartoon'  # 風格化參數,具體可設置范圍參見下面注釋
        '''
        cartoon:卡通畫風格
        pencil:鉛筆風格
        color_pencil:彩色鉛筆畫風格
        warm:彩色糖塊油畫風格
        wave:神奈川沖浪里油畫風格
        lavender:薰衣草油畫風格
        mononoke:奇異油畫風格
        scream:吶喊油畫風格
        gothic:哥特油畫風格
        '''
    else:
        others = ''

    file = open(img_before, 'rb')  # 二進制讀取圖片
    origin_img = base64.b64encode(file.read())  # 將圖片進行base64編碼
    headers = {'Content-Type': 'application/x-www-form-urlencoded'}
    data = {
        'access_token': get_access_token(),
        'image': origin_img,
        "type":'anime_mask',
        "mask_id":"2"
    }

    res = requests.post(request_url, data=data, headers=headers)

    res = res.json()
    print(res)
    if res:
        f = open(img_after, 'wb')
        after_img = res['image']
        after_img = base64.b64decode(after_img)
        f.write(after_img)
        f.close()


if __name__ == '__main__':
    img_before = 'img/mm1.jpg'  # 當前目錄下的圖片
    img_after = img_before.split('.')  # 將原文件名分成列表
    img_after = img_after[0] + '_2.' + img_after[1]  # 新生成的文件名為原文件名上加 _1

    image_process(img_before, img_after, 'selfie_anime')
    # 第三個參數: selfie_anime 為人像動漫化,colourize 圖像上色,style_trans 為圖像風格化
    print('done!')

返回結果說明

字段 是否必選 類型 說明
log_id uint64 唯一的log id,用於問題定位
image string 處理后圖片的Base64編碼


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM