本项目模型基本是参考论文:http://www.aclweb.org/anthology/N16-1030
-
安装好bazel代码构建工具,clone下来tensorflow项目代码,配置好(./configure)
-
clone 本项目地址到tensorflow同级目录,切换到本项目代码目录,运行./configure
-
编译后台服务
bazel build //kcws/cc:seg_backend_api
python kcws/train/process_anno_file.py <语料目录> pre_chars_for_w2v.txt
bazel build third_party/word2vec:word2vec
先得到初步词表
./bazel-bin/third_party/word2vec/word2vec -train pre_chars_for_w2v.txt -save-vocab pre_vocab.txt -min-count 3
处理低频词 python kcws/train/replace_unk.py pre_vocab.txt pre_chars_for_w2v.txt chars_for_w2v.txt
训练word2vec
./bazel-bin/third_party/word2vec/word2vec -train chars_for_w2v.txt -output kcws/models/vec.txt -size 50 -sample 1e-4 -negative 5 -hs 1 -binary 0 -iter 5
构建训练语料工具
bazel build kcws/train:generate_training
生成语料
./bazel-bin/kcws/train/generate_training vec.txt <语料目录> all.txt
得到train.txt , test.txt文件
python kcws/train/filter_sentence.py all.txt
- 安装好tensorflow,切换到kcws代码目录,运行:
python kcws/train/train_cws_lstm.py --word2vec_path vec.txt --train_data_path <绝对路径到train.txt> --test_data_path test.txt --max_sentence_len 80 --learning_rate 0.001
- 生成vocab
bazel build kcws/cc:dump_vocab
./bazel-bin/kcws/cc/dump_vocab kcws/models/vec.txt vocab.txt
- 运行web service
./bazel-bin/kcws/cc/seg_backend_api --model_path=kcws/models/seg_model.pbtxt(绝对路径到seg_model.pbtxt>) --vocab_path=vocab.txt(<绝对路径到vocab.txt>) --max_sentence_len=80
目前支持自定义词典是在解码阶段,参考具体使用方式请参考kcws/cc/test_seg.cc 字典为文本格式,每一行格式如下:
<自定义词条>\t<权重>
比如:
蓝瘦香菇 4
权重为一个正整数,一般4以上,越大越重要
附: 使用相同模型训练的公司名识别demo: