LCOV - code coverage report
Current view: top level - src/auxkernels - ShaftConnectedPump1PhaseAux.C (source / functions) Hit Total Coverage
Test: idaholab/moose thermal_hydraulics: #30301 (3b550b) with base 2ad78d Lines: 22 24 91.7 %
Date: 2025-07-30 13:02:48 Functions: 3 3 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : //* This file is part of the MOOSE framework
       2             : //* https://mooseframework.inl.gov
       3             : //*
       4             : //* All rights reserved, see COPYRIGHT for full restrictions
       5             : //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
       6             : //*
       7             : //* Licensed under LGPL 2.1, please see LICENSE for details
       8             : //* https://www.gnu.org/licenses/lgpl-2.1.html
       9             : 
      10             : #include "ShaftConnectedPump1PhaseAux.h"
      11             : #include "ADShaftConnectedPump1PhaseUserObject.h"
      12             : 
      13             : registerMooseObject("ThermalHydraulicsApp", ShaftConnectedPump1PhaseAux);
      14             : 
      15             : InputParameters
      16         368 : ShaftConnectedPump1PhaseAux::validParams()
      17             : {
      18         368 :   InputParameters params = AuxKernel::validParams();
      19             : 
      20         368 :   params.addClassDescription("Computes various quantities for a ShaftConnectedPump1Phase.");
      21             : 
      22         736 :   MooseEnum quantity("pump_head hydraulic_torque friction_torque moment_of_inertia");
      23         736 :   params.addRequiredParam<MooseEnum>("quantity", quantity, "Which quantity to compute");
      24         736 :   params.addRequiredParam<UserObjectName>("pump_uo", "Pump user object name");
      25             : 
      26         368 :   return params;
      27         368 : }
      28             : 
      29         196 : ShaftConnectedPump1PhaseAux::ShaftConnectedPump1PhaseAux(const InputParameters & parameters)
      30             :   : AuxKernel(parameters),
      31         196 :     _quantity(this->template getParam<MooseEnum>("quantity").template getEnum<Quantity>()),
      32         392 :     _pump_uo(this->template getUserObject<ADShaftConnectedPump1PhaseUserObject>("pump_uo"))
      33             : {
      34         196 : }
      35             : 
      36             : Real
      37        2948 : ShaftConnectedPump1PhaseAux::computeValue()
      38             : {
      39        2948 :   switch (_quantity)
      40             :   {
      41         737 :     case Quantity::PUMP_HEAD:
      42         737 :       return MetaPhysicL::raw_value(_pump_uo.getPumpHead());
      43             :       break;
      44         737 :     case Quantity::HYDRAULIC_TORQUE:
      45         737 :       return MetaPhysicL::raw_value(_pump_uo.getHydraulicTorque());
      46             :       break;
      47         737 :     case Quantity::FRICTION_TORQUE:
      48         737 :       return MetaPhysicL::raw_value(_pump_uo.getFrictionTorque());
      49             :       break;
      50         737 :     case Quantity::MOMENT_OF_INERTIA:
      51         737 :       return MetaPhysicL::raw_value(_pump_uo.getMomentOfInertia());
      52             :       break;
      53           0 :     default:
      54           0 :       mooseError("Invalid 'quantity' parameter.");
      55             :   }
      56             : }

Generated by: LCOV version 1.14