目前我正在尝试使用encog 3扩展我的数据文件(train.nn),我的数据文件看起来像这样(这是一个简化的例子,在我的真实文件中,每个样本我有多达249个功能SP):
1,0,1,2,SP
4,5,6,1,SP
这是我的缩放代码:
File rawFile = new File(MYDIR, "train.nn");
File scaledFile = new File(MYDIR, "scaledTrain.nn");
EncogAnalyst analyst = new EncogAnalyst();
AnalystNormalizeCSV norm = new AnalystNormalizeCSV();
norm.analyze(rawFile, true, CSVFormat.ENGLISH, analyst);
norm.setProduceOutputHeaders(false);
norm.normalize(scaledFile);
但我收到了这个错误:
Exception in thread "main" org.encog.app.analyst.AnalystError: Multiple fields named: 1
at org.encog.app.analyst.util.CSVHeaders.validateSameName(CSVHeaders.java:292)
at org.encog.app.analyst.util.CSVHeaders.init(CSVHeaders.java:270)
at org.encog.app.analyst.util.CSVHeaders.<init>(CSVHeaders.java:146)
at org.encog.app.analyst.csv.normalize.AnalystNormalizeCSV.analyze(AnalystNormalizeCSV.java:147)
我真的不知道为什么抱怨这个....有人能告诉我这里我做错了什么吗?
非常感谢你。
P / S:我已经看过this tutorial了。这对我来说并不方便,因为它手动定义了每个字段(功能),这很糟糕,因为在我的情况下,每个样本我有多达249个功能。
答案 0 :(得分:1)
您可以设置如下循环:
int fieldCount = 249;
InputFieldCSV[] inFields = new InputFieldCSV[fieldCount];
int i = 0;
while (i < fieldCount) {
norm.addInputField(inFields[i] = new InputFieldCSV(true, rawFile, i));
i++;
}
然后为代码的其余部分设置更多循环,您可以看到重复的相同行。 (代码未经过测试......)