python 给出数组是一维的,但索引了两个维度错误

我已经为 miniBatchGradientDescent 编写了 mini_batch 创建器

代码如下:

# 函数用于创建包含 mini-batches 的列表
def create_mini_batches(X,y, batch_size):
    print(X.shape, y.shape) # 输出 (280, 34) (280,)
    splitData=[]
    splitDataResults=[]
    batchCount=X.shape[0] // batch_size # 使用地板除法获取整数形式的索引
    for i in range(batchCount):
        splitData.append(X[(i) * batch_size : (i+1) * batch_size, :])
        splitDataResults.append(y[(i) * batch_size : (i+1) * batch_size, :]) # 产生错误
    splitData=np.asarray(splitData)
    splitDataResults=np.asarray(splitDataResults)
    return splitData, splitDataResults, batchCount

错误提示如下:

splitDataResults.append(y[(i) * batch_size : (i+1) * batch_size, :])
IndexError: too many indices for array: array is 1-dimensional, but 2 were indexed

我确定形状是正确的,但它还是给我报错了。哪里出了问题?


回答:

尝试重塑 y:

print(X.shape, y.shape) # 输出 (280, 34) (280,)
y = y.reshape(-1, 1)

这应该能解决你的问题,因为 y 将变成二维的

Related Posts

在 ImageDataGenerator 中,数据是在每个批次还是每个周期中进行增强的?

我知道在每个周期中我们会有一组新的增强。但我的问题是,…

如何使用Sk-learn的OneHotEncoder对数据框中的两个或多个列进行编码?

这是我的数据框 我想使用sklearn的OneHotE…

如何避免在Pandas中应用独热编码时出现NaN

我正在训练一个机器学习模型来预测我国内的房价。我不确定…

如何访问FastText分类器管道?

众所周知,Facebook的FastText是一个出色…

自定义Sklearn核函数的决策函数结果错误

我成功实现了自己的自定义线性核函数,使用clf.pre…

如何在Python中使用训练好的模型测试新句子 (sklearn)

我有用于多类文本分类的训练模型代码,并且它运行正常,但…

发表回复

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