Scicos_blocks: clean NonLinear blocks interfaces
[scilab.git] / scilab / modules / scicos_blocks / macros / NonLinear / SAT_f.sci
1 //  Scicos
2 //
3 //  Copyright (C) INRIA - METALAU Project <scicos@inria.fr>
4 //
5 // This program is free software; you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation; either version 2 of the License, or
8 // (at your option) any later version.
9 //
10 // This program is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with this program; if not, write to the Free Software
17 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 //
19 // See the file ../license.txt
20 //
21
22 function [x,y,typ]=SAT_f(job,arg1,arg2)
23     x=[];
24     y=[];
25     typ=[];
26     select job
27     case "set" then
28         x=arg1;
29         graphics=arg1.graphics;
30         exprs=graphics.exprs
31         model=arg1.model;
32         while %t do
33             [ok,minp,maxp,pente,exprs]=scicos_getvalue("Set Saturation parameters",..
34             ["Min";"Max";"Slope"],list("vec",1,"vec",1,"vec",1),exprs)
35             if ~ok then
36                 break,
37             end
38             if maxp<=0  then
39                 message("Max must be strictly positive")
40             elseif pente<=0 then
41                 message("Slope must be strictly positive")
42             else
43                 rpar=[minp/pente;maxp/pente;pente]
44                 model.rpar=rpar
45                 model.firing=[] //compatibility
46                 graphics.exprs=exprs
47                 x.graphics=graphics;
48                 x.model=model
49                 break
50             end
51         end
52     case "define" then
53         minp=-1;
54         maxp=1;
55         slope=1;
56         rpar=[minp;maxp;slope]
57
58         model=scicos_model()
59         model.sim=list("lusat",1)
60         model.in=1
61         model.nzcross=2
62         model.out=1
63         model.rpar=[minp;maxp;slope]
64         model.blocktype="c"
65         model.dep_ut=[%t %f]
66
67         exprs=[string(minp);string(maxp);string(slope)]
68         gr_i=[]
69         x=standard_define([2 2],model,exprs,gr_i)
70     end
71 endfunction