基于Python制作圖像完美超分處理工具
前言
根據(jù)上一篇文章:Python圖片視頻超分模型RealBasicVSR的使用教程
我把項(xiàng)目進(jìn)行的工具化調(diào)整,做成了對(duì)單一照片輸入進(jìn)行處理的工具。大家可以拿去直接集成到代碼中使用。
github項(xiàng)目地址:工具項(xiàng)目地址
項(xiàng)目說(shuō)明
項(xiàng)目結(jié)構(gòu)如下

注意項(xiàng)
1、 checkpoints中的模型文件太大,上傳不到github上,大家可以通過(guò)下面我分享的百度云盤地址下載,放到checkpoints目錄中。
鏈接 提取碼:1234
2、conda環(huán)境安裝,我這里就不多敘述了,直接參考上一篇文章中的安裝過(guò)程即可。
Python圖片視頻超分模型RealBasicVSR的使用教程
代碼說(shuō)明
主要的核心代碼是inference_hy.py文件,代碼如下:
#!/user/bin/env python
# coding=utf-8
"""
@project : hy_realbasicvsr
@author : 劍客阿良_ALiang
@file : inference_hy.py
@ide : PyCharm
@time : 2022-05-08 15:18:15
"""
import argparse
import glob
import os
import cv2
import mmcv
import numpy as np
import torch
import uuid
from mmcv.runner import load_checkpoint
from mmedit.core import tensor2img
from realbasicvsr.models.builder import build_model
def init_model(config, checkpoint=None):
if isinstance(config, str):
config = mmcv.Config.fromfile(config)
elif not isinstance(config, mmcv.Config):
raise TypeError('config must be a filename or Config object, '
f'but got {type(config)}')
config.model.pretrained = None
config.test_cfg.metrics = None
model = build_model(config.model, test_cfg=config.test_cfg)
if checkpoint is not None:
checkpoint = load_checkpoint(model, checkpoint)
model.cfg = config # save the config in the model for convenience
model.eval()
return model
class Worker:
def __init__(self):
self.checkpoint_path = 'checkpoints/RealBasicVSR_x4.pth'
self.config = 'configs/realbasicvsr_x4.py'
self.is_save_as_png = True
self.max_seq_len = 2
self.model = init_model(self.config, self.checkpoint_path)
def do_pic(self, input_image_path: str, output_dir: str):
inputs = []
img = mmcv.imread(input_image_path, channel_order='rgb')
ext = os.path.basename(input_image_path).split('.')[-1]
inputs.append(img)
for i, img in enumerate(inputs):
img = torch.from_numpy(img / 255.).permute(2, 0, 1).float()
inputs[i] = img.unsqueeze(0)
inputs = torch.stack(inputs, dim=1)
# map to cuda, if available
cuda_flag = False
if torch.cuda.is_available():
model = self.model.cuda()
cuda_flag = True
with torch.no_grad():
if isinstance(self.max_seq_len, int):
outputs = []
for i in range(0, inputs.size(1), self.max_seq_len):
imgs = inputs[:, i:i + self.max_seq_len, :, :, :]
if cuda_flag:
imgs = imgs.cuda()
outputs.append(self.model(imgs, test_mode=True)['output'].cpu())
outputs = torch.cat(outputs, dim=1)
else:
if cuda_flag:
inputs = inputs.cuda()
outputs = self.model(inputs, test_mode=True)['output'].cpu()
mmcv.mkdir_or_exist(output_dir)
for i in range(0, outputs.size(1)):
output = tensor2img(outputs[:, i, :, :, :])
filename = '{}.{}'.format(uuid.uuid1().hex, ext)
if self.is_save_as_png:
file_extension = os.path.splitext(filename)[1]
filename = filename.replace(file_extension, '.png')
result_path = os.path.join(output_dir, filename)
mmcv.imwrite(output, result_path)
if __name__ == '__main__':
worker = Worker()
worker.do_pic('data/136.jpeg', 'results/')代碼說(shuō)明
1、如果在真實(shí)項(xiàng)目中使用的話,worker對(duì)象可以在項(xiàng)目啟動(dòng)中創(chuàng)建,不需要每次調(diào)用時(shí)候創(chuàng)建。
2、主要使用方法為do_pic方法,入?yún)⒎謩e為:需要超分的照片地址,以及最后生成的目錄地址。
3、最終輸出的照片名使用uuid進(jìn)行命名,如果需要自定義的話,可以看著調(diào)整。
4、輸出的文件格式不一定需要是png,上面的類初始化有bool選項(xiàng),自行調(diào)整。
測(cè)試一下代碼,先看一下圖片。

執(zhí)行結(jié)果
2022-05-08 15:47:54,792 - mmedit - INFO - load checkpoint from torchvision path: torchvision://vgg19
load checkpoint from local path: checkpoints/RealBasicVSR_x4.pth
/home/zhangmaolin/.local/lib/python3.7/site-packages/torch/functional.py:445: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at ../aten/src/ATen/native/TensorShape.cpp:2157.)
return _VF.meshgrid(tensors, **kwargs) # type: ignore[attr-defined]
最終圖片輸出

總結(jié)
本文主要是造個(gè)輪子吧,相信有經(jīng)驗(yàn)的可以自己改造,包括視頻處理也可以不要使用作者的demo,自己優(yōu)化一下邏輯,性能應(yīng)該都跟得上。提供思路吧,視頻拆分圖片組和音頻,處理完之后壓縮為一個(gè)視頻。
以上就是基于Python制作圖像完美超分處理工具的詳細(xì)內(nèi)容,更多關(guān)于Python圖像超分處理的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
深入理解?Python?中的?pip?虛擬環(huán)境(最佳實(shí)踐)
本文深入講解了Python中pip虛擬環(huán)境的概念及其重要性,并詳細(xì)介紹了如何創(chuàng)建、激活和管理虛擬環(huán)境,以及如何使用requirements.txt文件記錄和管理項(xiàng)目依賴,文章指出,使用虛擬環(huán)境可以有效避免依賴沖突,為每個(gè)項(xiàng)目提供一個(gè)干凈的開(kāi)發(fā)環(huán)境,使得項(xiàng)目更易于維護(hù)和部署2024-10-10
使用Node.js和Socket.IO擴(kuò)展Django的實(shí)時(shí)處理功能
這篇文章主要介紹了使用Node.js和Socket.IO擴(kuò)展Django的實(shí)時(shí)處理功能,用異步處理實(shí)時(shí)功能是相當(dāng)強(qiáng)大的,文中給出的例子是建立一個(gè)實(shí)時(shí)聊天室,需要的朋友可以參考下2015-04-04
python 基本數(shù)據(jù)類型占用內(nèi)存空間大小的實(shí)例
今天小編就為大家分享一篇python 基本數(shù)據(jù)類型占用內(nèi)存空間大小的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
python解決OpenCV在讀取顯示圖片的時(shí)候閃退的問(wèn)題
這篇文章主要介紹了python解決OpenCV在讀取顯示圖片的時(shí)候閃退的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
Python的numpy庫(kù)下的幾個(gè)小函數(shù)的用法(小結(jié))
這篇文章主要介紹了Python的numpy庫(kù)下的幾個(gè)小函數(shù)的用法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
pandas 相關(guān)性和正態(tài)性分析的實(shí)踐
當(dāng)我們談?wù)撜龖B(tài)性(Normality)和相關(guān)性(Correlation)時(shí),我們實(shí)際上在嘗試?yán)斫鈹?shù)據(jù)的分布模式和不同變量之間的關(guān)系,本文就來(lái)介紹一下pandas 相關(guān)性和正態(tài)性的實(shí)踐,感興趣的可以了解一下2024-07-07

