#定义回调函数,以便使用早停技术并保持最佳模型

#!/usr/bin/env python
# -*- coding:utf-8 -*- 
# Author: Jia ShiLin

import numpy as np
import pandas as pd
from sklearn.model_selection import train_test_split

from keras.models import Sequential
from keras.layers import Dense
from keras.callbacks import EarlyStopping,ModelCheckpoint
from keras.optimizers import Adam
from sklearn.preprocessing import StandardScaler


SEED = 2019

#DATA
data = pd.read_csv('winequality-red.csv',sep=';')
y =data['quality']
x = data.drop(['quality',axis=1])

#拆分数据
X_train,X_test,y_train,y_test = train_test_split(X,y,test_size=0.2,random_state=SEED)
#显示平均品质和第一行训练集
print('Average quality training set:{:.4f}'.format(y_train.mean()))
X_train.head()

#数据标准化,
scalar = StandardScaler().fit(X_train)
X_train = pd.DataFrame(scalar.transform(X_train))
X_test = pd.DataFrame(scalar.transform(X_test))

#对每个验证输入的训练数据预测其平均质量
print('MSE:',np.mean((y_test-
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Keras 中使用 ModelCheckpoint 回调函数可以在每个 epoch 结束时保存模型的权重。下面是一个简单的示例,展示了如何定义 ModelCheckpoint 回调函数: ```python from keras.callbacks import ModelCheckpoint # 定义 ModelCheckpoint 回调函数 checkpoint = ModelCheckpoint(filepath='model_weights.h5', monitor='val_loss', verbose=1, save_best_only=True, mode='min') # 在模型训练时使用 ModelCheckpoint 回调函数 model.fit(X_train, y_train, validation_data=(X_val, y_val), epochs=10, batch_size=32, callbacks=[checkpoint]) ``` 在上面的示例中,我们首先从 Keras 中导入 ModelCheckpoint 回调函数。然后,我们定义了一个名为 `checkpoint` 的 ModelCheckpoint 对象。这个对象有几个参数: - `filepath`:保存模型权重的路径。可以是绝对路径或相对路径。 - `monitor`:监视的指标。在这个例子中,我们使用验证集上的损失函数作为监视指标。 - `verbose`:日志输出级别。在这个例子中,我们将它设置为 1,这样每次保存模型权重时,都会输出一条消息。 - `save_best_only`:是否只保存最佳模型权重。在这个例子中,我们将它设置为 True,这样只有当监视指标有所改善时,才会保存模型权重。 - `mode`:监视指标的模式。在这个例子中,我们将它设置为 'min',表示我们希望监视的指标越小越好。 最后,我们将 ModelCheckpoint 对象传递给模型的 `fit` 方法的 `callbacks` 参数中,这样在模型训练时,每当一个 epoch 结束时,ModelCheckpoint 回调函数就会自动保存模型的权重到指定的文件中。 需要注意的是,如果您要使用 ModelCheckpoint 回调函数,请确保您的代码中已经定义了一个 Keras 模型

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

贾世林jiashilin

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值