原来我想要的格式称为“SVM-Light”,并在此处描述http://svmlight.joachims.org/。
我有一个数据框,我想将其转换为格式如下的文本文件:
output featureIndex:featureValue ... featureIndex:featureValue
例如:
t = structure(list(feature1 = c(3.28, 6.88), feature2 = c(0.61, 1.83
), output = c("1", "-1")), .Names = c("feature1", "feature2",
"output"), row.names = c(NA, -2L), class = "data.frame")
t
# feature1 feature2 output
# 1 3.28 0.61 1
# 2 6.88 1.83 -1
会成为:
1 feature1:3.28 feature2:0.61
-1 feature1:6.88 feature2:1.83
到目前为止我的代码:
nvars = 2
l = array("row", nrow(t))
for(i in(1:nrow(t)))
{
l = t$output[i]
for(n in (1:nvars))
{
thisFeatureString = paste(names(t)[n], t[[names(t)[n]]][i], sep=":")
l[i] = paste(l[i], thisFeatureString)
}
}
但我不确定如何完成并将结果写入文本文件。此外,代码可能效率不高。
是否有执行此操作的库函数?例如,这种输出格式对于 Vowpal Wabbit 来说似乎很常见。