博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
对二维数据进行边界拓展
阅读量:5064 次
发布时间:2019-06-12

本文共 2163 字,大约阅读时间需要 7 分钟。

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

算法

举例说明什么是奇拓展。比方对原始二维数据向左拓展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)*S - (a2Min>0?

0:a2Min); // copy current bi-level image to the extended image for (int r = 0; r < rows; r++){ memcpy(imExtOrgData + r*S, imData+r*cols, cols*sizeof(io_byte)); } }

上面的函数,实现的是将原始二维数据(实际是一维存储在内存里的)放到一个新的内存块中存储,新内存块是加入了拓展边界的内存的。

a1min,表示将原数据向上拓展(a1min<0? -a1min:0)行数据。

a1max。表示将原数据向下拓展(a1max>0? a1max:0)行数据。

a2min,表示将原数据向左拓展(a2min<0?

-a2min:0)列数据。

a2max,表示将原数据向右右拓展(a2max>0?a2max:0)列数据。

void abOddFillExtendMemory(unsigned char *imExtData, unsigned char *imExtOrgData,  const int a1Min, const int a1Max,  const int a2Min, const int a2Max,  const int rows, const int cols,  const int S, const int R){  // vertical direction  for (int r = a1Min; r < 0; r++){    memcpy(imExtOrgData + r*S, imExtOrgData - r*S, sizeof(io_byte)*cols);  }  for (int r = a1Max; r > 0; r--){    memcpy(imExtOrgData + (rows-1+r)*S, imExtOrgData + (rows-1-r)*S, sizeof(io_byte)*cols);  }  // horizontal direction  if (a2Min < 0){    for (int r = 0; r < R; r++){      for (int ct = a2Min; ct < 0; ct++){        imExtData[r*S+ct-a2Min] = imExtData[r*S-ct-a2Min];      }    }  }  if (a2Max > 0){    for (int r = 0; r < R; r++){      for (int ct = a2Max; ct > 0; ct--){        imExtData[r*S+cols-(a2Min<0?

a2Min:0)+ct-1] = imExtData[r*S+cols-(a2Min<0?a2Min:0)-ct-1]; } } } }

上面的代码实现的是。对拓展出的边界进行数据填充,详细填充方式,依照奇对称填充规则实现。

总结

二维数据的拓展常常被使用到,特别是图像处理中,使用这段代码,能够降低点开发时间。另外。假设想使用其它拓展算法,能够直接将上面第二个函数的赋值操作改动成想要的规则就可以。

转载于:https://www.cnblogs.com/mfrbuaa/p/5168717.html

你可能感兴趣的文章
Java——去除字符串中的中文
查看>>
HTML5新增标签的汇总与详解
查看>>
转: 三大WEB服务器对比分析(apache ,lighttpd,nginx) (2008年的旧文,仅供参考之用)...
查看>>
git使用
查看>>
可实现自动设置尺寸的图片上传类
查看>>
bzoj3140: [Hnoi2013]消毒(二分图)
查看>>
bzoj 3131 [Sdoi2013]淘金(数位dp)
查看>>
CF662C Binary Table
查看>>
招行率先落地房贷新政 其他银行细则仍在制定
查看>>
Android 开发笔记——通过 Intent 传递类对象
查看>>
微信小程序 weui 使用方法
查看>>
Java学习笔记(7)——Java基础之IO&多线程&网络<思维导图>
查看>>
数据结构入门学习笔记-1
查看>>
HTML当中特殊字符的表示
查看>>
单调队列入门
查看>>
centos 忘记 root 密码
查看>>
Arduino学习笔记⑦ EEPROM断电保存数据
查看>>
剑、刀、箭详细介绍
查看>>
[转]Git分支管理策略
查看>>
pycharm 进行远程服务器修改与调试
查看>>