Line data Source code
1 : /********************************************************************/ 2 : /* SOFTWARE COPYRIGHT NOTIFICATION */ 3 : /* Cardinal */ 4 : /* */ 5 : /* (c) 2021 UChicago Argonne, LLC */ 6 : /* ALL RIGHTS RESERVED */ 7 : /* */ 8 : /* Prepared by UChicago Argonne, LLC */ 9 : /* Under Contract No. DE-AC02-06CH11357 */ 10 : /* With the U. S. Department of Energy */ 11 : /* */ 12 : /* Prepared by Battelle Energy Alliance, LLC */ 13 : /* Under Contract No. DE-AC07-05ID14517 */ 14 : /* With the U. S. Department of Energy */ 15 : /* */ 16 : /* See LICENSE for full restrictions */ 17 : /********************************************************************/ 18 : 19 : #pragma once 20 : 21 : #include "GeneralPostprocessor.h" 22 : 23 : #include "NekBase.h" 24 : 25 : /** 26 : * Base class for performing sideset postprocessor operations within nekRS. 27 : * This class just checks that the boundary supplied by the user is a valid 28 : * ID within the nekRS mesh. 29 : */ 30 : class NekSidePostprocessor : public GeneralPostprocessor, public NekBase 31 : { 32 : public: 33 : static InputParameters validParams(); 34 : 35 : NekSidePostprocessor(const InputParameters & parameters); 36 : 37 56385 : virtual void initialize() override {} 38 56385 : virtual void execute() override {} 39 : 40 : protected: 41 : /// Which NekRS mesh to act on 42 : const nek_mesh::NekMeshEnum _pp_mesh; 43 : 44 : /// boundary IDs of the nekRS mesh over which to find the extreme value 45 : const std::vector<int> & _boundary; 46 : };