当前位置: 首页 > news >正文

OpenCV项目实战-深度学习去阴影-图像去阴影

往期热门博客项目回顾:

计算机视觉项目大集合

改进的yolo目标检测-测距测速

路径规划算法

图像去雨去雾+目标检测+测距项目

交通标志识别项目

yolo系列-重磅yolov9界面-最新的yolo

姿态识别-3d姿态识别

深度学习小白学习路线

//正文开始!

图像去阴影算法旨在改善图像质量并恢复阴影下物体的真实颜色与亮度
这对于许多计算机视觉任务如物体识别、跟踪以及增强现实等至关重要。以下是一些图像去阴影算法的基本概述:
在这里插入图片描述

  1. 基于亮度差算法

    • 这种方法通过比较图像中相邻像素或同一物体不同部分的亮度差异来检测阴影。假设在同一光照条件下,物体表面颜色应相对一致,若出现较大差异则可能被认为是阴影区域。通过统计分析或者阈值处理,可以区分出阴影并尝试通过某种方式(例如线性插值、邻域平均或其他修复策略)填充阴影区域以还原原始色彩。
  2. 空洞卷积与注意力融合的对抗式图像阴影去除算法

    • 这类算法采用深度学习方法,尤其是结合生成对抗网络(GANs)的技术。空洞卷积(dilated convolution)有助于捕捉更大范围的上下文信息,而注意力机制能帮助网络更加关注阴影和非阴影区域的关键特征。通过训练这样的网络模型,它可以学习如何从含有阴影的图像中生成无阴影的输出图像。
      在这里插入图片描述
  3. 局部或全局对比度调整

    • 对比度增强和直方图均衡化等技术也可以用于减轻阴影的影响,它们通过对整幅图像或局部区域进行亮度和对比度调整来改善阴影区域的表现。
  4. 形态学操作

    • 在某些简单情况下,可以使用形态学操作如最大滤波和最小滤波来估计和校正阴影。例如,在图像背景较浅的情况下,先对图像应用最大滤波以提取潜在的背景亮度,然后用得到的信息来推测并填补阴影区域。
  5. 基于物理模型的方法

    • 根据光源方向、阴影投射角度及场景深度信息建立物理模型,通过逆向渲染过程来估计阴影并进行去除。
  6. 多尺度分析和混合模型

    • 利用多尺度分析结合多种算法,比如小波变换、高斯金字塔等,能够在不同分辨率层级上分析和处理阴影,然后组合多个层级的结果以获得更准确的阴影去除效果。
      在这里插入图片描述

随着深度学习在图像处理领域的快速发展,越来越多的算法倾向于利用神经网络构建端到端的学习系统来解决阴影去除问题,这些方法通常能提供更优秀的效果,特别是在处理复杂场景和具有丰富纹理的图像时。然而,每种方法都有其适用场景和局限性,实际应用中往往需要根据具体需求和数据特性选择合适的算法。

代码

def parse_args():desc = "Pytorch implementation of DCShadowNet"desc = "Pytorch implementation of DCShadowNet"parser = argparse.ArgumentParser(description=desc)parser.add_argument('--phase', type=str, default='test', help='[train / test]')parser.add_argument('--dataset', type=str, default='SRD', help='dataset_name')#parser.add_argument('--datasetpath', type=str, default='/disk1/yeying/dataset/SRD', help='dataset_path')parser.add_argument('--datasetpath', type=str, default='SRD', help='dataset_path')parser.add_argument('--iteration', type=int, default=1000000, help='The number of training iterations')parser.add_argument('--batch_size', type=int, default=1, help='The size of batch size')parser.add_argument('--print_freq', type=int, default=1000, help='The number of image print freq')parser.add_argument('--save_freq', type=int, default=100000, help='The number of model save freq')parser.add_argument('--decay_flag', type=str2bool, default=True, help='The decay_flag')parser.add_argument('--lr', type=float, default=0.0001, help='The learning rate')parser.add_argument('--weight_decay', type=float, default=0.0001, help='The weight decay')parser.add_argument('--adv_weight', type=int, default=1, help='Weight for GAN')parser.add_argument('--cycle_weight', type=int, default=10, help='Weight for Cycle')parser.add_argument('--identity_weight', type=int, default=10, help='Weight for Identity')parser.add_argument('--dom_weight', type=int, default=1, help='Weight for domain classification')parser.add_argument('--ch_weight', type=int, default=1, help='Weight for shadow-free chromaticity')parser.add_argument('--pecp_weight', type=int, default=1, help='Weight for shadow-robust feature')parser.add_argument('--smooth_weight', type=int, default=1, help='Weight for boundary smoothness')parser.add_argument('--use_ch_loss', type=str2bool, default=True, help='use shadow-free chromaticity loss')parser.add_argument('--use_pecp_loss', type=str2bool, default=True, help='use shadow-robust feature loss')parser.add_argument('--use_smooth_loss', type=str2bool, default=True, help='use boundary smoothness loss')parser.add_argument('--ch', type=int, default=64, help='base channel number per layer')parser.add_argument('--n_res', type=int, default=4, help='The number of resblock')parser.add_argument('--n_dis', type=int, default=6, help='The number of discriminator layer')parser.add_argument('--img_size', type=int, default=256, help='The size of image')parser.add_argument('--img_h', type=int, default=480, help='The org size of image')parser.add_argument('--img_w', type=int, default=640, help='The org size of image')parser.add_argument('--img_ch', type=int, default=3, help='The size of image channel')parser.add_argument('--result_dir', type=str, default='results', help='Directory name to save the results')parser.add_argument('--device', type=str, default='cpu', choices=['cpu', 'cuda'], help='Set gpu mode; [cpu, cuda]')parser.add_argument('--benchmark_flag', type=str2bool, default=False)parser.add_argument('--resume', type=str2bool, default=True)parser.add_argument('--epoch', type=int, default=1)parser.add_argument('--use_original_name', type=str2bool, default=False, help='use original name the same as the test images')parser.add_argument('--im_suf_A', type=str, default='.png', help='The suffix of test images [.png / .jpg]')

运行流程

1.pip install -r requirements.txt
2将图片放在dataset\SRD\testA文件夹下3.运行python main_test.py --dataset SRD --datasetpath  E:\001_code\DC-ShadowNet-Hard-and-Soft-Shadow-Removal-main_22\dataset\SRD\  --use_original_name False
E:\001_code\DC-ShadowNet-Hard-and-Soft-Shadow-Removal-main_22\dataset\SRD\是你的文件路径
4.results/SRD/500000查看结果

最后,计算机视觉、图像处理、毕业辅导、作业帮助、代码获取,远程协助,代码定制,私聊会回复!

call me :qq1309399183

相关文章:

  • Chatgpt掘金之旅—有爱AI商业实战篇|社交媒体管理|(七)
  • unity工程输出的log在哪里?
  • 手动实现Tomcat底层机制+自己设计Servlet
  • 倒三角形的两种输出方法
  • MES实施之工控机和电脑的选择
  • 条件变量的使用(golang)
  • 计算机网络-TCP重传、滑动窗口、流量控制、拥塞控制
  • 解决element-plus table组件 fixed=“right“(left)浮动后横向滚动文字穿透的问题
  • 【北邮国院大三下】Cybersecurity Law 网络安全法 Week1【更新Topic4, 5】_cyber security la
  • 12.自定义的多帧缓存架构
  • 【PostgreSQL】技术传承:使用Docker快速部署PostgreSQL数据库
  • 游戏引擎中的物理系统
  • 深入探讨string类的奥秘
  • 数据库的简单查询
  • 深入浅出 -- 系统架构之分布式多形态的存储型集群
  • Android 架构优化~MVP 架构改造
  • Druid 在有赞的实践
  • k8s 面向应用开发者的基础命令
  • Markdown 语法简单说明
  • spring学习第二天
  • Vue.js-Day01
  • WePY 在小程序性能调优上做出的探究
  • 创建一个Struts2项目maven 方式
  • 关于Flux,Vuex,Redux的思考
  • 类orAPI - 收藏集 - 掘金
  • 理清楚Vue的结构
  • 聊聊redis的数据结构的应用
  • 如何在 Tornado 中实现 Middleware
  • 学习HTTP相关知识笔记
  • 原生js练习题---第五课
  • 在electron中实现跨域请求,无需更改服务器端设置
  • 【运维趟坑回忆录 开篇】初入初创, 一脸懵
  • (定时器/计数器)中断系统(详解与使用)
  • (二)Eureka服务搭建,服务注册,服务发现
  • (附源码)springboot高校宿舍交电费系统 毕业设计031552
  • (亲测成功)在centos7.5上安装kvm,通过VNC远程连接并创建多台ubuntu虚拟机(ubuntu server版本)...
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • (转载)从 Java 代码到 Java 堆
  • ****Linux下Mysql的安装和配置
  • .dat文件写入byte类型数组_用Python从Abaqus导出txt、dat数据
  • .NET 的程序集加载上下文
  • .NET和.COM和.CN域名区别
  • .net开发时的诡异问题,button的onclick事件无效
  • .NET开源项目介绍及资源推荐:数据持久层
  • /etc/skel 目录作用
  • @manytomany 保存后数据被删除_[Windows] 数据恢复软件RStudio v8.14.179675 便携特别版...
  • [ Linux ] Linux信号概述 信号的产生
  • [20181219]script使用小技巧.txt
  • [2021ICPC济南 L] Strange Series (Bell 数 多项式exp)
  • [ai笔记9] openAI Sora技术文档引用文献汇总
  • [android] 练习PopupWindow实现对话框
  • [cogs2652]秘术「天文密葬法」
  • [CSAWQual 2019]Web_Unagi ---不会编程的崽
  • [CSS]CSS 字体属性
  • [DP 训练] Longest Run on a Snowboard, UVa 10285