对二维数据进行边界拓展

对二维数据处理的时候,经常遇到需要越界的问题,比如对图像进行滤波操作。对原始数据的边界进行拓展,然后使用拓展后的数据作处理,可以解决越界的问题。根据拓展出的数据的值来自哪里可以分为多种边界拓展方式,我们要实现的是将边界进行奇对称拓展。


算法

举例说明什么是奇拓展。比如对原始二维数据向左拓展4列,那么在边界上向左第一列复制边界上向右第一列,在边界上向左第二列复制边界上向右第二列,以此类推。边界列并没有被复制,因为C语言中是从0开始计数的,所以边界列是0列,按照0列对称拓展就称为奇对称拓展。如果0列被复制到左拓展的第一列,1列被复制到向左拓展的第二列,那么这种拓展方式成为偶拓展。


代码

对二维数据进行奇拓展的代码片段如下:

void abExtendMemory(unsigned char *&imExtData, unsigned char *&imExtOrgData, 
  int &S, int &R, 
  const int rows, const int cols, const io_byte *imData,
  const int a1Min, const int a1Max,
  const int a2Min, const int a2Max)
{
  S = cols + (a2Max>0? a2Max:0) - (a2Min<0? a2Min:0);
  R = rows + (a1Max>0? a1Max:0) - (a1Min<0? a1Min:0);
  imExtData = new io_byte[(R)*(S)];
  imExtOrgData = imExtData - (a1Min>0? 0:a1Min
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值