对二维数据进行边界拓展

简介:

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


算法

举例说明什么是奇拓展。比方对原始二维数据向左拓展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]; } } } }


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


总结

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







本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5168717.html,如需转载请自行联系原作者

相关文章
YI
|
存储 传感器 网络协议
物网概论2(上)
物网概论2(上)
YI
719 0
|
7月前
|
人工智能 JavaScript 数据安全/隐私保护
鸿蒙开发难题多到崩溃?然而 10 亿终端暗藏财富密码-卓伊凡
鸿蒙开发难题多到崩溃?然而 10 亿终端暗藏财富密码-卓伊凡
174 5
鸿蒙开发难题多到崩溃?然而 10 亿终端暗藏财富密码-卓伊凡
|
数据挖掘 索引 Python
如何在处理重复值时保持数据的原始顺序?
可以在处理数据重复值时有效地保持数据的原始顺序,确保数据在清洗和预处理过程中不会因为重复值的处理而导致顺序混乱,从而保证了数据分析结果的准确性和可靠性。
382 64
|
运维 监控 网络协议
|
9月前
|
监控 关系型数据库 MySQL
MySQL和SQLSugar百万条数据查询分页优化
在面对百万条数据的查询时,优化MySQL和SQLSugar的分页性能是非常重要的。通过合理使用索引、调整查询语句、使用缓存以及采用高效的分页策略,可以显著提高查询效率。本文介绍的技巧和方法,可以为开发人员在数据处理和查询优化中提供有效的指导,提升系统的性能和用户体验。掌握这些技巧后,您可以在处理海量数据时更加游刃有余。
843 9
|
10月前
|
存储 人工智能 开发框架
Eliza:TypeScript 版开源 AI Agent 开发框架,快速搭建智能、个性的 Agents 系统
Eliza 是一个开源的多代理模拟框架,支持多平台连接、多模型集成,能够快速构建智能、高效的AI系统。
1009 8
Eliza:TypeScript 版开源 AI Agent 开发框架,快速搭建智能、个性的 Agents 系统
|
API 数据库 开发者
Flask:Python的轻量级Web框架
Flask:Python的轻量级Web框架
350 2
|
机器学习/深度学习 人工智能 自然语言处理
人工智能在智能客服中的应用:技术革新与未来展望
【7月更文挑战第5天】人工智能在智能客服中的应用正引领着一场深刻的变革。通过自然语言处理、机器学习等核心技术的应用,智能客服不仅提高了服务效率和质量,还降低了企业成本,增强了客户满意度和忠诚度。未来,随着技术的不断进步和应用场景的拓展,智能客服将更加智能化、个性化,并在更多领域发挥重要作用。
1070 2
|
机器学习/深度学习 人工智能 运维
智能化运维:基于AI的系统异常检测与自动修复策略
【5月更文挑战第29天】 在现代IT基础设施管理领域,智能化运维正逐步成为推动效率和稳定性的关键因素。本文深入探讨了人工智能(AI)技术在系统异常检测和自动化故障修复中的应用,提出了一个集成的智能运维框架。该框架利用机器学习算法分析历史数据,实时监控关键性能指标,并在检测到潜在问题时触发自动化修复流程。通过这一方法,我们旨在降低人工干预的需求,提高系统的可靠性和业务连续性。
请解释鸿蒙操作系统的分布式能力是如何实现的。
请解释鸿蒙操作系统的分布式能力是如何实现的。
638 1