使用Sci-kit Learn神经网络训练2D输入

我正在尝试使用Python中的sci-kit learn训练一个神经网络来识别图像中的形状。我有一组位于边缘上的点,每个边缘用x和y坐标表示,形式为[x,y]。因此,我想使用格式为[[x,y],[x,y],[x,y],[x,y],[x,y],[x,y],等]的列表来训练网络。我尝试了以下代码,但得到了以下错误:

from sklearn.neural_network import MLPClassifierX = [[[0., 0.], [0., 0.]], [[1., 1.], [1., 1.]]]y = [0, 1]clf = MLPClassifier(solver='lbfgs', alpha=1e-5,                hidden_layer_sizes=(5, 2), random_state=1)clf.fit(X, y)

ValueError: Found array with dim 3. Estimator expected <= 2.

是否有人可以提供一些建议,告诉我如何处理这个问题,如果这是可能的话。根据神经网络的定义和逻辑,我不太确定这是否可行。请告诉我任何建议。谢谢!


回答:

Scikit-learn主要接受最多二维的输入。你可以尝试合并列表以降低维度。我使用了下面的代码将其转换为二维数据,并且对我来说运行良好

from sklearn.neural_network import MLPClassifierimport numpy as npX = [[[0., 0.], [0., 0.]], [[1., 1.], [1., 1.]]]y = [0, 1]clf = MLPClassifier(solver='lbfgs', alpha=1e-5,            hidden_layer_sizes=(5, 2), random_state=1)X_new = []for i in X:    temp =[]     for j in i:        for k in j:            temp.append(k)    X_new.append(temp)clf.fit(X_new,y)

循环结束时的X_new看起来像这样

[[0.0, 0.0, 0.0, 0.0], [1.0, 1.0, 1.0, 1.0]]

准确性将取决于数据。尝试一下,看看是否有效

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

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