File indexing completed on 2026-06-02 08:51:43
0001 #ifndef COLLINEAR_DISTRIBUTION_MODULE_H
0002 #define COLLINEAR_DISTRIBUTION_MODULE_H
0003
0004
0005
0006
0007
0008
0009
0010
0011 #include <ElementaryUtils/parameters/Parameters.h>
0012 #include <map>
0013 #include <string>
0014
0015 #include "../../beans/automation/BaseObjectData.h"
0016 #include "../../beans/collinear_distribution/CollinearDistributionType.h"
0017 #include "../../beans/List.h"
0018 #include "../../beans/parton_distribution/PartonDistribution.h"
0019 #include "../../ModuleObject.h"
0020
0021 namespace PARTONS {
0022
0023 class CollinearDistributionKinematic;
0024 class CollinearDistributionResult;
0025 class CollinearDistributionEvolutionModule;
0026
0027
0028
0029
0030
0031
0032
0033 class CollinearDistributionModule: public ModuleObject {
0034
0035 public:
0036
0037 static const std::string COLLINEAR_DISTRIBUTION_MODULE_CLASS_NAME;
0038
0039
0040
0041
0042 virtual ~CollinearDistributionModule();
0043
0044 virtual CollinearDistributionModule* clone() const = 0;
0045 virtual std::string toString() const;
0046 virtual void resolveObjectDependencies();
0047 virtual void run();
0048 void virtual configure(const ElemUtils::Parameters ¶meters);
0049 virtual void prepareSubModules(const std::map<std::string, BaseObjectData>& subModulesData);
0050
0051
0052
0053
0054
0055
0056
0057
0058
0059
0060
0061 virtual PartonDistribution compute(const CollinearDistributionKinematic &kinematic, CollinearDistributionType::Type colldistType);
0062
0063
0064
0065
0066
0067
0068
0069
0070
0071
0072
0073 virtual CollinearDistributionResult compute(const CollinearDistributionKinematic &kinematic,
0074 const List<CollinearDistributionType>& colldistType = List<CollinearDistributionType>());
0075
0076
0077
0078
0079 List<CollinearDistributionType> getListOfAvailableCollinearDistributionTypeForComputation() const;
0080
0081
0082
0083
0084
0085
0086
0087
0088
0089 virtual PartonDistribution computeUnpolPDF();
0090 virtual PartonDistribution computePolPDF();
0091 virtual PartonDistribution computeTransPDF();
0092 virtual PartonDistribution computeUnpolFF();
0093 virtual PartonDistribution computePolFF();
0094 virtual PartonDistribution computeTransFF();
0095
0096
0097
0098
0099
0100
0101 double getMuF2Ref() const;
0102
0103
0104
0105
0106 const CollinearDistributionEvolutionModule* getEvolQcdModule() const;
0107
0108
0109
0110
0111 void setEvolQcdModule(CollinearDistributionEvolutionModule* pEvolQcdModule);
0112
0113 protected:
0114
0115
0116
0117
0118 CollinearDistributionModule(const std::string &className);
0119
0120
0121
0122
0123
0124 CollinearDistributionModule(const CollinearDistributionModule &other);
0125
0126
0127
0128
0129
0130 virtual void setKinematics(const CollinearDistributionKinematic& kinematic);
0131 virtual void initModule();
0132 virtual void isModuleWellConfigured();
0133
0134
0135
0136
0137
0138 std::map<CollinearDistributionType::Type, PartonDistribution (CollinearDistributionModule::*)()> m_listCollinearDistributionComputeTypeAvailable;
0139
0140 double m_x;
0141 double m_MuF2;
0142 double m_MuR2;
0143 double m_MuF2_ref;
0144
0145 CollinearDistributionEvolutionModule* m_pCollinearDistributionEvolutionModule;
0146 };
0147
0148 }
0149
0150 #endif