File indexing completed on 2025-09-18 09:09:08
0001
0002
0003
0004
0005
0006
0007 #pragma once
0008
0009 #include <functional>
0010
0011 #include "corecel/data/CollectionMirror.hh"
0012 #include "celeritas/Quantities.hh"
0013 #include "celeritas/inp/Grid.hh"
0014 #include "celeritas/mat/IsotopeView.hh"
0015 #include "celeritas/mat/MaterialView.hh"
0016 #include "celeritas/neutron/data/NeutronInelasticData.hh"
0017 #include "celeritas/phys/AtomicNumber.hh"
0018 #include "celeritas/phys/Model.hh"
0019
0020 namespace celeritas
0021 {
0022 struct CascadeOptions;
0023 class MaterialParams;
0024 class ParticleParams;
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037
0038
0039
0040
0041
0042 class NeutronInelasticModel final : public Model, public StaticConcreteAction
0043 {
0044 public:
0045
0046 using AtomicMassNumber = IsotopeView::AtomicMassNumber;
0047 using MevEnergy = units::MevEnergy;
0048 using ReadData = std::function<inp::Grid(AtomicNumber)>;
0049 using HostRef = NeutronInelasticHostRef;
0050 using DeviceRef = NeutronInelasticDeviceRef;
0051
0052
0053 public:
0054
0055 NeutronInelasticModel(ActionId id,
0056 ParticleParams const& particles,
0057 MaterialParams const& materials,
0058 CascadeOptions const& options,
0059 ReadData load_data);
0060
0061
0062 SetApplicability applicability() const final;
0063
0064
0065 MicroXsBuilders micro_xs(Applicability) const final;
0066
0067
0068 void step(CoreParams const&, CoreStateHost&) const final;
0069
0070
0071 void step(CoreParams const&, CoreStateDevice&) const final;
0072
0073
0074
0075 HostRef const& host_ref() const { return data_.host_ref(); }
0076 DeviceRef const& device_ref() const { return data_.device_ref(); }
0077
0078
0079 private:
0080
0081
0082
0083 CollectionMirror<NeutronInelasticData> data_;
0084
0085
0086
0087 using HostXsData = HostVal<NeutronInelasticData>;
0088
0089
0090
0091 StepanovParameters const& get_channel_params(ChannelId id);
0092 inp::Grid const& get_channel_xs(ChannelId id);
0093 inp::TwodGrid const& get_channel_cdf(ChannelId id);
0094 };
0095
0096
0097 }