卷积边界 CopyMakeBorder

引自:http://blog.sina.com.cn/s/blog_627e716701015zeg.html
CopyMakeBorder

复制图像并且制作边界。(处理边界卷积)

函数定义如下:
void cvCopyMakeBorder( const CvArr* src, CvArr*dst, CvPoint offset, int bordertype, CvScalar value=cvScalarAll(0) );

src:输入图像。

dst:输出图像。

offset:
输入图像(或者其 ROI )欲拷贝到的输出图像长方形的左上角坐标(或者左下角坐标,如果以左下角为原点)。长方形的尺寸要和原图像的尺寸的 ROI 分之一匹配。

bordertype:
已拷贝的原图像长方形的边界的类型:
IPL_BORDER_CONSTANT - 填充边界为固定值,值由函数最后一个参数指定。 IPL_BORDER_REPLICATE - 边界用上下行或者左右列来复制填充。(其他两种 IPL 边界类型, IPL_BORDER_REFLECT IPL_BORDER_WRAP 现已不支持)。

value:
如果边界类型为 IPL_BORDER_CONSTANT 的话,那么此为边界像素的值。

函数 cvCopyMakeBorder 拷贝输入 2 维阵列到输出阵列的内部并且在拷贝区域的周围制作一个指定类型的边界。函数可以用来模拟和嵌入在指定算法实现中的边界不同的类型。例如:和 opencv 中大多数其他滤波函数一样,一些形态学函数内部使用复制边界类型,但是用户可能需要零边界或者填充为 1 255 的边界。

例子程序如下:


#include "highgui.h"
#include "cv.h"
int main(int argc,char **argv)
{ IplImage *src,*dst; src = cvLoadImage("lena.jpg",-1); 
dst = cvCreateImage(cvSize(src->width+100,src->height+100),IPL_DEPTH_8U,3); cvNamedWindow("src",0); 
cvShowImage("src",src); 
cvNamedWindow("filtering",0);
cvNamedWindow("dst",0); cvCopyMakeBorder(src,dst,cvPoint(1,1),IPL_BORDER_CONSTANT);//填充边界固定值,黑色 
cvShowImage("dst",dst); 
//cvWaitKey(0); cvCopyMakeBorder(src,dst,cvPoint(1,1),IPL_BORDER_REPLICATE);//复制边界 cvShowImage("filtering",dst); 
cvWaitKey(0); 
cvReleaseImage(&src); 
cvReleaseImage(&dst); 
cvDestroyAllWindows(); 
return (0);
}
显示图像结果如下:


在图像处理领域中,OpenCV是一个开源的计算机视觉和机器学习软件库,它提供了很多在图像和视频分析上的功能。图像的边界填充是指对图像边缘进行扩展,并对扩展部分赋予一定的值,这样在对图像进行卷积操作等过程中可以避免边界效应。 在OpenCV中,边界填充可以通过`cv2.copyMakeBorder()`函数来实现。该函数可以将源图像复制到新图像中,并在源图像的四周根据设定的参数进行边界填充。填充参数包括边界类型、边界的宽度以及填充的颜色值等。 边界填充类型主要分为以下几种: - `BORDER_CONSTANT`:使用固定值进行填充。 - `BORDER_REFLECT`:边界反射填充。 - `BORDER_REFLECT_101` 或 `BORDER_DEFAULT`:边界反射填充,但左右对称。 - `BORDER_REPLICATE`:复制最边缘的值。 - `BORDER_WRAP`:周期性填充。 以下是一个简单的示例代码,展示了如何使用`copyMakeBorder`函数进行边界填充: ```python import cv2 import numpy as np # 读取一张图片 image = cv2.imread('example.jpg') # 设置边界填充的参数 top, bottom, left, right = 10, 10, 10, 10 border_type = cv2.BORDER_CONSTANT value = (255, 255, 255) # 白色填充 # 执行边界填充 extended_image = cv2.copyMakeBorder(image, top, bottom, left, right, border_type, value=value) # 显示原图和填充后的图像 cv2.imshow('Original image', image) cv2.imshow('Extended image', extended_image) cv2.waitKey(0) cv2.destroyAllWindows() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值