File indexing completed on 2026-06-02 08:51:44
0001 #ifndef GAM2_CONVOL_COEFF_FUNCTION_MODULE_H
0002 #define GAM2_CONVOL_COEFF_FUNCTION_MODULE_H
0003
0004
0005
0006
0007
0008
0009
0010
0011 #include <ElementaryUtils/parameters/Parameters.h>
0012 #include <complex>
0013 #include <map>
0014 #include <string>
0015
0016 #include "../../../beans/automation/BaseObjectData.h"
0017 #include "../../../beans/convol_coeff_function/GAM2/GAM2ConvolCoeffFunctionKinematic.h"
0018 #include "../../../beans/convol_coeff_function/GAM2/GAM2ConvolCoeffFunctionResult.h"
0019 #include "../../../beans/gpd/GPDType.h"
0020 #include "../../../beans/List.h"
0021 #include "../../../beans/PerturbativeQCDOrderType.h"
0022 #include "../../../beans/PolarizationType.h"
0023 #include "../../../utils/type/PhysicalType.h"
0024 #include "../ConvolCoeffFunctionModule.h"
0025
0026 namespace PARTONS {
0027
0028
0029
0030
0031
0032
0033
0034
0035 class GAM2ConvolCoeffFunctionModule: public ConvolCoeffFunctionModule<
0036 GAM2ConvolCoeffFunctionKinematic, GAM2ConvolCoeffFunctionResult> {
0037
0038 public:
0039
0040 static const std::string GAM2_CONVOL_COEFF_FUNCTION_MODULE_CLASS_NAME;
0041
0042
0043
0044
0045 virtual ~GAM2ConvolCoeffFunctionModule();
0046
0047 virtual GAM2ConvolCoeffFunctionModule* clone() const = 0;
0048 virtual std::string toString() const;
0049 virtual void resolveObjectDependencies();
0050 virtual void run();
0051 virtual void configure(const ElemUtils::Parameters ¶meters);
0052 virtual void prepareSubModules(
0053 const std::map<std::string, BaseObjectData>& subModulesData);
0054 virtual GAM2ConvolCoeffFunctionResult compute(
0055 const GAM2ConvolCoeffFunctionKinematic& kinematic,
0056 const List<GPDType>& gpdType = List<GPDType>());
0057 virtual List<GPDType> getListOfAvailableGPDTypeForComputation() const;
0058
0059
0060
0061
0062
0063
0064 PerturbativeQCDOrderType::Type getQCDOrderType() const;
0065
0066
0067
0068
0069 void setQCDOrderType(PerturbativeQCDOrderType::Type qcdOrderType);
0070
0071
0072
0073
0074
0075
0076
0077
0078 virtual std::complex<double> computeUnpolarized();
0079
0080
0081
0082
0083
0084
0085 virtual std::complex<double> computePolarized();
0086
0087
0088
0089
0090
0091
0092 virtual std::complex<double> computeCFF();
0093
0094 virtual std::vector<double> test();
0095
0096 protected:
0097
0098
0099
0100
0101 GAM2ConvolCoeffFunctionModule(const std::string &className);
0102
0103
0104
0105
0106
0107
0108 GAM2ConvolCoeffFunctionModule(const GAM2ConvolCoeffFunctionModule &other);
0109
0110 virtual void setKinematics(
0111 const GAM2ConvolCoeffFunctionKinematic& kinematic);
0112 virtual void initModule();
0113 virtual void isModuleWellConfigured();
0114
0115
0116
0117
0118 std::map<GPDType::Type,
0119 std::complex<double> (GAM2ConvolCoeffFunctionModule::*)()> m_listOfCFFComputeFunctionAvailable;
0120
0121
0122
0123
0124 std::map<GPDType::Type,
0125 std::complex<double> (GAM2ConvolCoeffFunctionModule::*)()>::iterator m_it;
0126
0127 double m_uPrim;
0128 double m_Mgg2;
0129
0130 PolarizationType::Type m_polG0;
0131 PolarizationType::Type m_polG1;
0132 PolarizationType::Type m_polG2;
0133
0134 double m_phi;
0135
0136 PerturbativeQCDOrderType::Type m_qcdOrderType;
0137 };
0138
0139 }
0140
0141 #endif