码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 直方图均衡化算法


    直方图均衡化是一种图像处理算法,通过调整图像的灰度级分布,增强图像的对比度和细节。下面是直方图均衡化算法的基本步骤:

    1. 统计原始图像的灰度直方图:遍历整个图像,计算每个灰度级出现的频次。

    2. 计算累积直方图:对灰度直方图进行累加,得到每个灰度级及其之前所有灰度级的累积频次。

    3. 计算映射函数:将累积直方图归一化到期望的灰度范围(通常是0到255),得到一个映射函数。

    4. 应用映射函数:遍历原始图像,根据映射函数将每个像素的灰度值转换为新的灰度值。

    5. 生成均衡化后的图像:用转换后的灰度值替换原始图像中的相应像素值。

    通过直方图均衡化,图像的灰度级分布会更加平坦,从而增加图像的对比度。这个过程可以使得图像细节更加清晰,使得暗部和亮部的细节都更容易观察到。需要注意的是,直方图均衡化可能会改变图像的整体色调,因此在应用之前,需要根据具体需求进行调整和评估。

    以下是一个简单的直方图均衡化算法的例程,以Python语言为例:

    1. import cv2
    2. import numpy as np
    3. def histogram_equalization(image):
    4. # 统计原始图像的灰度直方图
    5. hist, bins = np.histogram(image.flatten(), 256, [0,256])
    6. # 计算累积直方图
    7. cdf = hist.cumsum()
    8. cdf_normalized = cdf * hist.max() / cdf.max()
    9. # 计算映射函数
    10. mapping = np.interp(image.flatten(), bins[:-1], cdf_normalized)
    11. # 应用映射函数,生成均衡化后的图像
    12. equalized_image = mapping.reshape(image.shape).astype(np.uint8)
    13. return equalized_image
    14. # 读取原始图像
    15. image = cv2.imread('input.jpg', 0) # 灰度图像读取
    16. # 执行直方图均衡化
    17. equalized_image = histogram_equalization(image)
    18. # 显示原始图像和均衡化后的图像
    19. cv2.imshow('Original Image', image)
    20. cv2.imshow('Equalized Image', equalized_image)
    21. cv2.waitKey(0)
    22. cv2.destroyAllWindows()

  • 相关阅读:
    【C++入门】string类常用方法(万字详解)
    一、爬虫基本概念
    hbase和aerospike基础概念
    python 基础:文件夹的创建
    JavaScript从入门到精通系列第三十七篇:详解JavaScript中文档的加载顺序
    【腾讯云 Cloud Studio 实战训练营】提升开发效率与协作:探索腾讯云 Cloud Studio 的强大功能与优势
    因果引擎(Causal Engine)是基于因果推理的人工智能系统
    虚拟环境安装、核验、进入
    2024-安装VMware® Workstation 17 Pro
    基于Delphi7的木马程序的查杀设计与实现
  • 原文地址:https://blog.csdn.net/wangjiaweiwei/article/details/131924181
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号