0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

众多常见的有效图像预处理方法

新机器视觉 来源:机器之心 作者:机器之心 2021-05-03 18:26 次阅读

一个经历了 39 场 Kaggle 比赛的团队在 reddit 上发帖表示,他们整理了一份结构化的图像分割技巧列表,涵盖数据增强、建模、损失函数、训练技巧等多个方面,不失为一份可以参考的图像分割技巧资料

图像分割是图像处理和计算机视觉的热点之一,是根据图像内容对指定区域进行标记的计算机视觉任务。它基于某些标准将输入图像划分为多个相同的类别,简言之就是「这张图片里有什么,其在图片中的位置是什么?」以便提取人们感兴趣的区域。图像分割是图像分析和图像特征提取及识别的基础。

图像分割也是 Kaggle 中的一类常见赛题,比如卫星图像分割与识别、气胸疾病图像分割等。除了密切的团队配合、给力的 GPU 配置等条件,技巧在这类比赛中也发挥了很大的作用。但这些技巧去哪里找呢?Medium、大牛博客、参赛经验帖中都散落着各种技巧分享,但这些资源往往比较零散,于是就有人想到,为什么不把它们集中到一起呢? Derrick Mwiti 就带头做了这么一件事,他和他所在的团队将过去 39 场 Kaggle 比赛中讨论过的图像分割技巧、资料都汇总到了一起,希望可以帮到在图像分割任务中遇到困难的同学。 这份列表分为十大板块,包括外部数据、预处理、数据增强、建模、硬件配置、损失函数、训练技巧、评估和交叉验证、集成方法以及后处理。

每个版块的具体内容以条目的形式呈现,每个条目又都嵌入了一些链接,点开可以看到一些优秀的 Kaggle 解决方案分享、Medium 博客教程、高赞的 GitHub 项目等,读者可以根据自己的具体问题和需要进行查找。 本文选取了其中一部分内容进行介绍,具体细节及链接请参见原文。 接下来,我们来看每个步骤都有哪些技巧吧。 预处理 这一部分包含众多常见的有效图像预处理方法,例如:

使用高斯差分方法进行斑点检测

使用基于图像块的输入进行训练,以减少训练时间;

加载数据时,用 cudf 替换 Pandas;

确保所有图像保持相同的方向;

使用 OpenCV 对所有常规图像进行预处理;

采用自主学习并手动添加注释;

将所有图像调整成相同的分辨率,以便将相同的模型用于不同厚度的扫描等。

数据增强 数据增强能够使网络具有更复杂的表征能力,从而减小网络性能在验证集和训练集以及最终测试集上的差距,让网络更好地学习迁移数据集上的数据分布。这部分介绍了一些常用的数据增强方法:

用 albumentations 包进行数据增强;

使用 90 度随机旋转;

使用水平、垂直翻转或这两个方向都做翻转;

尝试进行复杂的几何变换,包括弹性变换、透视变换、分段仿射变换、枕形失真;

应用随机 HSV;

使用损失较小的增强数据进行泛化,以防止有用图像信息丢失;

应用通道 shuffle;

根据类别频率进行数据扩充;

应用高斯噪声等。

建模网络架构 这一部分介绍了一些可用在图像分割上的常用网络框架,例如:

使用基于 U-net 的架构;

用 inception-ResNet v2 架构得到具备不同感受野的训练特征;

经过对抗训练的 Siamese 网络;

以密集(FC)层作为最后一层的 ResNet50、Xception、Inception ResNet v2 x 5;

使用全局最大池化层,无论输入尺寸如何,该层都将返回固定长度的输出;

使用堆叠的膨胀卷积;

VoxelNet;

用 concat 和 conv1x1 替换 LinkNet 跳跃连接中的加号;

广义平均池化;

用 3D 卷积网络在图像上滑动;

使用在 Imagenet 数据集上预训练的 ResNet152 作为特征提取器等。

以及下列经典网络框架:

23f94f26-9cde-11eb-8b86-12bb97331649.png

损失函数 损失函数常用来估计模型预测结果与真值之间的差距。选择合适的损失函数,对模型效果很重要。 这部分介绍了一系列损失函数和使用场景,例如:

dice 系数:能够很好地处理不平衡数据;

加权边界损失:减少预测分割与真值之间的距离;

MultiLabelSoftMarginLoss:基于最大熵优化多标签一对多损失的标准;

具备 logit 损失的平衡交叉熵(Balanced cross entropy,BCE):以特定系数权衡正例和负例;

……

此外,作者还介绍了 Arc margin 损失、BCE 和 dice 系数的组合等等,更多详情参见原文。

训练技巧 这部分介绍了常用的模型训练技巧,如:

尝试不同的学习率;

尝试不同批大小;

使用带有动量项的 SDG,并且手动设置学习率衰减;

数据增强过多会降低准确率;

使用裁剪后的图像训练,并在完整的图像上做预测;

在学习速率调整上使用 Keras 中的 ReduceLROnPlateau() 方法;

冻结除了最后一层以外所有的网络层,并使用 Stage1 中的 1000 张图片进行模型微调;

开发一个能使标签更加均匀的采样器;

使用类别感知采样(class aware sampling)等。

评估和交叉验证 这部分介绍了 k 折交叉验证、对抗验证和权衡等方法,以及在调整模型最后一层时使用交叉验证方法以有效避免过拟合。

集成方法 许多机器学习竞赛(包括 Kaggle)中最优秀的解决方案所采用的集成方法都建立在一个这样的假设上:将多个模型组合在一起通常可以产生更强大的模型。 这部分介绍了多种集成方法,如多数投票法、XGBoost、LightGBM、CatBoost 等方法,以及集成 ResNet50、InceptionV3 和 InceptionResNetV2 的方法。

后处理 这部分介绍了多种后处理方法:

测试时增强(Test Time Augmentation,TTA):向模型多次展示经过不同随机变换的图像,取预测平均值;

均衡使用测试预测概率,而不是仅使用预测类;

将几何平均数应用于预测;

在推理过程中将图块重叠,使每个边缘像素至少覆盖 3 次,因为 UNET 在边缘区域范围的预测往往较差;

非极大抑制和边界框收缩;

分水岭后处理:在实例分割问题中分离对象。

最后需要注意的是,这份列表给出的某些技巧可能有一定的适用范围,具体能不能用还要视数据而定。

原文标题:图像分割的实用技巧

文章出处:【微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

责任编辑:haq

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 图像处理
    +关注

    关注

    27

    文章

    1269

    浏览量

    56431
  • 机器视觉
    +关注

    关注

    161

    文章

    4278

    浏览量

    119688

原文标题:图像分割的实用技巧

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    图像识别技术包括自然语言处理

    计算机视觉技术对图像进行处理、分析和理解,从而实现对图像中的目标、场景、行为等信息的识别和理解。图像识别技术包括图像
    的头像 发表于 07-16 10:54 426次阅读

    图像识别技术的原理是什么

    图像识别技术是一种利用计算机视觉和机器学习技术对图像进行分析和理解的技术。它可以帮助计算机识别和理解图像中的对象、场景和活动。 图像预处理
    的头像 发表于 07-16 10:46 650次阅读

    机器学习中的数据预处理与特征工程

    在机器学习的整个流程中,数据预处理与特征工程是两个至关重要的步骤。它们直接决定了模型的输入质量,进而影响模型的训练效果和泛化能力。本文将从数据预处理和特征工程的基本概念出发,详细探讨这两个步骤的具体内容、方法及其在机器学习中的应
    的头像 发表于 07-09 15:57 213次阅读

    机器人视觉技术中常见图像分割方法

    、场景理解、导航和交互等任务至关重要。以下是一些常见图像分割方法: 阈值分割法(Thresholding) 阈值分割法是一种基于像素强度的简单图像分割
    的头像 发表于 07-09 09:31 280次阅读

    FPGA设计经验之图像处理

    的滤波、取边缘、膨胀腐蚀等算法。可能大家会觉得这些运算似乎都是最基本的图像处理运算,只是个前端的预处理,似乎用处不大。但问题是只有FPGA做这样的运算才是速度最快效率最高的,比如用CPU做一个取边缘
    发表于 06-12 16:26

    信号的预处理包括哪些环节

    的各个环节,包括信号的采集、预滤波、采样、量化、编码、去噪、特征提取等。 信号采集 信号采集是信号预处理的第一步,它涉及到从实际物理现象中获取信号的过程。信号采集的方法取决于信号的类型和来源,例如声音、图像、温
    的头像 发表于 06-03 10:35 1554次阅读

    常见的医学图像读取方式和预处理方法

    基于深度学习做医学图像数据分析,例如病灶检测、肿瘤或者器官分割等任务,第一步就是要对数据有一个大概的认识。但是我刚刚入门医学图像分割的时候,很迷茫不知道自己该干啥,不知道需要准备哪些知识,慢慢到现在才建立了一个简陋的知识体系。
    发表于 04-19 11:43 645次阅读
    <b class='flag-5'>常见</b>的医学<b class='flag-5'>图像</b>读取方式和<b class='flag-5'>预处理</b><b class='flag-5'>方法</b>

    C语言中的预处理

    所有的预处理器命令都是以井号(#)开头。它必须是第一个非空字符,为了增强可读性,预处理器指令应从第一列开始。
    发表于 03-01 12:16 692次阅读
    C语言中的<b class='flag-5'>预处理</b>器

    基于图像处理技术的螺纹几何参数测量系统设计

    摘要:针对螺纹几何参数测量过程中,传统人工测量效率低、仪器昂贵、耗时费力、偶伴有人为误差等不足。本研究采用非接触测量的方法, 利用计算机视觉的图像处理技术,通过系统标定、图像采集、
    的头像 发表于 01-15 11:13 751次阅读
    基于<b class='flag-5'>图像</b><b class='flag-5'>处理</b>技术的螺纹几何参数测量系统设计

    C语言有哪些预处理操作?

    C语言的预处理是在编译之前对源代码进行处理的阶段,它主要由预处理器完成。预处理器是一个独立的程序,它负责对源代码进行一些文本替换和处理,生成
    的头像 发表于 12-08 15:40 508次阅读
    C语言有哪些<b class='flag-5'>预处理</b>操作?

    FPGA图像处理方法

    图像在采集和传输的过程中,通常会产生噪声,使图像质量降低,影响后续处理。因此须对图像进行一些图像滤波、
    的头像 发表于 12-02 13:15 926次阅读

    机器视觉之图像增强和图像处理

    一、图像处理技术概述1.定义对原始获取图像进行一系列的运算处理,称为图像处理
    的头像 发表于 10-26 08:07 825次阅读
    机器视觉之<b class='flag-5'>图像</b>增强和<b class='flag-5'>图像</b><b class='flag-5'>处理</b>

    机器视觉之图像增强和图像处理

    对原始获取图像进行一系列的运算处理,称为图像处理图像处理是机器视觉技术的
    发表于 10-23 10:43 444次阅读
    机器视觉之<b class='flag-5'>图像</b>增强和<b class='flag-5'>图像</b><b class='flag-5'>处理</b>

    图像处理预处理方法

    灰度化,在RGB模型中,如果R=G=B时,则彩色表示一种灰度颜色,其中R=G=B的值叫灰度值,因此,灰度图像每个像素只需一个字节存放灰度值(又称强度值、亮度值),灰度范围为0-255。一般有分量法 最大值法平均值法加权平均法四种方法对彩色
    的头像 发表于 10-20 17:08 895次阅读
    <b class='flag-5'>图像</b><b class='flag-5'>处理</b>之<b class='flag-5'>预处理</b><b class='flag-5'>方法</b>

    机器视觉:图像处理技术、图像增强技术

    对原始获取图像进行一系列的运算处理,称为图像处理图像处理是机器视觉技术的
    发表于 10-20 10:17 1048次阅读
    机器视觉:<b class='flag-5'>图像</b><b class='flag-5'>处理</b>技术、<b class='flag-5'>图像</b>增强技术