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"])