प्राकृतिक भाषा टूलकिट - टैगर्स का संयोजन
टैग करने वालों को मिलाना
टैगर्स या एक दूसरे के साथ टैगर्स को जोड़ना एनएलटीके की महत्वपूर्ण विशेषताओं में से एक है। टैगर्स के संयोजन के पीछे मुख्य अवधारणा यह है कि यदि कोई टैगर किसी शब्द को टैग करने का तरीका नहीं जानता है, तो उसे जंजीर टैग करने वाले के पास भेज दिया जाएगा। इस उद्देश्य को प्राप्त करने के लिए,SequentialBackoffTagger हमें प्रदान करता है Backoff tagging सुविधा।
बैकऑफ टैगिंग
जैसा कि पहले बताया गया था, बैकऑफ़ टैगिंग महत्वपूर्ण विशेषताओं में से एक है SequentialBackoffTagger, जो हमें टैगर्स को इस तरह से संयोजित करने की अनुमति देता है कि यदि एक टैगर को किसी शब्द को टैग करने का तरीका नहीं पता है, तो शब्द अगले टैगर को पारित किया जाएगा और इसलिए जब तक कि कोई बैकऑफ़ टैगर्स जांचने के लिए शेष न हों।
यह कैसे काम करता है?
दरअसल, हर उपवर्ग SequentialBackoffTagger'बैकऑफ़' कीवर्ड तर्क ले सकता है। इस खोजशब्द तर्क का मूल्य एक और उदाहरण हैSequentialBackoffTagger। अब जब भी ऐसा होSequentialBackoffTaggerक्लास को इनिशियलाइज़ किया गया है, बैकऑफ़ टैगर्स की आंतरिक सूची (पहले तत्व के रूप में) बनाई जाएगी। इसके अलावा, अगर एक बैकऑफ़ टैगर दिया जाता है, तो इस बैकऑफ़ टैगर्स की आंतरिक सूची को जोड़ दिया जाएगा।
नीचे दिए गए उदाहरण में, हम ले रहे हैं DefaulTagger उपरोक्त पायथन नुस्खा में बैकऑफ़ टैगर के रूप में जिसके साथ हमने प्रशिक्षण लिया है UnigramTagger।
उदाहरण
इस उदाहरण में, हम उपयोग कर रहे हैं DefaulTaggerबैकऑफ टैगर के रूप में। जब भीUnigramTagger एक शब्द टैग करने में असमर्थ है, बैकऑफ़ टैगर, यानी DefaulTagger, हमारे मामले में, इसे 'एनएन' के साथ टैग करेगा।
from nltk.tag import UnigramTagger
from nltk.tag import DefaultTagger
from nltk.corpus import treebank
train_sentences = treebank.tagged_sents()[:2500]
back_tagger = DefaultTagger('NN')
Uni_tagger = UnigramTagger(train_sentences, backoff = back_tagger)
test_sentences = treebank.tagged_sents()[1500:]
Uni_tagger.evaluate(test_sentences)
उत्पादन
0.9061975746536931
उपरोक्त आउटपुट से, आप देख सकते हैं कि बैकऑफ़ टैगर को जोड़कर सटीकता में लगभग 2% की वृद्धि हुई है।
अचार के साथ टैगिंग सेविंग
जैसा कि हमने देखा है कि एक टैगर को प्रशिक्षित करना बहुत ही बोझिल होता है और इसमें समय भी लगता है। समय बचाने के लिए, हम बाद में इसका उपयोग करने के लिए एक प्रशिक्षित टैगर को चुन सकते हैं। नीचे दिए गए उदाहरण में, हम अपने पहले से ही प्रशिक्षित टैगर के नाम पर ऐसा करने जा रहे हैं‘Uni_tagger’।
उदाहरण
import pickle
f = open('Uni_tagger.pickle','wb')
pickle.dump(Uni_tagger, f)
f.close()
f = open('Uni_tagger.pickle','rb')
Uni_tagger = pickle.load(f)
NgramTagger वर्ग
पिछली इकाई में चर्चा की गई पदानुक्रम आरेख से, UnigramTagger से विरासत में मिला है NgarmTagger वर्ग लेकिन हमारे पास दो और उपवर्ग हैं NgarmTagger वर्ग -
बिग्रामटैगर उपवर्ग
वास्तव में एक एनग्राम एन आइटमों का एक क्रम है, इसलिए, जैसा कि नाम से ही स्पष्ट है, BigramTaggerउपवर्ग दो वस्तुओं को देखता है। पहला आइटम पिछला टैग किया गया शब्द है और दूसरा आइटम वर्तमान टैग किया हुआ शब्द है।
ट्रिग्रामटैगर उपवर्ग
के एक ही नोट पर BigramTagger, TrigramTagger उपवर्ग तीन वस्तुओं को देखता है अर्थात दो पिछले टैग किए गए शब्द और एक वर्तमान टैग किया हुआ शब्द।
व्यावहारिक रूप से अगर हम लागू होते हैं BigramTagger तथा TrigramTaggerउपवर्ग व्यक्तिगत रूप से जैसा कि हमने UnigramTagger उपवर्ग के साथ किया था, वे दोनों बहुत खराब प्रदर्शन करते हैं। हमें नीचे दिए गए उदाहरणों में देखते हैं:
BigramTagger उपवर्ग का उपयोग करना
from nltk.tag import BigramTagger
from nltk.corpus import treebank
train_sentences = treebank.tagged_sents()[:2500]
Bi_tagger = BigramTagger(train_sentences)
test_sentences = treebank.tagged_sents()[1500:]
Bi_tagger.evaluate(test_sentences)
उत्पादन
0.44669191071913594
TrigramTagger उपवर्ग का उपयोग करना
from nltk.tag import TrigramTagger
from nltk.corpus import treebank
train_sentences = treebank.tagged_sents()[:2500]
Tri_tagger = TrigramTagger(train_sentences)
test_sentences = treebank.tagged_sents()[1500:]
Tri_tagger.evaluate(test_sentences)
उत्पादन
0.41949863394526193
आप UnigramTagger के प्रदर्शन की तुलना कर सकते हैं, हमने BigramTagger (लगभग 44% सटीकता के साथ) और TrigramTagger (लगभग 41% सटीकता प्रदान की) के साथ पहले (लगभग 89% सटीकता के साथ) का उपयोग किया था। इसका कारण यह है कि बिग्राम और ट्रिग्राम टैग एक वाक्य में पहले शब्द (ओं) से संदर्भ नहीं सीख सकते हैं। दूसरी ओर, UnigramTagger वर्ग पिछले संदर्भ के बारे में परवाह नहीं करता है और प्रत्येक शब्द के लिए सबसे सामान्य टैग का अनुमान लगाता है, इसलिए उच्च आधारभूत सटीकता के लिए सक्षम है।
Ngram टैगर्स का संयोजन
उपरोक्त उदाहरणों से, यह स्पष्ट है कि जब हम बैकऑफ टैगिंग के साथ संयोजन करते हैं तो बिग्राम और ट्रिग्राम टैगर्स योगदान कर सकते हैं। नीचे दिए गए उदाहरण में, हम Unigram, Bigram और Trigram टैगर्स को बैकऑफ़ टैगिंग के साथ जोड़ रहे हैं। बैकग्राउंड टैगर के साथ UnigramTagger को मिलाते हुए अवधारणा पिछले नुस्खा के समान है। अंतर केवल इतना है कि हम बैकऑफ़ ऑपरेशन के लिए, नीचे दिए गए tagger_util.py से backoff_tagger () नाम के फ़ंक्शन का उपयोग कर रहे हैं।
def backoff_tagger(train_sentences, tagger_classes, backoff=None):
for cls in tagger_classes:
backoff = cls(train_sentences, backoff=backoff)
return backoff
उदाहरण
from tagger_util import backoff_tagger
from nltk.tag import UnigramTagger
from nltk.tag import BigramTagger
from nltk.tag import TrigramTagger
from nltk.tag import DefaultTagger
from nltk.corpus import treebank
train_sentences = treebank.tagged_sents()[:2500]
back_tagger = DefaultTagger('NN')
Combine_tagger = backoff_tagger(train_sentences,
[UnigramTagger, BigramTagger, TrigramTagger], backoff = back_tagger)
test_sentences = treebank.tagged_sents()[1500:]
Combine_tagger.evaluate(test_sentences)
उत्पादन
0.9234530029238365
उपरोक्त आउटपुट से, हम देख सकते हैं कि यह सटीकता में लगभग 3% की वृद्धि करता है।