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