स्टेमिंग और लेमेटेटाइजेशन

स्टेमिंग क्या है?

स्टेमिंग एक तकनीक है जिसका उपयोग शब्दों के आधार रूप को उनसे प्रत्यय हटाकर किया जाता है। यह वैसे ही है जैसे किसी पेड़ की शाखाओं को उसके तने से काटना। उदाहरण के लिए, शब्दों का तनाeating, eats, eaten है eat

खोज इंजन शब्दों को अनुक्रमित करने के लिए स्टेमिंग का उपयोग करते हैं। इसीलिए एक शब्द के सभी रूपों को संग्रहीत करने के बजाय, एक खोज इंजन केवल तनों को संग्रहीत कर सकता है। इस तरह, स्टेमिंग इंडेक्स के आकार को कम करता है और पुनर्प्राप्ति सटीकता को बढ़ाता है।

विभिन्न स्टेमिंग एल्गोरिदम

एनएलटीके में, stemmerI, जिन में हैं stem()पद्धति, इंटरफ़ेस में सभी स्टेमर्स हैं जिन्हें हम आगे कवर करने जा रहे हैं। इसे हम निम्नलिखित आरेख के साथ समझते हैं

पोर्टर स्टेमिंग एल्गोरिदम

यह सबसे आम स्टेमिंग एल्गोरिदम में से एक है जो मूल रूप से अंग्रेजी शब्दों के प्रसिद्ध प्रत्ययों को हटाने और बदलने के लिए डिज़ाइन किया गया है।

पोर्टरस्ट्रीमर वर्ग

एनएलटीके के पास है PorterStemmerवह वर्ग जिसकी सहायता से हम पोर्टर स्टेमर एल्गोरिदम को उस शब्द के लिए आसानी से लागू कर सकते हैं जिसे हम स्टेम करना चाहते हैं। यह वर्ग कई नियमित शब्द रूपों और प्रत्ययों को जानता है जिनकी मदद से यह इनपुट शब्द को अंतिम तने में बदल सकता है। परिणामी स्टेम अक्सर एक छोटा शब्द होता है जिसमें समान मूल अर्थ होता है। आइए एक उदाहरण देखें -

सबसे पहले, हमें प्राकृतिक भाषा टूलकिट (nltk) आयात करने की आवश्यकता है।

import nltk

अब, आयात करें PorterStemmer कुली स्टीमर एल्गोरिथ्म को लागू करने के लिए वर्ग।

from nltk.stem import PorterStemmer

इसके बाद, पोर्टर स्टीमर वर्ग का एक उदाहरण इस प्रकार बनाएं -

word_stemmer = PorterStemmer()

अब, उस शब्द को इनपुट करें जिसे आप स्टेम करना चाहते हैं।

word_stemmer.stem('writing')

उत्पादन

'write'
word_stemmer.stem('eating')

उत्पादन

'eat'

पूरा कार्यान्वयन उदाहरण

import nltk
from nltk.stem import PorterStemmer
word_stemmer = PorterStemmer()
word_stemmer.stem('writing')

उत्पादन

'write'

लैंकेस्टर स्टेमिंग एल्गोरिदम

इसे लैंकेस्टर यूनिवर्सिटी में विकसित किया गया था और यह एक और बहुत ही सामान्य स्टेमिंग एल्गोरिदम है।

लैंकेस्टरस्ट्रीमर वर्ग

एनएलटीके के पास है LancasterStemmerवह वर्ग जिसकी मदद से हम लैंकेस्टर स्टेमर एल्गोरिदम को आसानी से उस शब्द के लिए लागू कर सकते हैं जिसे हम स्टेम करना चाहते हैं। आइए एक उदाहरण देखें -

सबसे पहले, हमें प्राकृतिक भाषा टूलकिट (nltk) आयात करने की आवश्यकता है।

import nltk

अब, आयात करें LancasterStemmer लैंकेस्टर स्टीमर एल्गोरिथ्म को लागू करने के लिए वर्ग

from nltk.stem import LancasterStemmer

इसके बाद, एक उदाहरण बनाएं LancasterStemmer निम्नानुसार वर्ग -

Lanc_stemmer = LancasterStemmer()

अब, उस शब्द को इनपुट करें जिसे आप स्टेम करना चाहते हैं।

Lanc_stemmer.stem('eats')

उत्पादन

'eat'

पूरा कार्यान्वयन उदाहरण

import nltk
from nltk.stem import LancatserStemmer
Lanc_stemmer = LancasterStemmer()
Lanc_stemmer.stem('eats')

उत्पादन

'eat'

नियमित अभिव्यक्ति स्टेमिंग एल्गोरिथ्म

इस स्टेमिंग एल्गोरिदम की मदद से हम अपने स्वयं के स्टेमर का निर्माण कर सकते हैं।

RegexpStemmer वर्ग

एनएलटीके के पास है RegexpStemmerक्लास जिसकी मदद से हम रेगुलर एक्सप्रेशन स्टेमर एल्गोरिदम को आसानी से लागू कर सकते हैं। यह मूल रूप से एक एकल नियमित अभिव्यक्ति लेता है और अभिव्यक्ति से मेल खाने वाले किसी भी उपसर्ग या प्रत्यय को हटा देता है। आइए एक उदाहरण देखें -

सबसे पहले, हमें प्राकृतिक भाषा टूलकिट (nltk) आयात करने की आवश्यकता है।

import nltk

अब, आयात करें RegexpStemmer रेगुलर एक्सप्रेशन स्टीमर एल्गोरिदम को लागू करने के लिए क्लास।

from nltk.stem import RegexpStemmer

इसके बाद, एक उदाहरण बनाएं RegexpStemmer वर्ग और प्रत्यय या उपसर्ग प्रदान करता है जिसे आप शब्द से हटाना चाहते हैं -

Reg_stemmer = RegexpStemmer(‘ing’)

अब, उस शब्द को इनपुट करें जिसे आप स्टेम करना चाहते हैं।

Reg_stemmer.stem('eating')

उत्पादन

'eat'
Reg_stemmer.stem('ingeat')

उत्पादन

'eat'
Reg_stemmer.stem('eats')

उत्पादन

'eat'

पूरा कार्यान्वयन उदाहरण

import nltk
from nltk.stem import RegexpStemmer
Reg_stemmer = RegexpStemmer()
Reg_stemmer.stem('ingeat')

उत्पादन

'eat'

स्नोबॉल stemming एल्गोरिथ्म

यह एक और बहुत उपयोगी स्टेमिंग एल्गोरिदम है।

स्नोबॉलस्टेमर वर्ग

एनएलटीके के पास है SnowballStemmerवह वर्ग जिसकी सहायता से हम स्नोबॉल स्टेमर एल्गोरिदम को आसानी से लागू कर सकते हैं। यह 15 गैर-अंग्रेजी भाषाओं का समर्थन करता है। इस स्टीमिंग क्लास का उपयोग करने के लिए, हमें उस भाषा के नाम के साथ एक उदाहरण बनाने की आवश्यकता है जिसका हम उपयोग कर रहे हैं और फिर स्टेम () विधि को कॉल करें। आइए एक उदाहरण देखें -

सबसे पहले, हमें प्राकृतिक भाषा टूलकिट (nltk) आयात करने की आवश्यकता है।

import nltk

अब, आयात करें SnowballStemmer स्नोबॉल स्टीमर एल्गोरिथ्म को लागू करने के लिए वर्ग

from nltk.stem import SnowballStemmer

आइए देखें कि वह किन भाषाओं का समर्थन करती है -

SnowballStemmer.languages

उत्पादन

(
   'arabic',
   'danish',
   'dutch',
   'english',
   'finnish',
   'french',
   'german',
   'hungarian',
   'italian',
   'norwegian',
   'porter',
   'portuguese',
   'romanian',
   'russian',
   'spanish',
   'swedish'
)

इसके बाद, आप जिस भाषा का उपयोग करना चाहते हैं, उसके साथ स्नोबॉलस्टेमर क्लास का एक उदाहरण बनाएं। यहां, हम 'फ्रेंच' भाषा के लिए स्टेमर बना रहे हैं।

French_stemmer = SnowballStemmer(‘french’)

अब, स्टेम () विधि को कॉल करें और उस शब्द को इनपुट करें जिसे आप स्टेम करना चाहते हैं।

French_stemmer.stem (‘Bonjoura’)

उत्पादन

'bonjour'

पूरा कार्यान्वयन उदाहरण

import nltk
from nltk.stem import SnowballStemmer
French_stemmer = SnowballStemmer(‘french’)
French_stemmer.stem (‘Bonjoura’)

उत्पादन

'bonjour'

Lemmatization क्या है?

Lemmatization तकनीक स्टेमिंग की तरह है। लेमेट्रीकरण के बाद हमें जो आउटपुट मिलेगा, उसे 'लेम्मा' कहा जाता है, जो रूट स्टेम के बजाय एक रूट शब्द है, स्टेमिंग का आउटपुट। लेमेटेटाइजेशन के बाद, हमें एक वैध शब्द मिलेगा जिसका मतलब एक ही है।

एनएलटीके प्रदान करता है WordNetLemmatizer वर्ग जो चारों ओर एक पतली आवरण है wordnetकोष। यह वर्ग उपयोग करता हैmorphy() कार्य करने के लिए WordNet CorpusReaderलेम्मा खोजने के लिए कक्षा। आइए इसे एक उदाहरण से समझते हैं -

उदाहरण

सबसे पहले, हमें प्राकृतिक भाषा टूलकिट (nltk) आयात करने की आवश्यकता है।

import nltk

अब, आयात करें WordNetLemmatizer लेम्मेटाइजेशन तकनीक को लागू करने के लिए क्लास।

from nltk.stem import WordNetLemmatizer

इसके बाद, एक उदाहरण बनाएं WordNetLemmatizer कक्षा।

lemmatizer = WordNetLemmatizer()

अब, लेम्मेटाइज़ () विधि को कॉल करें और उस शब्द को इनपुट करें जिसे आप लेम्मा को ढूंढना चाहते हैं।

lemmatizer.lemmatize('eating')

उत्पादन

'eating'
lemmatizer.lemmatize('books')

उत्पादन

'book'

पूरा कार्यान्वयन उदाहरण

import nltk
from nltk.stem import WordNetLemmatizer
lemmatizer = WordNetLemmatizer()
lemmatizer.lemmatize('books')

उत्पादन

'book'

Stemming और Lemmatization के बीच अंतर

आइए हम निम्नलिखित उदाहरण की सहायता से स्टेमिंग और लेमेटेटाइजेशन के बीच के अंतर को समझते हैं -

import nltk
from nltk.stem import PorterStemmer
word_stemmer = PorterStemmer()
word_stemmer.stem('believes')

उत्पादन

believ
import nltk
from nltk.stem import WordNetLemmatizer
lemmatizer = WordNetLemmatizer()
lemmatizer.lemmatize(' believes ')

उत्पादन

believ

दोनों कार्यक्रमों का आउटपुट स्टेमिंग और लेमेटेटाइजेशन के बीच प्रमुख अंतर को बताता है। PorterStemmerवर्ग शब्द से 'तों' को काट देता है। दूसरी ओर,WordNetLemmatizerवर्ग एक वैध शब्द पाता है। सरल शब्दों में, स्टेमिंग तकनीक केवल शब्द के रूप को देखती है जबकि लेमेटेटाइजेशन तकनीक शब्द के अर्थ को देखती है। इसका मतलब है कि नींबू पानी लगाने के बाद, हमें हमेशा एक वैध शब्द मिलेगा।