ValueError: 无法将大小为3509的序列复制到维度为6的数组轴上

我在尝试将我的数据拟合到逻辑回归器时遇到了这个错误。

class Train:    def __init__(self, X_train, X_test, y_train, y_test):        self.X_train = X_train,        self.y_train = y_train,        self.X_test = X_test,        self.y_test = y_test    def train(self):        X_train = self.X_train        y_train = self.y_train        clf = LogisticRegression().fit(X_train, y_train)

X_trainy_train 是元组类型。这发生在 __init__ 方法中,所以我猜这是默认行为。
我刚开始写面向对象的代码,所以我相信有更好的方法来实现这一点,错误可能是由于类之间传递的数据引起的。

编辑:当我直接在主方法中放置 “clf = LogisticRegression().fit(X_train, y_train)” 时,它可以工作。


回答:

通过在 __init__ 中的那些语句添加逗号,你正在创建元组:

t = X_train,type(t)# tuple

另外,在初始化时将所有变量设置为类属性的目的是为了它们可以在类方法之间共享,所以 X_train = self.X_train 赋值是没有意义的。因此,你应该这样做:

class Train():    def __init__(self, X_train, X_test, y_train, y_test):        self.X_train = X_train        self.y_train = y_train        self.X_test = X_test        self.y_test = y_test            def train(self):        self.cls = LogisticRegression()         self.cls.fit(self.X_train, self.y_train)

最后一点,我猜你的类包含了一些除了当前内容之外的其他逻辑。否则,这没有意义,LogisticRegression 已经是一个带有 fit 方法的类了。

Related Posts

神经网络反向传播代码不工作

我需要编写一个简单的由1个输出节点、1个包含3个节点的…

值错误:y 包含先前未见过的标签:

我使用了 决策树分类器,我想将我的 输入 作为 字符串…

使用不平衡数据集进行特征选择时遇到的问题

我正在使用不平衡数据集(54:38:7%)进行特征选择…

广义随机森林/因果森林在Python上的应用

我在寻找Python上的广义随机森林/因果森林算法,但…

如何用PyTorch仅用标量损失来训练神经网络?

假设我们有一个神经网络,我们希望它能根据输入预测三个值…

什么是RNN中间隐藏状态的良好用途?

我已经以三种不同的方式使用了RNN/LSTM: 多对多…

发表回复

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