【发布时间】:2015-08-09 02:42:02
【问题描述】:
我正在使用 FANN 库构建神经网络来处理回归问题。问题是,一旦在相关训练集上对网络进行了训练(这似乎工作得很好),每个测试都会输出完全相同的输出。换句话说,给定我的 16 个预测变量的任何状态,根据 ANN,我的预测输出是相同的。
我的猜测是网络正确计算了计算的第一行,然后总是在其他计算中输出这个结果,无论我提供什么(因为它似乎在第一个训练示例中做得很好,给出准确的预测)。
例如,我的第一个训练示例变量是:
1 1 13.5 13.5 13.5 14.5 14.4 14.3 14.3 14.2 14.5 13 11.7 12.2 12.2 11.3
我的目标输出是 14.5,在每次测试中,网络输出的结果在 14.69 和 14.7 之间(由于计算时间短,而且我只玩这个包,我每次运行代码时都会对其进行训练)。 因此,对于该组数据,此输出似乎完全合法。
问题是,当我尝试在其他几个输入上运行它时,我总是得到相同的 14.69/14.7(即使是最小的数字也有相同的输出)。
由于网络似乎正确地处理了训练示例,学习了关系并在一个新的测试示例上正确计算,我倾向于相信所有训练部分都是正确的。由于网络没有理由总是输出相同的值,我的猜测是我的测试方式不正确。
我的问题是:在新数据集上测试 FANN 神经网络的确切语法是什么?以及,如何打印/保存相应的输出?
这是我的代码的当前状态:
fann_type *calc_out;
fann_type input[16];
for (int i = 0; i < 20; i++)
{
if (!rowHasNA(timeSerie, i))
{
cout << "Input : ";
for (int j = 1; j < 17; j++)
{
input[j - 1] = timeSerie(i, j);
cout << input[j - 1] << " ";
}
cout << endl;
calc_out = fann_run(ann, input);
cout << "Input " << i << " gives : " << calc_out[0] << endl;
}
}
地点:
-
rowHasNA是我用来确定我的示例是否至少有一个 NA 的自定义函数 -
ann是一个fann*,它已经被训练过 -
timeSerie是matrix<double>,其中每一行都是一个测试示例
我仍然对 FANN 包的工作原理有些困惑,因为我没有找到关于如何训练网络和测试它们的真正清晰的文档。我很难理解fann_type 的工作原理。
提前谢谢你。
【问题讨论】:
-
在训练和运行之前简单地缩放特征
标签: c++ neural-network fann