【Pytorch问题及解决】

### 出现的问题:

‘lengths‘ argument should be a 1D CPU int64 tensor, but got 1D cuda:0 Long tensor

解决办法:

packed = pack_padded_sequence(embed_src, src_length, batch_first=True)
改为
packed = pack_padded_sequence(embed_src, src_length.cup(), batch_first=True)

参考
https://github.com/joeynmt/joeynmt/pull/119/commits/ef1b0f081fedfcf83ce39cd2f27dcc33d3cbb2d1

同一问题,已解决 

### 出现的问题:

Python音频转成numpy数组:numpy.frombuffer报错ValueError: buffer size must be a multiple of element size

使用背景:导入音频信号,下面代码段最后一句报错

import wave
import numpy as np
 
f = wave.open(wav_path)
params = f.getparams()
nchannels, sampwidth, framerate, nframes = params[:4]
# 声道数; 量化位数(byte); 采样频率; 采样点数
str_audio = f.readframes(nframes)
f.close()
 
audio = np.frombuffer(str_data, dtype=np.short)

问题解决:最后一句dtype的参数改成与自己的声音信号相一致

查看sampwidth这一参数,量化位数(sampwidth)就是记录声波每次采样所需的位数,一般有16,24,32位

  • 数据量(总b) = 采样频率(Hz) x 量化位数(bit) x 时间(s) x 声道数(个)
  • 数据量(总B) = 采样频率(Hz) x 量化位数(bit) x 时间(s) x 声道数(个) / 8

如果音频的量化位数为24bit,如何读取?

可以使用wavio包,直接读取成numpy数组

import wavio
 
audio = wavio.read(wav_path)

附上wavio的github链接:

wavio/wavio.py at master · WarrenWeckesser/wavio · GitHub

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值