OpenStudioCore:model
 AllClasses Namespaces Functions Variables Typedefs Enumerations Enumerator Friends Pages

#include "HVACComponent.hpp"

Inheritance diagram for openstudio::model::HVACComponent:

Public Member Functions

bool addToNode (Node &node)
bool addToSplitter (Splitter &splitter)
boost::optional< AirLoopHVACairLoopHVAC () const
boost::optional
< AirLoopHVACOutdoorAirSystem
airLoopHVACOutdoorAirSystem () const
boost::optional< HVACComponentcontainingHVACComponent () const
boost::optional
< StraightComponent
containingStraightComponent () const
boost::optional
< ZoneHVACComponent
containingZoneHVACComponent () const
void disconnect ()
bool isRemovable () const
boost::optional< Looploop () const
boost::optional< PlantLoopplantLoop () const
std::vector< IdfObjectremove ()
virtual ~HVACComponent ()

Protected Types

typedef detail::HVACComponent_Impl ImplType

Protected Member Functions

virtual std::vector< ModelObjectchildren () const
 HVACComponent (IddObjectType type, const Model &model)
 HVACComponent (std::shared_ptr< ImplType > impl)

Detailed Description

HVACComponent is the base class for objects related to HVAC systems.

HVACComponent provides the ability to connect multiple HVACComponents together through ports. Connections are directional and they are created by identifying a source HVACComponent and port as well as a target HVACComponent object and port. Once a connection is made, it is easy to access the HVACComponent connected to a particular port using the member functions of HVACComponent.

New Connections are made using the openstudio::model::Model::connect function.

Connections and ports together form similar functionality as EnergyPlus nodes, however a connection between ports is more general then a node connection in Energyplus. Indeed, in the OpenStudio model connections are used to describe what is a node connection in EnergyPlus, but connections can be applied to other contexts then just EnergyPlus nodes. OpenStudio's connections and ports can be used anytime one "component" can be arbitrarily connected to another "component". For example EnergyPlus EMS sensors and actuaters could be thought of as source and target ports, where a connection can be made between the two.

Member Typedef Documentation

typedef detail::HVACComponent_Impl openstudio::model::HVACComponent::ImplType
protected

Constructor & Destructor Documentation

virtual openstudio::model::HVACComponent::~HVACComponent ( )
inlinevirtual
openstudio::model::HVACComponent::HVACComponent ( IddObjectType  type,
const Model model 
)
protected

Returns the optional ModelObject connected to this object's port.

Returns the optional Port on the connected object through which the connection to this object's port is made.

openstudio::model::HVACComponent::HVACComponent ( std::shared_ptr< ImplType impl)
explicitprotected

Member Function Documentation

bool openstudio::model::HVACComponent::addToNode ( Node node)

Adds this object to a new system node and returns a boolean indicating if the addition was successful.

This method is reimplemented in many of the derived classes to do the right thing based on the context of the node a particular object is added to. For example if a specific HVACComoponent is not allowed on an air loop and this interface is used to attempt to add the HVAC component to a node on an air loop the method will return false and the object will not be added.

Normally, this method will add this HVAC component immediatly after the node specified. There are exceptions, such as when a component is dropped on an outlet node such as the supply outlet node of an air loop. In this case the method will do the only thing possible and add this component before the outlet node.

bool openstudio::model::HVACComponent::addToSplitter ( Splitter splitter)

Adds this object to a splitter by creating a new branch.

Returns true if the operation was succesfull.

This method is reimplemented in many of the derived class to do the right thing based on the context of the splitter a particular object is added to.

boost::optional<AirLoopHVAC> openstudio::model::HVACComponent::airLoopHVAC ( ) const

Returns the optional AirLoopHVAC object that the HVAC component is attached to.

If the component is part of an outdoor air system, the containing AirLoopHVAC will be returned. If the HVAC component is not associated with an air loop then the optional will be false.

boost::optional<AirLoopHVACOutdoorAirSystem> openstudio::model::HVACComponent::airLoopHVACOutdoorAirSystem ( ) const

Returns the optional AirLoopHVACOutdoorAirSystem that the HVAC component is attached to.

If the HVAC component is not associated with an outdoor air system then the optional will be false.

virtual std::vector<ModelObject> openstudio::model::HVACComponent::children ( ) const
protectedvirtual
boost::optional<HVACComponent> openstudio::model::HVACComponent::containingHVACComponent ( ) const

EnergyPlus unitary equipment and air terminals are typically composed of other HVAC components.

This method returns any such component containing this component. In OpenStudio, AirLoopHVAC, PlantLoop, and AirLoopHVACOutdoorAirSystem are treated as systems, not unitary equipment, thus they are not returned by this method. See plantLoop(), airLoop(), and airLoopHVACOutdoorAirSystem() to access those systems.

boost::optional<StraightComponent> openstudio::model::HVACComponent::containingStraightComponent ( ) const
boost::optional<ZoneHVACComponent> openstudio::model::HVACComponent::containingZoneHVACComponent ( ) const

Returns any ZoneHVACComponent that contains this HVACComponent.

void openstudio::model::HVACComponent::disconnect ( )

Removes all connections to other HVACComponent objects.

bool openstudio::model::HVACComponent::isRemovable ( ) const

Indicates if the HVACComponent can be removed from the model.

One reason a component could not be removed is because it is attached to a loop and removing it would destroy the integrity of the loop. Zone splitters and mixers are examples of this, since they are required components of an air loop. In such a case, the HVACComponent must be disconnected before it can be removed.

boost::optional<Loop> openstudio::model::HVACComponent::loop ( ) const

Returns the optional Loop object that the HVAC component is attached to.

If the component is part of an outdoor air system, the containing AirLoopHVAC will be returned. If the component is attached to multiple loops, the optional will be false.

boost::optional<PlantLoop> openstudio::model::HVACComponent::plantLoop ( ) const

Returns the optional PlantLoop object that the HVAC component is attached to.

If the HVAC component is not associated with a plant loop then the optional will be false.

std::vector<IdfObject> openstudio::model::HVACComponent::remove ( )

Removes the HVACComponent from the model only if isRemovable() return true.