Python librosa.frames_to_time()和librosa.samples_like()的用法
发布时间:2023-01-06 16:39:27 322
相关标签: # linux# 数据
本文要实现的目标为:
假如:1个音频的总帧数=170880,采样率sr=48000,持续秒数=3.560000
假设音频数据为y:
y = [-0.00856018 -0.00930786 -0.00827026 ..., -0.03897095 -0.03567505 -0.03329468]
要转化成的时间为times:
times = [ 0.00000000e+00 2.08333333e-05 4.16666667e-05 ..., 3.55993750e+00
3.55995833e+00 3.55997917e+00]
即要实现:第1个音频帧y[0]对应的时间为0.00000000e+00,最后1个音频帧y[-1]对应的时间为3.55997917e+00。
采样使用y每个元素的下标除以采样率sr获取帧与帧的时间间隔的方法可能会更简单,本文仅是使用librosa.frames_to_time和librosa.samples_like来实现,代码在Ubuntu中实现,如下。
代码中,librosa.samples_like仅用来获取音频帧的下标,librosa.frames_to_time用来根据音频帧的下标转化为时间,这两个函数的返回值是ndarray类型。
代码运行结果如下:
文章来源: https://blog.51cto.com/u_15927439/5985415
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报