~ubuntu-branches/ubuntu/karmic/scilab/karmic

« back to all changes in this revision

Viewing changes to macros/robust/sensi.sci

  • Committer: Bazaar Package Importer
  • Author(s): Torsten Werner
  • Date: 2002-03-21 16:57:43 UTC
  • Revision ID: james.westby@ubuntu.com-20020321165743-e9mv12c1tb1plztg
Tags: upstream-2.6
ImportĀ upstreamĀ versionĀ 2.6

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
function [Se,R,T]=sensi(G,Sk,flag)
 
2
// [Se,R,T]=sensi(G,Sk) computes sensitivity functions
 
3
// If flag='o' or no flag:
 
4
// [Se;R;T]= [inv(eye+G*K);K*inv(eye+G*K);G*K*inv(eye+G*K)];
 
5
// 
 
6
// flag='i'
 
7
// [Si,Ri,Ti]= [inv(eye+K*G);G*inv(eye+K*G);K*G*inv(eye+K*G)];
 
8
//!
 
9
// Copyright INRIA
 
10
[LHS,RHS]=argn(0);
 
11
if RHS==2 then flag='o';end
 
12
select flag
 
13
  case 'o'
 
14
G1=G(1);Sk1=Sk(1);
 
15
ssflag=0;
 
16
if G1(1)=='r' then G=tf2ss(G);ssflag=1;end
 
17
if Sk1(1)=='r' then Sk=tf2ss(Sk);ssflag=ssflag+1;end
 
18
[ny,nu]=size(G);Iu=eye(nu,nu);Iy=eye(ny,ny);
 
19
Ouy=zeros(nu,ny);Oyu=zeros(ny,nu);Ouu=zeros(nu,nu);
 
20
Oyy=zeros(ny,ny);
 
21
W1=[Iy,Oyu,Oyy;
 
22
    Ouy,Iu,Ouy;
 
23
   -Iy,Oyu,Iy;
 
24
    Iy,Oyu,Oyy];
 
25
W2=[Iy,-G;
 
26
    Ouy,Iu;
 
27
    Iy,Oyu];
 
28
SRT=lft(W1*W2,Sk);
 
29
Se=SRT(1:ny,:);
 
30
R=SRT((ny+1):(ny+nu),:);
 
31
T=SRT((nu+ny+1):(nu+ny+ny),:);
 
32
if ssflag >0 then
 
33
   Se=ss2tf(Se);R=ss2tf(R);T=ss2tf(T);
 
34
end
 
35
  case 'i'
 
36
G1=G(1);Sk1=Sk(1);
 
37
ssflag=0;
 
38
if G1(1)=='r' then G=tf2ss(G);ssflag=1;end
 
39
if Sk1(1)=='r' then Sk=tf2ss(Sk);ssflag=ssflag+1;end
 
40
[ny,nu]=size(G);Iu=eye(nu,nu);Iy=eye(ny,ny);
 
41
Ouy=zeros(nu,ny);Oyu=zeros(ny,nu);Ouu=zeros(nu,nu);
 
42
Oyy=zeros(ny,ny);
 
43
 W1=[Iu,-Iu;
 
44
     Oyu,Oyu;
 
45
     Ouu,Iu;
 
46
     Oyu,Oyu];
 
47
 W2=[Ouy;Iy;Ouy;Iy];
 
48
 W3=[Iu,-Iu];
 
49
 P=W1+W2*G*W3;
 
50
SRT=lft(P,Sk);
 
51
Se=SRT(1:nu,:);
 
52
R=SRT((nu+1):(ny+nu),:);
 
53
T=SRT((nu+ny+1):(nu+ny+nu),:);
 
54
if ssflag >0 then
 
55
   Se=ss2tf(Se);R=ss2tf(R);T=ss2tf(T);
 
56
end
 
57
end
 
58
 
 
59
 
 
60