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/mat/MaterialParams.hh"
0012 #include "celeritas/phys/Applicability.hh"
0013 #include "celeritas/phys/ImportedProcessAdapter.hh"
0014 #include "celeritas/phys/ParticleParams.hh"
0015 #include "celeritas/phys/Process.hh"
0016
0017 namespace celeritas
0018 {
0019
0020
0021
0022
0023 class RayleighProcess : public Process
0024 {
0025 public:
0026
0027
0028 using SPConstParticles = std::shared_ptr<ParticleParams const>;
0029 using SPConstMaterials = std::shared_ptr<MaterialParams const>;
0030 using SPConstImported = std::shared_ptr<ImportedProcesses const>;
0031
0032
0033 public:
0034
0035 RayleighProcess(SPConstParticles particles,
0036 SPConstMaterials materials,
0037 SPConstImported process_data);
0038
0039
0040 VecModel build_models(ActionIdIter start_id) const final;
0041
0042
0043 StepLimitBuilders step_limits(Applicability range) const final;
0044
0045
0046 bool supports_integral_xs() const final { return false; }
0047
0048
0049 bool applies_at_rest() const final { return imported_.applies_at_rest(); }
0050
0051
0052 std::string_view label() const final;
0053
0054 private:
0055 SPConstParticles particles_;
0056 SPConstMaterials materials_;
0057 ImportedProcessAdapter imported_;
0058 };
0059
0060
0061 }