Package with models for source signals that are used with controllers
Information
This package contains components models for sources
that are used with controllers.
For additional models, see also
Modelica.Blocks.Sources.
Extends from Modelica.Icons.SourcesPackage (Icon for packages containing sources).
Package Content
| Name | Description | 
|  DayType | Block that outputs a signal that indicates week-day or week-end | 
|  Examples | Collection of models that illustrate model use and test models | 
Block that outputs a signal that indicates week-day or week-end
 
Information
This block outputs a periodic signal that indicates the type of the day.
It can for example be used to generate a signal that indicates whether
the current time is a work day or a non-working day.
The output signal is of type
Buildings.Controls.Types.Day.
The parameter nout determines how many days should be
sent to the output. For applications in which only the current day
is of interest, set nout=1.
For applications in which the load is predicted for the next 24 hours,
set nout=2 in order to output the type of day for today and for
tomorrow.
The transition from one day type to another always happens when the simulation time
is a multiple of 1 day. Hence, if the simulation starts for example
at t=-3600 seconds, then the first transition to another day will be
at t=0.
Extends from Modelica.Blocks.Icons.DiscreteBlock (Graphical layout of discrete block component icon).
Parameters
| Type | Name | Default | Description | 
|---|
| Integer | nout | 2 | Number of days to output. Set to two for one day predictions | 
| Day | days[:] | {Buildings.Controls.Types.Da... | Array where each element is a day indicator | 
| Integer | iStart | 1 | Index of element in days at simulation start | 
Connectors
| Type | Name | Description | 
|---|
| output DayTypeOutput | y[nout] | Type of the day for the current and the next (nout-1) days | 
Modelica definition
model DayType 
  "Block that outputs a signal that indicates week-day or week-end"
  extends Modelica.Blocks.Icons.DiscreteBlock;
  
parameter Integer nout = 2 
    "Number of days to output. Set to two for one day predictions";
  
parameter Buildings.Controls.Types.Day[:] days={
    Buildings.Controls.Types.Day.WorkingDay,
    Buildings.Controls.Types.Day.WorkingDay,
    Buildings.Controls.Types.Day.WorkingDay,
    Buildings.Controls.Types.Day.WorkingDay,
    Buildings.Controls.Types.Day.WorkingDay,
    Buildings.Controls.Types.Day.NonWorkingDay,
    Buildings.Controls.Types.Day.NonWorkingDay} 
    "Array where each element is a day indicator";
   
parameter Integer iStart(min=1, max=
size(days, 1)) = 1 
    "Index of element in days at simulation start";
  
Interfaces.DayTypeOutput y[nout] 
    "Type of the day for the current and the next (nout-1) days";
protected 
  parameter Modelica.SIunits.Time samplePeriod=86400 
    "Sample period of the component";
  
output Integer iDay(min=1, max=
size(days, 1)) 
    "Pointer to days that determines what day type is sent to the output";
  
parameter Modelica.SIunits.Time firstSample(fixed=false) 
    "Time when the sampling starts";
  
output Boolean sampleTrigger 
"True, if sample time instant";
  
output Boolean skipIDayIncrement 
    "If true, don't increment iDay in first sample";
initial equation 
  iDay = iStart;
  firstSample =
 ceil(time/86400)*86400;
  
// skipIDayIncrement is true if the simulation starts at midnight.
  skipIDayIncrement =
 abs(firstSample-time) < 1E-8;
equation 
  for i
 in 1:nout
 loop
    y[i] = days[
 mod(iDay+i-2,
 size(days, 1))+1];
  
end for;
  sampleTrigger =
 sample(firstSample, samplePeriod);
  
when sampleTrigger
 then
    skipIDayIncrement = false;
    
if pre(skipIDayIncrement)
 then
      iDay =
 pre(iDay);
    
else
      iDay =
 mod(
pre(iDay),
 size(days, 1))+1;
    
end if;
  
end when;
end DayType;
 
Automatically generated Mon May  4 10:18:40 2015.