Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
c91b7906
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c91b7906
编写于
12月 14, 2016
作者:
Q
qiaolongfei
提交者:
Yu Yang
12月 16, 2016
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
add python api_predict for quick start
上级
638cf8d4
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
178 addition
and
0 deletion
+178
-0
demo/quick_start/api_predict.py
demo/quick_start/api_predict.py
+148
-0
demo/quick_start/api_predict.sh
demo/quick_start/api_predict.sh
+30
-0
未找到文件。
demo/quick_start/api_predict.py
0 → 100755
浏览文件 @
c91b7906
# Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
import
os
,
sys
import
numpy
as
np
from
optparse
import
OptionParser
from
py_paddle
import
swig_paddle
,
DataProviderConverter
from
paddle.trainer.PyDataProvider2
import
sparse_binary_vector
from
paddle.trainer.config_parser
import
parse_config
"""
Usage: run following command to show help message.
python api_predict.py -h
"""
class
QuickStartPrediction
():
def
__init__
(
self
,
train_conf
,
dict_file
,
model_dir
=
None
,
label_file
=
None
):
"""
train_conf: trainer configure.
dict_file: word dictionary file name.
model_dir: directory of model.
"""
self
.
train_conf
=
train_conf
self
.
dict_file
=
dict_file
self
.
word_dict
=
{}
self
.
dict_dim
=
self
.
load_dict
()
self
.
model_dir
=
model_dir
if
model_dir
is
None
:
self
.
model_dir
=
os
.
path
.
dirname
(
train_conf
)
self
.
label
=
None
if
label_file
is
not
None
:
self
.
load_label
(
label_file
)
conf
=
parse_config
(
train_conf
,
"is_predict=1"
)
self
.
network
=
swig_paddle
.
GradientMachine
.
createFromConfigProto
(
conf
.
model_config
)
self
.
network
.
loadParameters
(
self
.
model_dir
)
input_types
=
[
sparse_binary_vector
(
self
.
dict_dim
)]
self
.
converter
=
DataProviderConverter
(
input_types
)
def
load_dict
(
self
):
"""
Load dictionary from self.dict_file.
"""
for
line_count
,
line
in
enumerate
(
open
(
self
.
dict_file
,
'r'
)):
self
.
word_dict
[
line
.
strip
().
split
(
'
\t
'
)[
0
]]
=
line_count
return
len
(
self
.
word_dict
)
def
load_label
(
self
,
label_file
):
"""
Load label.
"""
self
.
label
=
{}
for
v
in
open
(
label_file
,
'r'
):
self
.
label
[
int
(
v
.
split
(
'
\t
'
)[
1
])]
=
v
.
split
(
'
\t
'
)[
0
]
def
get_index
(
self
,
data
):
"""
transform word into integer index according to the dictionary.
"""
words
=
data
.
strip
().
split
()
word_slot
=
[
self
.
word_dict
[
w
]
for
w
in
words
if
w
in
self
.
word_dict
]
return
word_slot
def
batch_predict
(
self
,
data_batch
):
input
=
self
.
converter
(
data_batch
)
output
=
self
.
network
.
forwardTest
(
input
)
prob
=
output
[
0
][
"id"
].
tolist
()
print
(
"predicting labels is:"
)
print
prob
def
option_parser
():
usage
=
"python predict.py -n config -w model_dir -d dictionary -i input_file "
parser
=
OptionParser
(
usage
=
"usage: %s [options]"
%
usage
)
parser
.
add_option
(
"-n"
,
"--tconf"
,
action
=
"store"
,
dest
=
"train_conf"
,
help
=
"network config"
)
parser
.
add_option
(
"-d"
,
"--dict"
,
action
=
"store"
,
dest
=
"dict_file"
,
help
=
"dictionary file"
)
parser
.
add_option
(
"-b"
,
"--label"
,
action
=
"store"
,
dest
=
"label"
,
default
=
None
,
help
=
"dictionary file"
)
parser
.
add_option
(
"-c"
,
"--batch_size"
,
type
=
"int"
,
action
=
"store"
,
dest
=
"batch_size"
,
default
=
1
,
help
=
"the batch size for prediction"
)
parser
.
add_option
(
"-w"
,
"--model"
,
action
=
"store"
,
dest
=
"model_path"
,
default
=
None
,
help
=
"model path"
)
return
parser
.
parse_args
()
def
main
():
options
,
args
=
option_parser
()
train_conf
=
options
.
train_conf
batch_size
=
options
.
batch_size
dict_file
=
options
.
dict_file
model_path
=
options
.
model_path
label
=
options
.
label
swig_paddle
.
initPaddle
(
"--use_gpu=0"
)
predict
=
QuickStartPrediction
(
train_conf
,
dict_file
,
model_path
,
label
)
batch
=
[]
labels
=
[]
for
line
in
sys
.
stdin
:
[
label
,
text
]
=
line
.
split
(
"
\t
"
)
labels
.
append
(
int
(
label
))
batch
.
append
([
predict
.
get_index
(
text
)])
print
(
"lables is:"
)
print
labels
predict
.
batch_predict
(
batch
)
if
__name__
==
'__main__'
:
main
()
demo/quick_start/api_predict.sh
0 → 100644
浏览文件 @
c91b7906
#!/bin/bash
# Copyright (c) 2016 PaddlePaddle Authors. All Rights Reserved
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
set
-e
#Note the default model is pass-00002, you shold make sure the model path
#exists or change the mode path.
#only test on trainer_config.lr.py
model
=
output/pass-00001/
config
=
trainer_config.lr.py
label
=
data/labels.list
dict
=
data/dict.txt
batch_size
=
20
head
-n
$batch_size
data/test.txt | python api_predict.py
\
--tconf
=
$config
\
--model
=
$model
\
--label
=
$label
\
--dict
=
$dict
\
--batch_size
=
$batch_size
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录