Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleHub
提交
da6b6b42
P
PaddleHub
项目概览
PaddlePaddle
/
PaddleHub
大约 2 年 前同步成功
通知
285
Star
12117
Fork
2091
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
200
列表
看板
标记
里程碑
合并请求
4
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleHub
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
200
Issue
200
列表
看板
标记
里程碑
合并请求
4
合并请求
4
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
da6b6b42
编写于
11月 23, 2021
作者:
C
chenjian
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
modify according to review
上级
245cc67b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
166 addition
and
47 deletion
+166
-47
modules/image/image_processing/seeinthedark/README.md
modules/image/image_processing/seeinthedark/README.md
+57
-7
modules/image/image_processing/seeinthedark/module.py
modules/image/image_processing/seeinthedark/module.py
+109
-39
modules/image/image_processing/seeinthedark/requirements.txt
modules/image/image_processing/seeinthedark/requirements.txt
+0
-1
未找到文件。
modules/image/image_processing/seeinthedark/README.md
浏览文件 @
da6b6b42
...
...
@@ -13,6 +13,19 @@
## 一、模型基本信息
-
### 应用效果展示
-
样例结果示例:
<p
align=
"center"
>
<img
src=
"https://user-images.githubusercontent.com/22424850/142962370-a957d7b3-8050-4f5a-8462-3d6e49facb33.png"
width =
"450"
height =
"300"
hspace=
'10'
/>
<br
/>
输入图像
<br
/>
<img
src=
"https://user-images.githubusercontent.com/22424850/142962460-4a1b31ef-0eec-423b-ab3d-8622f3e8261a.png"
width =
"450"
height =
"300"
hspace=
'10'
/>
<br
/>
输出图像
<br
/>
</p>
-
### 模型介绍
-
通过大量暗光条件下短曝光和长曝光组成的图像对,以RAW图像为输入,RGB图像为参照进行训练,该模型实现端到端直接将暗光下的RAW图像处理得到可见的RGB图像。
...
...
@@ -25,7 +38,6 @@
-
### 1、环境依赖
-
rawpy
-
pillow
-
### 2、安装
...
...
@@ -53,26 +65,64 @@
denoiser = hub.Module(name="seeinthedark")
input_path = "/PATH/TO/IMAGE"
# Read from a raw file
denoiser.denoising(
input_path
, output_path='./denoising_result.png', use_gpu=True)
denoiser.denoising(
paths=[input_path]
, output_path='./denoising_result.png', use_gpu=True)
```
-
### 3、API
-
```python
def denoising(i
nput_path, output_path='./denoising_result.png', use_gpu=Fals
e)
def denoising(i
mages=None, paths=None, output_dir='./denoising_result/', use_gpu=False, visualization=Tru
e)
```
-
暗光增强API,完成对暗光RAW图像的降噪并处理生成RGB图像。
- **参数**
-
input\_path (str): 暗光图像文件的路径,Sony的RAW格式;
<br/>
- output\_
path (str): 结果保存的路径, 需要指定输出文件名
; <br/>
- images (list\[numpy.ndarray\]): 输入的图像,单通道的马赛克图像; <br/>
-
paths (list\[str\]): 暗光图像文件的路径,Sony的RAW格式;
<br/>
- output\_
dir (str): 结果保存的路径
; <br/>
- use\_gpu (bool): 是否使用 GPU;<br/>
- visualization(bool): 是否保存结果到本地文件夹
## 四、服务部署
-
PaddleHub Serving可以部署一个在线图像风格转换服务。
-
### 第一步:启动PaddleHub Serving
-
运行启动命令:
-
```shell
$ hub serving start -m seeinthedark
```
-
这样就完成了一个图像风格转换的在线服务API的部署,默认端口号为8866。
-
**NOTE:**
如使用GPU预测,则需要在启动服务之前,请设置CUDA
\_
VISIBLE
\_
DEVICES环境变量,否则不用设置。
-
### 第二步:发送预测请求
-
配置好服务端,以下数行代码即可实现发送预测请求,获取预测结果
-
```python
import requests
import json
import rawpy
import base64
def cv2_to_base64(image):
data = cv2.imencode('.jpg', image)[1]
return base64.b64encode(data.tostring()).decode('utf8')
# 发送HTTP请求
data = {'images':[cv2_to_base64(rawpy.imread("/PATH/TO/IMAGE").raw_image_visible)]}
headers = {"Content-type": "application/json"}
url = "http://127.0.0.1:8866/predict/seeinthedark/"
r = requests.post(url=url, headers=headers, data=json.dumps(data))
# 打印预测结果
print(r.json()["results"])
##
四
、更新历史
##
五
、更新历史
* 1.0.0
...
...
modules/image/image_processing/seeinthedark/module.py
浏览文件 @
da6b6b42
...
...
@@ -17,15 +17,19 @@ import argparse
import
paddle
import
paddlehub
as
hub
from
paddlehub.module.module
import
moduleinfo
,
runnable
from
paddlehub.module.module
import
moduleinfo
,
runnable
,
serving
import
numpy
as
np
import
rawpy
from
PIL
import
Image
import
cv2
from
.util
import
base64_to_cv2
def
pack_raw
(
raw
):
# pack Bayer image to 4 channels
im
=
raw
.
raw_image_visible
.
astype
(
np
.
float32
)
im
=
raw
if
not
isinstance
(
raw
,
np
.
ndarray
):
im
=
raw
.
raw_image_visible
.
astype
(
np
.
float32
)
im
=
np
.
maximum
(
im
-
512
,
0
)
/
(
16383
-
512
)
# subtract the black level
im
=
np
.
expand_dims
(
im
,
axis
=
2
)
...
...
@@ -42,47 +46,98 @@ def pack_raw(raw):
class
LearningToSeeInDark
:
def
__init__
(
self
):
self
.
pretrained_model
=
os
.
path
.
join
(
self
.
directory
,
"pd_model/inference_model"
)
self
.
cpu_have_loaded
=
False
self
.
gpu_have_loaded
=
False
def
set_device
(
self
,
use_gpu
=
False
):
if
use_gpu
==
False
:
if
not
self
.
cpu_have_loaded
:
exe
=
paddle
.
static
.
Executor
(
paddle
.
CPUPlace
())
[
prog
,
inputs
,
outputs
]
=
paddle
.
static
.
load_inference_model
(
path_prefix
=
self
.
pretrained_model
,
executor
=
exe
,
model_filename
=
"model.pdmodel"
,
params_filename
=
"model.pdiparams"
)
self
.
cpuexec
,
self
.
cpuprog
,
self
.
cpuinputs
,
self
.
cpuoutputs
=
exe
,
prog
,
inputs
,
outputs
self
.
cpu_have_loaded
=
True
return
self
.
cpuexec
,
self
.
cpuprog
,
self
.
cpuinputs
,
self
.
cpuoutputs
def
denoising
(
self
,
input_path
,
output_path
=
'./denoising_result.png'
,
use_gpu
=
False
):
else
:
if
not
self
.
gpu_have_loaded
:
exe
=
paddle
.
static
.
Executor
(
paddle
.
CUDAPlace
(
0
))
[
prog
,
inputs
,
outputs
]
=
paddle
.
static
.
load_inference_model
(
path_prefix
=
self
.
pretrained_model
,
executor
=
exe
,
model_filename
=
"model.pdmodel"
,
params_filename
=
"model.pdiparams"
)
self
.
gpuexec
,
self
.
gpuprog
,
self
.
gpuinputs
,
self
.
gpuoutputs
=
exe
,
prog
,
inputs
,
outputs
self
.
gpu_have_loaded
=
True
return
self
.
gpuexec
,
self
.
gpuprog
,
self
.
gpuinputs
,
self
.
gpuoutputs
def
denoising
(
self
,
images
=
None
,
paths
=
None
,
output_dir
=
'./enlightening_result/'
,
use_gpu
=
False
,
visualization
=
True
):
'''
Denoise a raw image in the low-light scene.
input_path: the raw image path
output_path: the path to save the results
images (list[numpy.ndarray]): data of images, shape of each is [H, W], must be sing-channel image captured by camera.
paths (list[str]): paths to images
output_dir: the dir to save the results
use_gpu: if True, use gpu to perform the computation, otherwise cpu.
visualization: if True, save results in output_dir.
'''
results
=
[]
paddle
.
enable_static
()
if
use_gpu
==
False
:
exe
=
paddle
.
static
.
Executor
(
paddle
.
CPUPlace
())
else
:
exe
=
paddle
.
static
.
Executor
(
paddle
.
CUDAPlace
(
0
))
[
prog
,
inputs
,
outputs
]
=
paddle
.
static
.
load_inference_model
(
path_prefix
=
self
.
pretrained_model
,
executor
=
exe
,
model_filename
=
"model.pdmodel"
,
params_filename
=
"model.pdiparams"
)
raw
=
rawpy
.
imread
(
input_path
)
input_full
=
np
.
expand_dims
(
pack_raw
(
raw
),
axis
=
0
)
*
300
px
=
input_full
.
shape
[
1
]
//
512
py
=
input_full
.
shape
[
2
]
//
512
rx
,
ry
=
px
*
512
,
py
*
512
input_full
=
input_full
[:,
:
rx
,
:
ry
,
:]
output
=
np
.
random
.
randn
(
rx
*
2
,
ry
*
2
,
3
)
input_full
=
np
.
minimum
(
input_full
,
1.0
)
for
i
in
range
(
px
):
for
j
in
range
(
py
):
input_patch
=
input_full
[:,
i
*
512
:
i
*
512
+
512
,
j
*
512
:
j
*
512
+
512
,
:]
result
=
exe
.
run
(
prog
,
feed
=
{
inputs
[
0
]:
input_patch
},
fetch_list
=
outputs
)
output
[
i
*
512
*
2
:
i
*
512
*
2
+
512
*
2
,
j
*
512
*
2
:
j
*
512
*
2
+
512
*
2
,
:]
=
result
[
0
][
0
]
output
=
np
.
minimum
(
np
.
maximum
(
output
,
0
),
1
)
print
(
'Denoising Over.'
)
try
:
Image
.
fromarray
(
np
.
uint8
(
output
*
255
)).
save
(
os
.
path
.
join
(
output_path
))
print
(
'Image saved in {}'
.
format
(
output_path
))
except
:
print
(
'Save image failed. Please check the output_path, should
\
be image format ext, e.g. png. current output path {}'
.
format
(
output_path
))
exe
,
prog
,
inputs
,
outputs
=
self
.
set_device
(
use_gpu
)
if
images
!=
None
:
for
raw
in
images
:
input_full
=
np
.
expand_dims
(
pack_raw
(
raw
),
axis
=
0
)
*
300
px
=
input_full
.
shape
[
1
]
//
512
py
=
input_full
.
shape
[
2
]
//
512
rx
,
ry
=
px
*
512
,
py
*
512
input_full
=
input_full
[:,
:
rx
,
:
ry
,
:]
output
=
np
.
random
.
randn
(
rx
*
2
,
ry
*
2
,
3
)
input_full
=
np
.
minimum
(
input_full
,
1.0
)
for
i
in
range
(
px
):
for
j
in
range
(
py
):
input_patch
=
input_full
[:,
i
*
512
:
i
*
512
+
512
,
j
*
512
:
j
*
512
+
512
,
:]
result
=
exe
.
run
(
prog
,
feed
=
{
inputs
[
0
]:
input_patch
},
fetch_list
=
outputs
)
output
[
i
*
512
*
2
:
i
*
512
*
2
+
512
*
2
,
j
*
512
*
2
:
j
*
512
*
2
+
512
*
2
,
:]
=
result
[
0
][
0
]
output
=
np
.
minimum
(
np
.
maximum
(
output
,
0
),
1
)
output
=
output
*
255
output
=
np
.
clip
(
output
,
0
,
255
)
output
=
output
.
astype
(
'uint8'
)
results
.
append
(
output
)
if
paths
!=
None
:
for
path
in
paths
:
raw
=
rawpy
.
imread
(
path
)
input_full
=
np
.
expand_dims
(
pack_raw
(
raw
),
axis
=
0
)
*
300
px
=
input_full
.
shape
[
1
]
//
512
py
=
input_full
.
shape
[
2
]
//
512
rx
,
ry
=
px
*
512
,
py
*
512
input_full
=
input_full
[:,
:
rx
,
:
ry
,
:]
output
=
np
.
random
.
randn
(
rx
*
2
,
ry
*
2
,
3
)
input_full
=
np
.
minimum
(
input_full
,
1.0
)
for
i
in
range
(
px
):
for
j
in
range
(
py
):
input_patch
=
input_full
[:,
i
*
512
:
i
*
512
+
512
,
j
*
512
:
j
*
512
+
512
,
:]
result
=
exe
.
run
(
prog
,
feed
=
{
inputs
[
0
]:
input_patch
},
fetch_list
=
outputs
)
output
[
i
*
512
*
2
:
i
*
512
*
2
+
512
*
2
,
j
*
512
*
2
:
j
*
512
*
2
+
512
*
2
,
:]
=
result
[
0
][
0
]
output
=
np
.
minimum
(
np
.
maximum
(
output
,
0
),
1
)
output
=
output
*
255
output
=
np
.
clip
(
output
,
0
,
255
)
output
=
output
.
astype
(
'uint8'
)
results
.
append
(
output
)
if
visualization
==
True
:
if
not
os
.
path
.
exists
(
output_dir
):
os
.
makedirs
(
output_dir
,
exist_ok
=
True
)
for
i
,
out
in
enumerate
(
results
):
cv2
.
imwrite
(
os
.
path
.
join
(
output_dir
,
'output_{}.png'
.
format
(
i
)),
out
[:,
:,
::
-
1
])
return
results
@
runnable
def
run_cmd
(
self
,
argvs
:
list
):
...
...
@@ -101,7 +156,21 @@ class LearningToSeeInDark:
self
.
add_module_config_arg
()
self
.
add_module_input_arg
()
self
.
args
=
self
.
parser
.
parse_args
(
argvs
)
self
.
denoising
(
input_path
=
self
.
args
.
input_path
,
output_path
=
self
.
args
.
output_path
,
use_gpu
=
self
.
args
.
use_gpu
)
self
.
denoising
(
paths
=
[
self
.
args
.
input_path
],
output_dir
=
self
.
args
.
output_dir
,
use_gpu
=
self
.
args
.
use_gpu
,
visualization
=
self
.
args
.
visualization
)
@
serving
def
serving_method
(
self
,
images
,
**
kwargs
):
"""
Run as a service.
"""
images_decode
=
[
base64_to_cv2
(
image
)
for
image
in
images
]
results
=
self
.
denoising
(
images
=
images_decode
,
**
kwargs
)
tolist
=
[
result
.
tolist
()
for
result
in
results
]
return
tolist
def
add_module_config_arg
(
self
):
"""
...
...
@@ -110,7 +179,8 @@ class LearningToSeeInDark:
self
.
arg_config_group
.
add_argument
(
'--use_gpu'
,
action
=
'store_true'
,
help
=
"use GPU or not"
)
self
.
arg_config_group
.
add_argument
(
'--output_path'
,
type
=
str
,
default
=
'denoising_result.png'
,
help
=
'output path for saving result.'
)
'--output_dir'
,
type
=
str
,
default
=
'denoising_result'
,
help
=
'output directory for saving result.'
)
self
.
arg_config_group
.
add_argument
(
'--visualization'
,
type
=
bool
,
default
=
False
,
help
=
'save results or not.'
)
def
add_module_input_arg
(
self
):
"""
...
...
modules/image/image_processing/seeinthedark/requirements.txt
浏览文件 @
da6b6b42
rawpy
pillow
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录