#include<iostream> #include <opencv2/opencv.hpp> #include <math.h> using namespace cv; using namespace std; ////该代码实现白平衡算法中的灰度世界法,能有效改善图像发红发蓝发绿的现象: #include <opencv2/opencv.hpp> using namespace cv; int main() { Mat g_srcImage,dstIm…
在用OpenCV对图像进行处理时,利用颜色定位是常常会接触到的方法,但RGB受光照影响比较严重,转换到HSV XYZ等空间也解决不了时, 可以用白平衡算法进行修正,使其发黄.发蓝.发红的照片更加趋于自然光下的图像.(转摘请说明来源) 程序代码示例如下: //该代码实现白平衡算法中的灰度世界法,能有效改善图像发红发蓝发绿的现象: #include <opencv2/opencv.hpp> using namespace cv; int main() { Mat g_srcImage,dstIma…
彩色相机内部有三个CCD电子耦合元件,分别用来感受红绿蓝三中颜色的光线,默认情况下,三个颜色的感光电路信号的放大比例是1:1:1的.在理想的拍摄环境下,纯白色的RGB分量按照1:1:1的比例放大之后,得到的是没有偏色的白色,当在非理想的环境光条件下,白色成像出来的效果会偏向环境光的颜色,而不是纯白色. 相机的自动白平衡就是要通过改变RGB感光电路信号的放大比例,让受环境光影响的白色还原成纯白色,保证在各种光线条件下,成像色彩跟物体真实的色彩保持一致. 常用的一种自动白平衡算法是灰度世界法,它假设…
% matlab彩色图像分离通道并合并成处理后的彩色图像(彩色变灰度再变彩色) % 白平衡算法(灰度世界法)消除RGB受光照影响 clear all; close all; %读入原始图像 srcImage = imread('7.jpg'); figure,imshow(srcImage); srcImageGray = rgb2gray(srcImage); figure,imshow(srcImageGray); %白平衡算法 R = srcImage(:,:,); G = srcImag…
分水岭算法是一种图像区域分割法,在分割的过程中,它会把跟临近像素间的相似性作为重要的参考依据,从而将在空间位置上相近并且灰度值相近的像素点互相连接起来构成一个封闭的轮廓,封闭性是分水岭算法的一个重要特征. 其他图像分割方法,如阈值,边缘检测等都不会考虑像素在空间关系上的相似性和封闭性这一概念,彼此像素间互相独立,没有统一性.分水岭算法较其他分割方法更具有思想性,更符合人眼对图像的印象. 其他关于分水岭"聚水盆地"."水坝"."分水线"等概念不准备…
上一节链接:http://www.cnblogs.com/zjutlitao/p/4116783.html 前言: 在上一节中我们已经大致介绍了该软件的是什么.可以干什么以及界面的大致样子.此外还详细地介绍了Bresenham直线扫描算法的核心思想及实现,并在最终在2-1小节引出工程中对于该算法具体的实现.本节将着手讲解多边形填充算法. 二.承接上篇 2-1.多边形扫描转换 把顶点表示转换为点阵表示:①从多边形的给定边界出发,求出其内部的各个像素:②并给帧缓冲器中各个对应元素设置相应灰度或颜色 …
一种效果很好的自动白平衡技术(WhiteBalance) 白平衡是图像处理的一个极重要概念.所谓白平衡(英文名称为White Balance),就是对白色物体的还原.当我们用肉眼观看这大千世界时,在不同的光线下,对相同的颜色的感觉基本是相同的,比如在早晨旭日初升时,我们看一个白色的物体,感到它是白的:而我们在夜晚昏暗的灯光下,看到的白色物体,感到它仍然是白的.这是由于人类从出生以后的成长过程中,人的大脑已经对不同光线下的物体的彩色还原有了适应性.但是,作为拍摄设备,如数码相机,可没有人眼的适应性…
http://www.cnblogs.com/tiandsp/archive/2013/04/20/3031862.html [学习opencv]高斯.中值.均值.双边滤波 四种经典滤波算法,在opencv文档中都能找到的,熟悉一下调用规范. #include "cv.h" #include "highgui.h" #include <iostream> using namespace std; using namespace cv; int main(…
简介 K近邻法(knn)是一种基本的分类与回归方法.k-means是一种简单而有效的聚类方法.虽然两者用途不同.解决的问题不同,但是在算法上有很多相似性,于是将二者放在一起,这样能够更好地对比二者的异同. 算法描述 knn 算法思路:如果一个样本在特征空间中的k个最相似(即特征空间中最邻近)的样本中的大多数属于某一个类别,则该样本也属于这个类别. k近邻模型的三个基本要素: k值的选择:k值的选择会对结果产生重大影响.较小的k值可以减少近似误差,但是会增加估计误差:较大的k值可以减小估计误差,但…
Java中  Set 和 List 集合  的contains()方法,检查数组链表中是否包含某元素检查数组链表中是否包含某元素,使用 Set 而不使用 List  的原因是效率问题, 前者的 set.contains()方法 实现的复杂度是O(1). 而后者 list.contains()方法 实现的复杂度是O(n) List特点: 元素有放入顺序,元素可重复 , Set特点: 元素无放入顺序,元素不可重复( 注意:元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的…