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_NEK_COUPLING 20 : 21 : #include "NekBinnedPlaneAverage.h" 22 : 23 : registerMooseObject("CardinalApp", NekBinnedPlaneAverage); 24 : 25 : InputParameters 26 49 : NekBinnedPlaneAverage::validParams() 27 : { 28 49 : InputParameters params = NekPlaneSpatialBinUserObject::validParams(); 29 49 : params.addClassDescription( 30 : "Compute the spatially-binned side average of a field over the NekRS mesh"); 31 49 : return params; 32 0 : } 33 : 34 25 : NekBinnedPlaneAverage::NekBinnedPlaneAverage(const InputParameters & parameters) 35 25 : : NekBinnedPlaneIntegral(parameters) 36 : { 37 24 : } 38 : 39 : void 40 24 : NekBinnedPlaneAverage::executeUserObject() 41 : { 42 24 : computeIntegral(); 43 : 44 : // divide by the bin volume if accessible; otherwise, we know that there weren't any counts, 45 : // and the bin value will remain zero 46 2296 : for (unsigned int i = 0; i < num_bins(); ++i) 47 2272 : if (_bin_volumes[i] > 0.0) 48 2272 : _bin_values[i] /= _bin_volumes[i]; 49 24 : } 50 : 51 : #endif