简单的图像显著性区域特征提取方法-----opencv实现LC,AC,FT
https://blog.csdn.net/cai13160674275/article/details/72991049?locationNum=7&fps=1
四种简单的图像显著性区域特征提取方法-----> AC/HC/LC/FT。
- void SalientRegionDetectionBasedonLC(Mat &src){
- int HistGram[256]={0};
- int row=src.rows,col=src.cols;
- int gray[row][col];
- //int Sal_org[row][col];
- int val;
- Mat Sal=Mat::zeros(src.size(),CV_8UC1 );
- Point3_<uchar>* p;
- for (int i=0;i<row;i++){
- for (int j=0;j<col;j++){
- p=src.ptr<Point3_<uchar> > (i,j);
- val=(p->x + (p->y) *2 + p->z)/4;
- HistGram[val]++;
- gray[i][j]=val;
- }
- }
- int Dist[256];
- int Y,X;
- int max_gray=0;
- int min_gray=1<<28;
- for (Y = 0; Y < 256; Y++)
- {
- val = 0;
- for (X = 0; X < 256; X++)
- val += abs(Y - X) * HistGram[X]; // 论文公式(9),灰度的距离只有绝对值,这里其实可以优化速度,但计算量不大,没必要了
- Dist[Y] = val;
- max_gray=max(max_gray,val);
- min_gray=min(min_gray,val);
- }
- for (Y = 0; Y < row; Y++)
- {
- for (X = 0; X < col; X++)
- {
- Sal.at<uchar>(Y,X) = (Dist[gray[Y][X]] - min_gray)*255/(max_gray - min_gray); // 计算全图每个像素的显著性
- //Sal.at<uchar>(Y,X) = (Dist[gray[Y][X]])*255/(max_gray); // 计算全图每个像素的显著性
- }
- }
- imshow("sal",Sal);
- waitKey(0);
- }
2.AC算法也挺有意思,利用了类似图像金字塔算法,在不同纬度(具体实现是用大小不同的均值滤波器过滤图像)与标准图像做差并累加,然后归一化,实现如下:
- void SalientRegionDetectionBasedonAC(Mat &src,int MinR2, int MaxR2,int Scale){
- Mat Lab;
- cvtColor(src, Lab, CV_BGR2Lab);
- int row=src.rows,col=src.cols;
- int Sal_org[row][col];
- memset(Sal_org,0,sizeof(Sal_org));
- Mat Sal=Mat::zeros(src.size(),CV_8UC1 );
- Point3_<uchar>* p;
- Point3_<uchar>* p1;
- int val;
- Mat filter;
- int max_v=0;
- int min_v=1<<28;
- for (int k=0;k<Scale;k++){
- int len=(MaxR2 - MinR2) * k / (Scale - 1) + MinR2;
- blur(Lab, filter, Size(len,len ));
- for (int i=0;i<row;i++){
- for (int j=0;j<col;j++){
- p=Lab.ptr<Point3_<uchar> > (i,j);
- p1=filter.ptr<Point3_<uchar> > (i,j);
- //cout<<(p->x - p1->x)*(p->x - p1->x)+ (p->y - p1->y)*(p->y-p1->y) + (p->z - p1->z)*(p->z - p1->z) <<" ";
- val=sqrt( (p->x - p1->x)*(p->x - p1->x)+ (p->y - p1->y)*(p->y-p1->y) + (p->z - p1->z)*(p->z - p1->z) );
- Sal_org[i][j]+=val;
- if(k==Scale-1){
- max_v=max(max_v,Sal_org[i][j]);
- min_v=min(min_v,Sal_org[i][j]);
- }
- }
- }
- }
- cout<<max_v<<" "<<min_v<<endl;
- int X,Y;
- for (Y = 0; Y < row; Y++)
- {
- for (X = 0; X < col; X++)
- {
- Sal.at<uchar>(Y,X) = (Sal_org[Y][X] - min_v)*255/(max_v - min_v); // 计算全图每个像素的显著性
- //Sal.at<uchar>(Y,X) = (Dist[gray[Y][X]])*255/(max_gray); // 计算全图每个像素的显著性
- }
- }
- imshow("sal",Sal);
- waitKey(0);
- }
SalientRegionDetectionBasedonAC(test,test.rows/8,test.rows/2,3);
- void SalientRegionDetectionBasedonFT(Mat &src){
- Mat Lab;
- cvtColor(src, Lab, CV_BGR2Lab);
- int row=src.rows,col=src.cols;
- int Sal_org[row][col];
- memset(Sal_org,0,sizeof(Sal_org));
- Point3_<uchar>* p;
- int MeanL=0,Meana=0,Meanb=0;
- for (int i=0;i<row;i++){
- for (int j=0;j<col;j++){
- p=Lab.ptr<Point3_<uchar> > (i,j);
- MeanL+=p->x;
- Meana+=p->y;
- Meanb+=p->z;
- }
- }
- MeanL/=(row*col);
- Meana/=(row*col);
- Meanb/=(row*col);
- GaussianBlur(Lab,Lab,Size(3,3),0,0);
- Mat Sal=Mat::zeros(src.size(),CV_8UC1 );
- int val;
- int max_v=0;
- int min_v=1<<28;
- for (int i=0;i<row;i++){
- for (int j=0;j<col;j++){
- p=Lab.ptr<Point3_<uchar> > (i,j);
- val=sqrt( (MeanL - p->x)*(MeanL - p->x)+ (p->y - Meana)*(p->y-Meana) + (p->z - Meanb)*(p->z - Meanb) );
- Sal_org[i][j]=val;
- max_v=max(max_v,val);
- min_v=min(min_v,val);
- }
- }
- cout<<max_v<<" "<<min_v<<endl;
- int X,Y;
- for (Y = 0; Y < row; Y++)
- {
- for (X = 0; X < col; X++)
- {
- Sal.at<uchar>(Y,X) = (Sal_org[Y][X] - min_v)*255/(max_v - min_v); // 计算全图每个像素的显著性
- //Sal.at<uchar>(Y,X) = (Dist[gray[Y][X]])*255/(max_gray); // 计算全图每个像素的显著性
- }
- }
- imshow("sal",Sal);
- waitKey(0);
- }
简单的图像显著性区域特征提取方法-----opencv实现LC,AC,FT的更多相关文章
- 四种比较简单的图像显著性区域特征提取方法原理及实现-----> AC/HC/LC/FT。
laviewpbt 2014.8.4 编辑 Email:laviewpbt@sina.com QQ:33184777 最近闲来蛋痛,看了一些显著性检测的文章,只是简单的看看,并没有深入的研究,以 ...
- 四种简单的图像显著性区域特征提取方法-----AC/HC/LC/FT。
四种简单的图像显著性区域特征提取方法-----> AC/HC/LC/FT. 分类: 图像处理 2014-08-03 12:40 4088人阅读 评论(4) 收藏 举报 salient regio ...
- 图像局部显著性—点特征(SURF)
1999年的SIFT(ICCV 1999,并改进发表于IJCV 2004,本文描述):参考描述:图像特征点描述. 参考原文:SURF特征提取分析 本文有大量删除,如有疑义,请参考原文. SURF对SI ...
- 基于qml创建最简单的图像处理程序(3)-使用opencv&qml进行图像处理
<基于qml创建最简单的图像处理程序>系列课程及配套代码基于qml创建最简单的图像处理程序(1)-基于qml创建界面http://www.cnblogs.com/jsxyhelu/p/83 ...
- Python下opencv使用笔记(二)(简单几何图像绘制)
简单几何图像一般包含点.直线.矩阵.圆.椭圆.多边形等等.首先认识一下opencv对像素点的定义. 图像的一个像素点有1或者3个值.对灰度图像有一个灰度值,对彩色图像有3个值组成一个像素值.他们表现出 ...
- 图像局部显著性—点特征(GLOH)
基于古老的Marr视觉理论,视觉识别和场景重建的基础即第一阶段为局部显著性探测.探测到的主要特征为直觉上可刺激底层视觉的局部显著性--特征点.特征线.特征块. 相关介绍:局部特征显著性-点特征(SIF ...
- 图像显著性论文(一)—A Model of saliency Based Visual Attention for Rapid Scene Analysis
这篇文章是图像显著性领域最具代表性的文章,是在1998年Itti等人提出来的,到目前为止引用的次数超过了5000,是多么可怕的数字,在它的基础上发展起来的有关图像显著性论文更是数不胜数,论文的提出主要 ...
- Python用Pillow(PIL)进行简单的图像操作
Python用Pillow(PIL)进行简单的图像操作 颜色与RGBA值 计算机通常将图像表示为RGB值,或者再加上alpha值(通透度,透明度),称为RGBA值.在Pillow中,RGBA的值表示为 ...
- 图像的全局特征--HOG特征、DPM特征
HOG特征:方向梯度直方图(Histogram of Oriented Gradient,)特征是一种全局图像特征描述子. 它通过计算和统计图像局部区域的梯度方向直方图来构成特征.Hog特征结合SVM ...
随机推荐
- content_type
1.作用 将app名称与其中表关系进行保存 在models创建表时,关联到ContentType并不会产生实际的字段 2.使用 在models中代码 from django.db import mod ...
- sap component 中各个组件的关系
1:
- 命令行方式调用winrar对文件夹进行zip压缩示例代码
调用winRAR进行压缩 using System; using System.Collections.Generic; using System.Linq; using System.Text; u ...
- Navicat 连接Oracle11g时出现ORA-12514:TNS:no listener
前两天做系统时用navicat连接Oracle数据库还好好的,今天一连突然就开始报ORA-12514:TNS:no listener.然后看网上大部分教程需要改listener.ora文件中的 将HO ...
- php 编译安装 mysql.so
编译mysql.so # 进入php-5.2.14源码目录 cd /usr/local/src/php- # 进入 mysql ext 的源码目录 cd ext/mysql # 构建编译配置, 假设p ...
- leetcode 22括号生成
非常好的一道题.一开始的思想是这样的,先把n对括号按照某一顺序生成一个string,然后用全排列算法生成所有可能,然后利用stack写一段判断括号是否匹配的字符串,匹配的假如结果中.不过会超时.因为全 ...
- ElementNotVisibleException: Message: element not visible
selenium自动化测试中,经常会报异常: 可能会有各种疑问,元素可以定位到啊.为什么报以下异常? ElementNotVisibleException: Message: element not ...
- keepalived+双主架构
简介 keepalived是基于VRRP协议的,全称 Virtual Redundent Routing Protocal 虚拟路由协议,为解决静态路由单点故障引起的网络失效问题设计的一套主备协议 两 ...
- hive中安装hive_utils模块
1. 因为在linux部署的python 3.6 在安装模块的时候遇到了许多问题,所以使用linux中的python3.6环境 2. 首先使用pip安装 hive_utils 模块sudo pip i ...
- java 中使用ajax调用后台方法注意事项
java 中使用ajax调用后台方法注意事项,后台方法一定要加@ResponseBody jQuery.validator.addMethod("checkRuleName",fu ...