Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
PaddleClas
提交
932e0eac
P
PaddleClas
项目概览
PaddlePaddle
/
PaddleClas
接近 2 年 前同步成功
通知
116
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看板
提交
932e0eac
编写于
12月 23, 2021
作者:
W
weishengyu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
dbg
上级
b6a7c531
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
7 deletion
+11
-7
ppcls/utils/gallery2fc.py
ppcls/utils/gallery2fc.py
+11
-7
未找到文件。
ppcls/utils/gallery2fc.py
浏览文件 @
932e0eac
...
...
@@ -25,10 +25,11 @@ def build_gallery_layer(configs, feature_extractor):
delimiter
=
configs
[
"IndexProcess"
][
"delimiter"
]
gallery_images
=
[]
gallery_docs
=
[]
gallery_labels
=
[]
with
open
(
data_file
,
'r'
,
encoding
=
'utf-8'
)
as
f
:
lines
=
f
.
readlines
()
for
_
,
ori_line
in
enumerate
(
lines
)
:
for
ori_line
in
lines
:
line
=
ori_line
.
strip
().
split
(
delimiter
)
text_num
=
len
(
line
)
assert
text_num
>=
2
,
f
"line(
{
ori_line
}
) must be splitted into at least 2 parts, but got
{
text_num
}
"
...
...
@@ -36,6 +37,7 @@ def build_gallery_layer(configs, feature_extractor):
gallery_images
.
append
(
image_file
)
gallery_docs
.
append
(
ori_line
.
strip
())
gallery_labels
.
append
(
line
[
1
].
strip
())
batch_index
=
0
gallery_feature
=
paddle
.
zeros
((
len
(
gallery_images
),
embedding_size
))
for
i
,
image_path
in
enumerate
(
gallery_images
):
...
...
@@ -45,12 +47,13 @@ def build_gallery_layer(configs, feature_extractor):
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
)
batch_feature
=
feature_extractor
(
input_tensor
)
[
"features"
]
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
)
norm_feature
=
paddle
.
nn
.
functional
.
normalize
(
feature
,
axis
=
0
)
gallery_feature
[
i
-
batch_index
+
j
]
=
norm_feature
gallery_layer
=
paddle
.
nn
.
Linear
(
embedding_size
,
len
(
gallery_images
),
bias_attr
=
False
)
gallery_layer
.
set_state_dict
({
"weight"
:
gallery_feature
.
T
})
return
gallery_layer
...
...
@@ -71,11 +74,12 @@ class FuseModel(paddle.nn.Layer):
super
().
__init__
()
self
.
feature_extractor
=
build_model
(
configs
)
load_dygraph_pretrain
(
self
.
feature_extractor
,
configs
[
"Global"
][
"pretrained_model"
])
self
.
feature_extractor
.
eval
()
self
.
feature_extractor
.
head
=
IdentityHead
()
self
.
gallery_layer
=
build_gallery_layer
(
configs
,
self
.
feature_extractor
)
def
forward
(
self
,
x
):
x
=
self
.
feature_
model
(
x
)[
"features"
]
x
=
self
.
feature_
extractor
(
x
)[
"features"
]
x
=
paddle
.
nn
.
functional
.
normalize
(
x
)
x
=
self
.
gallery_layer
(
x
)
return
x
...
...
@@ -86,7 +90,7 @@ def main():
configs
=
parse_config
(
args
.
config
)
init_logger
(
name
=
'gallery2fc'
)
fuse_model
=
FuseModel
(
configs
)
save_fuse_model
(
fuse_model
)
#
save_fuse_model(fuse_model)
if
__name__
==
'__main__'
:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录