Skip to content

Latest commit

 

History

History
114 lines (78 loc) · 1.7 KB

README.md

File metadata and controls

114 lines (78 loc) · 1.7 KB

FoolNLTK-train

FoolNLTK training process

1.train file

训练数据的格式和CRF++的训练数据一致,每一列用\t分隔,每一个句子用\n分隔

exmpale:

北	B	
京	E	
欢	B	
迎	E	
你	S	
cd train
vim main.sh

main.sh中指定以下参数

# train file
TRAIN_FILE=./datasets/demo/train.txt
# dev file
DEV_FILE=./datasets/demo/dev.txt
# test file
TEST_FILE=./datasets/demo/test.txt

# data out dir
DATA_OUT_DIR=./datasets/demo

# model save dir 
MODEL_OUT_DIR=./results/demo_seg/

# label tag column index
TAG_INDEX=1

# max length of sentlen
MAX_LENGTH=100

2.embeding

编译word2vec

cd third_paty && make

main.sh中指定 word2vec 路径

WORD2VEC=./third_party/word2vec/word2vec

默认使用word2vec 训练字向量

./main.sh vec

3.map file

这一步产生需要的映射文件

./main.sh map

4.tfrecord

为了处理好内存,先把训练数据转换成tfrecord格式

./mainsh data

5.train

./main.sh train

export model

训练好的模型导出成.pb文件,导出路径见 main.shMODEL_PATH 下面这个命令会导出最新的模型文件

./main.sh export

load model

训练好模型,现在可以直接调用

import fool

map_file = "./datasets/demo/maps.pkl"
checkpoint_ifle = "./results/demo_seg/modle.pb"

smodel = fool.load_model(map_file=map_file, model_file=checkpoint_ifle)
tags = smodel.predict(["北京欢迎你", "你在哪里"])
print(tags)

如果需要新增新的特征,要修改很多代码,请看懂后随意修改,没有东西是完全正确的当然也包括我的代码