- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在 Ubuntu 上的 opencv 2.4.12 中使用以下代码进行视频稳定,我使用 calcopticalflowpyrlk,它会引发断言失败错误:错误如下:
OpenCV 错误:断言失败 ((npoints = prevPtsMat.checkVector(2, CV_32F, true)) >= 0) in cv::calcOpticalFlowPyrLK,文件主页...\opencv\modules\video\src\lkpyramid.cpp,第 845 行
代码如下:
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <iostream>
#include <stdlib.h>
#include <opencv2/opencv.hpp>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
using namespace cv;
using namespace std;
int main()
{
int rows = 240;
int cols = 240;
int i = 1;
VideoCapture cap(0);
Mat Canvass;
Canvass.create(rows, cols * 2, CV_8UC3);
for(;;)
{Mat prev,cur;
Mat prev_gray,cur_gray, aligned;
Mat TT(2, 3, CV_64F);
vector <Point2f> cur_corner, cur_corner2, prev_corner2;
vector <Point2f> prev_corner;
Mat prev_grey;
vector <uchar> status;
vector <float> err;
double dx, dy, da;
const int max_no_of_corners = 20000;
const double quality_of_corners = 0.00001;
const double min_dist_bw_corners = 5;
const int search_window_size = 80;
const int pyramid_level = 5;
Mat cur_warped;
int rows = 240;
int cols = 240;
if(i == 1)
{ //capture the prev frame,resize,grayscale and display it
for (int x = 0; x < 10;x++)
{ cap >> prev; }
resize(prev, prev,Size(240,240));
cvtColor(prev,prev_gray,CV_BGR2GRAY);
prev.copyTo(Canvass(Range::all(), Range(0,cols)));
//capture the current frame,resize and grayscale it
cap>>cur;
resize(cur,cur,Size(240,240));
cvtColor(cur,cur_gray,CV_BGR2GRAY);
i++;
}
else{
cap>>cur;
resize(cur,cur,Size(240,240));
cvtColor(cur,cur_gray,CV_BGR2GRAY);
cvtColor(prev,prev_gray,CV_BGR2GRAY);
//display the previous image in canvass
cur.copyTo(Canvass(Range::all(), Range(0,cols)));
}
///find corner points here
goodFeaturesToTrack(prev_grey, prev_corner, max_no_of_corners, quality_of_corners, min_dist_bw_corners);
//usecalcopticalflowpyrlk
calcOpticalFlowPyrLK(prev_gray, cur_gray, prev_corner, cur_corner, status, err, Size(10,10),2);
//weed out bad matches
for (int t = 0; t < status.size(); t++) {
if (int(status[t])) {
cur_corner2.push_back(cur_corner[t]);
prev_corner2.push_back(prev_corner[t]);
}
}
//estimate transform
Mat T;
T = estimateRigidTransform(prev_corner2, cur_corner2,false);
if (T.data == NULL)
{cout<<"No transform found"<<endl;
cur.copyTo(Canvass(Range::all(), Range(cols,cols * 2)));
cur.copyTo(prev);
}
else{
cout<<"transform found "<<endl;
// decompose T
dx = T.at<double>(0, 2);
dy = T.at<double>(1, 2);
da = atan2(T.at<double>(1, 0), T.at<double>(0, 0));
da = -da;
//da = 0;
TT.at<double>(0, 0) = cos(da);;
TT.at<double>(0, 1) = -sin(da);
TT.at<double>(1, 0) = sin(da);
TT.at<double>(1, 1) = cos(da);
TT.at<double>(0, 2) = -dx;// / scale;
TT.at<double>(1, 2) = -dy;// / scale;
//TT.copyTo(Transform);
//warp
warpAffine(cur, cur_warped, TT, cur.size(),INTER_NEAREST|WARP_INVERSE_MAP);
cur.copyTo(prev);
cur_warped.copyTo(Canvass(Range::all(), Range(cols,(cols * 2))));
}
imshow( "Output",Canvass);
waitKey(1);
}
}
我认为 calcopticalflowpyrlk 中的 vector 数据类型可能存在一些问题,但我已经通过文档对其进行了验证,但我仍然遇到此错误。我该如何摆脱它?
最佳答案
你能显示和检查prev_corner.size()
和cur_corner.size()
吗?根据断言,这些 vector 似乎是空的。如果是这种情况 - 只需检查您是否有足够的特征点来寻找对应关系。
顺便说一句,您还应该在调用 estimateRigidTransform()
之前检查匹配项的数量;如果我没记错的话 - 它至少需要 3 个对应关系(估计 6 个自由度)。
关于c++ - calcopticalflowpyrlk 断言失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38721313/
我在使用以下代码时遇到问题: function http_file_exists($url){ $f=fopen($url,"r"); if($f){ fclose($f); retu
我已经通过 Git 部署到 Azure 几个月了,没有出现重大问题,但现在我似乎遇到了一个无法克服的错误。 我创建了一个新的 Azure 网站,为正在开发的项目创建单独的预览链接。我在新站点上设置了
我已经通过flutter创建了一个App并完成了它,我想在flutter文档中阅读时进行部署。 我收到此错误: FAILURE: Build failed with an exception. * W
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
我正在尝试使用 RapidJSON 解析从服务器接收到的数据。以下是收到的确切字符串: [ { "Node": "9478149a08f9", "Address": "172.17
我尝试为 ios 编译 OpenCV。我总是收到这些错误。我用不同版本的opencv试了一下,结果都是一样的。 我运行这个:python 平台/ios/build_framework.py ios_o
我在一台机器上做基本的发布/订阅,我的客户端是 StackExchange-Redis 的 C# 客户端,我在同一台机器上运行基于 Windows 的 Redis 服务器(服务器版本 2.8.4) 当
我有这段代码,但无法执行,请帮我解决这个问题 连接 connect_error) { die ("connection failed: " . $terhubung->connect_erro
我在 tomcat 上运行并由 maven 编译的 Web 应用程序给出了以下警告和错误。我可以在本地存储库中看到所有 JAR,但有人可以帮忙吗。 WARNING: Failed to scan JA
我正在 Windows 8 上使用 Android Studio 开发一个 android 应用程序,我正在使用一些 native 代码。突然间我无法编译我的 C 文件。当我运行 ndk-build
下面的代码对类和结构的成员进行序列化和反序列化。序列化工作正常,但我在尝试使用 oarch >> BOOST_SERIALIZATION_NVP(outObj); 反序列化时遇到了以下错误; 代码中是
如果我运行此命令“rspec ./spec/requests/api/v1/password_reset_request_spec.rb”,此文件中的所有测试都会通过。 但是,当我运行“rspec”时
我在尝试执行测试以使用 Protractor 上传文件时出错,我的代码是这个 it('it should be possible to upload a file', function() {
System.loadLibrary("nativefaceswap"); 当我运行我的应用程序时,我在 Android Studio 中发现了此类错误。在logcat中显示: java.lang.U
我希望有人能帮助我!使用任何方法或命令行的任何 SSL/HTTPS 调用均无效。 我在 Windows 10 中使用 Ubuntu Server 18.04 作为子系统。我的问题是昨天才开始出现的,因
通过删除这两个值将日期字段从 null=True 和 Blank=True 更改为 required 时,使用 db.alter 命令时遇到问题。 当以下行被注释掉时,迁移运行不会出现问题。
我第一次使用 Heroku 尝试创建应用程序(使用 SendGrid 的 Inbound Parse Webhook"和 Twilio SMS 通过电子邮件发送和接收 SMS 消息)。通过 Virtu
我正在将我的 swift 项目更新到 Xcode 7 上的 Swift 2.0。xcode 在构建项目时报告了以下错误: 命令/Applications/Xcode.app/Contents/Deve
在我的代码中,SSL 库函数 SSL_library_init() 没有按预期返回 1。我如何才能看到它返回了什么错误? 我在 SSL_library_init() 之后调用了 SSL_load_er
我正在尝试运行在以下链接中找到的答案: Asynchronously Load the Contents of a Div 但是当我这样做时,我会遇到我不太理解的错误。 我的代码: $(documen
我是一名优秀的程序员,十分优秀!