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
|
//
// Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
// Copyright (C) 2011-2011 - DIGITEO - Bruno JOFRET
//
// This file must be used under the terms of the CeCILL.
// This source file is licensed as described in the file COPYING, which
// you should have received as part of this distribution. The terms
// are also available at
// http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt
//
//
function [x, y, typ]=TIME_SAMPLE(job, arg1, arg2)
x=[];
y=[];
typ=[];
select job
case 'plot' then
// deprecated
case 'getinputs' then
// deprecater
case 'getoutputs' then
// deprecated
case 'getorigin' then
// deprecated
case 'set' then
x=arg1;
graphics=arg1.graphics;
exprs=graphics.exprs
model=arg1.model;
while %t do
[ok,tf,period,display_now,exprs]=scicos_getvalue('Time sample parameters',..
[gettext('Duration of acquisition (s)'),gettext('Sampling period (s)'),gettext('Display curvs continuously (1 yes / 0 no)')], list('vec',1,'vec',1,'vec',1), ..
exprs)
mess=[];
if ~ok then// Cancel
break;
end
if period <0.005 then
mess=[gettext("sampling period mus be greater than 0.005")];
ok=%f;
end
if display_now ~=1 & display_now~=0
mess=[mess ;_("Choose 1 or 0 to display curvs during simulation or at the end")]
ok = %f
end
if ok then// Everything's ok
model.rpar=[tf,period,display_now];
graphics.exprs = exprs;
x.model=model;
x.graphics = graphics;
break
else
message(mess);
end
end
case 'define' then
model=scicos_model();
model.sim=list("TIME_SAMPLE", 99)
model.blocktype='c';
model.dep_ut=[%f %f];
model.in=[];
tf=10;
period=0.1;
model.rpar=[tf,period,1]; //Digital Output number
x=standard_define([6 2],model,[],[]);
x.graphics.in_implicit=[];
x.graphics.style=["blockWithLabel;verticalLabelPosition=center;displayedLabel=Duration : %s<br> Sampling period %s"]
x.graphics.exprs=[string(tf),string(period),string(1)];
end
endfunction
|