File indexing completed on 2026-06-02 08:51:44
0001 #ifndef TCS_CFF_FROM_DVCS_H
0002 #define TCS_CFF_FROM_DVCS_H
0003
0004
0005
0006
0007
0008
0009
0010
0011 #include <complex>
0012 #include <map>
0013 #include <string>
0014
0015 #include "../../../beans/automation/BaseObjectData.h"
0016 #include "TCSConvolCoeffFunctionModule.h"
0017
0018 namespace PARTONS {
0019
0020
0021
0022
0023
0024
0025
0026
0027 class TCSCFFFromDVCS: public TCSConvolCoeffFunctionModule {
0028
0029 public:
0030
0031 static const unsigned int classId;
0032
0033
0034
0035
0036
0037
0038 TCSCFFFromDVCS(const std::string &className);
0039
0040 virtual TCSCFFFromDVCS* clone() const;
0041
0042
0043
0044
0045 virtual ~TCSCFFFromDVCS();
0046
0047 virtual void resolveObjectDependencies();
0048
0049 virtual void prepareSubModules(
0050 const std::map<std::string, BaseObjectData>& subModulesData);
0051
0052
0053
0054
0055 void setDVCSConvolCoeffFunctionModule(
0056 DVCSConvolCoeffFunctionModule* pDVCSConvolCoeffFunctionModule);
0057
0058
0059
0060
0061 DVCSConvolCoeffFunctionModule* getDVCSConvolCoeffFunctionModule() const;
0062
0063 protected:
0064
0065
0066
0067
0068
0069 TCSCFFFromDVCS(const TCSCFFFromDVCS &other);
0070
0071 virtual void initModule();
0072 virtual void isModuleWellConfigured();
0073
0074 virtual std::complex<double> computeUnpolarized();
0075 virtual std::complex<double> computePolarized();
0076
0077 private:
0078
0079
0080
0081
0082 DVCSConvolCoeffFunctionModule* m_pDVCSConvolCoeffFunctionModule;
0083 };
0084
0085 }
0086
0087 #endif