Python을 사용한 AI – NLTK 패키지

이 장에서는 Natural Language Toolkit 패키지를 시작하는 방법을 배웁니다.

전제 조건

자연어 처리를 사용하여 애플리케이션을 빌드하려는 경우 컨텍스트의 변경으로 인해 가장 어렵습니다. 문맥 요인은 기계가 특정 문장을 이해하는 방법에 영향을줍니다. 따라서 기계가 인간이 컨텍스트를 이해할 수있는 방식을 이해할 수 있도록 기계 학습 방식을 사용하여 자연어 응용 프로그램을 개발해야합니다.

이러한 애플리케이션을 구축하기 위해 NLTK (Natural Language Toolkit Package)라는 Python 패키지를 사용합니다.

NLTK 가져 오기

사용하기 전에 NLTK를 설치해야합니다. 다음 명령을 사용하여 설치할 수 있습니다.

pip install nltk

NLTK 용 conda 패키지를 빌드하려면 다음 명령을 사용하십시오.

conda install -c anaconda nltk

이제 NLTK 패키지를 설치 한 후 파이썬 명령 프롬프트를 통해 가져와야합니다. Python 명령 프롬프트에서 다음 명령을 작성하여 가져올 수 있습니다.

>>> import nltk

NLTK의 데이터 다운로드

이제 NLTK를 가져온 후 필요한 데이터를 다운로드해야합니다. Python 명령 프롬프트에서 다음 명령을 사용하여 수행 할 수 있습니다.

>>> nltk.download()

기타 필요한 패키지 설치

NLTK를 사용하여 자연어 처리 응용 프로그램을 빌드하려면 필요한 패키지를 설치해야합니다. 패키지는 다음과 같습니다-

Gensim

많은 애플리케이션에 유용한 강력한 시맨틱 모델링 라이브러리입니다. 다음 명령을 실행하여 설치할 수 있습니다.

pip install gensim

무늬

그것은 만드는 데 사용됩니다 gensim패키지가 제대로 작동합니다. 다음 명령을 실행하여 설치할 수 있습니다.

pip install pattern

토큰 화, 형태소 분석 및 기본형 화의 개념

이 섹션에서는 토큰 화, 형태소 분석 및 형식화가 무엇인지 이해합니다.

토큰 화

주어진 텍스트, 즉 문자 시퀀스를 토큰이라고하는 작은 단위로 나누는 프로세스로 정의 할 수 있습니다. 토큰은 단어, 숫자 또는 구두점 일 수 있습니다. 단어 분할이라고도합니다. 다음은 토큰 화의 간단한 예입니다.

Input − 망고, 바나나, 파인애플, 사과는 모두 과일입니다.

Output

주어진 텍스트를 나누는 과정은 단어 경계를 찾는 도움으로 수행 할 수 있습니다. 단어의 끝과 새 단어의 시작을 단어 경계라고합니다. 글자 체계와 단어의 인쇄 구조가 경계에 영향을줍니다.

Python NLTK 모듈에는 요구 사항에 따라 텍스트를 토큰으로 나누는 데 사용할 수있는 토큰 화와 관련된 다양한 패키지가 있습니다. 패키지 중 일부는 다음과 같습니다-

sent_tokenize 패키지

이름에서 알 수 있듯이이 패키지는 입력 텍스트를 문장으로 나눕니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.tokenize import sent_tokenize

word_tokenize 패키지

이 패키지는 입력 텍스트를 단어로 나눕니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.tokenize import word_tokenize

WordPunctTokenizer 패키지

이 패키지는 입력 텍스트를 구두점과 함께 단어로 나눕니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.tokenize import WordPuncttokenizer

어간

단어로 작업하는 동안 문법적인 이유로 많은 변형을 발견합니다. 여기서 변형의 개념은 우리가 같은 단어의 다른 형태를 다뤄야 함을 의미합니다.democracy, democratic,democratization. 기계는 이러한 다른 단어가 동일한 기본 형식을 가지고 있음을 이해하는 것이 매우 필요합니다. 이런 식으로 텍스트를 분석하는 동안 단어의 기본 형태를 추출하는 것이 유용 할 것입니다.

형태소 분석을 통해이를 달성 할 수 있습니다. 이런 식으로 형태소 분석은 단어의 끝 부분을 잘라내어 단어의 기본 형태를 추출하는 휴리스틱 프로세스라고 말할 수 있습니다.

Python NLTK 모듈에는 형태소 분석과 관련된 다양한 패키지가 있습니다. 이 패키지는 단어의 기본 형식을 가져 오는 데 사용할 수 있습니다. 이 패키지는 알고리즘을 사용합니다. 패키지 중 일부는 다음과 같습니다-

PorterStemmer 패키지

이 Python 패키지는 Porter의 알고리즘을 사용하여 기본 양식을 추출합니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.stem.porter import PorterStemmer

예를 들어, 우리가 ‘writing’ 이 형태소 분석기에 대한 입력으로 우리는 ‘write’ 형태소 분석 후.

LancasterStemmer 패키지

이 Python 패키지는 Lancaster의 알고리즘을 사용하여 기본 양식을 추출합니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.stem.lancaster import LancasterStemmer

예를 들어, 우리가 ‘writing’ 이 형태소 분석기에 대한 입력으로 우리는 ‘write’ 형태소 분석 후.

SnowballStemmer 패키지

이 Python 패키지는 snowball의 알고리즘을 사용하여 기본 양식을 추출합니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.stem.snowball import SnowballStemmer

예를 들어, 우리가 ‘writing’ 이 형태소 분석기에 대한 입력으로 우리는 ‘write’ 형태소 분석 후.

이 모든 알고리즘은 서로 다른 수준의 엄격함을 가지고 있습니다. 이 세 가지 형태소 분석기를 비교하면 Porter 형태소 분석기가 가장 덜 엄격하고 Lancaster가 가장 엄격합니다. Snowball 형태소 분석기는 속도와 엄격 성 측면에서 사용하기에 좋습니다.

주형 화

lemmatization을 통해 단어의 기본 형태를 추출 할 수도 있습니다. 기본적으로 어휘 및 단어의 형태 학적 분석을 사용하여이 작업을 수행하며 일반적으로 어미 만 제거하는 것을 목표로합니다. 이러한 종류의 모든 단어를 기본형이라고합니다.

형태소 분석과 lemmatization의 주요 차이점은 단어의 어휘 및 형태 학적 분석을 사용하는 것입니다. 또 다른 차이점은 형태소 분석은 가장 일반적으로 파생적으로 관련된 단어를 축소하는 반면, lemmatization은 일반적으로 보조 정리의 다양한 굴절 형태 만 축소한다는 것입니다. 예를 들어, saw라는 단어를 입력 단어로 제공하면 형태소 분석은 's'라는 단어를 반환 할 수 있지만 lemmatization은 토큰 사용이 동사인지 명사인지에 따라 see 또는 saw라는 단어를 반환하려고 시도합니다.

Python NLTK 모듈에는 단어의 기본 형식을 얻는 데 사용할 수있는 lemmatization 프로세스와 관련된 다음 패키지가 있습니다.

WordNetLemmatizer 패키지

이 Python 패키지는 단어가 명사로 사용되는지 동사로 사용되는지에 따라 단어의 기본 형식을 추출합니다. 다음 Python 코드를 사용하여이 패키지를 가져올 수 있습니다.

from nltk.stem import WordNetLemmatizer

청킹 : 데이터를 청크로 나누기

자연어 처리에서 중요한 프로세스 중 하나입니다. 청킹의 주요 작업은 품사 및 명사구와 같은 짧은 구를 식별하는 것입니다. 우리는 이미 토큰 화 과정, 토큰 생성 과정을 연구했습니다. 청킹은 기본적으로 해당 토큰의 라벨링입니다. 즉, 청킹은 문장의 구조를 보여줍니다.

다음 섹션에서는 다양한 유형의 청킹에 대해 알아 봅니다.

청크 유형

청킹에는 두 가지 유형이 있습니다. 유형은 다음과 같습니다-

청킹

이 청크 과정에서 객체, 사물 등은 더 일반적으로 이동하고 언어는 더 추상적이됩니다. 더 많은 합의 가능성이 있습니다. 이 과정에서 축소합니다. 예를 들어, "자동차는 어떤 목적을 위해"라는 질문을 정리한다면? “운송”이라는 답을 얻을 수 있습니다.

아래로 청킹

이 청크 과정에서 객체, 사물 등은 더 구체적으로 이동하고 언어가 더 많이 침투합니다. 더 깊은 구조는 chunking down에서 조사 될 것입니다. 이 과정에서 우리는 확대합니다. 예를 들어, "자동차에 대해 구체적으로 말하십시오"라는 질문을 쪼개면? 우리는 차에 대한 작은 정보를 얻을 것입니다.

Example

이 예제에서, 우리는 파이썬에서 NLTK 모듈을 사용하여 문장에서 명사구 청크를 찾을 청킹 범주 인 명사구 청킹을 수행 할 것입니다.

Follow these steps in python for implementing noun phrase chunking −

Step 1−이 단계에서는 청킹에 대한 문법을 ​​정의해야합니다. 그것은 우리가 따라야 할 규칙들로 구성 될 것입니다.

Step 2−이 단계에서는 청크 파서를 생성해야합니다. 문법을 구문 분석하고 출력을 제공합니다.

Step 3 −이 마지막 단계에서 출력은 트리 형식으로 생성됩니다.

다음과 같이 필요한 NLTK 패키지를 가져 오겠습니다.

import nltk

이제 문장을 정의해야합니다. 여기서 DT는 행렬식, VBP는 동사, JJ는 형용사, IN은 전치사, NN은 명사를 의미합니다.

sentence=[("a","DT"),("clever","JJ"),("fox","NN"),("was","VBP"),
          ("jumping","VBP"),("over","IN"),("the","DT"),("wall","NN")]

이제 문법을 알려줘야합니다. 여기서는 정규 표현식의 형태로 문법을 제공합니다.

grammar = "NP:{<DT>?<JJ>*<NN>}"

문법을 파싱 할 파서를 정의해야합니다.

parser_chunking = nltk.RegexpParser(grammar)

파서는 다음과 같이 문장을 구문 분석합니다.

parser_chunking.parse(sentence)

다음으로 출력을 얻어야합니다. 출력은 다음과 같은 단순 변수에서 생성됩니다.output_chunk.

Output_chunk = parser_chunking.parse(sentence)

다음 코드를 실행하면 출력을 트리 형태로 그릴 수 있습니다.

output.draw()

Bag of Word (BoW) 모델

자연어 처리 모델 인 Bag of Word (BoW)는 기본적으로 텍스트에서 특징을 추출하는 데 사용되므로 텍스트를 기계 학습 알고리즘과 같은 모델링에 사용할 수 있습니다.

이제 텍스트에서 특징을 추출해야하는 이유에 대한 의문이 생깁니다. 기계 학습 알고리즘은 원시 데이터로 작업 할 수없고 의미있는 정보를 추출 할 수 있도록 숫자 데이터가 필요하기 때문입니다. 텍스트 데이터를 숫자 데이터로 변환하는 것을 특징 추출 또는 특징 인코딩이라고합니다.

작동 원리

이것은 텍스트에서 특징을 추출하는 매우 간단한 접근 방식입니다. 우리가 텍스트 문서를 가지고 있고 그것을 숫자 데이터로 변환하거나 그것에서 특징을 추출하고 싶다고 말하고 싶다고 가정 해 봅시다. 그리고 나서 먼저이 모델은 문서의 모든 단어에서 어휘를 추출합니다. 그런 다음 문서 용어 매트릭스를 사용하여 모델을 빌드합니다. 이런 식으로 BoW는 문서를 단어 모음으로 만 표현합니다. 문서에서 단어의 순서 또는 구조에 대한 정보는 삭제됩니다.

문서 용어 매트릭스의 개념

BoW 알고리즘은 문서 용어 매트릭스를 사용하여 모델을 구축합니다. 이름에서 알 수 있듯이 문서 용어 행렬은 문서에서 발생하는 다양한 단어 수의 행렬입니다. 이 매트릭스의 도움으로 텍스트 문서는 다양한 단어의 가중치 조합으로 표현 될 수 있습니다. 임계 값을 설정하고 더 의미있는 단어를 선택하여 특성 벡터로 사용할 수있는 문서의 모든 단어에 대한 히스토그램을 작성할 수 있습니다. 다음은 문서 용어 매트릭스의 개념을 이해하는 예입니다.

Example

다음 두 문장이 있다고 가정합니다.

  • Sentence 1 − Bag of Words 모델을 사용하고 있습니다.

  • Sentence 2 − Bag of Words 모델은 특징 추출에 사용됩니다.

이제이 두 문장을 고려하면 다음과 같은 13 개의 뚜렷한 단어가 있습니다.

  • we
  • are
  • using
  • the
  • bag
  • of
  • words
  • model
  • is
  • used
  • for
  • extracting
  • features

이제 각 문장의 단어 수를 사용하여 각 문장에 대한 히스토그램을 구축해야합니다.

  • Sentence 1 − [1,1,1,1,1,1,1,1,0,0,0,0,0]

  • Sentence 2 − [0,0,0,1,1,1,1,1,1,1,1,1,1]

이런 식으로 추출 된 특징 벡터가 있습니다. 각 특징 벡터는 13 개의 고유 한 단어가 있기 때문에 13 차원입니다.

통계의 개념

통계의 개념을 tf-idf (TermFrequency-Inverse Document Frequency)라고합니다. 문서에서 모든 단어는 중요합니다. 통계는 모든 단어의 중요성을 이해하는 데 도움이됩니다.

기간 주파수 (tf)

문서에서 각 단어가 얼마나 자주 나타나는지 측정합니다. 각 단어의 수를 주어진 문서의 총 단어 수로 나누어 얻을 수 있습니다.

역 문서 빈도 (idf)

주어진 문서 세트에서 단어가이 문서에 대해 얼마나 고유한지 측정합니다. idf를 계산하고 고유 한 특징 벡터를 공식화하려면 the와 같이 자주 발생하는 단어의 가중치를 줄이고 희귀 단어의 가중치를 높여야합니다.

NLTK에서 Bag of Words 모델 구축

이 섹션에서는 CountVectorizer를 사용하여 이러한 문장에서 벡터를 생성하여 문자열 모음을 정의합니다.

필요한 패키지를 가져 오자-

from sklearn.feature_extraction.text import CountVectorizer

이제 문장 세트를 정의하십시오.

Sentences = ['We are using the Bag of Word model', 'Bag of Word model is
           used for extracting the features.']

vectorizer_count = CountVectorizer()

features_text = vectorizer.fit_transform(Sentences).todense()

print(vectorizer.vocabulary_)

위 프로그램은 아래와 같이 출력을 생성합니다. 위의 두 문장에 13 개의 뚜렷한 단어가 있음을 보여줍니다.

{'we': 11, 'are': 0, 'using': 10, 'the': 8, 'bag': 1, 'of': 7,
 'word': 12, 'model': 6, 'is': 5, 'used': 9, 'for': 4, 'extracting': 2, 'features': 3}

기계 학습에 사용할 수있는 특징 벡터 (텍스트에서 숫자 형식)입니다.

문제 해결

이 섹션에서는 몇 가지 관련 문제를 해결합니다.

카테고리 예측

문서 세트에서는 단어뿐만 아니라 단어의 범주도 중요합니다. 특정 단어가 속하는 텍스트 범주. 예를 들어, 주어진 문장이 이메일, 뉴스, 스포츠, 컴퓨터 등 카테고리에 속하는지 예측하려고합니다. 다음 예에서는 tf-idf를 사용하여 문서 카테고리를 찾기위한 특징 벡터를 공식화 할 것입니다. sklearn의 20 개 뉴스 그룹 데이터 세트의 데이터를 사용합니다.

필요한 패키지를 가져와야합니다.

from sklearn.datasets import fetch_20newsgroups
from sklearn.naive_bayes import MultinomialNB
from sklearn.feature_extraction.text import TfidfTransformer
from sklearn.feature_extraction.text import CountVectorizer

카테고리 맵을 정의하십시오. 우리는 종교, 자동차, 스포츠, 전자 및 우주라는 다섯 가지 범주를 사용하고 있습니다.

category_map = {'talk.religion.misc':'Religion','rec.autos''Autos',
   'rec.sport.hockey':'Hockey','sci.electronics':'Electronics', 'sci.space': 'Space'}

훈련 세트 만들기-

training_data = fetch_20newsgroups(subset = 'train',
   categories = category_map.keys(), shuffle = True, random_state = 5)

카운트 벡터 라이저를 구축하고 항 카운트를 추출합니다.

vectorizer_count = CountVectorizer()
train_tc = vectorizer_count.fit_transform(training_data.data)
print("\nDimensions of training data:", train_tc.shape)

tf-idf 변환기는 다음과 같이 생성됩니다.

tfidf = TfidfTransformer()
train_tfidf = tfidf.fit_transform(train_tc)

이제 테스트 데이터를 정의하십시오.

input_data = [
   'Discovery was a space shuttle',
   'Hindu, Christian, Sikh all are religions',
   'We must have to drive safely',
   'Puck is a disk made of rubber',
   'Television, Microwave, Refrigrated all uses electricity'
]

위의 데이터는 다항식 Naive Bayes 분류기를 학습하는 데 도움이됩니다.

classifier = MultinomialNB().fit(train_tfidf, training_data.target)

카운트 벡터 라이저를 사용하여 입력 데이터를 변환-

input_tc = vectorizer_count.transform(input_data)

이제 tfidf 변환기를 사용하여 벡터화 된 데이터를 변환합니다.

input_tfidf = tfidf.transform(input_tc)

출력 범주를 예측합니다.

predictions = classifier.predict(input_tfidf)

출력은 다음과 같이 생성됩니다.

for sent, category in zip(input_data, predictions):
   print('\nInput Data:', sent, '\n Category:', \
      category_map[training_data.target_names[category]])

카테고리 예측기는 다음 출력을 생성합니다.

Dimensions of training data: (2755, 39297)

Input Data: Discovery was a space shuttle
Category: Space

Input Data: Hindu, Christian, Sikh all are religions
Category: Religion

Input Data: We must have to drive safely
Category: Autos

Input Data: Puck is a disk made of rubber
Category: Hockey

Input Data: Television, Microwave, Refrigrated all uses electricity
Category: Electronics

성별 찾기

이 문제 설명에서 분류자는 이름을 제공하여 성별 (남성 또는 여성)을 찾도록 훈련됩니다. 휴리스틱을 사용하여 특징 벡터를 생성하고 분류기를 훈련해야합니다. scikit-learn 패키지에서 레이블이 지정된 데이터를 사용할 것입니다. 다음은 성별 찾기를 빌드하는 Python 코드입니다.

필요한 패키지를 가져 오겠습니다.

import random

from nltk import NaiveBayesClassifier
from nltk.classify import accuracy as nltk_accuracy
from nltk.corpus import names

이제 입력 단어에서 마지막 N 개의 문자를 추출해야합니다. 이 편지는 기능으로 작동합니다-

def extract_features(word, N = 2):
   last_n_letters = word[-N:]
   return {'feature': last_n_letters.lower()}
	
if __name__=='__main__':

NLTK에서 사용할 수있는 레이블이 지정된 이름 (남성 및 여성)을 사용하여 훈련 데이터 생성-

male_list = [(name, 'male') for name in names.words('male.txt')]
female_list = [(name, 'female') for name in names.words('female.txt')]
data = (male_list + female_list)

random.seed(5)
random.shuffle(data)

이제 테스트 데이터는 다음과 같이 생성됩니다.

namesInput = ['Rajesh', 'Gaurav', 'Swati', 'Shubha']

다음 코드를 사용하여 학습 및 테스트에 사용되는 샘플 수를 정의합니다.

train_sample = int(0.8 * len(data))

이제 정확도를 비교할 수 있도록 다른 길이를 반복해야합니다.

for i in range(1, 6):
   print('\nNumber of end letters:', i)
   features = [(extract_features(n, i), gender) for (n, gender) in data]
   train_data, test_data = features[:train_sample],
features[train_sample:]
   classifier = NaiveBayesClassifier.train(train_data)

분류기의 정확도는 다음과 같이 계산할 수 있습니다.

accuracy_classifier = round(100 * nltk_accuracy(classifier, test_data), 2)
   print('Accuracy = ' + str(accuracy_classifier) + '%')

이제 출력을 예측할 수 있습니다.

for name in namesInput:
   print(name, '==>', classifier.classify(extract_features(name, i)))

위의 프로그램은 다음 출력을 생성합니다-

Number of end letters: 1
Accuracy = 74.7%
Rajesh -> female
Gaurav -> male
Swati -> female
Shubha -> female

Number of end letters: 2
Accuracy = 78.79%
Rajesh -> male
Gaurav -> male
Swati -> female
Shubha -> female

Number of end letters: 3
Accuracy = 77.22%
Rajesh -> male
Gaurav -> female
Swati -> female
Shubha -> female

Number of end letters: 4
Accuracy = 69.98%
Rajesh -> female
Gaurav -> female
Swati -> female
Shubha -> female

Number of end letters: 5
Accuracy = 64.63%
Rajesh -> female
Gaurav -> female
Swati -> female
Shubha -> female

위의 출력에서 ​​최대 끝 문자 수의 정확도는 2이고 끝 문자 수가 증가함에 따라 감소하는 것을 볼 수 있습니다.

주제 모델링 : 텍스트 데이터에서 패턴 식별

일반적으로 문서는 주제별로 그룹화되어 있습니다. 때로는 특정 주제에 해당하는 텍스트의 패턴을 식별해야합니다. 이를 수행하는 기술을 주제 모델링이라고합니다. 즉, 주제 모델링은 주어진 문서 세트에서 추상적 인 주제 또는 숨겨진 구조를 발견하는 기술이라고 말할 수 있습니다.

다음 시나리오에서 주제 모델링 기법을 사용할 수 있습니다.

텍스트 분류

주제 모델링의 도움으로 각 단어를 기능으로 개별적으로 사용하지 않고 유사한 단어를 함께 그룹화하므로 분류가 향상 될 수 있습니다.

추천 시스템

주제 모델링의 도움으로 유사성 측정을 사용하여 추천 시스템을 구축 할 수 있습니다.

주제 모델링을위한 알고리즘

토픽 모델링은 알고리즘을 사용하여 구현할 수 있습니다. 알고리즘은 다음과 같습니다-

잠재 디리클레 할당 (LDA)

이 알고리즘은 주제 모델링에 가장 많이 사용됩니다. 주제 모델링을 구현하기 위해 확률 적 그래픽 모델을 사용합니다. LDA slgorithm을 사용하려면 Python에서 gensim 패키지를 가져와야합니다.

LDA (Latent Semantic Analysis) 또는 LSI (Latent Semantic Indexing)

이 알고리즘은 선형 대수를 기반으로합니다. 기본적으로 문서 용어 매트릭스에서 SVD (Singular Value Decomposition) 개념을 사용합니다.

NMF (Non-Negative Matrix Factorization)

또한 선형 대수를 기반으로합니다.

위에서 언급 한 주제 모델링을위한 모든 알고리즘은 number of topics 매개 변수로 Document-Word Matrix 입력으로 WTM (Word Topic Matrix) & TDM (Topic Document Matrix) 출력으로.