///*12 在Matlab中有个circShift()函数,可以实现行、列的循环移动
///    在返卷积运算中,会用到这个函数。所以,在Opencv中我也定义同样
///    功能的函数
///    该函数有3个参数,第1个src是输入矩阵或图像,第2、3个参数分别是
///    沿着'行'方向移动的函数,和沿着‘列’方向移动的列数。
在主函数circShift()中分别调用了两个子涵数:
circRowShift(Mat&src,int shift_m_rows)、
void circColShift(Mat& src,int shift_n_cols)
这两个函数分别实现了行循环移动和列循环移动,函数代码如下:
//*11.循环行、列移动函数circshift():
inline void circRowShift(Mat&src,int shift_m_rows)
{
int m=shift_m_rows;
int rows=src.rows;
//‘行’循环移动
if(m%rows==)
{
return;
} Mat mrows(abs(m),src.cols,src.type());//用于暂时保存末尾的m行数据
if(m>)
{
src(Range(rows-m,rows),Range::all()).copyTo(mrows);
src(Range(,rows-m),Range::all()).copyTo(src(Range(m,rows),Range::all()));
mrows.copyTo(src(Range(,m),Range::all()));
}else
{
src(Range(,-m),Range::all()).copyTo(mrows);
src(Range(-m,rows),Range::all()).copyTo(src(Range(,rows+m),Range::all()));
mrows.copyTo(src(Range(rows+m,rows),Range::all()));
}
}
inline void circColShift(Mat& src,int shift_n_cols)
{
int n=shift_n_cols;
int cols=src.cols;
int rows=src.rows;
if(n%cols==)
{
return;
}
///ncols,如果n>0,用于暂时保存末尾的n列数据
///ncols,如果n<0,用于暂时保存起始的n列数据
Mat ncols(rows,abs(n),src.type());
if(n>)
{
src(Range::all(),Range(cols-n,cols)).copyTo(ncols);
src(Range::all(),Range(,cols-n)).copyTo(src(Range::all(),Range(n,cols)));
ncols.copyTo(src(Range::all(),Range(,n)));
}
else
{
src(Range::all(),Range(,-n)).copyTo(ncols);
src(Range::all(),Range(-n,cols)).copyTo(src(Range::all(),Range(,cols+n)));
ncols.copyTo(src(Range::all(),Range(cols+n,cols)));
} } void circShift(Mat&src,int shift_m_rows,int shift_n_cols)
{
int m=shift_m_rows;
int n=shift_n_cols;
//‘行’循环移动
circRowShift(src,m);
//‘列’循环移动
circColShift(src,n);
}
//*11.行、列循环移动函数circshift() 结束

测试程序,对imgc移动3列:

int main()
{
// Mat img1=imread("D:/CodeWork/MyImage/baboon.jpg",0);
Mat imgc=(Mat_<uchar>(,)
<<,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,);
Mat imgr=imgc.t();
cout<<"original imgc="<<endl<<imgc<<endl;
circShift(imgc,,);
// circShift(imgc,0,3);
cout<<"3 cols-shifted imgc="<<endl<<imgc<<endl;
waitKey();
return ;
}

运行结果如下:

测试程序,对imgr移动3行:

int main()
{
// Mat img1=imread("D:/CodeWork/MyImage/baboon.jpg",0);
Mat imgc=(Mat_<uchar>(,)
<<,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,,
,,,,,,,,,,,);
Mat imgr=imgc.t();
cout<<"original imgr="<<endl<<imgr<<endl;
circShift(imgr,,);
cout<<"3 rows-shifted imgr="<<endl<<imgr<<endl;
waitKey();
return ;
}

运行结果如下:

基于OpenCV的循环行、列移动函数circShift()的更多相关文章

  1. 基于Opencv的自适应中值滤波函数selfAdaptiveMedianBlur()

    7.3.3 自适应滤波器 自适应中值滤波器 对于7.3.2节所讨论的中值滤波器,只要脉冲噪声的空间密度不大,性能还是可以的(根据经验需Pa和Pb小于0.2).本节将证明,自适应中值滤波器可以处理更大概 ...

  2. 基于OpenCv的人脸检测、识别系统学习制作笔记之一

    基于OpenCv从视频文件到摄像头的人脸检测 在OpenCv中读取视频文件和读取摄像头的的视频流然后在放在一个窗口中显示结果其实是类似的一个实现过程. 先创建一个指向CvCapture结构的指针 Cv ...

  3. 基于opencv的小波变换

    基于opencv的小波变换 提供函数DWT()和IDWT(),前者完成任意层次的小波变换,后者完成任意层次的小波逆变换.输入图像要求必须是单通道浮点图像,对图像大小也有要求(1层变换:w,h必须是2的 ...

  4. 基于OpenCV的火焰检测(一)——图像预处理

    博主最近在做一个基于OpenCV的火焰检测的项目,不仅可以检测图片中的火焰,还可以检测视频中的火焰,最后在视频检测的基础上推广到摄像头实时检测.在做这个项目的时候,博主参考了很多相关的文献,用了很多种 ...

  5. 基于Opencv和Mfc的图像处理增强库GOCVHelper(索引)

    GOCVHelper(GreenOpen Computer Version Helper )是我在这几年编写图像处理程序的过程中积累下来的函数库.主要是对Opencv的适当扩展和在实现Mfc程序时候的 ...

  6. OpenCV2学习笔记(十四):基于OpenCV卡通图片处理

    得知OpenCV有一段时间.除了研究的各种算法的内容.除了从备用,据导游书籍和资料,尝试结合链接的图像处理算法和日常生活,第一桌面上(随着摄像头)完成了一系列的视频流处理功能.开发平台Qt5.3.2+ ...

  7. 每日一练之自适应中值滤波器(基于OpenCV实现)

    本文主要介绍了自适应的中值滤波器,并基于OpenCV实现了该滤波器,并且将自适应的中值滤波器和常规的中值滤波器对不同概率的椒盐噪声的过滤效果进行了对比.最后,对中值滤波器的优缺点了进行了总结. 空间滤 ...

  8. Csharp调用基于Opencv编写的类库文件

    现在将Csharp调用基于Opencv编写的类库文件(Dll)的方法定下来,我取名叫做GreenOpenCsharpWarper,简称GOCW. 一.CLR编写的DLL部分 1.按照正常方法引入Ope ...

  9. 图像处理基础(2):自适应中值滤波器(基于OpenCV实现)

    本文主要介绍了自适应的中值滤波器,并基于OpenCV实现了该滤波器,并且将自适应的中值滤波器和常规的中值滤波器对不同概率的椒盐噪声的过滤效果进行了对比.最后,对中值滤波器的优缺点了进行了总结. 空间滤 ...

随机推荐

  1. 移动/Web开发必备工具!DevExtreme v19.1.7火热发布

    DevExtreme Complete Subscription是性能最优的 HTML5,CSS 和 JavaScript 移动.Web开发框架,可以直接在Visual Studio集成开发环境,构建 ...

  2. RobotFramework 截取中文中的数字比较时长

    先看下需求,这个报表中有个时长,需要对昨日和前日的时长进行比较,我们获取到的元素是例如“9分43秒”这样的格式 1.首先要讲中文中的分和秒分别提取出来 提取python代码如下: import res ...

  3. python 访问列表中的值

    #!/usr/bin/python list1 = ['physics', 'chemistry', 1997, 2000] list2 = [1, 2, 3, 4, 5, 6, 7 ] print ...

  4. .net大文件上传断点续传解决方案

    HTML部分 <%@PageLanguage="C#"AutoEventWireup="true"CodeBehind="index.aspx. ...

  5. H5 设计尺寸

    750*1218 微信下 兼容 7plus 内容高度 居中 1000px 内 750*1448 微信下 兼容 iphoneX 微信导航栏高度 64px 64px =  导航栏44+状态栏20 但是现在 ...

  6. CUDA-F-1-1-异构计算-CUDA

    开篇废话 成熟与智慧其实和年龄相关,但绝不是完全由年龄决定,少年老成的人肯定是存在的,不是长得老,而是心态成熟,当然大多数老年人其实有些事情思考起来还是老原则,所以他们有时候做事没那么周到,所以一个人 ...

  7. Centos 7禁止ftdi_sio模块

    $ dmesg[ 3305.097301] usb 1-1: USB disconnect, device number 7[ 3306.883704] usb 1-1: new high-speed ...

  8. Jmeter(十二)常用插件

    一.下载及安装 下载地址:https://jmeter-plugins.org/install/Install/ 下载后文件为一个jar包,将其放入jmeter安装目录下的lib/ext目录,然后重启 ...

  9. AcWing:145. 超市(贪心 + 小根堆 or 贪心 + 并查集)

    超市里有N件商品,每个商品都有利润pipi和过期时间didi,每天只能卖一件商品,过期商品(即当天di<=0di<=0)不能再卖. 求合理安排每天卖的商品的情况下,可以得到的最大收益是多少 ...

  10. Python + cx_Orcale 连接Oracle数据库

    这是我在使用python连接Oracle数据库时遇到的问题.在此做一下总结. 1.pip install cx_Oracle 2.然后还需要在下载一个数据库客户端工具instantclient-bas ...