哈嘍,大家好。
今天繼續跟大家分享有趣的 AI 專案。
上次我們分享了用GAN(產生對抗網路)讓靜態圖片動起來#。
今天我們分享用NoGAN的圖像增強技術來為老照片著色。效果如下:
原圖
#上色後
NoGAN是一種新型GAN ,它能花費最少的時間進行GAN訓練。
今天分享的這個專案已在GitHub開源項目,我們來先運行一下。
首先,用git clone指令下載原始碼。
git clone https://github.com/jantic/DeOldify.git
進入專案根目錄,安裝Python依賴套件。
pip3 install -r requirements.txt
在編寫程式碼運行專案之前,需要下載預先訓練好的模型。項目提供了三個模型:
模型
區別如下:
在專案根目錄同級目錄下建立Python文件,編寫程式碼載入剛下載好的模型檔。
from DeOldify.deoldify.generators import gen_inference_wide
from DeOldify.deoldify.filters import MasterFilter, ColorizerFilter
# 指定模型文件
learn = gen_inference_wide(root_folder=Path('./DeOldify'), weights_name='ColorizeVideo_gen')
# 加载模型
deoldfly_model = MasterFilter([ColorizerFilter(learn=learn)], render_factor=10)
root_folder指定專案根目錄,weights_name指定接下來使用哪個模型為照片上色。
讀取舊照片,進行上色;
import cv2
import numpy as np
from PIL import Image
img = cv2.imread('./images/origin.jpg')
img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
pil_img = Image.fromarray(img)
filtered_image = deoldfly_model.filter(
pil_img, pil_img, render_factor=35, post_process=True
)
result_img = np.asarray(filtered_image)
result_img = cv2.cvtColor(result_img, cv2.COLOR_RGB2BGR)
cv2.imwrite('deoldify.jpg', result_img)
用cv2讀取舊照片,並用PIL.Image模組將圖片轉換成模型輸入所需的格式,送入模型進行上色,完成後儲存。
上述程式碼是我從專案原始碼中抽取的,可以看到,運行程式碼還是非常簡單的。
#以上是Python+AI為舊照片上色的詳細內容。更多資訊請關注PHP中文網其他相關文章!