File indexing completed on 2025-02-22 10:31:19
0001
0002
0003
0004
0005
0006
0007
0008 #pragma once
0009
0010 #include <memory>
0011
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 MuIonizationProcess : public Process
0024 {
0025 public:
0026
0027
0028 using Energy = units::MevEnergy;
0029 using SPConstParticles = std::shared_ptr<ParticleParams const>;
0030 using SPConstImported = std::shared_ptr<ImportedProcesses const>;
0031
0032
0033
0034 struct Options
0035 {
0036
0037 Energy bragg_icru73qo_upper_limit{0.2};
0038
0039 Energy bethe_bloch_upper_limit{1e3};
0040
0041 bool use_integral_xs{true};
0042 };
0043
0044 public:
0045
0046 MuIonizationProcess(SPConstParticles particles,
0047 SPConstImported process_data,
0048 Options options);
0049
0050
0051 VecModel build_models(ActionIdIter start_id) const final;
0052
0053
0054 StepLimitBuilders step_limits(Applicability applicability) const final;
0055
0056
0057 bool use_integral_xs() const final { return options_.use_integral_xs; }
0058
0059
0060 std::string_view label() const final;
0061
0062 private:
0063 SPConstParticles particles_;
0064 ImportedProcessAdapter imported_;
0065 Options options_;
0066 };
0067
0068
0069 }