Assignment has more non-singleton rhs dimensions than non-singleton subscripts

조회 수: 13 (최근 30일)
David Costa
David Costa 2018년 3월 2일
답변: Jan 2018년 3월 2일
Hello, can anyone help me with this error with the code shown bellow?
if true
samplingRate = 11025;
%transform the signal to the frequency domain.
%fourierData = fft(data,length(data));
%magFour = abs(fourierData);
totalFileTimeInMSec = (length(data) / samplingRate)*100;
frameLengthInMSec = 1;
% calculate the number of frames
numberOfFrames = totalFileTimeInMSec / frameLengthInMSec;
numberOfFrames = floor(numberOfFrames);
% calculate the size of each frame in the data array.
frameSize = samplingRate * frameLengthInMSec / 100;
%initialize the frames.
% frames = zeros(numberOfFrames,frameSize);
% frame = zeros(1,frameSize);
frames = numberOfFrames;
frame = frameSize;
% copy the data from the signal to the frames.
startIndex = 1;
endIndex = frameSize;
for frameM = 1:1:numberOfFrames
frame = data(startIndex:endIndex,1);
startIndex = startIndex + frameSize;
endIndex = endIndex +frameSize;
frames(frameM,:) = frame.';
end
  댓글 수: 4
Stephen23
Stephen23 2018년 3월 2일
You define frames to be a single scalar number:
frames = numberOfFrames;
but you seem to be indexing into it as if it were an array.

댓글을 달려면 로그인하십시오.

답변 (1개)

Jan
Jan 2018년 3월 2일
Why did you change
% frames = zeros(numberOfFrames,frameSize);
to
% frame = zeros(1,frameSize);
frames = numberOfFrames;
frame = frameSize;
The first was working, and adding more definitions, partially as comment, overwriting the former one, is confusing only, obviously.

카테고리

Help CenterFile Exchange에서 Descriptive Statistics에 대해 자세히 알아보기

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by