opencv直方图均衡化
#include <iostream>
#include "highgui.h"
#include "cv.h"
#include "cxcore.h"
#include "math.h"
using namespace std;
using namespace cv;
//绘制1维直方图
Mat draw1DHistogram(Mat histogramMat) {
double maxVal = 0, minVal = 0;
minMaxLoc(histogramMat, &minVal, &maxVal, 0, 0);
Mat histImage(histogramMat.rows, histogramMat.rows, CV_8U, Scalar(255));
int hpt = static_cast<int>(0.9 * histogramMat.rows);
for (int h = 0; h < histogramMat.rows; h++) {
float binVal = histogramMat.at<float>(h);
int intensity = static_cast<int>((binVal / maxVal) * hpt);
line(histImage, Point(h, histogramMat.rows - 1),
Point(h, histogramMat.rows - 1 - intensity), Scalar::all(0));
}
return histImage;
}
//一维直方图计算(采用实际图像) 实验2
void get1DHistogramExperiment2(Mat& image) {
//计算直方图 使用的图片数量
int nImageArrays = 1;
//使用的直方图数组
Mat* imageArrays = new Mat[nImageArrays];
//加载实际图像
// Mat image = imread("e:\\citywall1.bmp", 0);
if (image.data == NULL) {
printf("加载图像失败\n");
return;
}
imageArrays[0] = image;
//直方图的维数
const int dims = 1;
//在图像的通道序列中 本次直方图计算使用了哪些通道,本代码中使用了编号为0的通道
int channels[dims] = { 0 };
//直方图中每一维上的bin数,本代码是创建一维直方图 并且 分为256个bin
int histBins[dims] = { 256 };
//保存直方图的结果 CV_32F,dims说明矩阵的维度,histBins说明矩阵每一维上的大小
Mat histND(dims, histBins, CV_32F, Scalar::all(0));
//手动指定各个bin的取值范围
//float image1Range[5]={0.0,50.0,200.0,220.0,256.0};
//统一分割,只需要指定bin[0]的下限值和bin[histBins[dims-1]-1]的上限值即可
float image1Range[5] = { 0.0, 256.0 };
//各个通道的 bin划分规则
const float* allRanges[dims] = { image1Range };
//直方图计算
calcHist(imageArrays, nImageArrays, channels, Mat(), histND, dims, histBins,
allRanges, true);
//绘制直方图
Mat histImage = draw1DHistogram(histND);
//显示直方图
namedWindow("hist");
imshow("hist", histImage);
waitKey(0);
}
/**
* 直方图均衡
*/
void HistogramEqual(Mat& src){
Mat dst;
equalizeHist(src,dst); //直方图均衡化
get1DHistogramExperiment2(dst);
namedWindow("equal");
imshow("equal",dst);
waitKey(0);
}
int main() {
Mat image = imread("e:\\test.bmp", CV_LOAD_IMAGE_GRAYSCALE);
namedWindow("src");
imshow("src",image);
get1DHistogramExperiment2(image);
HistogramEqual(image);
return 0;
}
opencv直方图均衡化的更多相关文章
- OpenCV——直方图均衡化(用于图像增强)
#include <opencv2/opencv.hpp> #include <iostream> #include <math.h> using namespac ...
- opencv::直方图均衡化
直方图均衡化 图像直方图: 是指对整个图像像在灰度范围内的像素值是指对整个图像像在灰度范围内的像素值(~)统计出现频率次数,据此生成的直方图,称为图像直方图-直方图. 直方图反映了图像灰度的分布情况. ...
- OpenCV-Python教程(10、直方图均衡化)
相比C++而言,Python适合做原型.本系列的文章介绍如何在Python中用OpenCV图形库,以及与C++调用相应OpenCV函数的不同之处.这篇文章介绍在Python中使用OpenCV和NumP ...
- opencv 彩色图像亮度、对比度调节 直方图均衡化
直接上代码: #include <Windows.h> #include <iostream>// for stand I/O #include <string> ...
- OpenCV图像增强算法实现(直方图均衡化、拉普拉斯、Log、Gamma)
http://blog.csdn.net/dcrmg/article/details/53677739 1. 基于直方图均衡化的图像增强 直方图均衡化是通过调整图像的灰阶分布,使得在0~255灰阶 ...
- 直方图均衡化的 C++ 实现(基于 openCV)
这是数字图像处理课的大作业,完成于 2013/06/17,需要调用 openCV 库,完整源码和报告如下: #include <cv.h> #include <highgui.h&g ...
- opencv图像直方图均衡化及其原理
直方图均衡化是什么有什么用 先说什么是直方图均衡化,通俗的说,以灰度图为例,原图的某一个像素为x,经过某个函数变为y.形成新的图.新的图的灰度值的分布是均匀的,这个过程就叫直方图均衡化. 图像直方图均 ...
- opencv 5 图像转换(3 重映射 仿射变换 直方图均衡化)
重映射 实现重映射(remap函数) 基础示例程序:基本重映射 //---------------------------------[头文件.命名空间包含部分]------------------- ...
- opencv —— equalizeHist 直方图均衡化实现对比度增强
直方图均匀化简介 从这张未经处理的灰度图可以看出,其灰度集中在非常小的一个范围内.这就导致了图片的强弱对比不强烈. 直方图均衡化的目的,就是把原始的直方图变换为在整个灰度范围(0~255)内均匀分布的 ...
随机推荐
- BZOJ 1935 园丁的烦恼
离线,BIT. #include<iostream> #include<cstdio> #include<cstring> #include<algorith ...
- php里少用到的session_module_name,以及session的key值限制,简单将session存储为json格式数据的方法
这个函数的作用就是动态的设置php.ini里的session_save_handler,配合session_set_savepath可以在程序里自由配置session的后台方式. session_ca ...
- ORACLE CONTROL FILE 笔记
控制文件包含的信息: 1.数据库的名字 2.联机重做日志文件和数据文件的名字和位置 3.数据库创建的时间戳 4.当前日志的序列号 5.检查点信息 6.备份信息 TIP:数据 ...
- 【转】linux设备驱动程序中的阻塞机制
原文网址:http://www.cnblogs.com/geneil/archive/2011/12/04/2275272.html 阻塞与非阻塞是设备访问的两种方式.在写阻塞与非阻塞的驱动程序时,经 ...
- delphi TeeChart保存3种图片文件
var vForm: Tfrm_ChemaShowMainChild;begin vForm := GetActiveForm; vForm.cht_Edit.SaveToMetafile('C:\1 ...
- 《Python 学习手册4th》 第十九章 函数的高级话题
''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点 ...
- CMDB反思4
CMDB模型设计2 http://blog.vsharing.com/xqscool/A1275233.html 估计大家看到破子的这两篇都有点晕哈,我也有点晕. 两篇对比来看. 第1处,属性部分 ...
- C#判断程序是由Windows服务启动还是用户启动
在Windows系统做网络开发,很多时候都是使用Windows服务的模式,但在调度阶段,我们更多的是使用控制台的模式.在开发程序的时候,我们在Program的Main入口进行判断.最初开始使用Envi ...
- fopen警告处理方式
warning C4996: “fopen”被声明为否决的 问题:vs2005中编程时,遇到如下: warning C4996: “fopen”被声明为否决的. 解释:微软的警告,主要是那些都是C库的 ...
- vim 配置语法高亮 行号标示
配置VIM主要是开启VIM的语法高亮和行号标示,因为默认在用户目录(~)下没有vimrc,所以需要先去复制一个,然后再编辑 cp /etc/vim/vimrc ~/.vimrc vim .vimrc ...