目前,我试图通过使用encog 3来扩展我的数据文件(train.nn),我的数据文件看起来如下(这是一个简化的示例,在我的实际文件中,我对每个示例SP有多达249个特性):
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)我真的不知道它为什么抱怨这个..。有人能告诉我我在这里做错了什么吗?
非常感谢。
我已经看过本教程了。这对我来说并不方便,因为它手动定义了每个字段(特性),这很糟糕,因为在我的示例中,每个示例最多有249个特性。
发布于 2014-03-10 13:25:21
您可以设置这样的循环:
int fieldCount = 249;
InputFieldCSV[] inFields = new InputFieldCSV[fieldCount];
int i = 0;
while (i < fieldCount) {
norm.addInputField(inFields[i] = new InputFieldCSV(true, rawFile, i));
i++;
}然后为代码的其余部分设置进一步的循环,在这些循环中可以看到相同的行被重复。(代码未测试.)
https://stackoverflow.com/questions/22297669
复制相似问题