04 May 2021 2 6K Report

HI guys, I have some problem during running the code below and it give me the error

  • Index exceeds array dimensions. Index value 3 exceeds valid range [1-2] for array 'a'. Error in 'TEST/TEST' (line 18) if a(i)> 0

This code is the code for computiong the parameter k for the scalar reference governor. and Hx and Hv is the maximal admissible output sets(MAS) with the matrices A,B,C,D hope can get some help to fix this code form your all.

function v = SRG_new(v_previous, r)

A=[0 1;-275.5 -21.22];

B=[0;1];

C=[11.02 275.5];

D=0;

I=eye(2);

Hx=(C*A);

Hv= C*((I-A)*((I-A)^-1)*B+D);

s=350; %s=max_output

a=Hx*(r-v_previous);

b=s-Hx-Hv*v_previous;

k=1;

for i=1:100

if a(i)> 0

k=min(k, b(i)/a(i));

end

end

k=max(k,0);

v=v_previous + k*(r-v_previous);

end

More Yen Li's questions See All
Similar questions and discussions