阿里开源黑白图片上色算法DDColor的部署与测试并将模型转onnx后用c++推理

阿里开源黑白图片上色算法DDColor的部署与测试并将模型转onnx后用c++推理

文章目录

  • 阿里开源黑白图片上色算法DDColor的部署与测试并将模型转onnx后用c++推理
    • 简介
    • 环境部署
      • 下载源码
      • 安装环境
      • 下载模型
    • 测试一下
    • 看看效果
    • 模型转onnx
    • 测试一下生成的onnx模型
    • 看看效果
    • C++ 推理

简介

DDColor是一种基于深度学习的图像上色技术,它利用卷积神经网络(CNN)对黑白图像进行上色处理。该模型通常包含一个编码器和一个解码器,编码器提取图像的特征,解码器则根据这些特征生成颜色。DDColor模型能够处理多种类型的图像,并生成自然且逼真的颜色效果。它在图像编辑、电影后期制作以及历史照片修复等领域有广泛的应用。

环境部署

下载源码

git clone https://github.com/piddnad/DDColor.git

安装环境

conda create -n ddcolor python=3.9
conda activate ddcolor
pip install -r requirements.txt
python3 setup.py develop
pip install modelscope
pip install onnx
pip install onnxruntime

下载模型

这里下载
或者运行下面的脚本下载:

from modelscope.hub.snapshot_download import snapshot_download
model_dir = snapshot_download('damo/cv_ddcolor_image-colorization', cache_dir='./modelscope')
print('model assets saved to %s'%model_dir)
#模型会被下载到modelscope/damo/cv_ddcolor_image-colorization/pytorch_model.pt

测试一下

import argparse
import cv2
import numpy as np
import os
from tqdm import tqdm
import torch
from basicsr.archs.ddcolor_arch import DDColor
import torch.nn.functional as Fclass ImageColorizationPipeline(object):def __init__(self, model_path, input_size=256, model_size='large'):self.input_size = input_sizeif torch.cuda.is_available():self.device = torch.device('cuda')else:self.device = torch.device('cpu')if model_size == 'tiny':self.encoder_name = 'convnext-t'else:self.encoder_name = 'convnext-l'self.decoder_type = "MultiScaleColorDecoder"if self.decoder_type == 'MultiScaleColorDecoder':self.model = DDColor(encoder_name=self.encoder_name,decoder_name='MultiScaleColorDecoder',input_size=[self.input_size, self.input_size],num_output_channels=2,last_norm='Spectral',do_normalize=False,num_queries=100,num_scales=3,dec_layers=9,).to(self.device)else:self.model = DDColor(encoder_name=self.encoder_name,decoder_name='SingleColorDecoder',input_size=[self.input_size, self.input_size],num_output_channels=2,last_norm='Spectral',do_normalize=False,num_queries=256,).to(self.device)self.model.load_state_dict(torch.load(model_path, map_location=torch.device('cpu'))['params'],strict=False)self.model.eval()@torch.no_grad()def process(self, img):self.height, self.width = img.shape[:2]# print(self.width, self.height)# if self.width * self.height < 100000:#     self.input_size = 256img = (img / 255.0).astype(np.float32)orig_l = cv2.cvtColor(img, cv2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/2298.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 中的 null 类型详解与在使用null类型时,有哪些常见陷阱需要避免?

在 C# 中&#xff0c;null 是一个非常特殊的概念&#xff0c;它是表示一个变量没有分配任何值的占位符。在本博客中&#xff0c;我们将深入探讨 C# 中的 null 类型&#xff0c;包括它的定义、特性、使用方法以及如何在面向对象编程中发挥作用。 1. null 类型在 C# 中的定义及特…

限时疯抢!阿里云服务器十大优惠活动合集,手慢无

限时疯抢&#xff01;阿里云服务器十大优惠活动合集&#xff0c;手慢无阿里云服务器优惠活动&#xff08;2024年最新整理&#xff09;&#xff0c;阿里云服务器优惠活动大全、2024阿里云优惠政策整理&#xff0c;包括官方优惠活动主会场、2024年4月优惠活动分为&#xff1a;免费…

遥测、遥信、遥控和遥调

遥测、遥信、遥控和遥调是电力系统自动化、远程监控和控制领域的关键术语&#xff0c;尽管它们在应用范围广泛的工业控制系统中也普遍存在。它们描述了远程测量和控制过程中的不同方面。 遥测&#xff08;Telemetry&#xff09; 遥测是指从远程或不便接近的地方自动测量和传输…

服务器(Linux、AIX)监控软件【nmon】使用

目录 1.安装 2.使用 3.使用 4.采集数据 5.查看log&#xff08;根据结果&#xff0c;生成报表&#xff09; 6.分析结果 1.安装 apt-get install nmon 2.使用 输入nmon进入下面的界面 x Use these keys to toggle statistics on/off: …

牛客网刷题 | BC60 判断是不是字母

描述 KiKi想判断输入的字符是不是字母&#xff0c;请帮他编程实现。 输入描述&#xff1a; 多组输入&#xff0c;每一行输入一个字符。 输出描述&#xff1a; 针对每组输入&#xff0c;输出单独占一行&#xff0c;判断输入字符是否为字母&#xff0c;输出内容详见输出样例…

加密、解密、签名、验签、数字证书、CA浅析

一、加密和解密 加密和解密应用的很广&#xff0c;主要作用就是防止数据或者明文被泄露。 加解密算法主要有两大类&#xff0c;对称加密和非对称加密。对称加密就是加密和解密的密钥都是一个&#xff0c;典型的有AES算法。非对称加密就是有公钥和私钥&#xff0c;公钥可以发布…

【Web】DASCTF X GFCTF 2024|四月开启第一局 题解(全)

目录 EasySignin cool_index SuiteCRM web1234 法一、条件竞争(没成功) 法二、session反序列化 EasySignin 先随便注册个账号登录&#xff0c;然后拿bp抓包改密码(username改成admin) 然后admin / 1234567登录 康好康的图片功能可以打SSRF&#xff0c;不能直接读本地文…

最详细步骤解决:Apps targeting Android12 and higher are required to specify...

问题原因&#xff1a; 当targetSdkVersion>31时&#xff0c;需要在AndroidManifest.xml中配置android:exported的值&#xff0c;该值为boolean类型。 android:exported解释&#xff1a; activity 是否可由其他应用的组件启动&#xff1a; 如果设为 "true"&#…

持续更新。。。

1、JAVA面试指南 https://javaguide.cn/ 简历优化&#xff1a;突出与应聘职位相关的项目经验、技术栈、技能证书和专业成就。确保简历中的技术关键词与JD&#xff08;Job Description&#xff09;相符。 自我评估&#xff1a;对照目标职位要求&#xff0c;梳理自身Java技能树&…

Java面试题:什么是Java中的单元测试以及如何编写单元测试?

Java中的单元测试是一种软件开发方法&#xff0c;用于验证代码中的最小可测试单元&#xff08;通常是方法或类&#xff09;是否按预期工作。单元测试的目标是隔离代码的各个部分&#xff0c;并验证每个部分是否都能正确执行其预期的功能。 在Java中&#xff0c;JUnit是最常用的…

【磁盘根目录扩容】

目的 给磁盘的根目录扩容&#xff0c;每个人在服务器上在根目录操作的可能性更大&#xff0c;如果单独指定一个目录扩容&#xff0c;很有可能使用不当 步骤 未扩容时&#xff0c;查看到sda下有两个分区&#xff0c;目前要扩展追加一个分区 使用fdisk -l查看到sda有4.9T&…

milvus datacoord启动源码分析

datacoord启动源码分析 结构体 // components.DataCoord // DataCoord implements grpc server of DataCoord server type DataCoord struct {ctx context.Contextsvr *grpcdatacoordclient.Server }// grpcdatacoord.Server // Server is the grpc server of datacoord type…

AI写作助手:一键智能改写文章质量高

无论是自媒体人写作文章、还是企业撰写宣传资料&#xff0c;文字都是表达思想和传递信息的重要介质。然而&#xff0c;有时候我们在工作中可能会遇到写作困难&#xff0c;或者想要对文章进行一定程度的改写以增加独特性和质量。而在这样的背景下&#xff0c;智能改写文章成为了…

VS2019编译OSG3.7.0+OSGEarth3.3+OSGQt

原文链接&#xff1a;VS2019编译OSG3.7.0OSGEarth3.3OSGQt-CSDN博客 工具与环境 这里使用的 cmake-3.18.3 、 VS2019 和 Qt5.15.2 进行编译。 一、编译OSG3.7.0 1、下载 下载不多赘述&#xff0c;在github上下master版本就是3.7.0版本。 另外还需要 3rdParty_VS2017_v141_…

新技术实现WEB前端零代码开发,将为0基础的人进入到IT行业创造极大便利!顺势破解低代码难以落地的魔咒:程序员集体排斥不喜欢、无基础的人不会代码用不来!

网站&#xff1a;hhtp://www.uiotos.net IT行业太大&#xff0c;从嵌入式硬件、到工具软件&#xff0c;到互联网、移动互联网&#xff0c;再到当前火爆的AI人工智能&#xff0c;都属于IT行业的阵地&#xff01;一度风光无两&#xff0c;即便当前大环境低迷&#xff0c;除了垄断…

Maxwell安装使用和简单案例

一、解压 cd /opt/software/ ​ tar -zxvf maxwell-1.29.2.tar.gz -C /opt/module/ ​ cd /opt/module/ 二、MySQL 环境准备 1、修改 mysql 的配置文件 修改 mysql 的配置文件&#xff0c;开启 MySQL Binlog 设置 vi /etc/my.cnf 添加以下内容 server_id1 log-binmysql-…

基于WOA优化的CNN-GRU-Attention的时间序列回归预测matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1卷积神经网络&#xff08;CNN&#xff09;在时间序列中的应用 4.2 GRU网络 4.3 注意力机制&#xff08;Attention&#xff09; 4.4 WOA优化算法 5.算法完整程序工程 1.算法运行效果图…

开发语言漫谈-脚本语言

前面讲的都称之为编程语言&#xff0c;就是做系统用的。还有一大类称之为脚本语言的语言&#xff0c;这类语言数量极多&#xff0c;大部分程序员用不上&#xff0c;也不关心&#xff0c;这是系统维护人员专用的邻域。这个定义其实也很不准确&#xff0c;不必较真。更准确的来讲…

get_or_insert_with

get_or_insert_with 是 Rust 中集合类型&#xff08;如 HashMap, HashSet, 或某些自定义类型如 BTreeMap&#xff09;提供的方法之一&#xff0c;用于处理“如果不存在则插入”的场景。它旨在简化在集合中查找某个键&#xff08;key&#xff09;&#xff0c;如果该键不存在&…

把 WordPress 变成 BaaS 服务:API 调用指南

有了前面两篇内容的铺垫&#xff0c;我们来聊聊 WordPress 作为 CMS / BaaS 服务使用时绕不开的问题&#xff0c;API 调用。 这篇内容同样的&#xff0c;会尽量少贴代码&#xff0c;简单的讲清楚一件事&#xff0c;降低阅读负担。 写在前面 首先&#xff0c;我们需要进行清晰…