File indexing completed on 2025-09-18 09:09:01
0001
0002
0003
0004
0005
0006
0007 #pragma once
0008
0009 #include <memory>
0010
0011 #include "celeritas/em/data/CoulombScatteringData.hh"
0012 #include "celeritas/em/model/CoulombScatteringModel.hh"
0013 #include "celeritas/io/ImportParameters.hh"
0014 #include "celeritas/mat/MaterialParams.hh"
0015 #include "celeritas/phys/Applicability.hh"
0016 #include "celeritas/phys/ImportedProcessAdapter.hh"
0017 #include "celeritas/phys/Process.hh"
0018
0019 namespace celeritas
0020 {
0021
0022
0023
0024
0025 class CoulombScatteringProcess : public Process
0026 {
0027 public:
0028
0029
0030 using SPConstParticles = std::shared_ptr<ParticleParams const>;
0031 using SPConstMaterials = std::shared_ptr<MaterialParams const>;
0032 using SPConstImported = std::shared_ptr<ImportedProcesses const>;
0033
0034
0035 public:
0036
0037 CoulombScatteringProcess(SPConstParticles particles,
0038 SPConstMaterials materials,
0039 SPConstImported process_data);
0040
0041
0042 VecModel build_models(ActionIdIter start_id) const final;
0043
0044
0045 StepLimitBuilders step_limits(Applicability range) const final;
0046
0047
0048 bool supports_integral_xs() const final { return true; }
0049
0050
0051 bool applies_at_rest() const final { return imported_.applies_at_rest(); }
0052
0053
0054 std::string_view label() const final;
0055
0056 private:
0057 SPConstParticles particles_;
0058 SPConstMaterials materials_;
0059 ImportedProcessAdapter imported_;
0060 };
0061
0062
0063 }