keras中fit_generator()的优势

我想知道在keras中使用fit_generator()与使用fit()方法并设置相同的batch_size相比,是否在内存使用上有任何优势。我见过一些类似的例子,如下所示:

def generator():(X_train, y_train), (X_test, y_test) = mnist.load_data()# 一些数据准备...while 1:    for i in range(1875): # 1875 * 32 = 60000 -> 训练样本数量        yield X_train[i*32:(i+1)*32], y_train[i*32:(i+1)*32]

如果我将这个生成器传入fit_generator()方法,或者直接将所有数据传入fit()方法并定义batch_size为32,这在(GPU?)内存使用上会有什么不同吗?


回答:

是的,差异实际上出现在你需要增强数据以提高模型精度的时候。

为了提高效率,它允许在CPU上实时进行图像数据增强。这意味着它可以将GPU用于模型训练及其更新,同时将图像增强和提供训练批次的负载委托给CPU处理。

Related Posts

L1-L2正则化的不同系数

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

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

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

f1_score metric in lightgbm

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

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

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

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

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

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

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

发表回复

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