班级类型
首先,如果您希望输出是连续的,我建议您将class
类型更改为 。numeric
否则,我建议将类标签类型保留为nominal
(就像您现在拥有的那样),但将您的评级更改为{1, 2, 3, 4, 5}
.
如果您更改为数字输出(例如,您可以给出 4.5 星的预测),那么您将需要使用能够进行数字类的分类器。
使用 Weka
我建议查看文档以了解有关使用 Weka 的更多信息,可能通过阅读一些教程。例如,双击您的 ARFF 文件后,您应该在Classify
选项卡中完成大部分工作。选择一个分类器,然后选择Start
。
分类器
回归
回归,特别是线性回归很好,因为它很容易解释,因为它只是为每个属性分配一个权重,并使用这些权重的乘法和加法来给出输出。
我使用了您的示例文件并LinearRegression
用.3.9667
0.4722
不满意,接下来我试SimpleLinearRegression
了 ,它给出了一个模型 -0.02 * activites + 4.13
,并且会给出一个 的平均绝对误差0.472
。
SMOreg
给出以下模型
weights:
+ 0.1147 * (normalized) lloc
- 0.0404 * (normalized) nid
- 0.1662 * (normalized) nle
- 0.0647 * (normalized) nel
+ 0.3385 * (normalized) nip
- 0.1352 * (normalized) activites
- 0.019 * (normalized) inside-permissions
- 0.0464 * (normalized) outside-permissions
+ 0.1602 * (normalized) all-permissions
+ 0.5921
并且平均绝对误差为0.3859
. 但在这一点上,我认为数据点如此之少,你的数据就过拟合了。
最近的邻居
如果您有更多数据(在 Weka 中称为) ,使用k 最近邻可能是一种可行的方法。KStar
决策树
该DecisionStump
算法输出该模型的平均绝对误差为0.3424
,但也可能过度拟合。
inside-permissions <= 1.5 : 2.6
inside-permissions > 1.5 : 4.090909090909091
inside-permissions is missing : 3.966666666666667
更多数据
如您所见,考虑到您只有 12 个数据点,模型和错误率并没有那么高。要建立一个非常好的模型,您需要更多的数据。要准确了解模型的运行情况,您不仅需要有足够的数据进行训练,还需要有足够的数据作为单独的测试集保存,仅用于测试模型的性能。