Вы должны использовать f
вместо x
, поскольку f
- это фактический сигнал, загруженный из вашего файла .wav. Переменная x
, вероятно, была просто другим скаляром в вашем рабочем пространстве, поэтому вы получили сообщение об ошибке.
Есть несколько других исправлений / улучшений, которые следует внести в ваш код. Во-первых, как Пол Р указал , вам нужно исправить способ вычисления numFrames
. Во-вторых, energy
следует инициализировать как вектор нулей. В-третьих, вы можете уменьшить внутренний цикл for до однострочной векторизованной операции.
Вот как я бы переписал ваш код ( РЕДАКТИРОВАТЬ: основываясь на комментариях, я обновил код для сохранения нескольких дополнительных переменных, вычисленных в цикле ):
[y, fs, nb] = wavread('Three.wav'); %# Load the signal into variable y
frameWidth = 441; %# 10 msec
numSamples = length(y); %# Number of samples in y
numFrames = floor(numSamples/frameWidth); %# Number of full frames in y
energy = zeros(1,numFrames); %# Initialize energy
startSample = zeros(1,numFrames); %# Initialize start indices of frame
endSample = zeros(1,numFrames); %# Initialize end indices of frame
for frame = 1:numFrames %# Loop over frames
startSample(frame) = (frame-1)*frameWidth+1; %# Starting index of frame
endSample(frame) = frame*frameWidth; %# Ending index of frame
frameIndex = startSample(frame):endSample(frame); %# Indices of frame samples
energy(frame) = sum(y(frameIndex).^2); %# Calculate frame energy
end