《数字图像处理》实验报告二:直方图均衡化

一、实验任务与要求

1、实验任务:

  • 读取图像,绘制直方图/归一化直方图(hist/histogram, subplot)
  • 使用直方图均衡化函数(histeq)
  • 自己实现直方图均衡化函数
     

2、要求:

  • 提交 m 文件,代码中需注释直方图均衡化的关键步骤。

二、实验报告 

实验代码:

%直方图均衡化函数
function img2 = myHisteq(img)[r,c]=size(img); %获取图像的大小%统计图像中各个灰度值出现的个数n=zeros(1,256);for i=1:rfor j=1:ck=img(i,j)+1;n(1,k)=n(1,k)+1;endend%统计图像中各个灰度值出现的概率p=zeros(1,256);for i=1:256p(1,i)=n(1,i)/(r*c);end%累计概率p_sum=zeros(1,256); p_sum(1,1)=p(1,1);for i=2:256p_sum(1,i)=p_sum(1,i-1)+p(1,i);end%变换函数TT=zeros(1,256);for i=1:256T(1,i)=255*p_sum(1,i);end%对每个像素点进行映射img2=ones(r,c); %创建一个rxc的全1矩阵img2=im2uint8(img2); %将图像转为uint8类型for i=1:rfor j=1:cimg2(i,j)=T(1,img(i,j)+1);endend end

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/34844.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

树莓派只是玩具?看看上海国际嵌入式展上用树莓派做的高大上产品!

三天的 Embedded World China 上海国际嵌入式展圆满落幕!这次展会上海晶珩、英国 Raspberry Pi、工业自动化软件领导者 CODESYS 集体亮相,为观众带来了精彩纷呈的视听盛宴。在展会现场,树莓派团队带来了最新的 Raspberry Pi AI Kit 场景演示&…

网络配置(IP、NETMASK、GATEWAY、DNS、DHCP)

参考: 初学Linux之网络配置(IP、NETMASK、GATEWAY、DNS、DHCP)-CSDN博客【学习笔记】网关 & 路由_网关和路由-CSDN博客【学习笔记】计算机网络 IP地址与MAC地址_根据mac分配ip-CSDN博客【学习笔记】TCP 和 UDP 协议_tcp 发送 syn 应答没有syn ack-CSDN博客 一…

java版CRM客户关系管理系统Spring Cloud alibaba Spring Boot成长型企业必备的客户关系管理系统

鸿鹄CRM客户关系管理系统是一款基于Java语言开发的CRM系统,采用了Spring Cloud Alibaba、Spring Boot、MybatisPlus、Redis和VUE3 ElementUI等技术,构建了一个微服务架构。该系统具有以下功能模块: 一、待办事项 1、今日需联系客户&#xf…

P2P去中心化网络的重点组件

P2P去中心化网络的重点组件 P2P(Peer-to-Peer)去中心化网络是一种网络架构,其中所有参与者(节点)都具有平等地位,直接相互通信,而无需中央协调机构。以下是P2P去中心化网络的关键组件及其详细介…

C# .NET 8 SQL 批量插入 Dapper、BulkCopy 和表值参数

介绍 在 .NET 应用程序中处理大型数据集通常需要将数据高效地插入到 SQL Server 中。本文探讨了使用 C# 和 .NET 8 批量插入数据的三种流行技术:Dapper、SqlBulkCopy 和表值参数 (TVP)。我们将比较它们的性能、易用性和对不同场景的适用性。 1. Dapper Bulk Inser…

论Lambda架构及其应用

摘要: 2023年3月,我公司承担了本市教育局智慧教育云平台的项目,该平台旨在为教育机构和学生提供一个在线学习与教学的环境,包含课程管理、在线学习、资源共享、互动交流等功能。在项目中我担任系统架构师,全面负责项目…

实在RPA的硬件交互功能:U盾机械臂组件

一、为什么需要U盾机械臂? 在使用银行U盾(USB Key)进行操作时,涉及到许多手动确认步骤,特别是按下U盾上的确认按键。这种手动操作是自动化过程中的一个瓶颈。为了实现完全自动化,需要一种方法来自动按下U…

代码随想录算法训练营:17/60

非科班学习算法day17 | LeetCode654:最大二叉树 ,Leetcode617:合并二叉树 ,Leetcode700:二叉搜索树中的搜索,Leetcode98:验证二叉搜索树 目录 介绍 一、基础概念补充: 1.二叉搜索树 二、LeetCode题目 1.LeetCode…

价格!六安市各地双软(软件企业、软件产品)办理流程步骤及申报材料、时间

六安市各地双软(软件企业、软件产品)办理流程步骤材料 (更多问题详情可以查看小编主页方式) 第一步:办理软件企业认定 1.打开办理软件企业认定的中心网站,然后注册并登录,下载双软认定申报表…

大数据系统软件助力工业数字化转型

随着科技的不断进步,大数据系统软件在工业领域的应用日益广泛,成为推动工业数字化转型的关键技术之一。工业数字化转型旨在通过技术手段提升生产效率、优化资源配置,并提供智能决策支持,从而实现更高效、可持续的生产模式。 数据采…

Kafka 集群如何处理生产者和消费者处理消息速率差异问题?

kafka 集群如何处理生产者和消费者处理消息速率差异问题? Kafka 集群通过多种机制来处理生产者和消费者处理消息速率的差异问题,确保消息的高效传递和系统的 稳定性。以下是详细的解释和机制: 1. 消息缓冲机制 Kafka 使用消息缓冲机制来处理生产者和消费者速率的不匹配。…

接口测试中遇到的sessionID验证问题

在接口测试中,经常会存在联调的接口,比如登录完去调用其他的接口,这时就会存在一个问题,那就是登录成功了,但是其他接口失败了,这个时候就需要用到一个sessionID去传入其他接口验证合法性请求,这…

k8s重启后报错Error getting node not found

今天升级一台3主的k8s集群的配置。升级其中一台后另外两个节点就出现Not Ready的状态。 升级之前最好把一些能停的应用停掉。或者能够通过增加临时节点来进行扩容,不然所有pod调度到其他节点,可能把其他节点压垮。没办法,只能把其他两台直接…

Python学习前简介

1.python简介 2.python特点 3.python解释器 4.pyCharm简介 一、python简介 Python是一种高级编程语言,用于多种应用,包括网站开发、数据科学、人工智能、机器学习、桌面应用、网络应用、软件开发、网络爬虫等。它由Guido van Rossum于1991年首次发布&am…

group by和select的兼容性问题

group by和select的兼容性问题 在标准的SQL语法中,GROUP BY 和 SELECT 之间不存在兼容性问题,因为它们是 SQL 查询语句的基本组成部分,而且它们的使用方式是相互兼容的。 SELECT 子句和 GROUP BY 子句的关系: SELECT 子句&#…

Matlab进阶绘图第61期—滑珠散点图

滑珠散点图也是一种在《Nature》中常见的数据图。 其功能类似于柱状图,但更加简洁易读。 由于Matlab中没有现成的函数绘制滑珠散点图,因此需要大家自行解决。 本文利用自己制作的BubbleScatter工具,进行滑珠散点图的绘制,先来看…

【山东大学项目实训】进度汇报16

进行了带有历史记录的问答链的修改优化 Chat_QA_chain_self from langchain.chains import ConversationalRetrievalChain from qa_chain.model_to_llm import model_to_llm from qa_chain.get_vectordb import get_vectordbclass Chat_QA_chain_self:"""&quo…

ServBay[中文] 下一代Web开发环境

ServBay是一个集成式、图形化的本地化Web开发环境。开发者通过ServBay几分钟就能部署一个本地化的开发环境。解决了Web开发者(比如PHP、Nodejs)、测试工程师、小型团队安装和维护开发测试环境的问题,同时可以快速的进行环境的升级以及维护。S…

头歌Python作业——8.1 模拟生成身份信息及查验身份(project)

目录 第1关 第2关 第3关 第4关 第1关 import random def person_name(gender_of_id, last_name_file, male_name_file, female_name_file):"""参数 gender_of_id:性别,字符串类型参数 last_name_file:百家姓文件名&…

Chrome开发者工具学习

打开开发者工具: 可以通过在网页上点击右键并选择“检查”来打开。 或者使用快捷键Ctrl Shift I(在Windows/Linux上)或Command Option I(在Mac上)。 界面概览: 熟悉DevTools的基本面板,如“…