opencv批处理提取图像的特征
_________________________________________________________________________________________________________________________________
批处理(dir/a/s/b)
例:某文件夹下有a、b、c、d、e、f、g、h、j的图片和一个文件夹JN,里边包括一张图片john.jpg
我们在该文件夹下的命令行中 输入:dir/b
b:仅仅显示当前文件夹下文件名称及文件夹名
a-d:仅仅是显示该文件夹下的文件名称(没有了文件夹的名)
我们在该文件夹下的命令行中 输入:dir/a-d/b
S:显示该文件夹下的文件名称和文件夹名,及子文件夹下的文件名称,并显示这些文件的绝对路径
我们在该文件夹下的命令行中 输入:dir/s/b
我们在该文件夹下的命令行中 输入:dir/s/a-d/b(因为a-d的作用,文件夹JN没有显示出来)
我们在该文件夹下的命令行中 输入:dir/s/a-d/b>F:\文件夹.txt
就会在F盘生成一个文件名称为 文件夹 的.txt文件,该文件包括上面的命令行打出的内容。
—————————————————————————————————————————————————————
第二步:既然已经生成上述文件 文件夹.txt,然会我们敲代码读取这个 文件夹.txt 就可以。
<span style="font-family:Microsoft YaHei;font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">#include<iostream>
#include<fstream>
#include<string>
using namespace std;
int main(int argc,char* argv[])
{
if(argc !=2)
{
cerr << "Wrong Argument !" <<endl;
return -1;
}
//定义文件流。仅仅能读取
ifstream inPutFile(argv[1],ios::in);
if(! inPutFile)
{
cerr << "File Open Erro !" <<endl;
return -1;
}
//读取文件流中的每一行,并赋值给fileName。并在命令行中打印
string fileName ;
/*
測试读取文件里的每一行
*/
//行数
int number = 0;
while (getline(inPutFile,fileName))
{
number ++;
cout<<"第"<< number << "行"<< fileName <<endl;
}
//注意一定要记得关闭文件流
inPutFile.close();
return 0;
}</span></span></span>
我们编译一下:
我们看一下输出结果:
好的,这样,说明我们读到了每一行。
————————————————————————————————————————————————————
第三步:配置Opencv,然后,读取显示每一幅图片
<span style="font-family:Microsoft YaHei;font-size:14px;"><span style="font-family:Microsoft YaHei;font-size:14px;">#include<iostream>
#include<fstream>
#include<string>
using namespace std;
#include<opencv2\imgproc\imgproc.hpp>
#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
using namespace cv;
int main(int argc,char* argv[])
{
if(argc !=2)
{
cerr << "Wrong Argument !" <<endl;
return -1;
}
//定义文件流,仅仅能读取
ifstream inPutFile(argv[1],ios::in);
if(! inPutFile)
{
cerr << "File Open Erro !" <<endl;
return -1;
}
//读取文件流中的每一行,并赋值给fileName。读取每一幅图像并显示
string fileName ;
Mat image;
while (getline(inPutFile,fileName))
{ image = imread(fileName,1);
namedWindow(fileName,1);
imshow(fileName,image);
}
waitKey(0);
//注意一定要记得关闭文件流
inPutFile.close();
return 0;
}</span></span>
结果:
我们看到我们已经成功把每一幅图像读入到内存中,这样我们就能够求每一幅图像的特征。
—————————————————————————————————————————————————————
第四步:我们计算每一幅图像的直方图特征(当然opencv中sift、surf、densesift等,由于我这里的图片大小不一样。所以我用直方图的特征。使得特征向量的长度一样)
<span style="font-family:Microsoft YaHei;font-size:14px;">#include<iostream>
#include<fstream>
#include<string>
using namespace std; #include<opencv2\imgproc\imgproc.hpp>
#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
using namespace cv; //计算二维直方图特征
Mat hist2d(const Mat& src); int main(int argc,char* argv[])
{
if(argc !=2)
{
cerr << "Wrong Argument !" <<endl;
return -1;
}
//定义文件流,仅仅能读取
ifstream inPutFile(argv[1],ios::in);
if(! inPutFile)
{
cerr << "File Open Erro !" <<endl;
return -1;
}
//读取文件流中的每一行,并赋值给fileName,读取每一幅图像并显示
string fileName ;
Mat image;
Mat featureHist;
Mat featureHists;
while (getline(inPutFile,fileName))
{ image = imread(fileName,1);
//计算二维直方图特征
featureHist = hist2d(image);
//按行存储每一幅图像的二维直方图特征
featureHists.push_back(featureHist);
}
//注意一定要记得关闭文件流
inPutFile.close();
return 0;
} Mat hist2d(const Mat& src)
{
Mat hsv; //颜色空间的转换 BGR2HSV
cvtColor(src,hsv,CV_BGR2HSV); //把H通道分为30个bin。把S通道分为32bin
int hbins = 30;
int sbins = 32;
int histSize[] = { hbins , sbins}; //H的取值范围 0-179
float hranges[]= {0,180};
//S的取值范围 0-255
float sranges [] ={0,256};
const float* ranges [] ={hranges,sranges}; Mat hist2D,histRow,histRowDst;
//我们依据图像的第一通道和第二通道,计算二维直方图,并且输出的hist2D为32F
int channels [] ={0,1};
calcHist(&hsv,1,channels,Mat(),hist2D,2,histSize,ranges,true,false);
//把直方图特征按一行来存储
histRow=hist2D.reshape(1,1); //把直方图归一化
normalize(histRow,histRowDst,1,0,NORM_L1); return histRowDst;
}</span>
这样就把全部的图像的二维直方图特征按行存储在featureHists中。
当然能够把二维直方图特征换成自己想要用的随意特征。
—————————————————————————————————————————————————————
第五步:
我们全部图像的颜色直方图存储到.xml文件里,
#include<iostream>
#include<fstream>
#include<string>
using namespace std; #include<opencv2\imgproc\imgproc.hpp>
#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
using namespace cv; //计算二维直方图特征
Mat hist2d(const Mat& src); int main(int argc,char* argv[])
{
if(argc !=2)
{
cerr << "Wrong Argument !" <<endl;
return -1;
}
//定义文件流。仅仅能读取
ifstream inPutFile(argv[1],ios::in);
if(! inPutFile)
{
cerr << "File Open Erro !" <<endl;
return -1;
}
//读取文件流中的每一行。并赋值给fileName。读取每一幅图像并显示
string fileName ;
Mat image;
Mat featureHist;
Mat featureHists;
while (getline(inPutFile,fileName))
{ image = imread(fileName,1);
//计算二维直方图特征
featureHist = hist2d(image);
//按行存储每一幅图像的二维直方图特征
featureHists.push_back(featureHist);
}
//注意一定要记得关闭文件流
inPutFile.close(); /*第五步。把图像特征保存到.xml文件里*/
FileStorage fs("C:\\Users\\zhaoyuan001\\Desktop\\test\\dirtest\\x64\\Debug\\da.xml",FileStorage::WRITE);
fs<<"featureHists"<<featureHists;
fs.release(); return 0;
} Mat hist2d(const Mat& src)
{
Mat hsv; //颜色空间的转换 BGR2HSV
cvtColor(src,hsv,CV_BGR2HSV); //把H通道分为30个bin,把S通道分为32bin
int hbins = 30;
int sbins = 32;
int histSize[] = { hbins , sbins}; //H的取值范围 0-179
float hranges[]= {0,180};
//S的取值范围 0-255
float sranges [] ={0,256};
const float* ranges [] ={hranges,sranges}; Mat hist2D,histRow,histRowDst;
//我们依据图像的第一通道和第二通道,计算二维直方图,并且输出的hist2D为32F
int channels [] ={0,1};
calcHist(&hsv,1,channels,Mat(),hist2D,2,histSize,ranges,true,false);
//把直方图特征按一行来存储
histRow=hist2D.reshape(1,1); //把直方图归一化
normalize(histRow,histRowDst,1,0,NORM_L1); return histRowDst;
}
_______________________________________________________________________________________________________________________________
上面已经批处理提取了图像的特征,那么通常我们再做目标识别、检測时。会给训练数据集,准备类标签。以下,继续对上述程序进行拓展。
opencv批处理提取图像的特征的更多相关文章
- CNN基础二:使用预训练网络提取图像特征
上一节中,我们采用了一个自定义的网络结构,从头开始训练猫狗大战分类器,最终在使用图像增强的方式下得到了82%的验证准确率.但是,想要将深度学习应用于小型图像数据集,通常不会贸然采用复杂网络并且从头开始 ...
- 原来CNN是这样提取图像特征的。。。
对于即将到来的人工智能时代,作为一个有理想有追求的程序员,不懂深度学习(Deep Learning)这个超热的领域,会不会感觉马上就out了?作为机器学习的一个分支,深度学习同样需要计算机获得强大的学 ...
- VGG16提取图像特征 (torch7)
VGG16提取图像特征 (torch7) VGG16 loadcaffe torch7 下载pretrained model,保存到当前目录下 th> caffemodel_url = 'htt ...
- 深度学习tensorflow实战笔记 用预训练好的VGG-16模型提取图像特征
1.首先就要下载模型结构 首先要做的就是下载训练好的模型结构和预训练好的模型,结构地址是:点击打开链接 模型结构如下: 文件test_vgg16.py可以用于提取特征.其中vgg16.npy是需要单独 ...
- 学习OpenCV——BOW特征提取函数(特征点篇)
没日没夜的改论文生活终于要告一段落了,比起改论文,学OpenCV就是一件幸福的事情.OpenCV的发展越来越完善了,已经可以直接使用BOW函数来进行对象分类了. 简单的通过特征点分类的方法: ...
- 图像的特征工程:HOG特征描述子的介绍
介绍 在机器学习算法的世界里,特征工程是非常重要的.实际上,作为一名数据科学家,这是我最喜欢的方面之一!从现有特征中设计新特征并改进模型的性能,这就是我们进行最多实验的地方. 世界上一些顶级数据科学家 ...
- MATLAB·提取图像中多个目标
基于matlab工具箱提取图像中的多目标特征(代码如下): 代码前面部分为提取图像的边界信息,调用了后面的遍历函数Pixel_Search,函数实现方法见后~ %%ROI Testing close ...
- OpenCV学习(33) 轮廓的特征矩Moment
在OpenCV中,可以很方便的计算多边形区域的3阶特征矩,opencv中的矩主要包括以下几种:空间矩,中心矩和中心归一化矩. class Moments { public: ...... // 空间矩 ...
- OpenCV代码提取:dft函数的实现
The Fourier Transform will decompose an image into its sinus and cosines components. In other words, ...
随机推荐
- 使用SuperSocket打造逾10万长连接的Socket服务
SuperSocket 是一个轻量级, 跨平台而且可扩展的 .Net/Mono Socket 服务器程序框架.你无须了解如何使用 Socket, 如何维护 Socket 连接和 Socket 如何工作 ...
- 【OpenCV】一种基于阈值的图片中的文字分割
在今年泰迪杯A题电商中图片的文字识别这道题中,我们先用了一种很笨的办法来分割字符. 首先对图片进行灰度化,然后二值化,这里的二值化要选择一个合适的阈值.然后我们进行轮廓的提取,计算轮廓最小矩形的面积, ...
- 我是如何理解Android的Handler模型_2
对比例程说明,如: 例:在新新线程中替换TextView显示内容. 界面如下,单击按键后original data 替换为 changed data Handler Message部分实现步骤: 1. ...
- Python——网络爬虫
此篇文章继续跟着小甲鱼的视频来初学网络爬虫,除了小甲鱼的网站上可下载视频,发现b站上也有全套的视频哦,会比下载来的更方便些. 网络爬虫,又称为网页蜘蛛(WebSpider),非常形象的一个名字.如果你 ...
- pt-log-player
简介 pt-log-player是MySQL日志回放工具,在pt2.4中被去除,由percona-playback取代. 在2.1中还是保留,如果想使用的话,需要下载2.1版本的. 使用方法 pt-l ...
- 《java.util.concurrent 包源码阅读》16 一种特别的BlockingQueue:SynchronousQueue
SynchronousQueue是一种很特别的BlockingQueue,任何一个添加元素的操作都必须等到另外一个线程拿走元素才会结束.也就是SynchronousQueue本身不会存储任何元素,相当 ...
- 【续】抓个Firefox的小辫子,jQuery表示不背这黑锅,Chrome,Edge,IE8-11继续围观中
引子 昨天我发了一篇文章[抓个Firefox的小辫子,围观群众有:Chrome.Edge.IE8-11],提到了一个Firefox很多版本都存在的问题,而相同的测试页面在Chrome.Edge.IE8 ...
- jQuery与别的js框架冲突
jQuery.noConflict()运行这个函数将变量$的控制权让渡给第一个实现它的那个库. 这有助于确保jQuery不会与其他库的$对象发生冲突. <script type="te ...
- django事务处理
#导包 from django.db import transaction try: #django默认是自动提交到数据库,此处设置不让其自动提交 transaction.set_autocommit ...
- [C#]使用GroupJoin将两个关联的集合进行分组
本文为原创文章.源代码为原创代码,如转载/复制,请在网页/代码处明显位置标明原文名称.作者及网址,谢谢! 本文使用的开发环境是VS2017及dotNet4.0,写此随笔的目的是给自己及新开发人员作为参 ...