Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleClas
提交
b6a7c531
P
PaddleClas
项目概览
PaddlePaddle
/
PaddleClas
大约 2 年 前同步成功
通知
118
Star
4999
Fork
1114
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
19
列表
看板
标记
里程碑
合并请求
6
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
PaddleClas
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
19
Issue
19
列表
看板
标记
里程碑
合并请求
6
合并请求
6
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
b6a7c531
编写于
12月 15, 2021
作者:
W
weishengyu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add feature extract
上级
c9411445
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
33 addition
and
11 deletion
+33
-11
ppcls/utils/gallery2fc.py
ppcls/utils/gallery2fc.py
+33
-11
未找到文件。
ppcls/utils/gallery2fc.py
浏览文件 @
b6a7c531
import
os
import
paddle
import
cv2
from
ppcls.arch
import
build_model
from
ppcls.arch.gears.identity_head
import
IdentityHead
...
...
@@ -9,8 +10,8 @@ from ppcls.utils.logger import init_logger
from
ppcls.data
import
transform
,
create_operators
def
build_gallery_
feature
(
configs
,
feature_extractor
):
transform_configs
=
configs
[
"In
fer"
][
"transform
s"
]
def
build_gallery_
layer
(
configs
,
feature_extractor
):
transform_configs
=
configs
[
"In
dexProcess"
][
"transform_op
s"
]
preprocess_ops
=
create_operators
(
transform_configs
)
embedding_size
=
configs
[
"Arch"
][
"Head"
][
"embedding_size"
]
...
...
@@ -35,13 +36,34 @@ def build_gallery_feature(configs, feature_extractor):
gallery_images
.
append
(
image_file
)
gallery_docs
.
append
(
ori_line
.
strip
())
def
save_fuse_model
(
fuse_model
):
pass
batch_index
=
0
gallery_feature
=
paddle
.
zeros
((
len
(
gallery_images
),
embedding_size
))
for
i
,
image_path
in
enumerate
(
gallery_images
):
image
=
cv2
.
imread
(
image_path
)
for
op
in
preprocess_ops
:
image
=
op
(
image
)
input_tensor
[
batch_index
]
=
image
batch_index
+=
1
if
batch_index
==
batch_size
or
i
==
len
(
gallery_images
)
-
1
:
batch_feature
=
feature_extractor
(
input_tensor
)
for
j
in
range
(
batch_index
):
feature
=
batch_feature
[
j
]
norm_feature
=
paddle
.
nn
.
functional
.
normalize
(
feature
)
gallery_feature
[
i
+
batch_index
-
j
]
=
norm_feature
gallery_layer
=
paddle
.
nn
.
Linear
(
embedding_size
,
len
(
gallery_images
),
weight_attr
=
gallery_feature
,
bias_attr
=
False
)
return
gallery_layer
def
export_fuse_model
(
model
,
config
):
model
.
eval
()
model
.
quanter
.
save_quantized_model
(
model
.
base_model
,
save_path
,
input_spec
=
[
paddle
.
static
.
InputSpec
(
shape
=
[
None
]
+
config
[
"Global"
][
"image_shape"
],
dtype
=
'float32'
)
])
class
FuseModel
(
paddle
.
nn
.
Layer
):
...
...
@@ -50,11 +72,11 @@ class FuseModel(paddle.nn.Layer):
self
.
feature_extractor
=
build_model
(
configs
)
load_dygraph_pretrain
(
self
.
feature_extractor
,
configs
[
"Global"
][
"pretrained_model"
])
self
.
feature_extractor
.
head
=
IdentityHead
()
self
.
gallery_layer
=
build_gallery_
feature
(
configs
,
self
.
feature_extractor
)
self
.
gallery_layer
=
build_gallery_
layer
(
configs
,
self
.
feature_extractor
)
def
forward
(
self
,
x
):
x
=
self
.
feature_model
(
x
)[
"features"
]
x
=
paddle
.
n
orm
(
x
)
x
=
paddle
.
n
n
.
functional
.
normalize
(
x
)
x
=
self
.
gallery_layer
(
x
)
return
x
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录