前言

项目车号识别过程中,车体有三种颜色黑车黑底白字、红车红底白字、绿车黄底绿字,可以通过判断车体的颜色信息,从而判断二值化是否需要反转,主要是基于rgb2hsv函数进行不同颜色的阈值判断。

matlab代码可参考:

http://www.cnblogs.com/happyamyhope/p/6650920.html

与matlab中的rgb2hsv函数功能相同的opencv代码:

vector<Mat> rgb2hsv(Mat image){
vector<Mat> image_rgb;
vector<Mat> hsv();
split(image, image_rgb);
Mat B = (Mat_<double>)image_rgb.at() / ;
Mat G = (Mat_<double>)image_rgb.at() / ;
Mat R = (Mat_<double>)image_rgb.at() / ;
Mat_<double> H(image.rows, image.cols, );
Mat_<double> S(image.rows, image.cols, );
Mat_<double> V(image.rows, image.cols, ); for (int m = ; m <image.rows; m++)
{
for (int n = ; n < image.cols; n++)
{
double var_B = B.at<double>(m, n);//image.at<cv::Vec3b>(j,i)[0];;B.data[m, n]
double var_G = G.at<double>(m, n);
double var_R = R.at<double>(m, n);
//double var_Min=0;
//double var_Max=100;
double var_Min = min(var_R, min(var_G, var_B)); //Min. value of RGB
double var_Max = max(var_R, max(var_G, var_B)); //Max. value of RGB
double del_Max = var_Max - var_Min; //Delta RGB value
V.at<double>(m, n) = var_Max; if (del_Max == 0.0) //This is a gray, no chroma...
{
H.at<double>(m, n) = 0.0; //HSV results from 0 to 1
S.at<double>(m, n) = 0.0;
}
else //Chromatic data...
{
if (var_Max == 0.0)
{
S.at<double>(m, n) = 0.0;
}
else{
S.at<double>(m, n) = del_Max / var_Max;
} if (var_R == var_Max) H.at<double>(m, n) = (var_G - var_B) / del_Max;
else if (var_G == var_Max) H.at<double>(m, n) = + (var_B - var_R) / del_Max;
else if (var_B == var_Max) H.at<double>(m, n) = + (var_R - var_G) / del_Max; H.at<double>(m, n) /= ;
if (H.at<double>(m, n) < ) H.at<double>(m, n) += 1.0; } } } // end for
hsv.at() = H;
hsv.at() = S;
hsv.at() = V;
return hsv; }

子函数程序代码:

bool isGreen(Mat image){

    vector< Mat > hsv_vec;//Mat M(7,7,CV_32FC2,Scalar(1,3));  

    //判断图像非空
if (image.channels() < )
{
std::cout << "ROI Image Error! " << std::endl;
return false;
} ofstream outfile("E:\\carriage_recognition\\train_identification\\ROI1095\\HSV.xls");
Mat h = hsv_vec.at()*;
Mat s = hsv_vec.at()*;
Mat v = hsv_vec.at()*; unsigned int green = ;
unsigned int yellow = ;
double hout = ;
double sout = ;
double vout = ;
double ratio_g = ;
double ratio = ;
for (int m = ; m < image.rows; m++)
{
for (int n = ; n < image.cols; n++)
{ hout = h.at<double>(m, n);
sout = s.at<double>(m, n);
vout = v.at<double>(m, n);
if ((hout >= && hout <= ) && (sout >= ) && (vout >= ))
green++;
else if ((hout >= && hout <= ) && (sout >= ) && (vout >= ))
yellow++;
//cout << m << "\t" << n << "\t" << hout << "\t" << sout << "\t" << vout << endl;
outfile << m << "\t" << n << "\t" << hout << "\t" << sout << "\t" << vout << "\t";
outfile << endl;
}
//outfile << endl;
}
ratio_g = (double)green * / (image.rows*image.cols);
ratio = (double)(green + yellow) * / (image.rows*image.cols); if ( ratio > 0.04 && ratio_g > 0.0004 )
return true;
else
return false; }

主程序代码:

/************************************************************************
* Copyright(c) 2016 ZRJ
* All rights reserved.
*
* File: isGreen.cpp
* Brief:
* Version: 1.0
* Author: ZRJ
* Email: happyamyhope@163.com
* Date: 2017/03/29
* History:
* 20170329: 颜色识别; ************************************************************************/
//-------------------------------------------------------------------------
//头文件
#include <iostream>
#include <vector>
#include<time.h>
#include <fstream>
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp" using namespace cv;
using namespace std; //-----------------------------------------------------------------------
//调参 //---------------------------------------------------------------------------------
//函数声明
bool isGreen(Mat image);
vector<Mat> rgb2hsv(Mat image);
//-----------------------------------------------------------------------------------------
//函数定义
int main(int argc, char** argv)
{
char image_path[];
char green_path[];
///处理图像 for (int i = ; i <= ; i++)
{
//获取图像帧
cout << i << endl;
sprintf(image_path, "E:\\carriage_recognition\\train_identification\\ROI1095\\ROI原图\\%d_number_ROI.png", i);
sprintf(green_path, "E:\\carriage_recognition\\train_identification\\ROI1095\\green原图\\%d_number_ROI.png", i);
Mat image = imread(image_path, );
bool flag = isGreen( image );
if ( flag )
imwrite(green_path, image); }//end for
//clock_t end = clock();
//double interval = (double)(end - begin) / CLOCKS_PER_SEC;
//cout << "处理图像耗时: " << interval << endl;
return ; }

问题总结:

1.opencv中的cvtColor(image, hsv, CV_BGR2HSV, 0);语句与matlab函数的输出数据类型有些微差别;

2.自己编写的rgb2hsv函数的运行速度很慢,难以保证实际场景的实时性,后续需要优化;

3.rgb2hsv的公式转换问题,需要仔细研读matlab函数代码;

也可参考:http://www.easyrgb.com/index.php?X=MATH&H=20#text20

4.将数据保存在.xls中,方便与matlab的输出结果进行比较;

判断颜色信息-RGB2HSV(opencv)的更多相关文章

  1. 判断颜色信息-RGB2HSV

    前言 项目车号识别过程中,车体有三种颜色黑车黑底白字.红车红底白字.绿车黄底绿字,可以通过判断车体的颜色信息,从而判断二值化是否需要反转,主要是基于rgb2hsv函数进行不同颜色的阈值判断. MATL ...

  2. Kinect SDK(1):读取彩色、深度、骨骼信息并用OpenCV显示

    Kinect SDK 读取彩色.深度.骨骼信息并用OpenCV显示 一.原理说明 对于原理相信大家都明白大致的情况,因此,在此只说比较特别的部分. 1.1 深度流数据: 深度数据流所提供的图像帧中,每 ...

  3. .NET C#生成随机颜色,可以控制亮度,生成暗色或者亮色 基于YUV模式判断颜色明亮度

    .NET C#生成随机颜色,可以控制亮度,生成暗色或者亮色 基于YUV模式判断颜色明亮度   随机颜色在日常开发中很常用到,有时候要控制颜色明亮度,比如在白色背景网页上的随机颜色,一般要求颜色稍微暗一 ...

  4. JAVASCRIPT和JQUERY判断浏览器信息总汇(备忘)

    <script type="text/javascript">        //jquery判断浏览器信息        $(function(){          ...

  5. JS 通过 navigator获取判断浏览器信息

    获取浏览器信息需要使用navigator.userAgent 对象 根据获取到的内容判断浏览器信息 亲身测试 navigator.userAgent IE 11  Mozilla/5.0 (Windo ...

  6. 提取bmp图片的颜色信息,可直接framebuffer显示(c版本与python版本)

    稍微了解了下linux的framebuffer,这是一种很简单的显示接口,直接写入像素信息即可 配置好的内核,会有/dev/fbn 的接口,于是想能否提前生成一个文件,比如logo.fb,里面仅包含像 ...

  7. 使用dcmtk库读取.dcm文件并获取信息+使用OpenCV显示图像

    借助VS2013和OpenCV的绘图功能,在工程DICOMReader.sln中实现了对单张.dcm图像的读取与显示,以下是详细步骤. 前期准备工作 编译器:VS2013 库:dcmtk-3.6.0( ...

  8. 图片模糊度判断程序(C++、opencv)

    //#include<opencv2\opencv.hpp> //using namespace cv; #include <opencv2/core/core.hpp> #i ...

  9. python脚本实例001 - 通过列表内容判断输入输出信息

    要点总结: 输入输出方法,input().print()方法 list列表应用,list是一种有序的集合,可以随时添加和删除其中的元素. 条件语句if-else应用 #! /usr/bin/pytho ...

随机推荐

  1. 《WAP团队项目需求分析改进》

    基于原型的团队项目需求调研与分析 本项目是一个家教系统的实现,随着时代的进步,现今已经进入信息技术时代,越来越多的人注意到了教育的重要性.家长对于孩子的学习提高注意力,大家都不想自己的孩子输在起跑线上 ...

  2. 《Blue_Flke》 团队项目用户验收评审

    一.beta冲刺 beta冲刺第一.二天:https://www.cnblogs.com/ruanjgc/p/9226434.html beta冲刺第三天:https://www.cnblogs.co ...

  3. angular5 生命周期钩子函数

    生命周期执行顺序ngOnChanges 在有输入属性的情况下才会调用,该方法接受当前和上一属性值的SimpleChanges对象.如果有输入属性,会在ngOnInit之前调用. ngOnInit 在组 ...

  4. TimeZone 时区 (JS .NET JSON MYSQL) + work week 闰年

    来源参考 : http://www.cnblogs.com/qiuyi21/archive/2008/03/04/1089456.html 来源参考 : http://walkingice.blogs ...

  5. Java 常用对象-System类

    2017-11-02 21:41:06 System类:System 类包含一些有用的类字段和方法.它不能被实例化. *常用方法 public static void gc() 运行垃圾回收器. 调用 ...

  6. oracle使用(1)

    纯粹是记录工作中使用的分析函数或是语法点,不做其他用处. (1) with as 先举个例子吧: 有两张表,分别为A.B,求得一个字段的值先在表A中寻找,如果A表中存在数据,则输出A表的值:如果A表中 ...

  7. codeforces 578c//Weakness and Poorness// Codeforces Round #320 (Div. 1)

    题意:一个数组arr,一个数字x,要使arr-x的最大子段最小,问该最小值. 三分x,复杂度logn,内层是最大子段的模板,只能用n复杂度的.因为是绝对值最大,正负各求一次,取大的.精度卡得不得了,要 ...

  8. spfa毒瘤算法

    终于知道怎么卡spfa(不优化)这一毒瘤算法了 下面就是造数据代码,点数才1e5,边数379980 随便测了一组数据: count: 831841219(入队次数) 68917.096 ms(足够t到 ...

  9. 检测Linux glibc幽灵漏洞和修补漏洞

    1.首先安装rpm : sudo apt-get install rpm   wget -OGHOST-test.sh http://www.antian365.com/lab/linux0day/G ...

  10. Mysql查询用逗号分隔的字段-字符串函数FIND_IN_SET(),以及此函数与in()函数的区别

    查询用逗号分隔的字段,可以用字符串函数FIND_IN_SET(): 查询数据库表中某个字段(值分行显示),可以用函数in(). 今天工作中遇到一个问题,就是用FIND_IN_SET()函数解决的. 第 ...