模型名称 | msgnet |
---|---|
类别 | 图像-图像编辑 |
网络 | msgnet |
数据集 | COCO2014 |
是否支持Fine-tuning | 是 |
模型大小 | 68MB |
指标 | - |
最新更新日期 | 2021-07-29 |
-
样例结果示例:
-
- 本示例将展示如何使用PaddleHub对预训练模型进行finetune并完成预测任务。
- 更多详情请参考:msgnet
-
-
paddlepaddle >= 2.0.0
-
paddlehub >= 2.0.0
-
-
-
$ hub install msgnet
-
如您安装时遇到问题,可参考:零基础windows安装 | 零基础Linux安装 | 零基础MacOS安装
-
$ hub run msgnet --input_path "/PATH/TO/ORIGIN/IMAGE" --style_path "/PATH/TO/STYLE/IMAGE"
import paddle
import paddlehub as hub
if __name__ == '__main__':
model = hub.Module(name='msgnet')
result = model.predict(origin=["/PATH/TO/ORIGIN/IMAGE"], style="/PATH/TO/STYLE/IMAGE", visualization=True, save_path ="/PATH/TO/SAVE/IMAGE")
-
-
在完成安装PaddlePaddle与PaddleHub后,通过执行
python train.py
即可开始使用msgnet模型对MiniCOCO等数据集进行Fine-tune。 -
代码步骤
-
Step1: 定义数据预处理方式
-
import paddlehub.vision.transforms as T transform = T.Compose([T.Resize((256, 256), interpolation='LINEAR')])
-
transforms
数据增强模块定义了丰富的数据预处理方式,用户可按照需求替换自己需要的数据预处理方式。
-
-
Step2: 下载数据集并使用
-
from paddlehub.datasets.minicoco import MiniCOCO styledata = MiniCOCO(transform=transform, mode='train')
-
transforms
: 数据预处理方式。 -
mode
: 选择数据模式,可选项有train
,test
, 默认为train
。 -
数据集的准备代码可以参考 minicoco.py。
hub.datasets.MiniCOCO()
会自动从网络下载数据集并解压到用户目录下$HOME/.paddlehub/dataset
目录。
-
-
-
Step3: 加载预训练模型
-
model = hub.Module(name='msgnet', load_checkpoint=None)
name
: 选择预训练模型的名字。load_checkpoint
: 是否加载自己训练的模型,若为None,则加载提供的模型默认参数。
-
-
Step4: 选择优化策略和运行配置
-
optimizer = paddle.optimizer.Adam(learning_rate=0.0001, parameters=model.parameters()) trainer = Trainer(model, optimizer, checkpoint_dir='test_style_ckpt') trainer.train(styledata, epochs=101, batch_size=4, eval_dataset=styledata, log_interval=10, save_interval=10)
-
-
-
模型预测
-
当完成Fine-tune后,Fine-tune过程在验证集上表现最优的模型会被保存在
${CHECKPOINT_DIR}/best_model
目录下,其中${CHECKPOINT_DIR}
目录为Fine-tune时所选择的保存checkpoint的目录。我们使用该模型来进行预测。predict.py脚本如下:import paddle import paddlehub as hub if __name__ == '__main__': model = hub.Module(name='msgnet', load_checkpoint="/PATH/TO/CHECKPOINT") result = model.predict(origin=["/PATH/TO/ORIGIN/IMAGE"], style="/PATH/TO/STYLE/IMAGE", visualization=True, save_path ="/PATH/TO/SAVE/IMAGE")
-
参数配置正确后,请执行脚本
python predict.py
, 加载模型具体可参见加载。 -
Args
origin
:原始图像路径或BGR格式图片;style
: 风格图像路径;visualization
: 是否可视化,默认为True;save_path
: 保存结果的路径,默认保存路径为'style_tranfer'。
NOTE: 进行预测时,所选择的module,checkpoint_dir,dataset必须和Fine-tune所用的一样。
-
-
-
-
PaddleHub Serving可以部署一个在线风格迁移服务。
-
-
运行启动命令:
-
$ hub serving start -m msgnet
-
这样就完成了一个风格迁移服务化API的部署,默认端口号为8866。
-
NOTE: 如使用GPU预测,则需要在启动服务之前,请设置CUDA_VISIBLE_DEVICES环境变量,否则不用设置。
-
-
-
配置好服务端,以下数行代码即可实现发送预测请求,获取预测结果
import requests import json import cv2 import base64 import numpy as np def cv2_to_base64(image): data = cv2.imencode('.jpg', image)[1] return base64.b64encode(data.tostring()).decode('utf8') def base64_to_cv2(b64str): data = base64.b64decode(b64str.encode('utf8')) data = np.fromstring(data, np.uint8) data = cv2.imdecode(data, cv2.IMREAD_COLOR) return data # 发送HTTP请求 org_im = cv2.imread('/PATH/TO/ORIGIN/IMAGE') style_im = cv2.imread('/PATH/TO/STYLE/IMAGE') data = {'images':[[cv2_to_base64(org_im)], cv2_to_base64(style_im)]} headers = {"Content-type": "application/json"} url = "http://127.0.0.1:8866/predict/msgnet" r = requests.post(url=url, headers=headers, data=json.dumps(data)) data = base64_to_cv2(r.json()["results"]['data'][0]) cv2.imwrite('style.png', data)
-
-
1.0.0
初始发布