File indexing completed on 2025-09-18 09:09:00
0001
0002
0003
0004
0005
0006
0007 #pragma once
0008
0009 #include <memory>
0010
0011 #include "celeritas/Quantities.hh"
0012 #include "celeritas/em/data/CoulombScatteringData.hh"
0013 #include "celeritas/phys/ImportedModelAdapter.hh"
0014 #include "celeritas/phys/Model.hh"
0015
0016 namespace celeritas
0017 {
0018 class MaterialParams;
0019 class ParticleParams;
0020 class IsotopeView;
0021
0022
0023
0024
0025
0026 class CoulombScatteringModel final : public Model, public StaticConcreteAction
0027 {
0028 public:
0029
0030
0031 using SPConstImported = std::shared_ptr<ImportedProcesses const>;
0032
0033
0034 public:
0035
0036 CoulombScatteringModel(ActionId id,
0037 ParticleParams const& particles,
0038 MaterialParams const& materials,
0039 SPConstImported data);
0040
0041
0042 SetApplicability applicability() const final;
0043
0044
0045 MicroXsBuilders micro_xs(Applicability) const final;
0046
0047
0048 void step(CoreParams const&, CoreStateHost&) const final;
0049
0050
0051 void step(CoreParams const&, CoreStateDevice&) const final;
0052
0053
0054
0055 CoulombScatteringData const& host_ref() const { return data_; }
0056 CoulombScatteringData const& device_ref() const { return data_; }
0057
0058
0059 private:
0060 CoulombScatteringData data_;
0061 ImportedModelAdapter imported_;
0062 ImportedModelAdapter::EnergyBounds energy_limit_;
0063 };
0064
0065
0066 }