fastText 安装
fasttext 是一个有效的学习字词表达和句子分类的库。建立在现代 Mac OS 和 Linux 发行版上。因为它使用了 C++11 的特性,所以需要一个支持 C++11 的编译器,这些包括:
gcc-4.8 或更高版本
clang-3.3 或更高版本
安装 fasttext
(1)最简单的方法是使用 pip 安装
$ git clone https://github.com/facebookresearch/fastText.git
$ cd fastText
$ pip install .
(2)也可以使用 setuptools 安装
$ git clone https://github.com/facebookresearch/fastText.git
$ cd fastText
$ python setup.py install
(3)现在可以直接安装
pip install fasttext
一般来说,正确处理数据是很重要的,fasttext 采用 UTF-8 编码的文本。所有的文本必须是 Python2的Unicode 和Python3的str。传递的文本将被 pybind11 编码为 UTF-8 ,然后传递给 fasttext c++ 库。这意味着在构建模型时使用 UTF-8 编码的文本非常重要。在类 unix 系统中,可以使用 iconv 转换文本。
fasttext 将基于以下 ASCII 字符进行标记(将文本分割成块)。特别是,它不知道 UTF-8 空格。建议将 UTF-8空格/字符边界转换成下列符号之一作为批准:
空格 tab 空字符 回车符
fastText 使用
fasttext 包有两个主要用例:单词表示学习 和 文本分类
1.单词表示学习
为了学习单词向量,我们可以使用 fasttext.skipgram 和 fasttext.cbow 功能
import fasttext
# skipgram model
model = fasttext.skipgram('data.txt','model')
print model.words # 字典中的词汇列表
# CBOW model
model = fasttext.cbow('data.txt','model')
print model.words
data.txt 是一个以 UTF-8 编码的训练文本文件,在默认情况下,单词向量将会考虑到 n-grams 的3 到 6 个字符。在优化结束时,程序将保存 2 个文件: model.bin 和 model.vec
获取词汇表外单词的向量,已经训练过的模型可以用来计算词汇表外的词汇向量。
# 单词 'king' 的词向量
print model['king']
加载训练好的词向量模型,我们可以使用 fasttext.load_model 方法
# 加载前面训练好的模型 model.bin
model = fasttext.load_model("model.bin")
print model.words # model 中的词汇列表
print model["king"] # "king" 的词向量
2.文本分类
该包还可以用于训练监督文本分类器,并从 fasttext 加载经过训练的分类器
训练文本分类器如下,data.train.txt 是一个包含训练语句和标签的文本文件,可以先参考上一节中训练语料的格式。默认情况下,我们假定标签是由字符串 __label__ 为前缀的单词。
# 训练文本分类器
classifier = fasttext.supervised('data.train.txt','model')
# 还可以用 label_prefix 指定标签前缀
classifier = fasttext.supervised('data.train.txt','model',label_prefix = '__label__')
将输出两个文件: model.bin 和 model.vec
一旦模型被训练,我们可以计算分类器在测试数据集上的准确率和召回率来评估模型 classifer.test 方法
# 加载模型
classifier = fasttext.load_model("model.bin",label_prefix = "__label__")
# 使用 classifier.test 方法在测试数据集上评估模型
result = classifier.test("test.txt")
print "准确率:" , result.precision
print "召回率:" , result.recall
print "Number of examples:", result.nexamples
为了使用训练的模型预测文本列表中最有可能的标签,我们可以用 classifier.predict 方法
texts = ["example very long text 1","example very longtext 2"]
labels = classifier.predict(texts)
print labels
或者加上可能性,也就是这个标签的预测概率,我们用 classifier.predict_proba 方法
texts = ["example very long text 1","example very longtext 2"]
labels = classifier.predict_proba(texts)
print labels
我们也可以指定 k 值,从分类器中得到 k-best 标签
# 不含预测可能性的 k = 3
labels = classifier.predict(texts,k = 3)
# 含可能性的 k = 3
labels = classifier.predict_proba(texts,k = 3)