Python人臉融合告訴你,你的下一代長啥樣

来源:https://www.cnblogs.com/123456feng/archive/2022/04/08/16116965.html
-Advertisement-
Play Games

前言 和換臉演算法的簡單粗暴相比,人臉融合演算法就要彈性的多。顧名思義,人臉融合是對兩張人臉進行融合處理,生成的人臉同時具 備兩張人臉的外貌特征。人臉融合有什麼實際意義呢?一個簡單的應用就是用父母雙方的臉部圖片融合,得到未來孩子可能的長相。 本文通過百度AI開放平臺的人臉融合功能來做一個簡單的試驗。 前 ...


前言

和換臉演算法的簡單粗暴相比,人臉融合演算法就要彈性的多。顧名思義,人臉融合是對兩張人臉進行融合處理,生成的人臉同時具

備兩張人臉的外貌特征。人臉融合有什麼實際意義呢?一個簡單的應用就是用父母雙方的臉部圖片融合,得到未來孩子可能的長相。

在這裡插入圖片描述

本文通過百度AI開放平臺的人臉融合功能來做一個簡單的試驗。

前期準備

賬號註冊

我們要使用百度AI開發平臺的功能,必須先註冊一個賬號。訪問 https://login.bce.baidu.com/ ,然後用你的百度賬號登錄就行。

在這裡插入圖片描述

登錄之後,在左邊的菜單欄依次選擇“產品服務 -> 人工智慧 -> 人臉識別”子菜單,進入到人臉識別的產品界面:

在這裡插入圖片描述

然後點擊“創建應用”,填寫“應用名稱”和“應用描述”即可創建應用:

在這裡插入圖片描述

然後返回應用列表,就可以看到你創建的應用:

在這裡插入圖片描述

創建完應用,你需要將 API Key 和 Secret Key 記下來,我們待會的代碼裡面會用到。

閱讀開發文檔

應用創建完後,我們需要知道怎麼調用百度的API來完成我們的試驗,所以我們需要閱讀官方文檔。我們需要做兩件事情:鑒權認

證和圖片融合。

在這裡插入圖片描述

鑒權認證文檔

如果要調用百度的 API 介面,必須先鑒權認證,也就是獲取應用 token 。獲取 token 的文檔地址為:https://ai.baidu.com/ai-

doc/FACE/5k37c1ti0。

文檔中對我們有用的幾處信息如下:

請求URL數據格式:

向授權服務地址https://aip.baidubce.com/oauth/2.0/token發送請求(推薦使用POST),併在URL中帶上以下參數:

•grant_type:必須參數,固定為client_credentials;

•client_id:必須參數,應用的API Key;

•client_secret:必須參數,應用的Secret Key;

請求舉例:

https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=Va5yQRHlA4Fq5eR3LT0vuXV4&client_secret=0rDSjzQ20XUj5itV6WRtznPQSzr5pVw2&

 

伺服器返回的JSON文本參數如下:

•access_token:要獲取的Access Token;

•expires_in:Access Token的有效期(秒為單位,一般為1個月);

•其他參數忽略,暫時不用;

返回舉例:

{  "refresh_token": "25.b55fe1d287227ca97aab219bb249b8ab.315360000.1798284651.282335-8574074",  "expires_in": 2592000,  "scope": "public wise_adapt",  "session_key": "9mzdDZXu3dENdFZQurfg0Vz8slgSgvvOAUebNFzyzcpQ5EnbxbF+hfG9DQkpUVQdh4p6HbQcAiz5RmuBAja1JJGgIdJI",  "access_token": "24.6c5e1ff107f0e8bcef8c46d3424a0e78.2592000.1485516651.282335-8574074",  "session_secret": "dfac94a3489fe9fca7c3221cbf7525ff"}

 

圖片融合文檔

圖片融合文檔的地址為:https://ai.baidu.com/ai-doc/FACE/5k37c1ti0。

文檔中對我們有用的幾處信息如下:

請求註意事項:

•請求體格式化:Content-Type為application/json,通過json格式化請求體。

•Base64編碼:請求的圖片需經過Base64編碼,圖片的base64編碼指將圖片數據編碼成一串字元串,使用該字元串代替圖像地

址。您可以首先得到圖片的二進位,然後用Base64格式編碼即可。需要註意的是,圖片的base64編碼是不包含圖片頭的,如

data:image/jpg;base64。

•圖片格式:現支持PNG、JPG、JPEG、BMP,不支持GIF圖片。

在這裡插入圖片描述

請求示例:

•HTTP方法:POST

•請求URL:https://aip.baidubce.com/rest/2.0/face/v1/merge

•URL參數:access_token

•Header:Content-Type 為application/json

•Body中放置請求參數

返回示例:

Python學習交流Q群:906715085####

{  
  "error_code": 0,   
   "error_msg": "SUCCESS",   
    "log_id": 1234567890123,  
      "timestamp": 1533094576,  
        "cached": 0,  
          "result": {      
            "merge_image": "iVBORw0KGgoAAAANSUhEUgAAAeoAAAHqCAYAAADLb..."     
               }
               }

 

編碼

獲取 token

根據上面的文檔描述,我們調用鑒權介面的方法如下:

#獲取token
def get_token(client_id, client_secret):   
 url = "https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials"    
 params = {"client_id": client_id, "client_secret": client_secret}    
 res = requests.get(url, params=params)  
   result = res.json()    return result['access_token']

 

這個介面很簡單,我們傳入我們應用的信息就可以直接獲得。

獲取圖片的 base64 編碼

我們調用百度人臉融合介面,需要傳入圖片的 base64 編碼,所以我們先要將圖片轉為 base64 格式,轉換方法如下:

#讀取圖片,轉換成base64
def read_pic(name):   
 with open('./%s' % name, 'rb') as f:       
  base64_data = base64.b64encode(f.read())       
   s = base64_data.decode()      
     return s

 

我將圖片放在程式同級目錄下,方法傳入圖片文件名就可以。

調用人臉融合介面並保存結果

token 值和圖片的 base64 編碼準備好了,我們就可以來調用介面進行融合。根據官方的 API 文檔,我們的調用方法如下:

#融合圖片
def merge(token, template, target):    
url = 'https://aip.baidubce.com/rest/2.0/face/v1/merge'    
request_url = url + '?access_token=' + token   
 params = {       
  "image_template": {           
   "image": template,           
    "image_type": "BASE64",            
    "quality_control": "NORMAL"     
       },       
        "image_target": {          
          "image": target,           
           "image_type": "BASE64",           
            "quality_control": "NORMAL"        
            },       
             "merge_degree": "HIGH"   
              }   
 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_pic(res)    
     else:       
      print(str(result['error_code'])+result['error_msg'])

 

在這裡插入圖片描述

參數中的 template 指的是模板圖片,target 指的是被融合圖片。也就是說將 target 圖片的人臉融合到 template 圖片的人臉中,最後輸出的圖片是以 template 圖片為模板的。

這裡有一個將介面返回的圖片轉存到本地的方法 down_pic ,其實現如下:

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

 

我們把融合的圖片命名為 result.jpg ,存儲在程式同級目錄下。

主程式

主要的方法我們都完成了,下麵我們通過編寫主程式來測試我們的融合效果,代碼如下:

if __name__ == '__main__':   
 girl = read_pic('girl.jpg')    
 boy = read_pic('boy.jpg')    
 token = get_token(API_KEY, SECRET_KEY)   
  merge(token, boy, girl)

 

我這裡用一個男人的圖片和一個女人的圖片來做測試,以男人的圖片作為模板,兩張圖片都是從百度圖片搜索出來的。

男人的人臉圖片為:
在這裡插入圖片描述

女人的人臉圖片為:

在這裡插入圖片描述

融合後的人臉圖片為:
在這裡插入圖片描述

是不是很帥氣,這個可能是這兩個人未來兒子的模樣。接著,我們調換一下模板,我們以女人的圖片作為模板,看看他們未來女兒的模樣,結果如下:

在這裡插入圖片描述
本文通過調用百度AI開放平臺的人臉融合介面,來實現兩張正面人臉圖片的融合試驗。大家覺得融合的效果怎麼樣?我覺得如果這兩個人結婚,生男孩子會好看些呢!大家也可以把自己和另一半的自拍照拿來試驗一下,看看未來孩子長啥樣?當然,如果你是單身狗,那可以找個漂亮明星圖片來幻想一下。

在這裡插入圖片描述


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • web前端開發規範 規範概述 一個人走的更快,一群人可以走的更遠,前提是統一的策略,還要不斷地反省和優化。不管有多少人共同參與同一項目,儘可能確保每一行代碼都像是同一個人編寫的 開發目錄規範 開發環境規範 開發編碼規範 一、目錄及文件命名規範 (一)、例靜態專題頁目錄 - src / html 源代 ...
  • ELK 基本概述 ELK是Elasticsearch、Logstash、Kibana的簡稱,常常用於部署分散式系統日誌服務。 Elasticsearch:全球實時全文搜索和分析引擎,提供搜集、分析、存儲數據三大功能;是一套開放REST和JAVA API等結構提供高效搜索功能,可擴展的分散式系統。它構 ...
  • Mysql主從環境概述 Mysql集群主從環境搭建 本次採用Docker部署集群,並且首先主從實例配置。 1.Mysql-Cluster集群服務規劃 2.Mysql-Cluster集群先決條件 創建 Mysql-Cluster集群主要配置目錄如下: 2.1 Mysql-Master節點[3308] ...
  • We are not here because we are free .we are here because we are not free. 我們在這裡不是因為我們自由,我們在這裡是因為我們不自由。——《黑客帝國》 寫在開頭 在這個互聯網最美好的時代,隨著業務產品線的增多,業務應用平臺逐漸增多 ...
  • Qt 實現文字輸入框,帶字數限制 核心構思 核心的點在於,限制輸入的字數;主要的方法為創建一個組合視窗 textChanged 這個信號,會在你輸入字元之後發射,可以連接這個信號,在發射了信號之後,去獲取當前QTextEdit里的內容,獲取數量,然後根據最大數量,來選擇是不是需要截取文本; 游標的移 ...
  • 一、我們在python語言中 常用@classmethod、@staticmethod這個裝飾器,裝飾器的作用簡單來講就是我們在很多地方可能都會用到一下相同的功能,這時我們會有兩種想法。 1. 將這部分相同的功能封裝成函數,然後在使用這個功能的時候程式中調用這個函數。 2. 將這部分相同的功能封裝成 ...
  • 一直以來,中式占卜都是基於算命先生手工實現,程式繁瑣(往往需要沐浴、計算天時、靜心等等流程)。準備工作複雜(通常需要銅錢等道具),計算方法複雜,需要純手工計算二進位並轉換為最終的卦象,為瞭解決這個問題,筆者基於python實現了一套科學算命工具,用於快速進行占卜。 本文的算命方式採用八卦 + 周易+ ...
  • RPC及Dubbo和ZooKeeper的安裝 RPC 通信有兩種方式:HTTP(無狀態協議,通信協議),RPC(遠程過程調用) 它兩的本質沒有區別,只是功能有點不一樣 官方解釋: RPC是指遠程過程調用,是一種進程間通信方式,他是一種技術的思想,而不是規範,它允許程式調用另一個地址空間的過程和函數, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...