File indexing completed on 2025-02-22 10:31:26
0001
0002
0003
0004
0005
0006
0007
0008 #pragma once
0009
0010 #include <functional>
0011
0012 #include "corecel/data/CollectionMirror.hh"
0013 #include "celeritas/Quantities.hh"
0014 #include "celeritas/mat/IsotopeView.hh"
0015 #include "celeritas/mat/MaterialView.hh"
0016 #include "celeritas/neutron/data/NeutronElasticData.hh"
0017 #include "celeritas/phys/AtomicNumber.hh"
0018 #include "celeritas/phys/Model.hh"
0019
0020 namespace celeritas
0021 {
0022 struct ImportPhysicsVector;
0023 class MaterialParams;
0024 class ParticleParams;
0025
0026
0027
0028
0029
0030 class ChipsNeutronElasticModel final : public Model, public StaticConcreteAction
0031 {
0032 public:
0033
0034 using AtomicMassNumber = IsotopeView::AtomicMassNumber;
0035 using MevEnergy = units::MevEnergy;
0036 using ReadData = std::function<ImportPhysicsVector(AtomicNumber)>;
0037 using HostRef = NeutronElasticHostRef;
0038 using DeviceRef = NeutronElasticDeviceRef;
0039
0040
0041 public:
0042
0043 ChipsNeutronElasticModel(ActionId id,
0044 ParticleParams const& particles,
0045 MaterialParams const& materials,
0046 ReadData load_data);
0047
0048
0049 SetApplicability applicability() const final;
0050
0051
0052 MicroXsBuilders micro_xs(Applicability) const final;
0053
0054
0055 void step(CoreParams const&, CoreStateHost&) const final;
0056
0057
0058 void step(CoreParams const&, CoreStateDevice&) const final;
0059
0060
0061
0062 HostRef const& host_ref() const { return mirror_.host_ref(); }
0063 DeviceRef const& device_ref() const { return mirror_.device_ref(); }
0064
0065
0066 private:
0067
0068
0069
0070 CollectionMirror<NeutronElasticData> mirror_;
0071
0072
0073
0074 using HostXsData = HostVal<NeutronElasticData>;
0075
0076
0077 void append_coeffs(AtomicMassNumber A, HostXsData* xs_data) const;
0078 };
0079
0080
0081 }