金字塔Lucas-Kanande光流算法实现
// Lucas-Kanade method Optical Flow in OpenCV
// BJTShang, 2016-12-13 #include <cv.h>
#include <cxcore.h>
#include <highgui.h> const int MAX_CORNERS = 500; int main(int argc, char** argv){
IplImage* imgA = cvLoadImage("/home/bjtshang/cpp_ws/opencv/data/OpticalFlow0.jpg",
CV_LOAD_IMAGE_GRAYSCALE);
IplImage* imgB = cvLoadImage("/home/bjtshang/cpp_ws/opencv/data/OpticalFlow1.jpg",
CV_LOAD_IMAGE_GRAYSCALE); // image to show the optical flow vectors
IplImage* imgC = cvLoadImage("/home/bjtshang/Desktop/OpticalFlow1.jpg",
CV_LOAD_IMAGE_UNCHANGED); CvSize img_size = cvGetSize(imgA);
CvSize win_size = cvSize(50, 50);
int corner_count = MAX_CORNERS; // get the features (detect corners) need to be tracked
IplImage* imgEig = cvCreateImage(img_size, IPL_DEPTH_32F, 1);
IplImage* imgTmp = cvCreateImage(img_size, IPL_DEPTH_32F, 1); CvPoint2D32f* cornersA = new CvPoint2D32f[corner_count]; cvGoodFeaturesToTrack(imgA, imgEig, imgTmp, cornersA, &corner_count,
0.02, 8.0, 0, 3, 0, 0.04); // find sub-pixel corners
cvFindCornerSubPix(imgA, cornersA, corner_count,
win_size, cvSize(-1,-1),
cvTermCriteria(CV_TERMCRIT_ITER|CV_TERMCRIT_EPS, 20, 0.1)); char features_found[MAX_CORNERS];
float feature_errors[MAX_CORNERS]; CvSize pyr_size = cvSize(imgA->width+8, imgB->height/3); IplImage* pyrA = cvCreateImage(pyr_size, IPL_DEPTH_32F, 1);
IplImage* pyrB = cvCreateImage(pyr_size, IPL_DEPTH_32F, 1); CvPoint2D32f* cornersB = new CvPoint2D32f[MAX_CORNERS]; cvCalcOpticalFlowPyrLK(imgA, imgB, pyrA, pyrB, cornersA, cornersB,
corner_count, win_size,
10, features_found, feature_errors,
cvTermCriteria(CV_TERMCRIT_ITER|CV_TERMCRIT_EPS, 20, 0.1),
0
); for(int i=0; i<corner_count; i++){
if(features_found[i]==0 || feature_errors[i] > 550){
printf("Error is: %f\n", feature_errors[i]);
continue;
}
//printf("Got it\n");
CvPoint p1 = cvPoint(cvRound(cornersA[i].x), cvRound(cornersA[i].y));
CvPoint p2 = cvPoint(cvRound(cornersB[i].x), cvRound(cornersB[i].y));
cvLine(imgC, p1, p2, CV_RGB(255, 0, 0), 1);
}
cvNamedWindow("imgA", 0);
cvNamedWindow("imgB", 0);
cvNamedWindow("Optical_flow", 0);
cvShowImage("imgA", imgA);
cvShowImage("imgB", imgB);
cvShowImage("Optical_flow", imgC); cvWaitKey(0);
return 0;
}
金字塔Lucas-Kanande光流算法实现的更多相关文章
- Lucas–Kanade光流算法学习
Lucas–Kanade光流算法是一种两帧差分的光流估计算法.它由Bruce D. Lucas 和 Takeo Kanade提出. 光流(Optical flow or optic f ...
- 光流算法:Brox算法(转载)
参考论文:1. High Accuracy Optical Flow Estimation Based on a Theory for Warping, Thomas Box, ECCV20042. ...
- 光流算法:Brox算法
参考论文:1. High Accuracy Optical Flow Estimation Based on a Theory for Warping, Thomas Box, ECCV20042. ...
- LK光流算法:提高计算精度和增加搜索范围
LK光流算法:提高计算精度和增加搜索范围 关于LK算法的基本理论,见:http://www.cnblogs.com/dzyBK/p/4960630.html 这里主要阐述如何提高LK算法的计算精度和在 ...
- 光流算法:关于OpenCV读写middlebury网站给定的光流的代码
Middlebury是每个研究光流算法的人不可能不使用的网站,Middlebury提供了许多标准的测试库,这极大地推进了光流算法的进展.Middlebury提供的标准库,其计算出的光流保存在后缀名为. ...
- 光流算法:Brox光流的OpenCV源码解析
OpenCV中DeepFlow代码其实是Brox光流,而非真正的DeepFlow光流,在将近一个月的研究.移植及优化过程中,对Brox光流有了较深刻的认识.我对OpenCV中源码进行了详细的分析,并以 ...
- LK光流算法的三个假设
在实际过程中采用 Lucas-Kanade 光流算法跟踪运动物体特征点的时候,一个很明显的特点是LK算法(包括其他光流算法)不能计算"大运动",加上金子塔的方法稍微好点. 这是什么 ...
- cvCalcOpticalFlowPyrLK的使用--基于高斯金字塔的稀疏光流特征集求解
void cvCalcOpticalFlowPyrLK( const CvArr* prev, const CvArr* curr, CvArr* prev_pyr, CvArr* curr_pyr, ...
- 优化梯度计算的改进的HS光流算法
前言 在经典HS光流算法中,图像中两点间的灰度变化被假定为线性的,但实际上灰度变化是非线性的.本文详细分析了灰度估计不准确造成的偏差并提出了一种改进HS光流算法,这种算法可以得到较好的计算结果,并能明 ...
随机推荐
- BZOJ 1030: [JSOI2007]文本生成器 [AC自动机 DP]
1030: [JSOI2007]文本生成器 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3953 Solved: 1614[Submit][Stat ...
- Intellij IDEA调试功能使用总结
Intellij IDEA调试功能使用总结 这段时间一直在使用Intellij IDEA, 今天把调试区工具的使用方法记录于此. 先编译好要调试的程序. 1.设置断点 选定要设置断点的代码行,在行号的 ...
- docker学习(7) docker-compose使用示例
上一回学习了如何利用docker搭建一个mysql + java service + nginx,总共4个docker容器,如果采用docker run的方式一个一个容器去创建十分麻烦.为了能更高效的 ...
- 单独使用Mybatis的配置文件
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC & ...
- [转]extjs组件添加事件监听的三种方式
原文地址:http://blog.csdn.net/y6300023290/article/details/18989635 1.在定义组件配置的时候设置 xtype : 'textarea', na ...
- js-读取复选框
js: var obj = document.getElementsByName("yk"); var check_val = []; for(k in obj){ if(obj[ ...
- [展示]手把手教你如何diy门户幻灯片
第一步后台新建页面:这个就不用说了大家都会 新建后FTP里面会出现如下一个模板页面 第二步从ftp里面下载 template的index.htm文件 给首页模板页面添加JS代码 如下 将这段jS ...
- cocos2d-x事件EventListenerTouchOneByOne没反应
今天写了 cocos2d-x事件EventListenerTouchOneByOne,发现死活没反应,原代码复制到新工程没问题啊, 后来发现cocostudio用的基础容器(ccui.Layout:c ...
- JavaScript中的类型转换
1.隐式类型转换 ①== 如果相等操作的两个变量不是同一类型,那么相等运算符会尝试进行一些类型转换: 如果一个是null,一个是undefined,则他们相等: 如果一个值是数字,另一个是字符串,先将 ...
- centeros:生产环境搭建
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #e4af0a } p. ...