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 : #ifdef ENABLE_OPENMC_COUPLING 20 : 21 : #include "AddCriticalitySearchAction.h" 22 : #include "OpenMCCellAverageProblem.h" 23 : #include "CriticalitySearchBase.h" 24 : 25 : registerMooseAction("CardinalApp", AddCriticalitySearchAction, "add_criticality_search"); 26 : 27 : InputParameters 28 96 : AddCriticalitySearchAction::validParams() 29 : { 30 96 : auto params = MooseObjectAction::validParams(); 31 96 : params.addClassDescription("Adds a criticality search for OpenMC"); 32 96 : return params; 33 0 : } 34 : 35 96 : AddCriticalitySearchAction::AddCriticalitySearchAction(const InputParameters & parameters) 36 96 : : MooseObjectAction(parameters) 37 : { 38 96 : } 39 : 40 : void 41 96 : AddCriticalitySearchAction::act() 42 : { 43 96 : if (_current_task == "add_criticality_search") 44 : { 45 96 : auto openmc_problem = dynamic_cast<OpenMCCellAverageProblem *>(_problem.get()); 46 : 47 96 : if (!openmc_problem) 48 2 : mooseError("The [CriticalitySearch] block can only be used with wrapped OpenMC cases! " 49 : "You need to change the [Problem] block to 'OpenMCCellAverageProblem'."); 50 : 51 170 : openmc_problem->addObject<CriticalitySearchBase>(_type, _name, _moose_object_pars, false); 52 : } 53 76 : } 54 : #endif