forked from sanchit95/CSIT_GUI_Tool
-
Notifications
You must be signed in to change notification settings - Fork 0
/
dcgain.sci
114 lines (103 loc) · 2.88 KB
/
dcgain.sci
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
function[x]=dcgain(p)
//function is to find the dc gain of LTI system
//k = dcgain(sys) computes the DC gain k of the LTI model sys.
//DC gain is infinite for systems with integrators.
//author:- Paresh Yeole emailid:[email protected]
[lhs rhs]=argn(0);
if rhs<1 then
error("dcgain:input parameter as a dynamic system is expected");
end
select typeof(p)
case "rational" then
case "state-space" then
p=ss2tf(p)
else
msprintf("\n")
error(97,1),
end;
if(p.dt=='c') then
//if system is continuous then put s=o for dc gain
if(ndims(p)==3) then
//x=cell(size(p,'r'),size(p,'c'),size(p,3));
//t=cell(size(p,'r'),size(p,'c'),size(p,3));
for i=1:size(p,'r')
for j=1:size(p,'c')
for k=1:size(p,3)
try
t=horner(p(i,j,k),0);
catch
//x(i,j,k).entries=1;
//continue;
x(i,j,k)=%inf;
//disp(t);
continue;
//return;
end
x(i,j,k)=t;
//=y;
// if(t==1) then
// x(i,j,k).entries=%inf;
// end
end
end
end
elseif(ndims(p)==2) then
//x=cell(size(p,'r'),size(p,'c'));
for i=1:size(p,'r')
for j=1:size(p,'c')
try
t=horner(p(i,j),0);
catch
x=%inf;
continue;
end
x(i,j)=t
end
end
else
try
x=horner(p,0)
catch
x=%inf;
end
end
else
//discrete systems
if(ndims(p)==3) then
// x=cell(size(p,'r'),size(p,'c'),size(p,3));
for i=1:size(p,'r')
for j=1:size(p,'c')
for k=1:size(p,3)
try
t=horner(p(i,j,k),1);
catch
x(i,j,k)=%inf;
continue;
end
x(i,j,k)=t;
end
end
end
elseif(ndims(p)==2) then
//x=cell(size(p,'r'),size(p,'c'));
for i=1:size(p,'r')
for j=1:size(p,'c')
try
t=horner(p(i,j),1);
catch
x(i,j)=%inf;
continue;
end
x(i,j,k)=t;
end
end
else
//if system is discrete then put z=1 for dc gain
try
x=horner(p,1)
catch
x=%inf;
end
end
end
endfunction