summaryrefslogtreecommitdiff
path: root/tools/scilab/linux/macros/TIME_SAMPLE.sci
blob: b9d1729cd129f4a4e12c0d31de02b31c45d3618a (plain)
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