Gensim - Документы и корпус
Здесь мы узнаем об основных концепциях Gensim, уделяя основное внимание документам и корпусу.
Основные концепции Gensim
Ниже приведены основные концепции и термины, необходимые для понимания и использования Gensim.
Document - З.Это относится к какому-то тексту.
Corpus - Речь идет о сборнике документов.
Vector - Математическое представление документа называется векторным.
Model - Это относится к алгоритму, используемому для преобразования векторов из одного представления в другое.
Что такое документ?
Как уже говорилось, это относится к некоторому тексту. Если вдаваться в подробности, это объект типа текстовой последовательности, который известен как‘str’ в Python 3. Например, в Gensim документ может быть любым, например -
- Короткий твит из 140 символов
- Отдельный абзац, например, аннотация статьи или исследовательской работы
- Новостная статья
- Book
- Novel
- Theses
Текстовая последовательность
Тип текстовой последовательности обычно известен как ‘str’ в Python 3. Как мы знаем, в Python текстовые данные обрабатываются с помощью строк или, более конкретно, ‘str’объекты. Строки в основном представляют собой неизменяемые последовательности кодовых точек Unicode и могут быть записаны следующими способами:
Single quotes - Например, ‘Hi! How are you?’. Это позволяет нам также вставлять двойные кавычки. Например,‘Hi! “How” are you?’
Double quotes - Например, "Hi! How are you?". Это также позволяет нам вставлять одинарные кавычки. Например,"Hi! 'How' are you?"
Triple quotes - Может иметь три одинарные кавычки, например, '''Hi! How are you?'''. или три двойные кавычки, например,"""Hi! 'How' are you?"""
Все пробелы будут включены в строковый литерал.
пример
Ниже приведен пример документа в Gensim -
Document = “Tutorialspoint.com is the biggest online tutorials library and it’s all free also”
Что такое Корпус?
Корпус можно определить как большой и структурированный набор машиночитаемых текстов, созданных в естественной коммуникативной среде. В Gensim набор объектов документа называется корпусом. Множественное число корпусаcorpora.
Роль Корпуса в Генсиме
Корпус в Gensim выполняет две следующие роли:
Служит исходными данными для обучения модели
Самая первая и важная роль, которую корпус играет в Gensim, - это входные данные для обучения модели. Чтобы инициализировать внутренние параметры модели, во время обучения модель ищет некоторые общие темы и темы из корпуса обучения. Как обсуждалось выше, Gensim фокусируется на неконтролируемых моделях, поэтому не требует какого-либо вмешательства человека.
Служит экстрактором тем
После обучения модели ее можно использовать для извлечения тем из новых документов. Здесь новые документы - это те, которые не используются на этапе обучения.
пример
Корпус может включать все твиты конкретного человека, список всех статей в газете или всех исследовательских работ по определенной теме и т. Д.
Сбор корпуса
Ниже приведен пример небольшого корпуса, состоящего из 5 документов. Здесь каждый документ представляет собой строку, состоящую из одного предложения.
t_corpus = [
"A survey of user opinion of computer system response time",
"Relation of user perceived response time to error measurement",
"The generation of random binary unordered trees",
"The intersection graph of paths in trees",
"Graph minors IV Widths of trees and well quasi ordering",
]
Предварительная обработка Collecting Corpus
После того, как мы соберем корпус, необходимо предпринять несколько шагов предварительной обработки, чтобы корпус оставался простым. Мы можем просто удалить некоторые часто используемые английские слова, такие как «the». Мы также можем удалить слова, которые встречаются в корпусе только один раз.
Например, следующий скрипт Python используется для нижнего регистра каждого документа, разделения его пробелами и фильтрации стоп-слов:
пример
import pprint
t_corpus = [
"A survey of user opinion of computer system response time",
"Relation of user perceived response time to error measurement",
"The generation of random binary unordered trees",
"The intersection graph of paths in trees",
"Graph minors IV Widths of trees and well quasi ordering",
]
stoplist = set('for a of the and to in'.split(' '))
processed_corpus = [[word for word in document.lower().split() if word not in stoplist]
for document in t_corpus]
pprint.pprint(processed_corpus)
]
Вывод
[['survey', 'user', 'opinion', 'computer', 'system', 'response', 'time'],
['relation', 'user', 'perceived', 'response', 'time', 'error', 'measurement'],
['generation', 'random', 'binary', 'unordered', 'trees'],
['intersection', 'graph', 'paths', 'trees'],
['graph', 'minors', 'iv', 'widths', 'trees', 'well', 'quasi', 'ordering']]
Эффективная предварительная обработка
Gensim также предоставляет функцию для более эффективной предварительной обработки корпуса. При такой предварительной обработке мы можем преобразовать документ в список токенов нижнего регистра. Мы также можем игнорировать слишком короткие или слишком длинные токены. Такая функцияgensim.utils.simple_preprocess(doc, deacc=False, min_len=2, max_len=15).
gensim.utils.simple_preprocess() fucntion
Gensim предоставляет эту функцию для преобразования документа в список токенов нижнего регистра, а также для игнорирования слишком коротких или слишком длинных токенов. Он имеет следующие параметры -
doc (str)
Он относится к входному документу, к которому должна применяться предварительная обработка.
deacc (булево, необязательно)
Этот параметр используется для удаления знаков ударения с токенов. Оно используетdeaccent() сделать это.
min_len (целое число, необязательно)
С помощью этого параметра мы можем установить минимальную длину токена. Токены короче заданной длины будут отброшены.
max_len (целое число, необязательно)
С помощью этого параметра мы можем установить максимальную длину токена. Жетоны, длина которых превышает определенную, будут отброшены.
Результатом этой функции будут токены, извлеченные из входного документа.