I keep getting the error "subscript must either be real positive integers or logicals" even when I place an 'if' statement

조회 수: 1 (최근 30일)
It seems I keep getting the error "subscript must either be real positive integers or logicals".
This must be because I have started of from i = 1, hence i - 1 = 0 and thats where the problem is. I thought that my ' if ' loop would have solved that issue, but it does not seem to be working.
Thank you,
My script is below:
U=1
S = 1.7*1.2*ones(1, 10);
Tout = 5
ma = 1
ca = 2
DTM = 1
deltat = 1
index = 1:30;
%Prealloacate
SQAmb = zeros(numel(index), numel(S));
QAmb_Total = zeros(size(index));
deltaTin = zeros(size(index));
Tin = zeros(size(index));
%for loop
for i = index
if (i)==1
Tin(i) = 20
else
Tin(i) = Tin(i-1)+deltaTin(i)
end
SQAmb(i,:) = S*U*(Tout-Tin(i));
%Total Ambient Load in Array Form
QAmb_Total(i) = sum(SQAmb(i,:))
%change in air cabin temperature where deltat is timestep
deltaTin(i) = (QAmb_Total(i)/((ma*ca)+DTM))*(deltat)
%New car cabin temperature
Tin(i) = Tin(i-1)+deltaTin(i)
end

채택된 답변

Star Strider
Star Strider 2019년 2월 20일
I thought that my ' if ' loop would have solved that issue, but it does not seem to be working.
It is working in the if block, but not afterwards.
The line that throws the error is:
%New car cabin temperature
Tin(i) = Tin(i-1)+deltaTin(i)
  댓글 수: 6
Jamil Dudhwala
Jamil Dudhwala 2019년 2월 21일
I moved the equations for when i=1 before the else statement and the then when i>1 after the else statement. It was longer but seemed to work.
Revamped script is below:
U=1
S = 1.7*1.2*ones(1, 10);
Tout=5
ma=1
ca=2
DTM=1
deltat=1
index=1:30;
%Prealloacate
SQAmb = zeros(numel(index), numel(S)); %Preallocation of Ambient Load matrix
QAmb_Total = zeros(size(index)); %Preallocation of Total Ambient Load matrix
deltaTin = zeros(size(index));
Tin = zeros(size(index));
for i=index
if (i)==1
SQAmb(i,:) = S*U*(Tout-20)
%Total Ambient Load in Array Form
QAmb_Total(i)=sum(SQAmb(i,:))
%change in air cabin temperature where deltat is timestep
deltaTin(i)=(QAmb_Total(i)/((ma*ca)+DTM))*(deltat)
%New car cabin temperature
Tin(i)=20+deltaTin(i)
else
SQAmb(i,:) = S*U*(Tout-Tin(i-1))
%Total Ambient Load in Array Form
QAmb_Total(i)=sum(SQAmb(i,:))
%change in air cabin temperature where deltat is timestep
deltaTin(i)=(QAmb_Total(i)/((ma*ca)+DTM))*(deltat)
%New car cabin temperature
Tin(i)=Tin(i-1)+deltaTin(i)
end
end

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

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Loops and Conditional Statements에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by