中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

opencv3/C++如何實現(xiàn)光流點追蹤-創(chuàng)新互聯(lián)

這篇文章主要介紹了opencv3/C++如何實現(xiàn)光流點追蹤,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)是一家專業(yè)提供靖遠企業(yè)網(wǎng)站建設,專注與網(wǎng)站建設、成都網(wǎng)站制作H5頁面制作、小程序制作等業(yè)務。10年已為靖遠眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設公司優(yōu)惠進行中。

光流金字塔

calcOpticalFlowPyrLK()函數(shù)參數(shù)說明:

void calcOpticalFlowPyrLK(
InputArray prevImg, //第一個8位輸入圖像或者通過 buildOpticalFlowPyramid()建立的金字塔
InputArray nextImg,//第二個輸入圖像或者和prevImg相同尺寸和類型的金字塔
InputArray prevPts, //二維點向量存儲找到的光流;點坐標必須是單精度浮點數(shù)
InputOutputArray nextPts,//輸出二維點向量(用單精度浮點坐標)包括第二幅圖像中計算的輸入特征的新點位置;當OPTFLOW_USE_INITIAL_FLOW 標志通過,向量必須有和輸入一樣的尺寸。
OutputArray status, //輸出狀態(tài)向量(無符號char);如果相應的流特征被發(fā)現(xiàn),向量的每個元素被設置為1,否則,被置為0.
OutputArray err,//輸出錯誤向量;向量的每個元素被設為相應特征的一個錯誤,誤差測量的類型可以在flags參數(shù)中設置;如果流不被發(fā)現(xiàn)然后錯誤未被定義(使用status(狀態(tài))參數(shù)找到此情形)。
Size winSize = Size(21,21), //在每個金字塔水平搜尋窗口的尺寸。
int maxLevel = 3,//大金字塔層數(shù); 如果設置為0,則不使用金字塔(單層),如果設置為1,則使用兩個層次,依此類推; 如果將金字塔傳遞給輸入,則算法將使用與金字塔一樣多的級別,但不超過maxLevel。
TermCriteria criteria = TermCriteria(TermCriteria::COUNT+TermCriteria::EPS, 30, 0.01),//指定迭代搜索算法的終止標準(指定的大迭代次數(shù)criteria.maxCount或搜索窗口移動小于criteria.epsilon)
int flags = 0, //操作標志
double minEigThreshold = 1e-4 //計算光流方程的2×2標準矩陣的最小特征值除以窗口中的像素數(shù)量;如果這個值小于minEigThreshold,那么一個相應的特征被過濾出來,且它的光流不被處理,所以它允許去除壞點提升性能。
);
#include<opencv2/opencv.hpp>
using namespace cv;

//光流跟蹤
Mat frame, gray, pr_frame, pr_gray;
std::vector<Point2f> inPoints;
std::vector<Point2f> fpts[2];
void trackFeature();

int main()
{
  VideoCapture capture;
  capture.open(0);
  if(!capture.isOpened())
  {
    printf("can not open the camear......\n");
    return -1;
  }
  namedWindow("input", CV_WINDOW_AUTOSIZE);
  namedWindow("output", CV_WINDOW_AUTOSIZE);

  while (capture.read(frame))
  {  
    cvtColor(frame, gray, COLOR_BGR2GRAY);
    if (fpts[0].size() < 40)
    {
      imshow("input", frame);
      std::vector<Point2f> features;
      //角點檢測
      goodFeaturesToTrack(gray, features, 300, 0.01, 10);
      fpts[0].insert(fpts[0].end(), features.begin(), features.end());
      inPoints.insert(inPoints.end(), features.begin(), features.end());
    }
    else
      printf("object tracking......\n"); 
    if (pr_gray.empty()) 
      gray.copyTo(pr_gray);
    trackFeature();
    for (int i = 0; i < fpts[0].size(); i++) 
      circle(frame, fpts[0][i], 2, Scalar(0,255,0),2,8,0);
    gray.copyTo(pr_gray);
    frame.copyTo(pr_frame);
    imshow("output", frame);
    waitKey(1);
  }
  waitKey(0);
  capture.release();
  return 0;
}


void trackFeature()
{
  std::vector<uchar> status;
  std::vector<float> errors;
  //計算稀疏特征集的光流
  calcOpticalFlowPyrLK(pr_gray, gray, fpts[0], fpts[1], status, errors);
  int k = 0;
  for (int i = 0; i < fpts[1].size(); i++)
  {
    double dist = abs(fpts[0][i].x-fpts[1][i].x) + abs(fpts[0][i].y-fpts[1][i].y);
    if (dist > 2 && status[i])
    {
      inPoints[k] = inPoints[i];
      fpts[1][k++] = fpts[1][i];
    }
  }
  inPoints.resize(k);
  fpts[1].resize(k);
  //繪制光流軌跡
  RNG rng(0); 
  for (int i = 0; i < fpts[0].size(); i++)
  {
    Scalar color = Scalar(rng.uniform(0,255),rng.uniform(0,255),rng.uniform(0,255));
    line(frame, inPoints[i], fpts[1][i], color,2);
    circle(frame, fpts[1][i], 2, Scalar(0,255,255),2);
  }
  std::swap(fpts[1], fpts[0]);
}

opencv3/C++如何實現(xiàn)光流點追蹤

opencv3/C++如何實現(xiàn)光流點追蹤

感謝你能夠認真閱讀完這篇文章,希望小編分享的“opencv3/C++如何實現(xiàn)光流點追蹤”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)建站,關注創(chuàng)新互聯(lián)網(wǎng)站建設公司行業(yè)資訊頻道,更多相關知識等著你來學習!

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站www.rwnh.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網(wǎng)站名稱:opencv3/C++如何實現(xiàn)光流點追蹤-創(chuàng)新互聯(lián)
本文鏈接:http://www.rwnh.cn/article4/doeiie.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、品牌網(wǎng)站設計網(wǎng)站改版、營銷型網(wǎng)站建設、微信小程序品牌網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

h5響應式網(wǎng)站建設
剑河县| 贵南县| 聊城市| 萨嘎县| 安宁市| 尼勒克县| 朝阳县| 青龙| 阿鲁科尔沁旗| 岑溪市| 宝兴县| 东阳市| 任丘市| 赞皇县| 潜山县| 文山县| 理塘县| 克山县| 商河县| 东兰县| 响水县| 龙泉市| 五寨县| 酉阳| 洛浦县| 广元市| 青龙| 乌鲁木齐县| 剑阁县| 特克斯县| 南漳县| 扎兰屯市| 沂源县| 苏州市| 永平县| 溆浦县| 马尔康县| 江达县| 托里县| 凯里市| 方正县|