Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly

Sequences for VAV cooling only terminal unit

Information

This package contains sequences for VAV cooling only terminal unit. They are created according to Section 5.5 of ASHRAE Guideline 36, May 2020.

Package Content

Name Description
Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Controller Controller Controller for cooling only VAV box
Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences Subsequences Package of subsequences for cooling only box control
Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Validation Validation Collection of validation models

Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Controller Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Controller

Controller for cooling only VAV box

Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Controller

Information

Controller for cooling only terminal box according to Section 5.5 of ASHRAE Guideline 36, May 2020. It outputs discharge airflow setpoint VSet_flow, damper position setpoint yDam, AHU cooling supply temperature setpoint reset request yZonTemResReq, and static pressure setpoint reset request yZonPreResReq. It also outputs the alarms about the low airflow yLowFloAla, leaking damper yLeaDamAla, and airflow sensor calibration alarm yFloSenAla.

The sequence consists of six subsequences.

a. Heating and cooling control loop

The subsequence is implementd according to Section 5.3.4. The measured zone temperature TZon, zone setpoints temperatures TZonHeaSet and TZonCooSet are inputs to the instance of class Buildings.Controls.OBC.ASHRAE.G36.ThermalZones.ZoneStates to generate the heating and cooling control loop signal.

b. Active airflow setpoint calculation

This sequence sets the active maximum and minimum airflow according to Section 5.5.4. Depending on operation modes uOpeMod, it sets the airflow rate limits for cooling supply. See Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.ActiveAirFlow.

c. Damper control

This sequence sets the damper position setpoints for the terminal unit. The implementation is according to Section 5.5.5. According to heating and cooling control loop signal, along with the active maximum and minimum airflow setpoint, measured zone temperature, the sequence outputs damper position setpoint, and active airflow rate setpoint. See Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.Dampers.

d. System reset requests generation

According to Section 5.5.8, this sequence outputs the system reset requests, i.e. cooling supply air temperature reset requests yZonTemResReq, static pressure reset requests yZonPreResReq. See Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.SystemRequests.

e. Alarms

According to Section 5.5.6, this sequence outputs the alarms of low discharge flow, leaking damper and airflow sensor calibration alarm. See Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.Alarms.

f. Testing and commissioning overrides

According to Section 5.5.7, this sequence allows the override the aiflow setpoints, damper position setpoints. See Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.Dampers.

Parameters

TypeNameDefaultDescription
VentilationStandardvenStdBuildings.Controls.OBC.ASHRA...Ventilation standard, ASHRAE 62.1 or Title 24
Booleanhave_winSentrueTrue: the zone has window sensor
Booleanhave_occSentrueTrue: the zone has occupancy sensor
Booleanhave_CO2SentrueTrue: the zone has CO2 sensor
Booleanpermit_occStandbytrueTrue: occupied-standby mode is permitted
RealVOccMin_flow Zone minimum outdoor airflow for occupants [m3/s]
RealVAreMin_flow Zone minimum outdoor airflow for building area [m3/s]
Design conditions
RealVAreBreZon_flow Design area component of the breathing zone outdoor airflow [m3/s]
RealVPopBreZon_flow Design population component of the breathing zone outdoor airflow [m3/s]
RealVMin_flow Design zone minimum airflow setpoint [m3/s]
RealVCooMax_flow Design zone cooling maximum airflow rate [m3/s]
Control loops
Cooling
RealkCooCon0.1Gain of controller for cooling control loop
RealTiCooCon900Time constant of integrator block for cooling control loop [s]
Heating
RealkHeaCon0.1Gain of controller for heating control loop
RealTiHeaCon900Time constant of integrator block for heating control loop [s]
Damper control
Booleanhave_preIndDamfalseTrue: the VAV damper is pressure independent (with built-in flow controller)
Controller
SimpleControllerdamConBuildings.Controls.OBC.CDL.T...Type of controller
RealkDam0.5Gain of controller for damper control
RealTiDam300Time constant of integrator block for damper control [s]
RealTdDam0.1Time constant of derivative block for damper control [s]
System requests
RealthrTemDif3Threshold difference between zone temperature and cooling setpoint for generating 3 cooling SAT reset requests [K]
RealtwoTemDif2Threshold difference between zone temperature and cooling setpoint for generating 2 cooling SAT reset requests [K]
Duration time
RealdurTimTem120Duration time of zone temperature exceeds setpoint [s]
RealdurTimFlo60Duration time of airflow rate less than setpoint [s]
Alarms
RealstaPreMul1Importance multiplier for the zone static pressure reset control loop
ReallowFloTim300Threshold time to check low flow rate [s]
RealfanOffTim600Threshold time to check fan off [s]
RealleaFloTim600Threshold time to check damper leaking airflow [s]
Time-based suppresion
RealsamplePeriod120Sample period of component, set to the same value as the trim and respond that process static pressure reset [s]
RealchaRat540Gain factor to calculate suppression time based on the change of the setpoint, second per degC
RealmaxSupTim1800Maximum suppression time [s]
Advanced
RealdTHys0.25Near zero temperature difference, below which the difference will be seen as zero [K]
RealfloHys0.01Near zero flow rate, below which the flow rate or difference will be seen as zero [m3/s]
ReallooHys0.01Loop output hysteresis below which the output will be seen as zero [1]
RealdamPosHys0.05Near zero damper position, below which the damper will be seen as closed [1]
Control loops
RealtimChe30Threshold time to check the zone temperature status [s]
Distribution effectiveness
RealzonDisEff_cool1.0Zone cooling air distribution effectiveness [1]
RealzonDisEff_heat0.8Zone heating air distribution effectiveness [1]

Connectors

TypeNameDescription
input RealInputTZonMeasured room temperature [K]
input RealInputTCooSetZone cooling setpoint temperature [K]
input RealInputTHeaSetZone heating setpoint temperature [K]
input BooleanInputu1WinWindow status, true if the window is open, false if it is closed
input BooleanInputu1OccTrue: the zone is populated
input IntegerInputuOpeModZone operation mode
input RealInputppmCO2SetCO2 concentration setpoint
input RealInputppmCO2Detected CO2 concentration
input RealInputTDisMeasured discharge air temperature [K]
input RealInputTSupTemperature of the air supplied from central air handler [K]
input RealInputVDis_flowMeasured primary discharge airflow rate [m3/s]
input IntegerInputoveFloSetIndex of overriding flow setpoint, 1: set to zero; 2: set to cooling maximum; 3: set to minimum flow; 4: set to heating maximum
input IntegerInputoveDamPosIndex of overriding damper position, 1: set to close; 2: set to open
input BooleanInputu1FanAHU supply fan status
output RealOutputVSet_flowDischarge airflow setpoint after considering override [m3/s]
output RealOutputyDamDamper commanded position, or commanded flow rate ratio [1]
output RealOutputVAdjPopBreZon_flowAdjusted population component breathing zone flow rate [m3/s]
output RealOutputVAdjAreBreZon_flowAdjusted area component breathing zone flow rate [m3/s]
output RealOutputVMinOA_flowMinimum outdoor airflow setpoint [m3/s]
output RealOutputVZonAbsMin_flowZone absolute minimum outdoor airflow setpoint [m3/s]
output RealOutputVZonDesMin_flowZone design minimum outdoor airflow setpoint [m3/s]
output RealOutputyCO2CO2 control loop signal [1]
output IntegerOutputyZonTemResReqZone cooling supply air temperature reset request
output IntegerOutputyZonPreResReqZone static pressure reset requests
output IntegerOutputyLowFloAlaLow airflow alarms
output IntegerOutputyFloSenAlaAirflow sensor calibration alarm
output IntegerOutputyLeaDamAlaLeaking damper alarm

Modelica definition

block Controller "Controller for cooling only VAV box" parameter Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard venStd=Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.ASHRAE62_1_2016 "Ventilation standard, ASHRAE 62.1 or Title 24"; parameter Boolean have_winSen=true "True: the zone has window sensor"; parameter Boolean have_occSen=true "True: the zone has occupancy sensor"; parameter Boolean have_CO2Sen=true "True: the zone has CO2 sensor"; parameter Boolean permit_occStandby=true "True: occupied-standby mode is permitted"; parameter Real VOccMin_flow(unit="m3/s") "Zone minimum outdoor airflow for occupants"; parameter Real VAreMin_flow(unit="m3/s") "Zone minimum outdoor airflow for building area"; // ---------------- Design parameters ---------------- parameter Real VAreBreZon_flow(unit="m3/s") "Design area component of the breathing zone outdoor airflow"; parameter Real VPopBreZon_flow(unit="m3/s") "Design population component of the breathing zone outdoor airflow"; parameter Real VMin_flow(unit="m3/s") "Design zone minimum airflow setpoint"; parameter Real VCooMax_flow(unit="m3/s") "Design zone cooling maximum airflow rate"; // ---------------- Control loop parameters ---------------- parameter Real kCooCon=0.1 "Gain of controller for cooling control loop"; parameter Real TiCooCon(unit="s")=900 "Time constant of integrator block for cooling control loop"; parameter Real kHeaCon=0.1 "Gain of controller for heating control loop"; parameter Real TiHeaCon(unit="s")=900 "Time constant of integrator block for heating control loop"; // ---------------- Damper control parameters ---------------- parameter Boolean have_preIndDam=false "True: the VAV damper is pressure independent (with built-in flow controller)"; parameter CDL.Types.SimpleController damCon= Buildings.Controls.OBC.CDL.Types.SimpleController.PI "Type of controller"; parameter Real kDam=0.5 "Gain of controller for damper control"; parameter Real TiDam(unit="s")=300 "Time constant of integrator block for damper control"; parameter Real TdDam(unit="s")=0.1 "Time constant of derivative block for damper control"; // ---------------- System request parameters ---------------- parameter Real thrTemDif(unit="K")=3 "Threshold difference between zone temperature and cooling setpoint for generating 3 cooling SAT reset requests"; parameter Real twoTemDif(unit="K")=2 "Threshold difference between zone temperature and cooling setpoint for generating 2 cooling SAT reset requests"; parameter Real durTimTem(unit="s")=120 "Duration time of zone temperature exceeds setpoint"; parameter Real durTimFlo(unit="s")=60 "Duration time of airflow rate less than setpoint"; // ---------------- Parameters for alarms ---------------- parameter Real staPreMul=1 "Importance multiplier for the zone static pressure reset control loop"; parameter Real lowFloTim(unit="s")=300 "Threshold time to check low flow rate"; parameter Real fanOffTim(unit="s")=600 "Threshold time to check fan off"; parameter Real leaFloTim(unit="s")=600 "Threshold time to check damper leaking airflow"; // ---------------- Parameters for time-based suppression ---------------- parameter Real samplePeriod(unit="s")=120 "Sample period of component, set to the same value as the trim and respond that process static pressure reset"; parameter Real chaRat=540 "Gain factor to calculate suppression time based on the change of the setpoint, second per degC"; parameter Real maxSupTim(unit="s")=1800 "Maximum suppression time"; // ---------------- Advanced parameters ---------------- parameter Real dTHys(unit="K")=0.25 "Near zero temperature difference, below which the difference will be seen as zero"; parameter Real floHys(unit="m3/s")=0.01 "Near zero flow rate, below which the flow rate or difference will be seen as zero"; parameter Real looHys(unit="1")=0.01 "Loop output hysteresis below which the output will be seen as zero"; parameter Real damPosHys(unit="1")=0.05 "Near zero damper position, below which the damper will be seen as closed"; parameter Real timChe(unit="s")=30 "Threshold time to check the zone temperature status"; parameter Real zonDisEff_cool(unit="1")=1.0 "Zone cooling air distribution effectiveness"; parameter Real zonDisEff_heat(unit="1")=0.8 "Zone heating air distribution effectiveness"; Buildings.Controls.OBC.CDL.Interfaces.RealInput TZon( final quantity="ThermodynamicTemperature", final unit="K", final displayUnit="degC") "Measured room temperature"; Buildings.Controls.OBC.CDL.Interfaces.RealInput TCooSet( final quantity="ThermodynamicTemperature", final unit="K", final displayUnit="degC") "Zone cooling setpoint temperature"; Buildings.Controls.OBC.CDL.Interfaces.RealInput THeaSet( final quantity="ThermodynamicTemperature", final unit="K", final displayUnit="degC") "Zone heating setpoint temperature"; Buildings.Controls.OBC.CDL.Interfaces.BooleanInput u1Win if have_winSen "Window status, true if the window is open, false if it is closed"; Buildings.Controls.OBC.CDL.Interfaces.BooleanInput u1Occ if have_occSen "True: the zone is populated"; Buildings.Controls.OBC.CDL.Interfaces.IntegerInput uOpeMod "Zone operation mode"; Buildings.Controls.OBC.CDL.Interfaces.RealInput ppmCO2Set if have_CO2Sen "CO2 concentration setpoint"; Buildings.Controls.OBC.CDL.Interfaces.RealInput ppmCO2 if have_CO2Sen "Detected CO2 concentration"; Buildings.Controls.OBC.CDL.Interfaces.RealInput TDis( final quantity="ThermodynamicTemperature", final unit="K", final displayUnit="degC") "Measured discharge air temperature"; Buildings.Controls.OBC.CDL.Interfaces.RealInput TSup( final unit="K", final displayUnit="degC", final quantity="ThermodynamicTemperature") "Temperature of the air supplied from central air handler"; Buildings.Controls.OBC.CDL.Interfaces.RealInput VDis_flow( final min=0, final unit="m3/s", final quantity="VolumeFlowRate") "Measured primary discharge airflow rate"; Buildings.Controls.OBC.CDL.Interfaces.IntegerInput oveFloSet "Index of overriding flow setpoint, 1: set to zero; 2: set to cooling maximum; 3: set to minimum flow; 4: set to heating maximum"; Buildings.Controls.OBC.CDL.Interfaces.IntegerInput oveDamPos "Index of overriding damper position, 1: set to close; 2: set to open"; Buildings.Controls.OBC.CDL.Interfaces.BooleanInput u1Fan "AHU supply fan status"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput VSet_flow( final min=0, final unit="m3/s", final quantity="VolumeFlowRate") "Discharge airflow setpoint after considering override"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput yDam( final min=0, final unit="1") "Damper commanded position, or commanded flow rate ratio"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput VAdjPopBreZon_flow( final quantity="VolumeFlowRate", final unit="m3/s") if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.ASHRAE62_1_2016 "Adjusted population component breathing zone flow rate"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput VAdjAreBreZon_flow( final quantity="VolumeFlowRate", final unit="m3/s") if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.ASHRAE62_1_2016 "Adjusted area component breathing zone flow rate"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput VMinOA_flow( final quantity="VolumeFlowRate", final unit="m3/s") if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.ASHRAE62_1_2016 "Minimum outdoor airflow setpoint"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput VZonAbsMin_flow( final quantity="VolumeFlowRate", final unit="m3/s") if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.California_Title_24_2016 "Zone absolute minimum outdoor airflow setpoint"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput VZonDesMin_flow( final quantity="VolumeFlowRate", final unit="m3/s") if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.California_Title_24_2016 "Zone design minimum outdoor airflow setpoint"; Buildings.Controls.OBC.CDL.Interfaces.RealOutput yCO2( final unit="1") if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.California_Title_24_2016 "CO2 control loop signal"; Buildings.Controls.OBC.CDL.Interfaces.IntegerOutput yZonTemResReq "Zone cooling supply air temperature reset request"; Buildings.Controls.OBC.CDL.Interfaces.IntegerOutput yZonPreResReq "Zone static pressure reset requests"; Buildings.Controls.OBC.CDL.Interfaces.IntegerOutput yLowFloAla "Low airflow alarms"; Buildings.Controls.OBC.CDL.Interfaces.IntegerOutput yFloSenAla "Airflow sensor calibration alarm"; Buildings.Controls.OBC.CDL.Interfaces.IntegerOutput yLeaDamAla "Leaking damper alarm"; Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.ActiveAirFlow actAirSet( final VCooMax_flow=VCooMax_flow) "Active airflow setpoint"; Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.SystemRequests sysReq( final thrTemDif=thrTemDif, final twoTemDif=twoTemDif, final durTimTem=durTimTem, final durTimFlo=durTimFlo, final dTHys=dTHys, final floHys=floHys, final looHys=looHys, final damPosHys=damPosHys, final samplePeriod=samplePeriod) "Specify system requests "; Buildings.Controls.OBC.ASHRAE.G36.ThermalZones.ControlLoops conLoo( final kCooCon=kCooCon, final TiCooCon=TiCooCon, final kHeaCon=kHeaCon, final TiHeaCon=TiHeaCon, final timChe=timChe, final dTHys=dTHys, final looHys=looHys) "Heating and cooling control loop"; Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.Alarms ala( final staPreMul=staPreMul, final VCooMax_flow=VCooMax_flow, final lowFloTim=lowFloTim, final fanOffTim=fanOffTim, final leaFloTim=leaFloTim, final floHys=floHys, final damPosHys=damPosHys) "Generate alarms"; Buildings.Controls.OBC.ASHRAE.G36.Generic.TimeSuppression timSup( final samplePeriod=samplePeriod, final chaRat=chaRat, final maxTim=maxSupTim, final dTHys=dTHys) "Specify suppresion time due to the setpoint change and check if it has passed the suppresion period"; Buildings.Controls.OBC.ASHRAE.G36.VentilationZones.ASHRAE62_1.Setpoints setPoi( final have_winSen=have_winSen, final have_occSen=have_occSen, final have_CO2Sen=have_CO2Sen, final have_typTerUni=true, final permit_occStandby=permit_occStandby, final VAreBreZon_flow=VAreBreZon_flow, final VPopBreZon_flow=VPopBreZon_flow, final VMin_flow=VMin_flow, final VCooMax_flow=VCooMax_flow, final zonDisEff_cool=zonDisEff_cool, final zonDisEff_heat=zonDisEff_heat, final dTHys=dTHys) if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.ASHRAE62_1_2016 "Output the minimum outdoor airflow rate setpoint, when using ASHRAE 62.1"; Buildings.Controls.OBC.ASHRAE.G36.TerminalUnits.CoolingOnly.Subsequences.Dampers dam( final have_preIndDam=have_preIndDam, final VMin_flow=VMin_flow, final VCooMax_flow=VCooMax_flow, final damCon=damCon, final kDam=kDam, final TiDam=TiDam, final TdDam=TdDam, final dTHys=dTHys) "Damper control"; Buildings.Controls.OBC.ASHRAE.G36.ThermalZones.ZoneStates zonSta "Check if the zone is in cooling state"; Buildings.Controls.OBC.ASHRAE.G36.VentilationZones.Title24.Setpoints minFlo( final have_winSen=have_winSen, final have_occSen=have_occSen, final have_CO2Sen=have_CO2Sen, final have_typTerUni=true, final have_parFanPowUni=false, final VOccMin_flow=VOccMin_flow, final VAreMin_flow=VAreMin_flow, final VMin_flow=VMin_flow, final VCooMax_flow=VCooMax_flow) if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.California_Title_24_2016 "Output the minimum outdoor airflow rate setpoint, when using Title 24"; Buildings.Controls.OBC.CDL.Logical.Sources.Constant noVenStd( final k=venStd ==Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.Not_Specified) "No ventilation standard"; Buildings.Controls.OBC.CDL.Logical.Not not1 "Logical not"; Buildings.Controls.OBC.CDL.Utilities.Assert assMes1( final message="Warning: Ventilation standard is not specified!") "Warning when the ventilation standard is not specified"; Buildings.Controls.OBC.CDL.Continuous.Sources.Constant zerFlo( final k=0) if venStd == Buildings.Controls.OBC.ASHRAE.G36.Types.VentilationStandard.Not_Specified "Zero flow when the ventilation standard is not specified"; equation connect(TZon, timSup.TZon); connect(TCooSet, timSup.TSet); connect(TCooSet, conLoo.TCooSet); connect(TZon, conLoo.TZon); connect(THeaSet, conLoo.THeaSet); connect(u1Win, setPoi.u1Win); connect(u1Occ, setPoi.u1Occ); connect(uOpeMod, setPoi.uOpeMod); connect(ppmCO2, setPoi.ppmCO2); connect(TZon, setPoi.TZon); connect(TDis, setPoi.TDis); connect(uOpeMod, actAirSet.uOpeMod); connect(setPoi.VOccZonMin_flow, actAirSet.VOccMin_flow); connect(VDis_flow, dam.VDis_flow); connect(conLoo.yCoo, dam.uCoo); connect(actAirSet.VActCooMax_flow, dam.VActCooMax_flow); connect(TSup, dam.TSup); connect(actAirSet.VActMin_flow, dam.VActMin_flow); connect(TZon, dam.TZon); connect(timSup.yAftSup, sysReq.uAftSup); connect(TCooSet, sysReq.TCooSet); connect(TZon, sysReq.TZon); connect(conLoo.yCoo, sysReq.uCoo); connect(VDis_flow, sysReq.VDis_flow); connect(VDis_flow, ala.VDis_flow); connect(u1Fan, ala.u1Fan); connect(sysReq.yZonTemResReq, yZonTemResReq); connect(sysReq.yZonPreResReq, yZonPreResReq); connect(ala.yLowFloAla, yLowFloAla); connect(ala.yFloSenAla, yFloSenAla); connect(ala.yLeaDamAla, yLeaDamAla); connect(conLoo.yHea, zonSta.uHea); connect(conLoo.yCoo, zonSta.uCoo); connect(zonSta.yZonSta, dam.uZonSta); connect(ppmCO2Set, setPoi.ppmCO2Set); connect(u1Win, minFlo.u1Win); connect(u1Occ, minFlo.u1Occ); connect(uOpeMod, minFlo.uOpeMod); connect(ppmCO2Set, minFlo.ppmCO2Set); connect(ppmCO2, minFlo.ppmCO2); connect(minFlo.VOccZonMin_flow, actAirSet.VOccMin_flow); connect(dam.VSet_flow, sysReq.VSet_flow); connect(dam.VSet_flow, ala.VActSet_flow); connect(oveFloSet, dam.oveFloSet); connect(oveDamPos, dam.oveDamPos); connect(dam.VSet_flow, VSet_flow); connect(dam.yDam, yDam); connect(setPoi.VAdjPopBreZon_flow, VAdjPopBreZon_flow); connect(setPoi.VAdjAreBreZon_flow, VAdjAreBreZon_flow); connect(setPoi.VMinOA_flow, VMinOA_flow); connect(minFlo.VZonAbsMin_flow, VZonAbsMin_flow); connect(minFlo.VZonDesMin_flow, VZonDesMin_flow); connect(minFlo.yCO2, yCO2); connect(noVenStd.y, not1.u); connect(not1.y, assMes1.u); connect(zerFlo.y, actAirSet.VOccMin_flow); connect(dam.yDam, sysReq.uDam); connect(dam.yDam, ala.uDam); end Controller;