- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在 Visual Studio 2012、C++ 中进行 multimap 像拼接。我修改了stitching_detailed.cpp根据我的要求,它给出了高质量的结果。这里的问题是,执行起来需要太多时间。 10 张图片,大约需要 110 秒。
这里是花费最多时间的地方:
1) 成对匹配 - 10 张图像需要 55 秒!我正在使用 ORB 来查找特征点。这是代码:
vector<MatchesInfo> pairwise_matches;
BestOf2NearestMatcher matcher(false, 0.35);
matcher(features, pairwise_matches);
matcher.collectGarbage();
我尝试使用这段代码,因为我已经知道图像的顺序:
vector<MatchesInfo> pairwise_matches;
BestOf2NearestMatcher matcher(false, 0.35);
Mat matchMask(features.size(),features.size(),CV_8U,Scalar(0));
for (int i = 0; i < num_images -1; ++i)
matchMask.at<char>(i,i+1) =1;
matcher(features, pairwise_matches, matchMask);
matcher.collectGarbage();
它肯定会减少时间(18 秒),但不会产生所需的结果。只有 6 张图像被拼接(最后 4 张被遗漏,因为图像 6 和图像 7 的特征点不匹配。因此循环中断。)
2) 合成 - 10 张图像需要 38 秒!这是代码:
for (int img_idx = 0; img_idx < num_images; ++img_idx)
{
printf("Compositing image #%d\n",indices[img_idx]+1);
// Read image and resize it if necessary
full_img = imread(img_names[img_idx]);
Mat K;
cameras[img_idx].K().convertTo(K, CV_32F);
// Warp the current image
warper->warp(full_img, K, cameras[img_idx].R, INTER_LINEAR, BORDER_REFLECT, img_warped);
// Warp the current image mask
mask.create(full_img.size(), CV_8U);
mask.setTo(Scalar::all(255));
warper->warp(mask, K, cameras[img_idx].R, INTER_NEAREST, BORDER_CONSTANT, mask_warped);
// Compensate exposure
compensator->apply(img_idx, corners[img_idx], img_warped, mask_warped);
img_warped.convertTo(img_warped_s, CV_16S);
img_warped.release();
full_img.release();
mask.release();
dilate(masks_warped[img_idx], dilated_mask, Mat());
resize(dilated_mask, seam_mask, mask_warped.size());
mask_warped = seam_mask & mask_warped;
// Blend the current image
blender->feed(img_warped_s, mask_warped, corners[img_idx]);
}
Mat result, result_mask;
blender->blend(result, result_mask);
原图分辨率为4160*3120。我没有在合成中使用压缩,因为它会降低质量。我在其余代码中使用了压缩图像。
如您所见,我修改了代码并缩短了时间。但我还是想尽可能地减少时间。
3) 寻找特征点 - 使用 ORB。 10 张图片需要 10 秒。查找图像的最大 1530 个特征点。
55 + 38 + 10 = 103 + 7 对于其余代码 = 110。
当我在 android 中使用这段代码时,它几乎占用了智能手机的整个内存 (RAM) 来执行。如何减少 Android 设备的时间和内存消耗? (我使用的 Android 设备有 2 GB RAM)
我已经优化了其余代码。非常感谢任何帮助!
编辑 1:我在合成步骤中使用了图像压缩,时间从 38 秒减少到 16 秒。我还设法减少了其余代码的时间。
现在,从 110 -> 85 秒。帮助我减少配对匹配的时间;我不知道如何减少它!
编辑 2:我在 matchers.cpp 中找到了成对匹配的代码.我在主代码中创建了自己的函数来优化时间。对于合成步骤,我使用压缩直到最终图像不失去清晰度。对于特征查找,我使用图像缩放来以缩小的图像比例查找图像特征。现在我可以轻松拼接多达 50 张图像。
最佳答案
由于 55 秒到 18 秒是一个很好的改进,也许您可以稍微控制匹配过程。我首先建议的是——如果你还没有——学习调试过程的每一步,了解当图像没有被缝合时出了什么问题。这样,您将始终学会控制例如您正在检测的 ORB 功能的数量。也许在某些情况下,您可以限制它们并仍然获得结果,从而加快过程(这不仅应该加快查找特征的速度,而且还会加快匹配过程)。
希望这会让您能够检测到这种情况,当 - 正如您所说的那样 - 循环中断时。因此,您可以相应地对情况使用react。您仍然可以在循环中匹配序列,从而节省时间,但当您检测到匹配特定对时出现问题时,会强制程序继续(或更改参数并尝试再次匹配该对)。
我认为这里的合成过程没有太大的改进空间,因为您不想失去质量。如果我是你,我会尝试研究的是,线程和并行计算是否可以提供帮助。
这是一个有趣且普遍存在的问题 - 如果您能够在不放弃质量的情况下加快速度,您应该调用 LG 或 Google,因为我在我的 Nexus 中的算法质量真的很差 :) 它既慢又不准确.
关于android - 如何优化 multimap 像拼接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42548868/
我在 Multimap 中创建了 Integer 和 Multimap,并且尝试循环获取键和值。然而,对于 Multimap,它以数组形式返回,我无法删除该数组并仅获取 int。 这是我的代码 pub
// this has data from elsewhere, just showing its the same type multimap map_with_data; string strin
假设我有这个 multimap std::multimap mymm; mymm.insert (std::make_pair('x',10)); mymm.insert (std::make_pai
我已经解析了 HTML 时间表并将每个主题加载到我的类对象中。所以我有我的科目的数组列表,其中包含姓名、老师、...、小时和日期的信息现在我想重建表格,所以我需要先对其进行分类。我认为最好的结构是这样
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: stl::multimap - how do i get groups of data? 我想做的是计算存储
我已经声明了一个包含字符串和映射的多重映射。该映射包含字符串和一对整数。 std::multimap>> traders; std::map> products; std::pair side; 我通
我需要将多重映射转换为空缓冲区,并将其传递到应重建多重映射的函数中。 我知道有一种简单的方法可以简单地传递多重映射,但我需要通过 void 指针来完成,所以请查看下面的逻辑: using namesp
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 有关您编写的代码问题的问题必须在问题本身中描述具体问题 - 并包含有效代码以重现该问题。请参阅SSCCE.o
我正在尝试从 Java 中的 MultiMap (org.apache.commons.collections.MultiMap) 中删除单个值。问题是它包含两个值。当我删除一个时,另一个也会被删除。
我是 RavenDB 的新手。我正在尝试使用多 map 索引功能,但我不确定这是否是解决我的问题的最佳方法。所以我有三个文件:Unit、Car、People。 汽车文件看起来像这样: { Id: "
我要解决的问题是我必须在树中输入 IP 地址前缀和与它们关联的数据,以便以后可以查询它们。我正在从一个文件中读取这些地址,该文件可能包含多达 1600 万条记录,并且该文件可能有重复项,我也必须存储这
假设我有一个这样的值列表: ["abc","abd","aab","123"] 我想通过使用将任何元素映射到键的函数将这些值分组到 Haskell 中的 MultiMap(概念上,不限于特定的数据结构
我目前正在使用 Guava Multimap执行。 map = Multimaps.synchronizedSetMultimap(HashMultimap. create()); 但是我发现我的程序
我试图在数据结构中存储一个键的多个值,因此我使用 Guava(Google Collection)的 MultiMap。 Multimap destinations = HashMultimap.cr
一个希望很快的问题: 我计划构建一个 MultiMap 样式结构,内部使用 Map> 结构进行构建,并重写方法以适当的方式重定向到内部映射和列表(因此这对于用户而言表现为 multiMap)。当然,还
我有一个 Multimap 并且需要搜索值。看起来像这样 ListMultiMap pers = ArrayListMultimap.create(); .... Person person = n
我有一个Multimap来存储一些带有复合键(数据类型、数据ID)的数据。这是我的代码: public class Data { private final String type;
我有一个由 定义的 multimap typedef std::pair comp_buf_pair; //pair typedef std::pair node_buf_pair; typedef
我正在尝试使用多键结构作为键来创建多重映射,但出现如下错误: 代码: struct stCont { long long Tok; char Reserved; long lo
我目前正处于在 Qt5 中建立 MVC 模型的概念阶段。 我想提供一种方法来调整 QAbstractTableModel 的标题.此方法应该接受单个变量来定义 header 的标签以及相关的角色,它由
我是一名优秀的程序员,十分优秀!