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的Tornado框架实现图片上传及图片大小修改功能
Jun 30 Python
Python实现简单网页图片抓取完整代码实例
Dec 15 Python
详解Python3.6安装psutil模块和功能简介
May 30 Python
python筛选出两个文件中重复行的方法
May 31 Python
python使用pygame框架实现推箱子游戏
Nov 20 Python
python 将对象设置为可迭代的两种实现方法
Jan 21 Python
django与vue的完美结合_实现前后端的分离开发之后在整合的方法
Aug 12 Python
Python 限定函数参数的类型及默认值方式
Dec 24 Python
基于python3.7利用Motor来异步读写Mongodb提高效率(推荐)
Apr 29 Python
Python如何避免文件同名产生覆盖
Jun 09 Python
python实现单机五子棋
Aug 28 Python
python 如何对logging日志封装
Dec 02 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/04 星际争霸
MySQL时间字段究竟使用INT还是DateTime的说明
2012/02/27 PHP
PHP图片裁剪函数(保持图像不变形)
2014/05/04 PHP
php实现scws中文分词搜索的方法
2015/12/25 PHP
Laravel中基于Artisan View扩展包创建及删除应用视图文件的方法
2016/10/08 PHP
PHP文件类型检查及fileinfo模块安装使用详解
2019/05/09 PHP
jquery 学习笔记一
2010/04/07 Javascript
JavaScript 面向对象编程(2) 定义类
2010/05/18 Javascript
jQuery中attr()和prop()在修改checked属性时的区别
2014/07/18 Javascript
jQuery解决浏览器兼容性问题案例分析
2016/04/15 Javascript
对js eval()函数的一些见解
2016/08/15 Javascript
Javascript 实现放大镜效果实例详解
2016/12/03 Javascript
js实现带简单弹性运动的导航条
2017/02/22 Javascript
Vue 2.X的状态管理vuex记录详解
2017/03/23 Javascript
Vue的百度地图插件尝试使用
2017/09/06 Javascript
原生JS实现获取及修改CSS样式的方法
2018/09/04 Javascript
angularJS实现不同视图同步刷新详解
2018/10/09 Javascript
JavaScript数组去重实现方法小结
2020/01/17 Javascript
Electron整合React使用搭建开发环境的步骤详解
2020/06/07 Javascript
微信小程序实现弹幕墙(祝福墙)
2020/11/18 Javascript
[02:40]DOTA2超级联赛专访430 从小就爱玩对抗性游戏
2013/06/18 DOTA
Python检测生僻字的实现方法
2016/10/23 Python
基于python socketserver框架全面解析
2017/09/21 Python
Python中的单继承与多继承实例分析
2018/05/10 Python
python算法题 链表反转详解
2019/07/02 Python
python字符串下标与切片及使用方法
2020/02/13 Python
Python 面向对象部分知识点小结
2020/03/09 Python
PIP和conda 更换国内安装源的方法步骤
2020/09/21 Python
html5 css3 动态气泡按钮实例演示
2012/12/02 HTML / CSS
css3+jq创作含苞待放的荷花
2014/02/20 HTML / CSS
CSS3动画和HTML5新特性详解
2020/08/31 HTML / CSS
web字体加载方案优化小结
2019/11/29 HTML / CSS
英国领先的酒杯和水晶玻璃器皿制造商:Dartington Crystal
2019/06/23 全球购物
小小商店教学反思
2014/04/27 职场文书
教师个人读书活动总结
2014/07/08 职场文书
《暗黑破坏神2:重制版》本周进行第一轮A测 目前可官网进行申请报名
2021/04/07 其他游戏