keras自定义损失函数并且模型加载的写法介绍


Posted in Python onJune 15, 2020

keras自定义函数时候,正常在模型里自己写好自定义的函数,然后在模型编译的那行代码里写上接口即可。如下所示,focal_loss和fbeta_score是我们自己定义的两个函数,在model.compile加入它们,metrics里‘accuracy'是keras自带的度量函数。

def focal_loss():
 ...
 return xx
def fbeta_score():
 ...
 return yy
model.compile(optimizer=Adam(lr=0.0001), loss=[focal_loss],metrics=['accuracy',fbeta_score] )

训练好之后,模型加载也需要再额外加一行,通过load_model里的custom_objects将我们定义的两个函数以字典的形式加入就能正常加载模型啦。

weight_path = './weights.h5'
model = load_model(weight_path,custom_objects={'focal_loss': focal_loss,'fbeta_score':fbeta_score})

补充知识:keras如何使用自定义的loss及评价函数进行训练及预测

1.有时候训练模型,现有的损失及评估函数并不足以科学的训练评估模型,这时候就需要自定义一些损失评估函数,比如focal loss损失函数及dice评价函数 for unet的训练。

2.在训练建模中导入自定义loss及评估函数。

#模型编译时加入自定义loss及评估函数
model.compile(optimizer = Adam(lr=1e-4), loss=[binary_focal_loss()],
    metrics=['accuracy',dice_coef])

#自定义loss及评估函数
def binary_focal_loss(gamma=2, alpha=0.25):
 """
 Binary form of focal loss.
 适用于二分类问题的focal loss
 focal_loss(p_t) = -alpha_t * (1 - p_t)**gamma * log(p_t)
  where p = sigmoid(x), p_t = p or 1 - p depending on if the label is 1 or 0, respectively.
 References:
  https://arxiv.org/pdf/1708.02002.pdf
 Usage:
  model.compile(loss=[binary_focal_loss(alpha=.25, gamma=2)], metrics=["accuracy"], optimizer=adam)
 """
 alpha = tf.constant(alpha, dtype=tf.float32)
 gamma = tf.constant(gamma, dtype=tf.float32)

 def binary_focal_loss_fixed(y_true, y_pred):
  """
  y_true shape need be (None,1)
  y_pred need be compute after sigmoid
  """
  y_true = tf.cast(y_true, tf.float32)
  alpha_t = y_true * alpha + (K.ones_like(y_true) - y_true) * (1 - alpha)

  p_t = y_true * y_pred + (K.ones_like(y_true) - y_true) * (K.ones_like(y_true) - y_pred) + K.epsilon()
  focal_loss = - alpha_t * K.pow((K.ones_like(y_true) - p_t), gamma) * K.log(p_t)
  return K.mean(focal_loss)

 return binary_focal_loss_fixed

#'''
#smooth 参数防止分母为0
def dice_coef(y_true, y_pred, smooth=1):
 intersection = K.sum(y_true * y_pred, axis=[1,2,3])
 union = K.sum(y_true, axis=[1,2,3]) + K.sum(y_pred, axis=[1,2,3])
 return K.mean( (2. * intersection + smooth) / (union + smooth), axis=0)

注意在模型保存时,记录的loss函数名称:你猜是哪个

a:binary_focal_loss()

b:binary_focal_loss_fixed

3.模型预测时,也要加载自定义loss及评估函数,不然会报错。

该告诉上面的答案了,保存在模型中loss的名称为:binary_focal_loss_fixed,在模型预测时,定义custom_objects字典,key一定要与保存在模型中的名称一致,不然会找不到loss function。所以自定义函数时,尽量避免使用我这种函数嵌套的方式,免得带来一些意想不到的烦恼。

model = load_model('./unet_' + label + '_20.h5',custom_objects={'binary_focal_loss_fixed': binary_focal_loss(),'dice_coef': dice_coef})

以上这篇keras自定义损失函数并且模型加载的写法介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python的三目运算符和not in运算符使用示例
Mar 03 Python
python中dir函数用法分析
Apr 17 Python
Python操作MySQL数据库9个实用实例
Dec 11 Python
深入理解NumPy简明教程---数组3(组合)
Dec 17 Python
python安装教程 Pycharm安装详细教程
May 02 Python
python版飞机大战代码分享
Nov 20 Python
Python实现深度遍历和广度遍历的方法
Jan 22 Python
Django 开发调试工具 Django-debug-toolbar使用详解
Jul 23 Python
python实现简易学生信息管理系统
Apr 05 Python
opencv调整图像亮度对比度的示例代码
Sep 27 Python
用python中的matplotlib绘制方程图像代码
Nov 21 Python
opencv python在视屏上截图功能的实现
Mar 05 Python
python语言是免费还是收费的?
Jun 15 #Python
DataFrame.groupby()所见的各种用法详解
Jun 14 #Python
详解pandas.DataFrame.plot() 画图函数
Jun 14 #Python
Pandas把dataframe或series转换成list的方法
Jun 14 #Python
详解pandas获取Dataframe元素值的几种方法
Jun 14 #Python
Pandas对DataFrame单列/多列进行运算(map, apply, transform, agg)
Jun 14 #Python
Python脚本破解压缩文件口令实例教程(zipfile)
Jun 14 #Python
You might like
《被神捡到的男人》动画化计划进行中!
2020/03/06 日漫
MOTOROLA 摩托罗拉 MODEL 66-XI五灯中波收音机
2021/03/02 无线电
Yii使用ajax验证显示错误messagebox的解决方法
2014/12/03 PHP
如何利用http协议发布博客园博文评论
2015/08/03 PHP
浅谈Coreseek、Sphinx-for-chinaese、Sphinx+Scws的区别
2016/12/15 PHP
基于thinkPHP类的插入数据库操作功能示例
2017/01/06 PHP
PHP格式化显示时间date()函数代码
2018/10/03 PHP
JavaScript 字符串与数组转换函数[不用split与join]
2009/12/13 Javascript
clientX,pageX,offsetX,x,layerX,screenX,offsetLeft区别分析
2010/03/12 Javascript
复制Input内容的js代码_支持所有浏览器,修正了Firefox3.5以上的问题
2010/06/21 Javascript
JavaScript数组常用操作技巧汇总
2014/11/17 Javascript
jQuery中:image选择器用法实例
2015/01/03 Javascript
jQuery实现的fixedMenu下拉菜单效果代码
2015/08/24 Javascript
异步JS框架的作用以及实现方法
2015/10/29 Javascript
功能强大的Bootstrap使用手册(一)
2016/08/02 Javascript
Vue.js 2.0窥探之Virtual DOM到底是什么?
2017/02/10 Javascript
Bootstrap实现基于carousel.js框架的轮播图效果
2017/05/02 Javascript
vue使用vue-cli快速创建工程
2017/07/28 Javascript
深入浅析ES6 Class 中的 super 关键字
2017/10/20 Javascript
微信小程序实现留言板(Storage)
2018/11/02 Javascript
Node.js 路由的实现方法
2019/06/05 Javascript
Vue 页面权限控制和登陆验证功能的实例代码
2019/06/20 Javascript
关于layui表单中按钮自动提交的解决方法
2019/09/09 Javascript
js找出5个数中最大的一个数和倒数第二大的数实现方法示例小结
2020/03/04 Javascript
js实现简单选项卡制作
2020/08/05 Javascript
微信小程序组件生命周期的踩坑记录
2021/03/03 Javascript
[52:32]完美世界DOTA2联赛PWL S2 Magma vs LBZS 第三场 11.18
2020/11/18 DOTA
python时间日期函数与利用pandas进行时间序列处理详解
2018/03/13 Python
flask框架json数据的拿取和返回操作示例
2019/11/28 Python
python中get和post有什么区别
2020/06/19 Python
HTML5 placeholder属性详解
2016/06/22 HTML / CSS
澳大利亚百货商店中销量第一的商务衬衫品牌:Van Heusen
2018/07/26 全球购物
物流管理专业应届生求职信
2013/11/21 职场文书
中秋节超市促销方案
2014/01/30 职场文书
专题组织生活会方案
2014/06/15 职场文书
python可视化大屏库big_screen示例详解
2021/11/23 Python