Участник:Kruglikov/PLSA: различия между версиями

Материал из Алговики
Перейти к навигации Перейти к поиску
 
(не показана 1 промежуточная версия этого же участника)
Строка 11: Строка 11:
  
 
=== Математическое описание алгоритма ===
 
=== Математическое описание алгоритма ===
Пусть <math>D</math> — конечное множество документов, <math>W</math> — конечное множество терминов, <math>T</math> — конечное множество тем. <math>(d_i, w_i, t_i)_{i=1}^n \subset D \times W \times T</math> — коллекция текстовых документов.
+
 
 +
====Обозначения====
 +
Пусть <math>D</math> — конечное множество документов, <math>W</math> — конечное множество терминов, <math>T</math> — конечное множество тем.
 +
 
 +
<math>(d_i, w_i, t_i)_{i=1}^n \subset D \times W \times T</math> — коллекция текстовых документов.
  
 
Тематическая модель коллекции: <math>p(w|d) = \sum_{t \in T} p(w|t)p(t|d) = \sum_{t \in T} \phi_{wt} \theta_{td}</math>
 
Тематическая модель коллекции: <math>p(w|d) = \sum_{t \in T} p(w|t)p(t|d) = \sum_{t \in T} \phi_{wt} \theta_{td}</math>
  
Задача состоит в том, чтобы найти параметры <math>\phi_{wt}</math>и <math>\theta_{td}</math>
+
Задача состоит в том, чтобы найти параметры <math>\phi_{wt}</math> и <math>\theta_{td}</math>
  
  
Строка 37: Строка 41:
  
  
 +
====EM-алгоритм в PLSA====
 
В модели PLSA предлагается максимизировать правдоподобие  
 
В модели PLSA предлагается максимизировать правдоподобие  
  
Строка 56: Строка 61:
  
  
Эту систему можно решить EM-алгоритмом, применяя последовательно E- и M-шаги.
+
Эту систему можно решить EM-алгоритмом, применяя последовательно E- и M-шаги до сходимости.
  
 
== Программная реализация алгоритма ==
 
== Программная реализация алгоритма ==

Текущая версия на 23:28, 2 ноября 2017

Общая схема описания алгоритмов имеет следующий вид:

1 Свойства и структура алгоритмов

1.1 Общее описание алгоритма

Задача тематического моделирования заключается в том, чтобы выделить в коллекции текстовых документов скрытые структуры, называемые темами. Неформально под темой понимается семантически однородное множество документов. Более формально, темой называется условное распределение на множестве терминов [math]p(w|t)[/math], а тематикой документа называется условное распределение [math]p(t|d)[/math]. Переменная [math]t[/math] является скрытой. Таким образом, задача тематического моделирования — оценить вероятности [math]p(w|t)[/math] и [math]p(t|d)[/math] по наблюдаемым частотам [math]p(w|d)[/math] слов в документах.

Задачу восстановления скрытого распределения можно решать, максимизируя правдоподобие выборки EM-алгоритмом. В применении к тематическому моделированию такой подход называется probabilistic latent semantic analysis — PLSA.


1.2 Математическое описание алгоритма

1.2.1 Обозначения

Пусть [math]D[/math] — конечное множество документов, [math]W[/math] — конечное множество терминов, [math]T[/math] — конечное множество тем.

[math](d_i, w_i, t_i)_{i=1}^n \subset D \times W \times T[/math] — коллекция текстовых документов.

Тематическая модель коллекции: [math]p(w|d) = \sum_{t \in T} p(w|t)p(t|d) = \sum_{t \in T} \phi_{wt} \theta_{td}[/math]

Задача состоит в том, чтобы найти параметры [math]\phi_{wt}[/math] и [math]\theta_{td}[/math]


Введём набор счётчиков:

[math]n_{dwt} = \sum_{i=1}^n [d_i = d][w_i = w][t_i = t][/math] — частота [math](d_i, w_i, t_i)[/math] в коллекции;

[math]n_{wt} = \sum_{d} n_{dwt}[/math] — частота термина [math]w[/math] в теме [math]t[/math];

[math]n_{td} = \sum_{w} n_{dwt}[/math] — частота терминов темы [math]t[/math] в документе [math]d[/math];

[math]n_{t} = \sum_{d, w} n_{dwt}[/math] — частота терминов темы [math]t[/math] коллекции;

[math]n_{dw} = \sum_{t} n_{dwt}[/math] — частота термина [math]w[/math] в документе [math]d[/math];

[math]n_{w} = \sum_{d, t} n_{dwt}[/math] — частота термина [math]w[/math] в коллекции;

[math]n_{d} = \sum_{w, t} n_{dwt}[/math] — длина документа [math]d[/math];

[math]n = \sum_{d, w, t} n_{dwt}[/math] — длина коллекции.


1.2.2 EM-алгоритм в PLSA

В модели PLSA предлагается максимизировать правдоподобие

[math]\mathcal{L}(\Phi, \Theta) = \sum_{d \in D} \sum_{w \in d} n_{dw} \ln \sum_{t \in T} \phi_{wt} \theta_{dw} \to \max_{\Phi, \Theta}[/math]

при ограничениях неотрицательности и нормировки

[math]\phi_{wt} \le 0; \sum_{w \in W} \phi_{wt} = 1; \theta_{td} \le 0; \sum_{t \in T} = 1.[/math]

Утверждается, что точка максимума правдоподобия удовлетворяет системе уравнений

[math] \begin{cases} n_{dwt} & = & n_{dw} \frac{\phi_{wt}\theta_{td}}{\sum_s \phi_{ws} \theta{ws}}; & \text{(E-шаг)} \\ \phi_{wt} & = & \frac{n_{wt}}{n_t}; n_{wt} = \sum_{d \in D} n_{dwt}; n_t = \sum_w n_{wt}; & \text{(M-шаг)} \\ \theta_{td} & = & \frac{n_{td}}{n_d}; n_{td} = \sum_{w \in d} n_{dwt}; n_d = \sum_t n_{wt} . \end{cases} [/math]


Эту систему можно решить EM-алгоритмом, применяя последовательно E- и M-шаги до сходимости.

2 Программная реализация алгоритма

3 Литература

Воронцов К. В. Вероятностные тематические модели. Лекция 1. Введение (слайды)