前言

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

MATLAB代码如下:

% /************************************************************************
% * Copyright(c) 2017 ZRJ
% * All rights reserved.
% *
% * File: isGreen.m
% * Brief: 车号区域颜色信息判断算法
% * Version: 1.0
% * Author: ZRJ
% * Email: happyamyhope@163.com
% * Date: 2017/03/28
% * Reference:
% * History:
% * 20170328:得到ROI的颜色信息;
%
% ************************************************************************/
function [ ] = isGreen( )
%程序功能:车号区域颜色信息判断算法;
%输入input:
% roi -- roi color image;
%输出output:
% flip -- flip flag; roi = 'E:\carriage_recognition\train_identification\ROI1095\';
roi_path = [roi,'ROI原图\'];
roi_format = '*.png';
roi_list = dir(strcat(roi_path, roi_format));
roi_num = length(roi_list);%获取图像总数量 for num = 1 : roi_num %逐一读取图像
% num
close all
% HSV颜色信息提取
% roi_name = roi_list(num).name;% 图像名
% roi_image = imread(strcat(roi_path, roi_name));%读取图像
roi_name = [int2str(num), '_number_ROI.png'];
roi_image = imread([roi_path, roi_name]);
%RGB2HSV of ROI
hsv_f = rgb2hsv(roi_image);
H = hsv_f(:,:,1)*180;
S = hsv_f(:,:,2)*255;
V = hsv_f(:,:,3)*255;
[y,x,z]=size(roi_image);
green = 0;
yellow = 0;
for i=1:y
for j=1:x
if(((H(i,j)>=40)&&(H(i,j)<=75)) && (S(i,j)>=60)&&(S(i,j)<=255) && (V(i,j)>=55)&&(V(i,j)<=255))
green = green + 1;%绿像素点统计
elseif(((H(i,j)>=27)&&(H(i,j,1)<=33)) &&(S(i,j)>=60)&&(S(i,j)<=255) && (V(i,j)>=80)&&(V(i,j)<=255))
yellow = yellow + 1;%黄像素点统计
end
end
end ss = x * y;
ratio_g = green *100/ ss;
ratio = (green + yellow) *100/ ss;
flip = 0;
if( ratio > 0.04 && ratio_g > 0.0004 )
flip = 1;
end if ( flip )
bw_name = [roi_name(1: end-4), '_flip'];
imwrite(roi_image, [roi, 'green\', bw_name,'.png']);
end end % end for end % end function

问题总结:

1.注意不同颜色H/S/V的范围,可以根据实际情况设置;

2.matlab自带的rgb2hsv函数的输出范围是[0 1];

3.判断是否反转的阈值需要根据具体的情况进行设定;

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

  1. 判断颜色信息-RGB2HSV(opencv)

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

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

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

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

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

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

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

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

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

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

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

  7. js判断设备信息,安卓、ios、还是pc端

    前端开发获取设备信息的代码if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) { window.location.href =" ...

  8. 00ff00 颜色信息

    RGB 0, 255, 0 百分比 0.0%, 100.0%, 0.0% 十六进制 00ff00 十进制 65280 二进制 00000000,11111111,00000000 CMYK 100.0 ...

  9. 74859a颜色信息

    74859a十进制的RGB值为R:116, G:133, B:154. CMYK值为C:24.675, M:13.636, Y: 0.0, K: 39.608 RGB 116, 133, 154 百分 ...

随机推荐

  1. Jmeter 中多线程并发和循环控制器

    今天遇到一个场景, 给一个手机号发送短信验证码,通过正确输入短信验证码即登录并获得token,进行其他操作. 短信验证码是4位,即9999个组合, 接口没有对验证次数做校验,所以可以一直一直尝试通过验 ...

  2. tp3.x和tp 5的区别

    由于TP5.0是一个全新的颠覆重构版本,所以现在面试很多面试官喜欢问TP3.2和TP5之间的区别,那他们之间到底有哪些区别呢?一.目录  TP5目录 二.需要摒弃的 3.X 旧思想 模型的变动     ...

  3. [.NET开发] C# 如何在PDF文档中创建表格

    表格能够直观的传达数据信息,使信息显得条理化,便于阅读同时也利于管理.那在PDF类型的文档中如何来添加表格并且对表格进行格式化操作呢?使用常规方法直接在PDF中添加表格行不通,那我们可以在借助第三方组 ...

  4. English trip -- VC(情景课)4 D

    What do you see? I can see three men in the pictrue. one older man is a doctor, two younger men are ...

  5. LeetCode--155--最小栈

    问题描述: 设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈. push(x) -- 将元素 x 推入栈中. pop() -- 删除栈顶的元素. top() -- 获取 ...

  6. 49 BOM 和DOM

    一.BOM window 对象  1.确认,输入,    window.alert(123) // 弹框    let ret = window.confirm("是否删除") / ...

  7. kmp练习

    kmp板子如下, 失配数组不优化的话, $f_i$就表示子串[0...i]前后缀最大匹配长度 int main() { scanf("%s%s", t, p); int n = s ...

  8. Cloud Commander

    一.Cloud Commander简介: Cloud Commander 是一个基于 web 的文件管理程序,它允许你通过任何计算机.移动端或平板电脑的浏览器查看.访问或管理系统文件或文件夹.它有两个 ...

  9. mysql语句查询时间检测

    explain的使用 1.首先我们是要登入你的mysql的,然后选择数据库输入:use 你要选择的库名 2执行语句 eg:  explain SELECT * FROM wish_orders1412 ...

  10. POJ 1014 Dividing (多重可行性背包)

    题意 有分别价值为1,2,3,4,5,6的6种物品,输入6个数字,表示相应价值的物品的数量,问一下能不能将物品分成两份,是两份的总价值相等,其中一个物品不能切开,只能分给其中的某一方,当输入六个0是( ...