mindspore.dataset.audio.transforms.AmplitudeToDB

class mindspore.dataset.audio.transforms.AmplitudeToDB(stype=ScaleType.POWER, ref_value=1.0, amin=1e-10, top_db=80.0)[源代码]

将输入音频从振幅/功率标度转换为分贝标度。

Note

待处理音频维度需为(…, freq, time)。

参数:

  • stype ( mindspore.dataset.audio.utils.ScaleType , 可选) - 输入音频的原始标度,取值可为ScaleType.MAGNITUDE或ScaleType.POWER,默认值:ScaleType.POWER。

  • ref_value (float, 可选) - 系数参考值,默认值:1.0,用于计算分贝系数 db_multiplier ,公式为

    \(db\_multiplier = Log10(max(ref\_value, amin))\)

  • amin (float, 可选) - 波形取值下界,低于该值的波形将会被裁切,取值必须大于0,默认值:1e-10。

  • top_db (float, 可选) - 最小截止分贝值,取值为非负数,默认值:80.0。

异常:

  • TypeError - 当 stype 的类型不为 mindspore.dataset.audio.utils.ScaleType

  • TypeError - 当 ref_value 的类型不为float。

  • ValueError - 当 ref_value 不为正数。

  • TypeError - 当 amin 的类型不为float。

  • ValueError - 当 amin 不为正数。

  • TypeError - 当 top_db 的类型不为float。

  • ValueError - 当 top_db 不为正数。

  • RuntimeError - 当输入音频的shape不为<…, freq, time>。

支持平台:

CPU

样例:

>>> import numpy as np
>>> from mindspore.dataset.audio import ScaleType
>>>
>>> waveform = np.random.random([1, 400 // 2 + 1, 30])
>>> numpy_slices_dataset = ds.NumpySlicesDataset(data=waveform, column_names=["audio"])
>>> transforms = [audio.AmplitudeToDB(stype=ScaleType.POWER)]
>>> numpy_slices_dataset = numpy_slices_dataset.map(operations=transforms, input_columns=["audio"])