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 : #pragma once 11 : 12 : #include "EulerAngleProvider.h" 13 : #include "MooseRandom.h" 14 : 15 : // Forward declaration 16 : class GrainTrackerInterface; 17 : 18 : /** 19 : * Assign random Euler angles to each grains 20 : */ 21 : class RandomEulerAngleProvider : public EulerAngleProvider 22 : { 23 : public: 24 : static InputParameters validParams(); 25 : 26 : RandomEulerAngleProvider(const InputParameters & parameters); 27 : 28 : virtual void initialize() override; 29 74 : virtual void execute() override {} 30 74 : virtual void finalize() override {} 31 : 32 : virtual const EulerAngles & getEulerAngles(unsigned int) const override; 33 : virtual unsigned int getGrainNum() const override; 34 : 35 : protected: 36 : const GrainTrackerInterface & _grain_tracker; 37 : std::vector<EulerAngles> & _angles; 38 : 39 : MooseRandom _random; 40 : };