- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我一直在将代码从 Python 的一个答案移植到 C++,我希望有人可以帮助做到这一点,并阐明该过程的一部分。
我说的答案 - https://stackoverflow.com/a/11366549
我正处于对质心进行排序的步骤(一个在最后一个之前)。有问题的代码完成了工作,但我不确定如何使用 C++ 获得相同的结果而不会使代码更长。
centroids = np.array(centroids,dtype = np.float32)
c = centroids.reshape((100,2))
c2 = c[np.argsort(c[:,1])]
b = np.vstack([c2[i*10:(i+1)*10][np.argsort(c2[i*10:(i+1)*10,0])] for i in xrange(10)])
bm = b.reshape((10,10,2))
我想要实现这一目标的方法是执行以下操作:
初始质心数组已经按某种方式排序(最高 y 值点的索引为 0,最低为 99),所以我想反转它,使数组从上到下排序。
之后就是对行进行排序(按 x 轴对 10 行 10 列进行排序)
我相信这就是所有必须要做的事情,但我找不到一种优雅的方式来对此进行编码(不使用 vector 和手动排序)。
我也不太明白最后一步,图像被扭曲(使其难以移植),所以如果有人可以提供一些关于这部分所做的事情以及可能与此等效的 C++ 的见解,我将不胜感激。
output = np.zeros((450,450,3),np.uint8)
for i,j in enumerate(b):
ri = i/10
ci = i%10
if ci != 9 and ri!=9:
src = bm[ri:ri+2, ci:ci+2 , :].reshape((4,2))
dst = np.array( [ [ci*50,ri*50],[(ci+1)*50-1,ri*50],[ci*50,(ri+1)*50-1],[(ci+1)*50-1,(ri+1)*50-1] ], np.float32)
retval = cv2.getPerspectiveTransform(src,dst)
warp = cv2.warpPerspective(res2,retval,(450,450))
output[ri*50:(ri+1)*50-1 , ci*50:(ci+1)*50-1] = warp[ri*50:(ri+1)*50-1 , ci*50:(ci+1)*50-1].copy()
我只是在学习 OpenCV 和 C++,我知道这可能是微不足道的,所以我希望有人能抽出一些时间来提供一些基本的答案。
编辑
根据要求,这是代码。我已经处理了第一部分,但仍然不确定这是否是正确的方法。
#pragma mark Correcting the defects
findContours(res, contours, RETR_LIST, CHAIN_APPROX_SIMPLE);
vector<cv::Point> centroids;
centroids.reserve(100);
for (int i = 0; i < contours.size(); i++) {
vector<cv::Point> contour = contours.at(i);
Moments mom = moments(contour);
cv::Point center = cv::Point(int(mom.m10 / mom.m00), int(mom.m01 / mom.m00));
centroids.push_back(center);
}
std::reverse(centroids.begin(), centroids.end());
struct {
bool operator()(const cv::Point p1, const cv::Point p2) {
return p1.x < p2.x;
}
} pointXGreater;
for (int i = 0; i < 10; i++) {
std::sort(centroids.begin() + i * 10, centroids.begin() + (i + 1) * 10, pointXGreater);
}
Mat b(centroids);
Mat bm = b.reshape(10, 10);
用索引在图像上绘制质心后,似乎它们是正确的。
现在我被困在最后一部分,试图破译 Python 代码,但并不真正了解它的作用。到目前为止,我得到了这个:
Mat output = Mat::zeros(450, 450, CV_8U);
for (int i = 0; i < centroids.size(); i++) {
cv::Point j = centroids.at(i);
int ri = i / 10;
int ci = i % 10;
if (ci != 9 && ri != 9) {
Mat src = ??
Mat dst = ??
Mat retval = getPerspectiveTransform(src, dst);
Mat warp;
warpPerspective(res2, warp, retval, (450, 450));
Mat output = ??
}
}
我会继续努力理解它,但如果您能提供一些帮助,我们将不胜感激,因为这种 Python 语法不是很友好,尤其是当您真的不知道正在做什么时。
最佳答案
经过一段时间的努力,这就是我想出的(似乎可行)
#pragma mark Correcting the defects
findContours(res, contours, RETR_LIST, CHAIN_APPROX_SIMPLE);
vector<cv::Point> centroids;
centroids.reserve(100);
for (int i = 0; i < contours.size(); i++) {
vector<cv::Point> contour = contours.at(i);
Moments mom = moments(contour);
cv::Point center = cv::Point(int(mom.m10 / mom.m00), int(mom.m01 / mom.m00));
centroids.push_back(center);
}
std::reverse(centroids.begin(), centroids.end());
struct {
bool operator()(const cv::Point p1, const cv::Point p2) {
return p1.x < p2.x;
}
} pointXGreater;
for (int i = 0; i < 10; i++) {
std::sort(centroids.begin() + i * 10, centroids.begin() + (i + 1) * 10, pointXGreater);
}
Mat bm = Mat(centroids);
bm = bm.reshape(2, 10);
Mat output(450, 450, CV_8UC3, CV_RGB(1, 1, 1));
for (int i = 0; i < centroids.size(); i++) {
int ri = i / 10;
int ci = i % 10;
if (ci != 9 && ri != 9) {
cv::Point2f src[4];
src[0] = cv::Point2f(bm.at<cv::Point>(ri, ci).x, bm.at<cv::Point>(ri, ci).y);
src[1] = cv::Point2f(bm.at<cv::Point>(ri, ci + 1).x, bm.at<cv::Point>(ri, ci + 1).y);
src[2] = cv::Point2f(bm.at<cv::Point>(ri + 1, ci).x, bm.at<cv::Point>(ri + 1, ci).y);
src[3] = cv::Point2f(bm.at<cv::Point>(ri + 1, ci + 1).x, bm.at<cv::Point>(ri + 1, ci + 1).y);
cv::Point2f dst[4];
dst[0] = cv::Point2f(ci * 50, ri * 50);
dst[1] = cv::Point2f((ci + 1) * 50 - 1, ri * 50);
dst[2] = cv::Point2f(ci * 50, (ri + 1) * 50 - 1);
dst[3] = cv::Point2f((ci + 1) * 50 - 1, (ri + 1) * 50 - 1);
Mat retval = getPerspectiveTransform(src, dst);
Mat warp;
warpPerspective(res2, warp, retval, cv::Size(450, 450));
for (int j = ri * 50; j < (ri + 1) * 50 - 1; j++) {
for (int k = ci * 50; k < (ci + 1) * 50 - 1; k++) {
output.at<Vec3b>(j, k) = warp.at<Vec3b>(j, k);
}
}
}
}
关于c++ - OpenCV - 去除凸性缺陷(Python 到 C++),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18542264/
给定一个字符串"5 900 000" 我想通过以下模式使用 gsub 去除空格: gsub(/\s/, '') 但这似乎行不通。也没有: gsub(' ', '') 最佳答案 如果你想就地替换,你需要
我编写了一个程序来抓取网站以获取数据并输出到 Excel 表。该程序使用 Microsoft Visual Studio 2010 用 C# 编写。 大多数时候,我从网站获取内容、解析内容并将数据存储
在 MS Access 2007 项目报告中,我有以下(已编辑)查询: SELECT SomeCol FROM SomeTable 问题是, SomeCol 显然包含一些不可见的字符。例如,我看到一个
如 Removing left recursion 中所述,有两种方法可以去除左递归。 使用一些过程修改原始语法以删除左递归 写文法原来没有左递归 人们通常使用什么来删除(没有)ANTLR 的左递归?
我在 CoreData 中存储了一堆艺术家,并希望按名称对它们进行排序,但忽略前缀“the”。例如,“The Beatles”将被排序为“Beatles”,有点像 iTunes/iPod 的做法。 因
我有一个 WebView ,我想从中删除弹性。现在,当滚动小于 webview 的页面时,它会产生弹性效果,显示下面的背景。我想删除这个。 我尝试过执行以下操作,但没有成功。它找到了 WebDynam
我正在调查我们公司使用 Prometheus 从我们在 Kubernetes 上运行的实验中收集统计数据。有计划使用标签来标记我们的云/集群中特定实验的名称。这意味着我们将生成大量标签,这些标签会随着
我正在添加聚合物元素。我想在单击其(自己的)图像时删除元素(自我)。根据封装,我将不得不让 parent 删除 child 。但这也需要为母体生成聚合物元素(我在这里吗??)。 children.ad
现在如果我点击按钮 A,按钮 B 会显示 DropShadow 效果: Private Sub ButtonA_Click(ByVal sender As System.Object, ByVal
我尝试过这个,但它对我不起作用: char * remove_nl(char * newstr) { newstr = strdup(newstr); newstr[strlen(ne
我陷入了两难境地。我有一个图像,我想占据网页的背景。我希望它横跨屏幕的宽度和高度,并保持那个尺寸。当我使用 标签,我不知道如何将它拉伸(stretch)到没有白条的屏幕上。 wspace 和 hspa
Jade .foo .foo 结果 想要的结果 在 haml 中我会做类似 .foo>< 的事情但这在 Jade 中不起作用。我已经搜索并空手而归如何处理这个问题。我如何达到预期的结果
我是 Maven 的新手,当我尝试将我当前的项目从使用 Ant 转换为 -> 使用 Maven 时遇到了问题。 那个项目需要很多 Jar,我在 mvnrepository 上查找这些 jar 并将它们
我需要一个正则表达式来删除 xml 标记开头和结尾之间的空格。例如:有人创建 xml 并将其发送给我,这样我就可以验证、签名并发送到网络服务。 为此,我需要删除标签开头和结尾之间的空格: String
我写了几个方法来将项目添加到数组中,如果它们已经在数组中,它们将被忽略。在对数据结构做了一些研究之后,我意识到我可以通过简单地将它们放在一个集合中来摆脱重复(特别是因为我不关心对象的顺序)。然而,在玩
使用 HighCharts,我想移除 SVG 曲线上的抗锯齿。 到目前为止,我正在使用这个: $('path').each(function(i,j){$(j).attr('shape-renderi
由于某些奇怪的原因(黑色但不是黑色部分),我的 SeekBar 和拇指后面出现随机阴影。我该如何摆脱它? 我的搜索栏: 拇指.xml progress_appearance.xml(有一些
我有一个 Url,我想获取路径部分但没有尾随文件名。如果 Url 是 http://my.com/dir1/dir2/file.ext 那么我想获取 /dir1/dir2 . 我已经尝试了各种拆分(l
我有这个字符串: dataSourceURL = URL(string:"https://api.abc.com/api/p4/products?pid=uid8225&format=json&off
在我的网页中,我有一个菜单 (HorizontalPanel) 应该隐藏在页面的底部。为此,我尝试使用 RootLayoutPanel 类并在其中添加一个 south 小部件,我成功地做到了。但问
我是一名优秀的程序员,十分优秀!