Hotel review multi-aspect sentiment classification using T5
We fine tune a T5 pretrained model to generate multi-aspect sentiment classes. The outputs are whole sentiment, aspect, and aspect+sentiment.
T5情緒面向分類多任務,依據中文簡體孟子T5預訓練模型微調,訓練資料集只有3萬筆,做NLP研究與課程的範例模型用途。
如何測試
在右側測試區輸入不同的任務文字
範例1:
面向::早餐可以吃的饱,但是东西没了,不一定会补
範例2:
面向情绪::房间空调系统有烟味,可考虑做调整
範例3:
整体情绪::位置离逢甲很近
資料集: 資料集蒐集自線上訂房網站的顧客留言10050筆,整理成3項任務,總筆數變成為3倍,共有30150筆(資料由本實驗室成員YYChang蒐集)。
輸入與輸出格式:有三個種類任務分別為:
'整体情绪::' '面向::', '面向情绪::'
舉例如下:
整体情绪::因为防疫期间早餐要在房内用餐,但房内电视下的平台有点窄,有点不方便,负面情绪
整体情绪::只是隔音有点不好,负面情绪
整体情绪::订的是豪华家庭房,空间还算大,正面情绪
整体情绪::床大,正面情绪
面向::房间有奇怪的味道,"整洁舒适面向,设施面向"
面向::干净、舒适、亲切,价钱好~,"整洁舒适面向,性价比面向"
面向::位置便利,可以在附近悠闲散步,至市区也不远,又临近大海,住得十分舒服。,"整洁舒适面向,地点面向"
面向情绪::反应无效,服务面向的负面情绪
面向情绪::床其实还蛮好睡,枕头床被还算干净,至少不会让皮肤痒。离火车站市场闹区近。,"整洁舒适面向的正面情绪,设施面向的正面情绪,地点面向的正面情绪"
面向情绪::设备真的太旧了,灯光太暗了。,设施面向的负面情绪
面向情绪::住四天,没人打扫清洁,第一天有盥洗用品,其余就没补充,热水供应不正常,交通尚可。,"整洁舒适面向的负面情绪,设施面向的负面情绪,地点面向的正面情绪"
面向情绪::饭店太过老旧,房内桌子衣橱近乎溃烂,浴室有用过未清的毛巾,排水孔有近半垃圾未清,马桶肮脏,未提供浴巾,莲蓬头只能手持无法挂著墙上使用,空调无法控制,壁纸剥落,走道昏暗,近车站。,"整洁舒适面向的负面情绪,设施面向的负面情绪,地点面向的正面情绪"
預訓練模型: 目前初步先使用"Langboat/mengzi-t5-base"簡體中文預訓練模型加以微調。 由"Langboat/mengzi-t5-base"官網資訊得知是由簡體中文語料所訓練,因此我們將繁體中文留言先轉成簡體中文,再進行微調訓練。
訓練平台: 使用Google colab Tesla T4 GPU進行了3 epochs訓練,費時55分鐘,val_loss約為0.0315,初步實驗,仍有很大的改善空間。
未來改善工作:下一階段會進行數據增強(由於蒐集的語料是不平衡),以及使用Google的mt5繁體簡體中文預訓練模型加以微調,微調語料就可直接使用繁體中文。
使用範例:(輸入繁體中文需先將文字轉為簡體中文,再丟給模型產出輸出文字)
載入模型(使用的是simplet5套件)
#pip install simplet5
from simplet5 import SimpleT5
model = SimpleT5()
model.load_model("t5","clhuang/t5-hotel-review-sentiment", use_gpu=False)
整體情緒分類任務
text="整体情绪::位置离逢甲很近"
model.predict(text)
#['正面情绪']
面向分類任務
text="面向::早餐可以吃的饱,但是东西没了,不一定会补"
model.predict(text)
#['服务面向']
面向分類+情绪分類任務
text='面向情绪::房间空调系统有烟味,可考虑做调整'
model.predict(text)
#['设施面向的负面情绪']
輸入輸出改成是繁(正)體中文,輸出三項分類任務資訊
from opencc import OpenCC
t2s = OpenCC('t2s') # convert from Traditional Chinese to Simplified Chinese
s2t = OpenCC('s2t') # convert from Simplified Chinese to Traditional Chinese
class_types = ['整体情绪::','面向::','面向情绪::']
def predict(text):
text = t2s.convert(text)
response=[]
for prefix in class_types:
response.append(s2t.convert(model.predict(prefix+text)[0]))
return response
text='位置近市區,人員親切,食物好吃'
predict(text)
#['正面情緒', '服務面向,地點面向', '服務面向的正面情緒,地點面向的正面情緒']