【发布时间】:2013-06-23 01:16:06
【问题描述】:
我使用玩具语料库导出了一个 LDA 主题模型,如下所示:
documents = ['Human machine interface for lab abc computer applications',
'A survey of user opinion of computer system response time',
'The EPS user interface management system',
'System and human system engineering testing of EPS',
'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',
'Graph minors A survey']
texts = [[word for word in document.lower().split()] for document in documents]
dictionary = corpora.Dictionary(texts)
id2word = {}
for word in dictionary.token2id:
id2word[dictionary.token2id[word]] = word
我发现,当我使用少量主题来推导模型时,Gensim 会生成一份完整的主题分布报告,其中包含测试文档的所有潜在主题的主题分布。例如:
test_lda = LdaModel(corpus,num_topics=5, id2word=id2word)
test_lda[dictionary.doc2bow('human system')]
Out[314]: [(0, 0.59751626959781134),
(1, 0.10001902477790173),
(2, 0.10001375856907335),
(3, 0.10005453508763221),
(4, 0.10239641196758137)]
但是当我使用大量主题时,报告不再完整:
test_lda = LdaModel(corpus,num_topics=100, id2word=id2word)
test_lda[dictionary.doc2bow('human system')]
Out[315]: [(73, 0.50499999999997613)]
在我看来,概率小于某个阈值(我观察到 0.01 更具体)的主题在输出中被省略了。
我想知道这种行为是否是出于某种审美考虑?以及如何获得所有其他主题的概率质量残差分布?
感谢您的友好回答!
【问题讨论】:
-
可能其他主题的百分比太低而无法视为突出。
-
我遇到了同样的问题。你找到解决办法了吗?
-
你能说出你是如何创建“语料库”的吗