CalcOpticalFlowPyrLK的使用(转)

CalcOpticalFlowPyrLK

计算一个稀疏特征集的光流,使用金字塔中的迭代 Lucas-Kanade 方法

void cvCalcOpticalFlowPyrLK( const CvArr* prev, const CvArr* curr, CvArr* prev_pyr, CvArr* curr_pyr,
                             const CvPoint2D32f* prev_features, CvPoint2D32f* curr_features,
                             int count, CvSize win_size, int level, char* status,
                             float* track_error, CvTermCriteria criteria, int flags );
prev
在时间 t 的第一帧
curr
在时间 t + dt 的第二帧
prev_pyr
第一帧的金字塔缓存. 如果指针非 NULL , 则缓存必须有足够的空间来存储金字塔从层 1 到层 #level 的内容。尺寸 (image_width+8)*image_height/3 比特足够了
curr_pyr
与 prev_pyr 类似, 用于第二帧
prev_features
需要发现光流的点集
curr_features
包含新计算出来的位置的 点集
count
特征点的数目
win_size
每个金字塔层的搜索窗口尺寸
level
最大的金字塔层数。如果为 0 , 不使用金字塔 (即金字塔为单层), 如果为 1 , 使用两层,下面依次类推。
status
数组。如果对应特征的光流被发现,数组中的每一个元素都被设置为 1, 否则设置为 0。
error
双精度数组,包含原始图像碎片与移动点之间的差。为可选参数,可以是 NULL .
criteria
准则,指定在每个金字塔层,为某点寻找光流的迭代过程的终止条件。
flags
其它选项:
  • CV_LKFLOW_PYR_A_READY , 在调用之前,第一帧的金字塔已经准备好
  • CV_LKFLOW_PYR_B_READY , 在调用之前,第二帧的金字塔已经准备好
  • CV_LKFLOW_INITIAL_GUESSES , 在调用之前,数组 B 包含特征的初始坐标 (Hunnish: 在本节中没有出现数组 B,不知是指的哪一个)

函数 cvCalcOpticalFlowPyrLK 实现了金字塔中 Lucas-Kanade 光流计算的稀疏迭代版本 ([Bouguet00])。 它根据给出的前一帧特征点坐标计算当前视频帧上的特征点坐标。 函数寻找具有子象素精度的坐标值。

两个参数 prev_pyr 和 curr_pyr 都遵循下列规则: 如果图像指针为 0, 函数在内部为其分配缓存空间,计算金字塔,然后再处理过后释放缓存。 否则,函数计算金字塔且存储它到缓存中,除非设置标识 CV_LKFLOW_PYR_A[B]_READY 。 图像应该足够大以便能够容纳 Gaussian 金字塔数据。调用函数以后,金字塔被计算而且相应图像的标识可以被设置,为下一次调用准备就绪 (比如:对除了第一个图像的所有图像序列,标识 CV_LKFLOW_PYR_A_READY 被设置).

 

上面的对opencv中对这个函数的具体介绍: 我把自己使用中获得的收获写下

1 这里的pre 和 cur 分别代表我们需要跟踪图像的前一帧和当前帧,对物体的跟踪,我们在第一帧的时候一般是定位特征点,同时把这帧保存为 pre ,那么处理第二帧的时候这两个参数都会有了。可以进行跟踪了。

2 关于 flag, 根据我们的金字搭是否建立了,设置不同的值,一般在第一次使用0,在一帧处理完了保留当前金字塔为前一帧金字塔,下次处理时候直接可以使用。

转载于:https://www.cnblogs.com/xingma0910/archive/2012/07/26/2610281.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
读取文件夹下所有图片,可以使用OpenCV中的`cv::glob`函数,该函数可以根据通配符模式匹配指定目录下的所有文件。具体步骤如下: 1. 使用`cv::glob`函数获取指定目录下的所有图像文件路径。 2. 按顺序读取每一张图像,计算对应点的运动,绘制轨迹。 下面是一个代码示例: ```c++ #include <iostream> #include <string> #include <vector> #include <opencv2/opencv.hpp> int main() { // 指定图像文件夹路径 std::string image_folder = "path/to/image/folder"; // 获取图像文件路径 std::vector<cv::String> image_paths; cv::glob(image_folder, image_paths); // 定义关键点和颜色 std::vector<cv::Point2f> prev_keypoints, curr_keypoints; cv::Scalar prev_color = cv::Scalar(0, 0, 255), curr_color = cv::Scalar(0, 255, 0); // 读取第一张图像 cv::Mat prev_image = cv::imread(image_paths[0]); cv::cvtColor(prev_image, prev_image, cv::COLOR_BGR2GRAY); cv::goodFeaturesToTrack(prev_image, prev_keypoints, 500, 0.01, 10); // 遍历每一张图像 for (int i = 1; i < image_paths.size(); i++) { // 读取当前帧图像 cv::Mat curr_image = cv::imread(image_paths[i]); cv::cvtColor(curr_image, curr_image, cv::COLOR_BGR2GRAY); // 计算光流 std::vector<uchar> status; std::vector<float> err; cv::calcOpticalFlowPyrLK(prev_image, curr_image, prev_keypoints, curr_keypoints, status, err); // 绘制轨迹 for (int j = 0; j < prev_keypoints.size(); j++) { if (status[j]) { cv::line(curr_image, prev_keypoints[j], curr_keypoints[j], curr_color, 2); } } // 更新关键点和颜色 prev_keypoints = curr_keypoints; prev_color = curr_color; // 重新检测关键点 cv::goodFeaturesToTrack(curr_image, curr_keypoints, 500, 0.01, 10); // 更新上一帧图像 prev_image = curr_image.clone(); } return 0; } ``` 在上面的代码中,我们使用了`cv::goodFeaturesToTrack`函数来检测关键点,使用`cv::calcOpticalFlowPyrLK`函数计算对应点的运动,使用`cv::line`函数绘制轨迹。注意,为了方便绘制轨迹,我们将图像从灰度图换为了彩色图。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值