- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在我的项目中,我想裁剪图像的 ROI。为此,我创建了一个包含感兴趣区域的 map 。现在我想裁剪具有最重要像素的区域(黑色不重要,白色很重要)。
有人知道如何实现它吗?我认为这是一个最大化问题
下图中的红色边框是我要如何裁剪此图像的示例
最佳答案
如果我正确理解了您的问题,那么您已经计算了图像中每个点的值。这些值表明每个点的“重要性”/“趣味性”/“显着性”。包含这些值的矩阵/图像是您所指的“ map ”。您的目标是获得具有高“重要性”分数的感兴趣区域 (ROI) 的边界框。
我认为您可以分割 ROI 的方法是应用基于 Graph Cut 的分割,使用重要性图在每个像素处计算“分数”。分割的结果是一个二进制掩码,它掩盖了“重要”像素。接下来,运行 OpenCV 的 findcontours在此二进制掩码上运行以获取各个连接的组件。然后使用 OpenCV 的 boundingRect findContours(...) 返回的轮廓上的函数以获取边界框。
以这种方式使用基于 Graph Cut 的分割算法的好处在于,它将连接碎片化的组件,即即使您的“重要性”图嘈杂,生成的二进制掩码也不会有小洞。
在 OpenCV 中已经实现的一种基于 Graph Cut 的分割算法是 GrabCut 算法。一个快速的技巧是将它应用到你的“重要性” map 上,以获得我上面提到的二进制掩码。一种更复杂的方法是使用您的“重要性”图构建前景和背景(可能是颜色?)模型并将其作为输入传递给函数。有关 OpenCV 中 GrabCut 的更多详细信息,请参见:http://docs.opencv.org/modules/imgproc/doc/miscellaneous_transformations.html?highlight=grabcut#void grabCut(InputArray img, InputOutputArray mask, Rect rect, InputOutputArray bgdModel, InputOutputArray fgdModel, int iterCount, int mode)
如果您想要更大的灵 active ,您可以使用以下 MRF 库破解您自己的基于图形的分割算法。该库允许您在计算图割时指定自定义目标函数:http://vision.middlebury.edu/MRF/code/
要使用 MRF 库,您需要在图像中的每个点指定“成本”,指示该点是“前景”还是“背景”。您也可以将这种二分法视为“重要”或“不重要”,而不是“前景”与“背景”。
MRF 库的目标是在每个点返回一个标签,以便分配这些标签的总成本尽可能小。因此,游戏是想出一个函数来计算你认为重要的点的小成本,否则大。
具体来说,每个点的成本由两部分组成:1)数据项/函数和 2)平滑项/函数。如前所述,每个点的数据项越小,该点被选中的可能性就越大。如果您的“重要性”分数 s_ij 在 [0, 1] 范围内,那么计算数据项的常用方法是 -log(s_ij)。
平滑项是一种建议 2 个相邻像素 p、q 是否应该具有相同标签的方法,即“前景”、“背景”或一个“前景”和另一个“背景”。与数据成本类似,您必须构建它,使得具有相似“重要性”分数的相邻像素的成本很小,以便为它们分配相同的标签。该术语负责“平滑”生成的蒙版,这样您就不会在“重要性”高的区域内散布低“重要性”的像素,反之亦然。如果有这样的区域,上面提到的 OpenCV 的 findContours(...) 函数将返回这些区域的轮廓,也许可以通过检查它们的大小来过滤掉它们。
有关计算成本的函数的详细信息,请参阅 GrabCut 论文:GrabCut
这篇博文提供了更多关于在 OpenCV 中创建自己的图形分割算法的详细信息(和代码):http://www.morethantechnical.com/2010/05/05/bust-out-your-own-graphcut-based-image-segmentation-with-opencv-w-code/
另一篇论文展示了如何在 GrabCut 论文中使用更好的符号和没有复杂的图像抠图部分(未在 OpenCV 版本中实现)对灰度图像(您的情况)执行图形切割分割,这是:Graph Cuts and Efficient N-D Image Segmentation
希望这可以帮助。
关于opencv - 如何裁剪图像的 roi,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13725696/
我正在从事中间阶段的视频处理项目,需要用另一幅图像的 ROI(相同维度)替换某些图像的 ROI。有内置函数吗?? 最佳答案 您可以使用 Mat::copyTo 在 Mat 实例之间传输内容: cv::
我过去曾这样做过并且运行良好,但我的功能很奇怪。我正在尝试提取图像的投资返回率。这是我的代码: cv::Rect roi(x - 1, y - 1, 3, 3); cv::Mat patch_t(cu
我有真菌图像数据集,每个图像都有其 ROI 掩码。我想使用给定的掩码并从真菌图像中提取 ROI。 以下是我想使用一些机器学习技术提取 ROI 的掩码。 提前致谢。 最佳答案 您需要做的是,使用掩码作为
我有一个非矩形 ROI 的图像,由二值掩码图像定义。 在 OpenCV 中,如何将 ROI 外的像素设置为 ROI 内最接近的像素值?类似于 cv::BORDER_REPLICATE 中的内容,或类似
晚上好! 我的问题如下: 1.roi的形状只应该是200,200。这里显示 313,313,我不确定为什么。 2.当我将 roi 的 frame 切换为 imshow() 的参数时,结果也不是正确的
我对图像 ROI 的特征提取很感兴趣,这些特征将用作支持 vector 机的特征向量输入。要提取的特征包括纹理(颜色共现/haralick 特征)和颜色(rgb-直方图,4 bins 和均值 r,g,
我目前正在尝试运行EfficientPS(https://github.com/vincrichard/EfficientPS)。当我开始训练时,网络的初始化由于属于Detectron2的关键错误而崩
After applying mask original image import cv2 import dlib import numpy as np img = cv2.imread("Aayus
我试过在不同的网站上搜索解释,但我没有得到一个完整解释的答案。 import cv2 import numpy as np img1 = cv2.imread('3D-Matplotlib.png')
我的问题是关于如何仅将 Mat 的 roi 的 header 复制到 Mat 的另一个 roi 以避免复制整个 Mat 的数据以节省计算时间。 例如,我的源 Mat 的 roi 为 Mat src(c
我组织(开发API的中间件)中的软件开发团队正在准备一次采用至少一种最佳实践。列表中有以下内容: 单元测试(实际意义上), 自动化的单元测试 测试驱动设计与开发, 静态代码分析 持续集成能力等。 有人
我有一个视频序列,其中一帧如下所示。我试图使用角点检测来找到纸张上矩形的边缘。 我正在使用 Shi-Tomasi 角点检测器。然而,它从图像的背景中检测到许多我不需要的其他东西。我怎样才能将我的投资返
我正在尝试使用 opencv C++ 检测图像中固定重复模式的 ROI。 我试图找到的投资返回率 - 如图所示用红色边界显示: 我在模糊后尝试了精明的边缘检测,但它检测到垂直/水平黑白线的边缘。这不是
我目前正在使用足迹识别项目进行动物识别。我的主要任务是处理取自天然基质的动物足迹,并识别足迹所属的动物。第一步是预处理图像并提取 ROI。这是我遇到困难的地方,因为处理后的图像包含很多噪音。 我已经执
我正在寻找一种方法来找到感兴趣的非正方形区域。我在这里看到了所有基于矩形的示例。例如here they find the tilted rectangle .我看过像 this SO page 这样的
OpenCV 如何处理感兴趣区域 (ROI)? 假设我使用 cvSetImageROI() 设置了一个感兴趣区域。该 ROI 是否存储在 IplImage 结构中? 如果是这样,当我将图像传递给 cv
我得到了一些养牛场的图像。每个图像假设只覆盖两笔(小牛房)。但是,相机也会覆盖相邻的笔。我需要摆脱邻近笔的区域。 输入图像 - 输出图像 - 我已经尝试了以下命令并且它完成了工作。但是,它缩小了图像的
在我的项目中,我想裁剪图像的 ROI。为此,我创建了一个包含感兴趣区域的 map 。现在我想裁剪具有最重要像素的区域(黑色不重要,白色很重要)。 有人知道如何实现它吗?我认为这是一个最大化问题 下图中
我有一个电影文件,我感兴趣的是记录一个点的运动;圆形特征的中心是特定的。我正在尝试使用 Matlab 中的边缘检测和角点检测技术来执行此操作。 要执行此操作,我该如何指定视频中的感兴趣区域?子图是个好
我在提取非直线 ROI 时遇到了问题。到目前为止,我有以下内容: cv::RotatedRect face_rotated_roi(rotated_center, face_roi.size(), r
我是一名优秀的程序员,十分优秀!