File indexing completed on 2026-06-02 08:51:43
0001 #ifndef DVCS_CFF_DISPERSION_RELATION_H
0002 #define DVCS_CFF_DISPERSION_RELATION_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 #include <vector>
0016
0017 #include "../../../beans/automation/BaseObjectData.h"
0018 #include "DVCSConvolCoeffFunctionModule.h"
0019
0020 namespace NumA {
0021 class FunctionType1D;
0022 }
0023 namespace PARTONS {
0024 class GPDSubtractionConstantModule;
0025 }
0026
0027 namespace PARTONS {
0028
0029
0030
0031
0032
0033
0034
0035
0036 class DVCSCFFDispersionRelation: public DVCSConvolCoeffFunctionModule {
0037
0038 public:
0039
0040 static const unsigned int classId;
0041
0042
0043
0044
0045
0046
0047
0048 DVCSCFFDispersionRelation(const std::string &className);
0049
0050
0051
0052
0053 virtual ~DVCSCFFDispersionRelation();
0054
0055 virtual DVCSCFFDispersionRelation* clone() const;
0056 virtual void resolveObjectDependencies();
0057 virtual void configure(const ElemUtils::Parameters ¶meters);
0058 virtual void prepareSubModules(
0059 const std::map<std::string, BaseObjectData>& subModulesData);
0060
0061
0062
0063
0064 GPDSubtractionConstantModule* getSubtractionConstantModule() const;
0065
0066
0067
0068
0069
0070 void setSubtractionConstantModule(
0071 GPDSubtractionConstantModule* subtractionConstantModule);
0072
0073 protected:
0074
0075
0076
0077
0078 DVCSCFFDispersionRelation(const DVCSCFFDispersionRelation &other);
0079
0080 virtual void initModule();
0081 virtual void isModuleWellConfigured();
0082
0083 private:
0084
0085 virtual std::complex<double> computeUnpolarized();
0086 virtual std::complex<double> computePolarized();
0087
0088
0089
0090
0091
0092 double computeSquareChargeAveragedGPD(double xi);
0093
0094
0095
0096
0097
0098
0099 double dispersionRelationIntegralPartDiagonalA(double xi,
0100 std::vector<double> par);
0101
0102
0103
0104
0105
0106
0107 double dispersionRelationIntegralPartDiagonalB(double xi,
0108 std::vector<double> par);
0109
0110
0111
0112
0113 void initFunctorsForIntegrations();
0114
0115 NumA::FunctionType1D* m_p_int_dispersionRelationIntegralPartDiagonalA;
0116 NumA::FunctionType1D* m_p_int_dispersionRelationIntegralPartDiagonalB;
0117
0118 GPDSubtractionConstantModule* m_pSubtractionConstantModule;
0119 };
0120
0121 }
0122
0123 #endif