Nodes of different colours represent the following:
Solid arrows point from a parent (sub)module to the submodule which is descended from it. Dashed arrows point from a module being used to the module or program unit using it. Where possible, edges connecting nodes are given different colours to make them easier to distinguish in large graphs.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
integer, | intent(in) | :: | ControlNum |
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed arrows point from an interface to procedures which implement that interface. This could include the module procedures in a generic interface or the implementation in a submodule of an interface in a parent module. Where possible, edges connecting nodes are given different colours to make them easier to distinguish in large graphs.
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed arrows point from an interface to procedures which implement that interface. This could include the module procedures in a generic interface or the implementation in a submodule of an interface in a parent module. Where possible, edges connecting nodes are given different colours to make them easier to distinguish in large graphs.
SUBROUTINE UpdateController(ControlNum)
! SUBROUTINE INFORMATION:
! AUTHOR <author>
! DATE WRITTEN <date_written>
! MODIFIED na
! RE-ENGINEERED na
! PURPOSE OF THIS SUBROUTINE:
! This subroutine updates the actuated node with the next candidate value.
! METHODOLOGY EMPLOYED:
! Needs description, as appropriate.
! REFERENCES:
! na
! USE STATEMENTS:
USE PlantUtilities, ONLY : SetActuatedBranchFlowRate
IMPLICIT NONE ! Enforce explicit typing of all variables in this routine
! SUBROUTINE ARGUMENT DEFINITIONS:
INTEGER, INTENT(IN) :: ControlNum
! SUBROUTINE PARAMETER DEFINITIONS:
! na
! INTERFACE BLOCK SPECIFICATIONS
! na
! DERIVED TYPE DEFINITIONS
! na
! SUBROUTINE LOCAL VARIABLE DECLARATIONS:
INTEGER :: ActuatedNode
INTEGER :: SensedNode
! Set the sensed and actuated node numbers
ActuatedNode = ControllerProps(ControlNum)%ActuatedNode
SensedNode = ControllerProps(ControlNum)%SensedNode
! Set the actuated node of the Controller
SELECT CASE(ControllerProps(ControlNum)%ActuatorVar)
CASE (iFlow) ! 'Flow'
Call SetActuatedBranchFlowRate(ControllerProps(ControlNum)%NextActuatedValue, &
ControllerProps(ControlNum)%ActuatedNode , &
ControllerProps(ControlNum)%ActuatedNodePlantLoopNum, &
ControllerProps(ControlNum)%ActuatedNodePlantLoopSide, &
ControllerProps(ControlNum)%ActuatedNodePlantLoopBranchNum, &
.FALSE.)
! Node(ActuatedNode)%MassFlowRate = ControllerProps(ControlNum)%NextActuatedValue
CASE DEFAULT
CALL ShowFatalError( &
'UpdateController: Invalid Actuator Variable Type='// &
TRIM(ControlVariableTypes(ControllerProps(ControlNum)%ActuatorVar)) &
)
END SELECT
RETURN
END SUBROUTINE UpdateController