Merge branch 'main' of https://huggingface.co/PhucDanh/Bartpho-fine-tuning-model-for-question-answering
Browse files- README.md +143 -1
- front_end.py +30 -0
README.md
CHANGED
@@ -2,9 +2,151 @@
|
|
2 |
license: mit
|
3 |
datasets:
|
4 |
- taidng/UIT-ViQuAD2.0
|
|
|
|
|
5 |
language:
|
6 |
- vi
|
7 |
pipeline_tag: question-answering
|
8 |
metrics:
|
9 |
- bleu
|
10 |
-
---
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2 |
license: mit
|
3 |
datasets:
|
4 |
- taidng/UIT-ViQuAD2.0
|
5 |
+
model:
|
6 |
+
- vinai/bartpho-syllable
|
7 |
language:
|
8 |
- vi
|
9 |
pipeline_tag: question-answering
|
10 |
metrics:
|
11 |
- bleu
|
12 |
+
---
|
13 |
+
# Model Card for Bartpho fine-tuned model for question answering task
|
14 |
+
|
15 |
+
Bartpho is a powerful language model that tackles Vietnamese text with impressive results. It comes in two versions, focusing on words or syllables, and excels at generative tasks like summarizing Vietnamese text.
|
16 |
+
The syllable version of Bartpho, specifically called BARTpho-syllable, takes a unique approach to processing Vietnamese text. Here's how it works:
|
17 |
+
- Syllable-based processing: Unlike traditional word-based models, BARTpho-syllable breaks down Vietnamese words into their individual syllables. This approach can be particularly beneficial for Vietnamese because syllables often hold more meaning than individual letters.
|
18 |
+
- Improved performance: By understanding the language at a syllable level, BARTpho-syllable can potentially capture the nuances of Vietnamese more effectively. This has been shown in tasks like text summarization, where BARTpho-syllable outperforms other strong models.
|
19 |
+
|
20 |
+
The Vietnamese language presents unique challenges for natural language processing (NLP) tasks due to its tonal nature and complex morphology. BARTpho, a pre-trained sequence-to-sequence model specifically designed for Vietnamese, offers a powerful solution for various NLP applications. This essay explores the potential of fine-tuning BARTpho for question answering (QA), a crucial component in building intelligent systems that can understand and respond to Vietnamese queries.
|
21 |
+
|
22 |
+
Traditional QA approaches often rely on word-based models, which can struggle with Vietnamese due to its agglutinative nature, where words are formed by combining smaller meaningful units. BARTpho, particularly the syllable-based version (BARTpho-syllable), offers a distinct advantage. By processing text at the syllable level, BARTpho-syllable can capture the finer nuances of Vietnamese, potentially leading to more accurate answer extraction.
|
23 |
+
|
24 |
+
# Dataset
|
25 |
+
The Vietnamese QA dataset, created by Nguyen et al. (2020), is known as UIT-ViQuAD and was introduced in their research paper. This dataset has also been used in a shared task.
|
26 |
+
### Original Version:
|
27 |
+
- Comprises over 23,000 question-answer (QA) pairs.
|
28 |
+
- Sourced from 174 Vietnamese Wikipedia articles.
|
29 |
+
### UIT-ViQuAD 2.0:
|
30 |
+
- Adds over 12,000 unanswerable questions to the same passages.
|
31 |
+
- Includes new fields: is_impossible and plausible_answer.
|
32 |
+
- These additions and modifications ensure that the dataset is more comprehensive by including both answerable and unanswerable questions.
|
33 |
+
- The dataset has been refined to eliminate a few duplicated questions and answers.
|
34 |
+
### Fields in UIT-ViQuAD 2.0:
|
35 |
+
- Context: The passage from which questions are derived.
|
36 |
+
- Question: The question to be answered based on the context.
|
37 |
+
- Answer: The correct answer extracted from the context for answerable questions.
|
38 |
+
- is_impossible: A boolean indicating if the question is unanswerable (True) or answerable (False).
|
39 |
+
- plausible_answer: For unanswerable questions, this provides a seemingly correct but actually incorrect answer extracted from the context.
|
40 |
+
|
41 |
+
# The term for hyperparameters used in the fine-tuning process
|
42 |
+
- epochs = 4
|
43 |
+
- batch_size = 16
|
44 |
+
- learning rate = 2e-5
|
45 |
+
- evaluation strategy = "steps"
|
46 |
+
- save_total_limit = 1
|
47 |
+
- save_steps = 2000
|
48 |
+
- eval_steps = 2000
|
49 |
+
- gradient_accumulation_steps = 2
|
50 |
+
- eval_accumulation_steps = 2
|
51 |
+
- load_best_model_at_end = True
|
52 |
+
|
53 |
+
# Best result
|
54 |
+
- epoch = 3250207813798838
|
55 |
+
- grad_norm = 136582374572754
|
56 |
+
- learning_rate = 3.3610648918469217e-06
|
57 |
+
- loss = 0.9397
|
58 |
+
- step = 2000
|
59 |
+
- eval_loss = 0.7907648682594299
|
60 |
+
|
61 |
+
# Inference
|
62 |
+
## Using a pipeline as a high-level helper
|
63 |
+
```py
|
64 |
+
from transformers import pipeline
|
65 |
+
|
66 |
+
context="""
|
67 |
+
Trường Đại học Công nghệ Thông tin (ĐH CNTT), Đại học Quốc gia Thành phố Hồ Chí Minh (ĐHQG-HCM) là trường đại học công lập đào tạo về công nghệ thông tin và truyền thông (CNTT&TT) được thành lập theo quyết định số 134/2006/QĐ-TTg ngày 08/06/2006 của Thủ tướng Chính phủ. Là trường thành viên của ĐHQG-HCM, trường ĐH CNTT có nhiệm vụ đào tạo nguồn nhân lực công nghệ thông tin chất lượng cao, góp phần tích cực vào sự phát triển của nền công nghiệp công nghệ thông tin Việt Nam, đồng thời tiến hành nghiên cứu khoa học và chuyển giao công nghệ thông tin tiên tiến, đặc biệt là hướng vào các ứng dụng nhằm góp phần đẩy mạnh sự nghiệp công nghiệp hóa, hiện đại hóa đất nước.
|
68 |
+
Sau hơn 10 năm xây dựng và phát triển, hiện trường ĐH CNTT sở hữu cơ sở vật chất gồm khu học tập, nghiên cứu và làm việc được đầu tư xây dựng khang trang, hiện đại với tổng diện tích trên 14 hecta trong khuôn viên khu đô thị ĐHQG-HCM.
|
69 |
+
"""
|
70 |
+
question="""
|
71 |
+
Trường UIT mang trong mình nhiệm vụ gì?
|
72 |
+
"""
|
73 |
+
|
74 |
+
pipe = pipeline("question-answering", model="PhucDanh/Bartpho-fine-tuning-model-for-question-answering")
|
75 |
+
pipe(question=question, context=context)
|
76 |
+
```
|
77 |
+
|
78 |
+
## Load model directly
|
79 |
+
```py
|
80 |
+
from transformers import AutoTokenizer
|
81 |
+
from transformers import AutoModelForQuestionAnswering
|
82 |
+
import torch
|
83 |
+
|
84 |
+
context="""
|
85 |
+
Trường Đại học Công nghệ Thông tin (ĐH CNTT), Đại học Quốc gia Thành phố Hồ Chí Minh (ĐHQG-HCM) là trường đại học công lập đào tạo về công nghệ thông tin và truyền thông (CNTT&TT) được thành lập theo quyết định số 134/2006/QĐ-TTg ngày 08/06/2006 của Thủ tướng Chính phủ. Là trường thành viên của ĐHQG-HCM, trường ĐH CNTT có nhiệm vụ đào tạo nguồn nhân lực công nghệ thông tin chất lượng cao, góp phần tích cực vào sự phát triển của nền công nghiệp công nghệ thông tin Việt Nam, đồng thời tiến hành nghiên cứu khoa học và chuyển giao công nghệ thông tin tiên tiến, đặc biệt là hướng vào các ứng dụng nhằm góp phần đẩy mạnh sự nghiệp công nghiệp hóa, hiện đại hóa đất nước.
|
86 |
+
Sau hơn 10 năm xây dựng và phát triển, hiện trường ĐH CNTT sở hữu cơ sở vật chất gồm khu học tập, nghiên cứu và làm việc được đầu tư xây dựng khang trang, hiện đại với tổng diện tích trên 14 hecta trong khuôn viên khu đô thị ĐHQG-HCM.
|
87 |
+
"""
|
88 |
+
question="""
|
89 |
+
Trường UIT mang trong mình nhiệm vụ gì?
|
90 |
+
"""
|
91 |
+
|
92 |
+
tokenizer = AutoTokenizer.from_pretrained("PhucDanh/Bartpho-fine-tuning-model-for-question-answering")
|
93 |
+
tokenizer.model_input_names.remove("token_type_ids")
|
94 |
+
|
95 |
+
inputs = tokenizer(question, context, return_tensors="pt")
|
96 |
+
|
97 |
+
model = AutoModelForQuestionAnswering.from_pretrained("PhucDanh/Bartpho-fine-tuning-model-for-question-answering")
|
98 |
+
with torch.no_grad():
|
99 |
+
outputs = model(**inputs)
|
100 |
+
|
101 |
+
answer_start_index = outputs.start_logits.argmax()
|
102 |
+
answer_end_index = outputs.end_logits.argmax()
|
103 |
+
|
104 |
+
predict_answer_tokens = inputs.input_ids[0, answer_start_index : answer_end_index + 1]
|
105 |
+
print(tokenizer.decode(predict_answer_tokens))
|
106 |
+
```
|
107 |
+
|
108 |
+
# Inference API
|
109 |
+
Contact for API token authentication
|
110 |
+
```py
|
111 |
+
import requests
|
112 |
+
|
113 |
+
API_URL = "https://api-inference.huggingface.co/models/PhucDanh/Bartpho-fine-tuning-model-for-question-answering"
|
114 |
+
headers = {"Authorization": "Bearer hf_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"}
|
115 |
+
|
116 |
+
def query(payload):
|
117 |
+
response = requests.post(API_URL, headers=headers, json=payload)
|
118 |
+
return response.json()
|
119 |
+
|
120 |
+
output = query({
|
121 |
+
"inputs": {
|
122 |
+
"question": "What is my name?",
|
123 |
+
"context": "My name is Clara and I live in Berkeley."
|
124 |
+
},
|
125 |
+
})
|
126 |
+
```
|
127 |
+
|
128 |
+
# Reference
|
129 |
+
## Model:
|
130 |
+
```
|
131 |
+
@article{tran2021bartpho,
|
132 |
+
title={BartPho: pre-trained sequence-to-sequence models for Vietnamese},
|
133 |
+
author={Tran, Nguyen Luong and Le, Duong Minh and Nguyen, Dat Quoc},
|
134 |
+
journal={arXiv preprint arXiv:2109.09701},
|
135 |
+
year={2021}
|
136 |
+
}
|
137 |
+
```
|
138 |
+
## Dataset:
|
139 |
+
```
|
140 |
+
@article{Nguyen_2022,
|
141 |
+
title={VLSP 2021-ViMRC Challenge: Vietnamese Machine Reading Comprehension},
|
142 |
+
volume={38},
|
143 |
+
ISSN={2615-9260},
|
144 |
+
url={http://dx.doi.org/10.25073/2588-1086/vnucsce.340},
|
145 |
+
DOI={10.25073/2588-1086/vnucsce.340},
|
146 |
+
number={2},
|
147 |
+
journal={VNU Journal of Science: Computer Science and Communication Engineering},
|
148 |
+
publisher={Vietnam National University Journal of Science},
|
149 |
+
author={Nguyen, Kiet and Tran, Son Quoc and Nguyen, Luan Thanh and Huynh, Tin Van and Luu, Son Thanh and Nguyen, Ngan Luu-Thuy},
|
150 |
+
year={2022},
|
151 |
+
month=dec}
|
152 |
+
```
|
front_end.py
ADDED
@@ -0,0 +1,30 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import uvicorn
|
2 |
+
from fastapi import FastAPI, Request
|
3 |
+
from fastapi.staticfiles import StaticFiles
|
4 |
+
from fastapi.templating import Jinja2Templates
|
5 |
+
from fastapi.responses import HTMLResponse
|
6 |
+
from fastapi.middleware.cors import CORSMiddleware
|
7 |
+
|
8 |
+
app = FastAPI()
|
9 |
+
|
10 |
+
app.add_middleware(
|
11 |
+
CORSMiddleware,
|
12 |
+
# Replace ["*"] with the appropriate list of allowed origins
|
13 |
+
allow_origins=["*"],
|
14 |
+
allow_credentials=True,
|
15 |
+
allow_methods=["*"],
|
16 |
+
allow_headers=["*"],
|
17 |
+
)
|
18 |
+
|
19 |
+
app.mount("/static", StaticFiles(directory="static", html=True), name="static")
|
20 |
+
templates = Jinja2Templates(directory="static")
|
21 |
+
|
22 |
+
@app.get("/{path_name:path}", response_class=HTMLResponse, tags=["Frontend"])
|
23 |
+
async def catch_all(request: Request, path_name: str):
|
24 |
+
return templates.TemplateResponse("index.html", {"request": request})
|
25 |
+
|
26 |
+
if __name__ == "__main__":
|
27 |
+
# uvicorn.run("front_end:app", host="0.0.0.0", port=443, reload=False)
|
28 |
+
uvicorn.run("front_end:app", host="0.0.0.0", port=443, reload=False,
|
29 |
+
ssl_keyfile="ssl/private.pem",
|
30 |
+
ssl_certfile="ssl/certificate.crt")
|