Collection of validation models
Information
This package contains validation models for the classes in
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.
Note that most validation models contain simple input data
which may not be realistic, but for which the correct
output can be obtained through an analytic solution.
The examples plot various outputs, which have been verified against these
solutions. These model outputs are stored as reference data and
used for continuous validation whenever models in the library change.
Package Content
Name |
Description |
GroupStatus
|
Validate block for checking temperatures in the group |
OperationMode
|
Validate block for selecting operation mode |
ZoneGroupSystem
|
Validate block for calculating AHU mode from the zone group modes |
ZoneStatus
|
Validate block for checking temperatures in the zone |
ZoneStatusDuplicator
|
Validate block for duplicating zone status |
Validate block for checking temperatures in the group
Information
This example validates
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.GroupStatus
for checking group temperature status.
The block takes 3 zones as input, but filters them
down to only processing zone 1 and 3
(reindexed in output to 1 and 2 respectively).
Modelica definition
model GroupStatus
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.GroupStatus zonGroSta(
final nBuiZon=3,
final nGroZon=2,
final zonGroMsk={true,false,true}) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant warUpTim[3](
final k={1800,1700,1900})
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant cooDowTim[3](
final k={1600,1700,1800})
;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse winSta[3](
final width={0.3,0.2,0.1},
final period=
fill(3600, 3),
final shift={150,130,120})
;
Buildings.Controls.OBC.CDL.Reals.Sources.Ramp ramp2(
final offset=0,
final height=6.2831852,
final duration=24*3600) ;
Buildings.Controls.OBC.CDL.Reals.Sin sin2
;
Buildings.Controls.OBC.CDL.Reals.MultiplyByParameter gai(
final k=6)
;
Buildings.Controls.OBC.CDL.Reals.AddParameter zonTem(
final p=273.15 + 22.5)
;
Buildings.Controls.OBC.CDL.Logical.Sources.Constant uOccOve[3](
final k=
fill(false,3))
;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse zonOcc1(
final width=0.8,
final period=7200,
shift=1800)
;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse zonOcc3(
final width=0.8,
final period=7200,
shift=2100) ;
Buildings.Controls.OBC.CDL.Logical.Not not1 ;
Buildings.Controls.OBC.CDL.Logical.Not not3 ;
Buildings.Controls.OBC.CDL.Logical.Timer tim1 ;
Buildings.Controls.OBC.CDL.Logical.Timer tim3 ;
Buildings.Controls.OBC.CDL.Reals.Subtract addPar1
;
Buildings.Controls.OBC.CDL.Reals.Subtract addPar3
;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse lowOccHea[3](
final width=
fill(0.5, 3),
final period=
fill(3600, 3),
final shift=
fill(1000, 3)) ;
Buildings.Controls.OBC.CDL.Logical.Sources.Constant higOccCoo[3](
final k=
fill(false, 3))
;
Buildings.Controls.OBC.CDL.Logical.And and2[3]
;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse lowUnoHea1[3](
final width=
fill(0.1, 3),
final period=
fill(3600, 3))
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant heaSetOff[3](
final k={285.15,282.15,283.15})
;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse endSetBac[3](
final width=
fill(0.8, 3),
final period=
fill(3600, 3),
final shift=
fill(900, 3)) ;
Buildings.Controls.OBC.CDL.Logical.Sources.Constant higUnoCoo[3](
final k=
fill(false, 3))
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant cooSetOff[3](
final k={303.15,304.15,305.15})
;
Buildings.Controls.OBC.CDL.Logical.Sources.Constant endSetUp[3](
final k=
fill(false,3))
;
Buildings.Controls.OBC.CDL.Reals.Sources.Pulse zonTem3(
final amplitude=7,
final period=600,
final offset=273.15 + 19) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant zonTem2(
final k=273.15 + 20)
;
Buildings.Controls.OBC.CDL.Logical.Sources.Constant zonOcc2(
final k=true)
;
Buildings.Controls.OBC.CDL.Logical.Not not2
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant tNexOcc2(
final k=0) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant con(
final k=1800)
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant con1(
final k=2100)
;
equation
connect(ramp2.y,sin2. u);
connect(not1.y, tim1.u);
connect(not3.y,tim3. u);
connect(uOccOve.y, zonGroSta.zonOcc);
connect(zonOcc1.y, not1.u);
connect(zonOcc3.y,not3. u);
connect(zonOcc1.y, zonGroSta.u1Occ[1]);
connect(zonOcc3.y, zonGroSta.u1Occ[3]);
connect(addPar1.y, zonGroSta.tNexOcc[1]);
connect(addPar3.y, zonGroSta.tNexOcc[3]);
connect(cooDowTim.y, zonGroSta.uCooTim);
connect(warUpTim.y, zonGroSta.uWarTim);
connect(not1.y, and2[1].u2);
connect(not3.y, and2[3].u2);
connect(lowOccHea.y, and2.u1);
connect(and2.y, zonGroSta.u1OccHeaHig);
connect(higOccCoo.y, zonGroSta.u1HigOccCoo);
connect(lowUnoHea1.y, zonGroSta.u1UnoHeaHig);
connect(heaSetOff.y, zonGroSta.THeaSetOff);
connect(endSetBac.y, zonGroSta.u1EndSetBac);
connect(higUnoCoo.y, zonGroSta.u1HigUnoCoo);
connect(cooSetOff.y, zonGroSta.TCooSetOff);
connect(endSetUp.y, zonGroSta.u1EndSetUp);
connect(zonTem.y, zonGroSta.TZon[1]);
connect(zonTem3.y, zonGroSta.TZon[3]);
connect(winSta.y, zonGroSta.u1Win);
connect(zonTem2.y, zonGroSta.TZon[2]);
connect(zonOcc2.y, not2.u);
connect(not2.y, and2[2].u2);
connect(zonOcc2.y, zonGroSta.u1Occ[2]);
connect(tNexOcc2.y, zonGroSta.tNexOcc[2]);
connect(con.y, addPar1.u1);
connect(tim1.y, addPar1.u2);
connect(con1.y, addPar3.u1);
connect(tim3.y, addPar3.u2);
connect(sin2.y, gai.u);
connect(gai.y, zonTem.u);
end GroupStatus;
Validate block for selecting operation mode
Information
This example validates
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.OperationMode
for a change of zone temperature and occupancy schedule.
Modelica definition
model OperationMode
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.OperationMode
opeModSel(
final nZon=1) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Ramp ramp1(
final height=6.2831852,
final duration=172800)
;
Buildings.Controls.OBC.CDL.Reals.Sin sin1
;
Buildings.Controls.OBC.CDL.Reals.AddParameter zonTem(
final p=295.65) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant TZonHeaSetUno(
final k=285.15) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant TZonCooSetUno(
final k=303.15) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant TZonHeaSetOcc(
final k=293.15) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant TZonCooSetOcc(
final k=297.15) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant warUpTim(
final k=1800) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant cooDowTim(
final k=1800) ;
Buildings.Controls.OBC.CDL.Integers.Sources.Constant cloWin(
final k=0) ;
Buildings.Controls.OBC.CDL.Reals.Greater lowThaHeaSet
;
Buildings.Controls.OBC.CDL.Reals.Greater higThaCooSet
;
Buildings.Controls.OBC.CDL.Reals.Greater greEqu2
;
Buildings.Controls.OBC.CDL.Conversions.BooleanToInteger booToInt ;
Buildings.Controls.OBC.CDL.Reals.Greater greEqu3
;
Buildings.Controls.OBC.CDL.Conversions.BooleanToInteger booToInt1 ;
Buildings.Controls.SetPoints.OccupancySchedule occSch ;
Buildings.Controls.OBC.CDL.Reals.Subtract dif2
;
Buildings.Controls.OBC.CDL.Reals.Hysteresis hys3(
final uLow=-0.5,
final uHigh=0.5)
;
Buildings.Controls.OBC.CDL.Reals.Subtract dif1
;
Buildings.Controls.OBC.CDL.Reals.Hysteresis hys1(
final uLow=-0.5,
final uHigh=0.5)
;
Buildings.Controls.OBC.CDL.Reals.MultiplyByParameter gai(
final k=14.5) ;
equation
connect(ramp1.y, sin1.u);
connect(cooDowTim.y, opeModSel.maxCooDowTim);
connect(warUpTim.y, opeModSel.maxWarUpTim);
connect(TZonHeaSetOcc.y, lowThaHeaSet.u1);
connect(zonTem.y, lowThaHeaSet.u2);
connect(zonTem.y, higThaCooSet.u1);
connect(TZonCooSetOcc.y, higThaCooSet.u2);
connect(TZonHeaSetUno.y, greEqu2.u1);
connect(zonTem.y, greEqu2.u2);
connect(greEqu2.y, booToInt.u);
connect(booToInt.y, opeModSel.totColZon);
connect(zonTem.y, opeModSel.TZonMin);
connect(zonTem.y, greEqu3.u1);
connect(TZonCooSetUno.y, greEqu3.u2);
connect(greEqu3.y, booToInt1.u);
connect(booToInt1.y, opeModSel.totHotZon);
connect(occSch.occupied, opeModSel.u1Occ);
connect(occSch.tNexOcc, opeModSel.tNexOcc);
connect(higThaCooSet.y, opeModSel.u1HigOccCoo);
connect(lowThaHeaSet.y, opeModSel.u1OccHeaHig);
connect(cloWin.y, opeModSel.uOpeWin);
connect(greEqu2.y, opeModSel.u1SetBac);
connect(greEqu3.y, opeModSel.u1SetUp);
connect(zonTem.y,dif2. u1);
connect(TZonHeaSetUno.y,dif2. u2);
connect(dif2.y, hys3.u);
connect(hys3.y, opeModSel.u1EndSetBac);
connect(dif1.y, hys1.u);
connect(hys1.y, opeModSel.u1EndSetUp);
connect(sin1.y, gai.u);
connect(gai.y, zonTem.u);
connect(TZonCooSetUno.y, dif1.u1);
connect(zonTem.y, dif1.u2);
end OperationMode;
Validate block for calculating AHU mode from the zone group modes
Information
This example validates
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.ZoneGroupSystem
for specifing the AHU operating mode when the system serves multiple zone groups.
Modelica definition
Validate block for checking temperatures in the zone
Information
This example validates
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.ZoneStatus
for checking zone temperature status.
Modelica definition
model ZoneStatus
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.ZoneStatus noWinZonSta(
final have_winSen=false)
;
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.ZoneStatus witWinZonSta(
final have_winSen=true)
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant warUpTim(
final k=1800) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant cooDowTim(
final k=1800) ;
Buildings.Controls.OBC.CDL.Logical.Sources.Pulse uWinSta(
final width=0.3,
final period=43200,
final shift=1800)
;
Buildings.Controls.OBC.CDL.Reals.Sources.Ramp ramp2(
final offset=0,
final height=6.2831852,
final duration=24*3600) ;
Buildings.Controls.OBC.CDL.Reals.Sin sin2
;
Buildings.Controls.OBC.CDL.Reals.AddParameter zonTem(
final p=273.15 + 22.5)
;
Buildings.Controls.OBC.CDL.Reals.MultiplyByParameter gai(
final k=12.5) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant THeaSetOcc(
final k=293.15)
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant TCooSetOcc(
final k=297.15)
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant THeaSetUno(
final k=285.15)
;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant TCooSetUno(
final k=303.15)
;
Buildings.Controls.OBC.CDL.Logical.Not not2 ;
equation
connect(cooDowTim.y, noWinZonSta.cooDowTim);
connect(warUpTim.y, noWinZonSta.warUpTim);
connect(ramp2.y,sin2. u);
connect(zonTem.y, noWinZonSta.TZon);
connect(cooDowTim.y, witWinZonSta.cooDowTim);
connect(warUpTim.y, witWinZonSta.warUpTim);
connect(zonTem.y, witWinZonSta.TZon);
connect(sin2.y, gai.u);
connect(gai.y, zonTem.u);
connect(THeaSetOcc.y,noWinZonSta.TOccHeaSet);
connect(TCooSetOcc.y,noWinZonSta.TOccCooSet);
connect(THeaSetUno.y,noWinZonSta.TUnoHeaSet);
connect(TCooSetUno.y,noWinZonSta.TUnoCooSet);
connect(THeaSetOcc.y,witWinZonSta.TOccHeaSet);
connect(TCooSetOcc.y,witWinZonSta.TOccCooSet);
connect(THeaSetUno.y,witWinZonSta.TUnoHeaSet);
connect(TCooSetUno.y,witWinZonSta.TUnoCooSet);
connect(uWinSta.y, not2.u);
connect(not2.y, witWinZonSta.u1Win);
end ZoneStatus;
Validate block for duplicating zone status
Information
This example validates
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.ZoneStatusDuplicator
for duplicating zone status.
Modelica definition
model ZoneStatusDuplicator
Buildings.Controls.OBC.ASHRAE.G36.ZoneGroups.ZoneStatusDuplicator zonStaDup(
final nZon=5,
final nZonGro=2) ;
Buildings.Controls.OBC.CDL.Reals.Sources.Constant reaInp[6,5](
final k=
fill({1,2,3,4,5}, 6))
;
Buildings.Controls.OBC.CDL.Logical.Sources.Constant booInp[9,5](
final k=
fill({true,true,false,true,false},9))
;
equation
connect(reaInp[1, :].y, zonStaDup.tNexOcc);
connect(reaInp[2, :].y, zonStaDup.uCooTim);
connect(reaInp[3, :].y, zonStaDup.uWarTim);
connect(reaInp[4, :].y, zonStaDup.THeaSetOff);
connect(reaInp[5, :].y, zonStaDup.TCooSetOff);
connect(reaInp[6, :].y, zonStaDup.TZon);
connect(booInp[1, :].y, zonStaDup.zonOcc);
connect(booInp[2, :].y, zonStaDup.u1Occ);
connect(booInp[3, :].y, zonStaDup.u1OccHeaHig);
connect(booInp[4, :].y, zonStaDup.u1HigOccCoo);
connect(booInp[5, :].y, zonStaDup.u1UnoHeaHig);
connect(booInp[6, :].y, zonStaDup.u1EndSetBac);
connect(booInp[7, :].y, zonStaDup.u1HigUnoCoo);
connect(booInp[8, :].y, zonStaDup.u1EndSetUp);
connect(booInp[9, :].y, zonStaDup.u1Win);
end ZoneStatusDuplicator;