【学习笔记】昇思25天学习打卡(D04)初学05-数据变换Transforms.ipynb

数据变换 Transforms

在机器学习和深度学习中,数据预处理是一个至关重要的步骤。通常情况下,原始数据并不能直接用于模型训练,需要进行一系列的转换和处理。MindSpore框架提供了多种数据变换(Transforms)工具,配合数据处理流水线(Pipeline),可以高效地实现数据预处理。

MindSpore的dataset模块提供了面向图像、文本、音频等不同数据类型的Transforms,同时也支持使用Lambda函数进行自定义处理。这些Transforms可以通过map方法应用到指定的数据列上。下面我们将详细介绍几种主要的Transforms类型。

Common Transforms

mindspore.dataset.transforms模块支持一系列通用的Transforms。其中,Compose是一个非常实用的工具,它可以将多个数据增强操作组合成一个单一的操作,使得数据处理流程更加简洁和高效。

Vision Transforms

对于图像数据,mindspore.dataset.vision模块提供了丰富的处理工具。以下是几个常用的图像处理变换:

  1. Rescale:用于调整图像像素值的大小。它包含缩放因子和平移因子两个参数,可以对图像进行线性变换。

  2. Normalize:用于图像的归一化处理。它可以指定每个通道的均值和标准差,将图像数据调整到一个标准化的范围内。这对于模型的训练稳定性和收敛速度有很大帮助。

  3. HWC2CHW:用于转换图像的数据格式。在不同的硬件设备上,可能会对(height, width, channel)或(channel, height, width)两种不同格式有针对性优化。MindSpore默认使用HWC格式,但在需要时可以方便地转换为CHW格式。

Text Transforms

对于文本数据,mindspore.dataset.text模块提供了专门的处理工具。文本数据的处理通常包括分词(Tokenize)、构建词表、将词转换为索引等步骤。以下是几个常用的文本处理工具:

  1. PythonTokenizer:这是一个基础的分词器,允许用户自定义分词策略。它非常灵活,可以根据具体需求实现不同的分词方法。

  2. Lookup:这是一个词表映射工具,用于将分词后的词转换为对应的索引。在使用Lookup之前,需要先构建词表,可以使用预定义的词表或从数据集中生成新的词表。

Lambda Transforms

除了预定义的Transforms,MindSpore还支持使用Lambda函数进行自定义的数据处理。Lambda函数是一种匿名函数,可以在数据处理过程中灵活地定义和使用。这为复杂的数据处理需求提供了极大的灵活性。

通过合理使用这些Transforms,我们可以高效地完成数据预处理,为后续的模型训练做好准备。在实际应用中,往往需要根据具体的数据特点和模型需求,选择合适的Transforms组合使用。

Reference

教程来自:
https://gitee.com/mindspore/docs/blob/r2.3/tutorials/source_zh_cn/beginner/transforms.ipynb
其他可以用来参考的文档有:
https://www.mindspore.cn/docs/zh-CN/r2.3/api_python/mindspore.dataset.transforms.html

  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值