Accord Machine Learning knn.decide 引发 IndexOutOfRangeException

我尝试使用Accord库实现的k近邻算法。首先,我使用了以下代码:

        double[][] inputs = new double[15000][];        int[] outputs = new int[15000];        for (int list_counter= 0; list_counter < training_set.Count; list_counter ++ ) {            outputs[list_counter] = (char.Parse(training_set[list_counter].letter));            double[] input = new double[16];            for(int i =0; i< 16; i++) {                input[i] = (double)training_set[list_counter].integers[i];            }            inputs[list_counter] = input;        }        var knn = new KNearestNeighbors(k: 4);        knn.NumberOfInputs = 16;        Console.WriteLine("学习算法");        knn.Learn(inputs, outputs);

这段代码用于教knn学习算法。我有一组15000个整数,首先将它们转换为双精度浮点数作为输入。然后我有一组15000个单字符字符串,首先将它们转换为字符以获取整数值,然后将它们分类为输出。
这里是输入和输出的截图。 输入输出

我还将输入的数量设置为16以避免这种问题。但在以下代码中

            for (int list_counter = 0; list_counter < validation_set.Count; list_counter++) {               double[] input = new double[16];               for (int i = 0; i < 16; i++) {                   input[i] = (double)validation_set[list_counter].integers[i];               }               int answer = knn.Decide(input); 

每当我尝试使用knn.Decide时,就会引发IndexOutOfRangeException。这看起来很奇怪,因为我使用了完全相同的逻辑来插入输入(一个包含15000个双精度浮点数数组的数组,每个数组包含16个元素)。
这是程序崩溃前输入数组的截图崩溃前的输入

决定方法的文档对我没有帮助,但我会留下链接:
knn决定文档
knn文档

编辑:堆栈跟踪


回答:

所以,这个特定问题的答案很奇怪,我在knn算法的文档中找不到它。
问题出在knn.Learn部分的输出必须从0开始并向上计数。将大写字符转换为整数时,最小值为65(’A’),我修改了代码的第一部分

                outputs[list_counter] = (char.Parse(training_set[list_counter].letter)) -65 ;

现在一切运行得像钟表一样顺畅!

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注