ViNLP is a system annotation for Vietnamese, it use pretrain Bert4news to fine-turning to NLP problems in Vietnamese components of wordsegmentation,Named entity recognition (NER) and achieve high accuracy.
New version of tookit use pretrained model NlpHUST/electra-base-vn with higher accuaracy and easier to use at NlpHUST/ner-vietnamese-electra-base and NlpHUST/vi-word-segmentation
git clone https://github.com/bino282/ViNLP.git
cd ViNLP
python setup.py develop build
or
pip install git+https://github.com/bino282/ViNLP.git
The model achieved F1 score : 0.984 on VLSP 2013 dataset
Model | F1 |
---|---|
BertVnTokenizer | 98.40 |
DongDu | 96.90 |
JvnSegmenter-Maxent | 97.00 |
JvnSegmenter-CRFs | 97.06 |
VnTokenizer | 97.33 |
UETSegmenter | 97.87 |
VnTokenizer | 97.33 |
VnCoreNLP (i.e. RDRsegmenter) | 97.90 |
from ViNLP import BertVnTokenizer
tokenizer = BertVnTokenizer()
sentences = tokenizer.split(["Tổng thống Donald Trump ký sắc lệnh cấm mọi giao dịch của Mỹ với ByteDance và Tecent - chủ sở hữu của 2 ứng dụng phổ biến TikTok và WeChat sau 45 ngày nữa."])
print(sentences[0])
Tổng_thống Donald_Trump ký sắc_lệnh cấm mọi giao_dịch của Mỹ với ByteDance và Tecent - chủ_sở_hữu của 2 ứng_dụng phổ_biến TikTok và WeChat sau 45 ngày nữa .
The model achieved F1 score VLSP 2018 for all named entities including nested entities : 0.786
Model | F1 |
---|---|
BertVnNer | 78.60 |
VNER Attentive Neural Network | 77.52 |
vietner CRF (ngrams + word shapes + cluster + w2v) | 76.63 |
ZA-NER BiLSTM | 74.70 |
from ViNLP import BertVnNer
bert_ner_model = BertVnNer()
sentence = "Theo SCMP, báo cáo của CSIS với tên gọi Định hình Tương lai Chính sách của Mỹ với Trung Quốc cũng cho thấy sự ủng hộ tương đối rộng rãi của các chuyên gia về việc cấm Huawei, tập đoàn viễn thông khổng lồ của Trung Quốc"
entities = bert_ner_model.annotate([sentence])
print(entities)
[{'ORGANIZATION': ['SCMP', 'CSIS', 'Huawei'], 'LOCATION': ['Mỹ', 'Trung Quốc']}]
For personal communication related to this project, please contact Nha Nguyen Van (nha282@gmail.com).