代码解读——Retinex低光照图像增强(Deep Retinex Decomposition for Low-Light Enhancement)

本文详细解析了一篇2018年BMVC论文中的RetinexNet算法,该算法基于Retinex理论,通过DecomNet和RelightNet网络对图像进行反射和光照分量的分解与修正,实现低光照图像增强。虽然存在色彩失真的问题,但其网络结构轻量且效果良好。
摘要由CSDN通过智能技术生成

今天带来一篇代码解读的文章,是2018年BMVC上的一篇暗光增强文章。个人觉得网络比较轻量并且能够取得还不错的效果。废话不多说,直接贴传送门:

文章地址:http://arxiv.org/abs/1808.04560

源码地址:https://github.com/weichen582/RetinexNet

文章基于Retinex理论,不懂的请戳这里:https://blog.csdn.net/lz0499/article/details/81154937

整体结构主要包括两个网络:DecomNet和RelightNet。DecomNet用于分解图片为反射分量和光照分量,RelightNet用于将光照分量修正,再与反射分量重建,得到修正后的图像。可参考下图:

其中,作者提到了在RelightNet中同时对反射分量进行去噪处理,但在代码中我没有明确看到这步操作,有知道的小伙伴可以评论区留言。

先来看DecomNet的网络构建部分。整体就是全卷积网络,具体看我代码注释。

def DecomNet(input_im, layer_num, channel=64, kernel_size=3):       #分解网络
    input_max = tf.reduce_max(input_im, axis=3, keepdims=True)
    input_im = concat([input_max, input_im])                          #选取RGB三通道中的最大值(亮度)进行堆叠,变成4通道,与最后一层卷积'recon_layer'相呼应
    with tf.variable_scope('DecomNet', reuse=tf.AUTO_REUSE):         #这里面创建的所有tensor都带有'DecomNet'
        conv = tf.layers.conv2d(input_im, channel, kernel_size * 3, padding='same', activation=None, name="shallow_feature_extraction")
        for idx in range(layer_num):                                 #进行5次带r
  • 21
    点赞
  • 170
    收藏
    觉得还不错? 一键收藏
  • 55
    评论
评论 55
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值