PARTONS
|
PARtonic Tomography Of Nucleon Software
|
Class used to compute CFF for photoproduction of diphoton Used formulas are presented in https://arxiv.org/pdf/2108.03426.pdf (called the NLO paper), in some cases we refer also to: https://arxiv.org/pdf/2108.03426.pdf (OG's MSc thesis) More...
Public Member Functions | |
GAM2CFFStandard (const std::string &className) | |
Constructor. More... | |
virtual GAM2CFFStandard * | clone () const |
Virtual clone function to allow the factory to clone all derived members object stored in the BaseObjectRegistry. More... | |
virtual | ~GAM2CFFStandard () |
Default destructor. More... | |
virtual void | resolveObjectDependencies () |
Because of the initialization step order of the program, objects are registered in a total random order and some objects depend on others. More... | |
void | prepareSubModules (const std::map< std::string, BaseObjectData > &subModulesData) |
Method used in automation to prepare all the modules used by this current module and configure them recursively. More... | |
RunningAlphaStrongModule * | getRunningAlphaStrongModule () const |
Get alphaS module. More... | |
void | setRunningAlphaStrongModule (RunningAlphaStrongModule *pRunningAlphaStrongModule) |
Set alphaS module. More... | |
void | setIEpsilon (double iEps) |
double | getIEpsilon () const |
void | setReIm (int reim) |
int | getReIm () const |
void | setPhiDep (bool phiDep) |
bool | getPhiDep () const |
double | Convol_NLO_V_x (double x, const std::vector< double > ¶ms) |
double | Convol_NLO_V_x_Sym (double x, const std::vector< double > ¶ms) |
double | Convol_NLO_V_x_Sym_Const (double x, const std::vector< double > ¶ms) |
double | Convol_NLO_V_xz (double x, double z, const std::vector< double > ¶ms) |
Public Member Functions inherited from PARTONS::GAM2ConvolCoeffFunctionModule | |
virtual | ~GAM2ConvolCoeffFunctionModule () |
Destructor. More... | |
virtual std::string | toString () const |
Return a pre-formatted characters string for output visualization of class member's values. More... | |
virtual void | run () |
virtual void | configure (const ElemUtils::Parameters ¶meters) |
Provides a generic method to configure all types of modules by passing a Parameters object. More... | |
virtual GAM2ConvolCoeffFunctionResult | compute (const GAM2ConvolCoeffFunctionKinematic &kinematic, const List< GPDType > &gpdType=List< GPDType >()) |
Computes the coefficient functions at given kinematics. More... | |
virtual List< GPDType > | getListOfAvailableGPDTypeForComputation () const |
Must be implemented in child class. More... | |
PerturbativeQCDOrderType::Type | getQCDOrderType () const |
Get order of the perturbative QCD computation. More... | |
void | setQCDOrderType (PerturbativeQCDOrderType::Type qcdOrderType) |
Set order of the perturbative QCD computation. More... | |
virtual std::complex< double > | computeCFF () |
Method to compute some CFFs. More... | |
Public Member Functions inherited from PARTONS::ConvolCoeffFunctionModule< GAM2ConvolCoeffFunctionKinematic, GAM2ConvolCoeffFunctionResult > | |
virtual | ~ConvolCoeffFunctionModule () |
Destructor. More... | |
GPDModule * | getGPDModule () const |
Get pointer to the underlying GPD module. More... | |
void | setGPDModule (GPDModule *gpdModule) |
Set pointer to the underlying GPD module. More... | |
bool | isGPDModuleDependent () const |
True if this CCF module depends on a GPD module. More... | |
void | setIsGPDModuleDependent (bool isGPDModuleDependent) |
True if this CCF module depends on a GPD module. More... | |
Public Member Functions inherited from PARTONS::ModuleObject | |
ModuleObject (const std::string &className, ChannelType::Type channelType) | |
Constructor. More... | |
virtual | ~ModuleObject () |
Default destructor. More... | |
unsigned int | getReferenceModuleId () const |
Get reference module id. More... | |
void | setReferenceModuleId (unsigned int referenceModuleId) |
Set reference module id. More... | |
ChannelType::Type | getChannelType () const |
Get channel type. More... | |
Public Member Functions inherited from PARTONS::BaseObject | |
BaseObject (const std::string &className) | |
Constructor. More... | |
virtual | ~BaseObject () |
Default destructor. More... | |
void | serialize (ElemUtils::Packet &packet) const |
Used to split a complex C++ object into a concatenation of simple types. More... | |
void | unserialize (ElemUtils::Packet &packet) |
Used to rebuild a complex C++ object from a concatenation of simple type. More... | |
bool | operator< (const BaseObject &other) const |
Overload of < operator to sort BaseObject object by its indexId value. More... | |
const std::string & | getClassName () const |
unsigned int | getObjectId () const |
int | getIndexId () const |
void | setIndexId (int indexId) |
Public Member Functions inherited from PARTONS::MathIntegratorModule | |
MathIntegratorModule () | |
Default constructor. More... | |
virtual | ~MathIntegratorModule () |
Default destructor. More... | |
Static Public Attributes | |
static const unsigned int | classId |
Unique ID to automatically register the class in the registry. More... | |
Static Public Attributes inherited from PARTONS::GAM2ConvolCoeffFunctionModule | |
static const std::string | GAM2_CONVOL_COEFF_FUNCTION_MODULE_CLASS_NAME |
Type of the module in XML automation. More... | |
Static Public Attributes inherited from PARTONS::ModuleObject | |
static const std::string | CLASS_NAME = "className" |
Static Public Attributes inherited from PARTONS::MathIntegratorModule | |
static const std::string | PARAM_NAME_INTEGRATOR_TYPE |
Parameter used in configureIntegrator() or XML automation to set the type of integrator. More... | |
Protected Member Functions | |
GAM2CFFStandard (const GAM2CFFStandard &other) | |
Copy constructor. More... | |
virtual void | initModule () |
Pure virtual function that provides skeleton for module initialization. More... | |
virtual void | isModuleWellConfigured () |
Pure virtual function that provides skeleton to check if the module is well initialized and configured. More... | |
virtual std::complex< double > | computeUnpolarized () |
Method to compute some CFFs. More... | |
virtual std::complex< double > | computePolarized () |
Method to compute some CFFs. More... | |
Protected Member Functions inherited from PARTONS::GAM2ConvolCoeffFunctionModule | |
GAM2ConvolCoeffFunctionModule (const std::string &className) | |
Default constructor. More... | |
GAM2ConvolCoeffFunctionModule (const GAM2ConvolCoeffFunctionModule &other) | |
Copy constructor. More... | |
virtual void | setKinematics (const GAM2ConvolCoeffFunctionKinematic &kinematic) |
Set internal kinematics. More... | |
Protected Member Functions inherited from PARTONS::ConvolCoeffFunctionModule< GAM2ConvolCoeffFunctionKinematic, GAM2ConvolCoeffFunctionResult > | |
ConvolCoeffFunctionModule (const std::string &className, ChannelType::Type channelType) | |
Constructor. More... | |
ConvolCoeffFunctionModule (const ConvolCoeffFunctionModule &other) | |
Copy constructor. More... | |
void | setCurrentGPDType (GPDType::Type gpdType) |
Set current GPD type to be computed. More... | |
Protected Member Functions inherited from PARTONS::ModuleObject | |
ModuleObject (const ModuleObject &other) | |
Protected Member Functions inherited from PARTONS::BaseObject | |
BaseObject (const BaseObject &other) | |
Copy constructor. More... | |
void | info (const std::string &functionName, const std::string &message) const |
Print info message into logger. More... | |
void | debug (const std::string &functionName, const std::string &message) const |
Print debug message into logger. More... | |
void | warn (const std::string &functionName, const std::string &message) const |
Print warning message into logger. More... | |
void | errorMissingParameter (const std::string ¶meterName) const |
Use in automation process to throw exception when a parameter is missing from the XML scenario file. More... | |
Protected Member Functions inherited from PARTONS::MathIntegratorModule | |
MathIntegratorModule (const MathIntegratorModule &other) | |
Copy constructor. More... | |
void | setIntegrator (NumA::IntegratorType1D::Type integratorType) |
Sets a given integrator available in NumA++. More... | |
double | integrate (NumA::FunctionType1D *pFunction, double a, double b, std::vector< double > ¶meters) |
Computes the integral of a function defined via a functor. More... | |
void | configureIntegrator (const ElemUtils::Parameters ¶meters) |
Provides a generic method to configure all types of integration routines by passing a Parameters object. More... | |
NumA::Integrator1D * | getMathIntegrator () |
Protected Attributes | |
double | m_CF |
( Nc^2 - 1 ) / ( 2 Nc ) (colour) More... | |
double | m_alphaSOver2Pi |
Protected Attributes inherited from PARTONS::ConvolCoeffFunctionModule< GAM2ConvolCoeffFunctionKinematic, GAM2ConvolCoeffFunctionResult > | |
double | m_xi |
Skewness. More... | |
double | m_t |
Mandelstam variable, momentum transfer on the hadron target (in GeV^2). More... | |
double | m_MuF2 |
Factorization scale (in GeV^2). More... | |
double | m_MuR2 |
Renormalization scale (in GeV^2) More... | |
GPDType::Type | m_currentGPDComputeType |
GPDType of the current CFF computation. More... | |
GPDModule * | m_pGPDModule |
Pointer to the underlying GPD module. More... | |
bool | m_isGPDModuleDependent |
Boolean (true if this CCF module depends on a GPD module). More... | |
Protected Attributes inherited from PARTONS::ModuleObject | |
ModuleObjectFactory * | m_pModuleObjectFactory |
Pointer tp module object factory. More... | |
Private Member Functions | |
double | gslIntegrationWrapper (NumA::FunctionType1D *functor, NumA::FunctionType1D *functorSym, NumA::FunctionType1D *functorSymConst, const std::vector< double > &range, const std::vector< double > ¶ms) |
double | computeCubedChargeAveragedGPD (const PartonDistribution &partonDistribution) |
void | computeDiagonalGPD_V () |
void | computeDiagonalGPD_A () |
void | initFunctorsForIntegrations () |
double | A (double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
std::complex< double > | M0 (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
std::complex< double > | M23LR (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
std::complex< double > | M3M (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
double | Tr_4L_F210 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_F201 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_F211 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_F220 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_F221 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_F100 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_F110 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_4L_G (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F201 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F210 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F211 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F220 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F221 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F100 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_F110 (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
double | Tr_5L_G (double xi, double s, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) const |
std::complex< double > | M4L (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
std::complex< double > | M5L (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
std::complex< double > | M4R (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
std::complex< double > | M5R (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek) |
std::complex< double > | M4L (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek, double z) |
std::complex< double > | M5L (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek, double z) |
std::complex< double > | M4R (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek, double z) |
std::complex< double > | M5R (double s, double x, double xi, const std::vector< double > &beta, const std::vector< double > &ee, const std::vector< double > &ek, double z) |
std::complex< double > | M_scale (double s, double x, double xi, std::vector< double > beta, std::vector< double > ee, std::vector< double > ek) |
std::complex< double > | Ccoll (double s, double x, double xi, std::vector< double > beta, std::vector< double > ee, std::vector< double > ek) |
double | NLO_V_permutation (double x, const std::vector< double > ¶ms) |
double | NLO_V_permutation (double x, double z, const std::vector< double > ¶ms) |
double | NLO_V (double x, const std::vector< double > ¶ms) |
double | NLO_V (double x, double z, const std::vector< double > ¶ms) |
std::complex< double > | F100 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | F110 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | F201 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | F210 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | F211 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | F220 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | F221 (double x, double xi, const std::vector< double > &beta, double s) |
std::complex< double > | G (double x, double xi, const std::vector< double > &beta, double z) |
double | sgn (double x) const |
Private Attributes | |
LiSK::LiSK< std::complex< double > > | m_lisk |
RunningAlphaStrongModule * | m_pRunningAlphaStrongModule |
Related alphaS module. More... | |
NumA::FunctionType1D * | m_pConvol_NLO_V_x |
NumA::FunctionType1D * | m_pConvol_NLO_V_x_Sym |
NumA::FunctionType1D * | m_pConvol_NLO_V_x_Sym_Const |
double | m_quark_diagonal_V |
double | m_quark_diagonal_A |
std::complex< double > | m_iepsilon |
int | m_reim |
bool | m_phiDep |
Class used to compute CFF for photoproduction of diphoton Used formulas are presented in https://arxiv.org/pdf/2108.03426.pdf (called the NLO paper), in some cases we refer also to: https://arxiv.org/pdf/2108.03426.pdf (OG's MSc thesis)
Available CFF types: H, E, Ht, Et.
PARTONS::GAM2CFFStandard::GAM2CFFStandard | ( | const std::string & | className | ) |
Constructor.
See BaseObject::BaseObject and ModuleObject::ModuleObject for more details.
className | Name of last child class. |
|
virtual |
Default destructor.
|
protected |
Copy constructor.
other |
|
private |
|
private |
|
virtual |
Virtual clone function to allow the factory to clone all derived members object stored in the BaseObjectRegistry.
Implements PARTONS::GAM2ConvolCoeffFunctionModule.
|
private |
|
private |
|
private |
|
protectedvirtual |
Method to compute some CFFs.
Can be implemented and used in child class, if needed.
Reimplemented from PARTONS::GAM2ConvolCoeffFunctionModule.
|
protectedvirtual |
Method to compute some CFFs.
Can be implemented and used in child class, if needed.
Reimplemented from PARTONS::GAM2ConvolCoeffFunctionModule.
double PARTONS::GAM2CFFStandard::Convol_NLO_V_x | ( | double | x, |
const std::vector< double > & | params | ||
) |
double PARTONS::GAM2CFFStandard::Convol_NLO_V_x_Sym | ( | double | x, |
const std::vector< double > & | params | ||
) |
double PARTONS::GAM2CFFStandard::Convol_NLO_V_x_Sym_Const | ( | double | x, |
const std::vector< double > & | params | ||
) |
double PARTONS::GAM2CFFStandard::Convol_NLO_V_xz | ( | double | x, |
double | z, | ||
const std::vector< double > & | params | ||
) |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
double PARTONS::GAM2CFFStandard::getIEpsilon | ( | ) | const |
bool PARTONS::GAM2CFFStandard::getPhiDep | ( | ) | const |
int PARTONS::GAM2CFFStandard::getReIm | ( | ) | const |
RunningAlphaStrongModule * PARTONS::GAM2CFFStandard::getRunningAlphaStrongModule | ( | ) | const |
Get alphaS module.
|
private |
|
private |
|
protectedvirtual |
Pure virtual function that provides skeleton for module initialization.
Children must define and override it.
Reimplemented from PARTONS::GAM2ConvolCoeffFunctionModule.
|
protectedvirtual |
Pure virtual function that provides skeleton to check if the module is well initialized and configured.
Children must define and override it.
Reimplemented from PARTONS::GAM2ConvolCoeffFunctionModule.
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
virtual |
Method used in automation to prepare all the modules used by this current module and configure them recursively.
The recursion is linked to the imbrication in XML files.
Can be implemented in the child class if it needs modules not needed by the parent class. But there must be first a call to the parent method.
subModulesData | Data used to retrieve the needed modules and their configuration. |
Reimplemented from PARTONS::GAM2ConvolCoeffFunctionModule.
|
virtual |
Because of the initialization step order of the program, objects are registered in a total random order and some objects depend on others.
To avoid the problem of pointer resolution order, this method is called by the BaseObjectRegistery after all objects are well registered in it. See BaseObjectRegistry class documentation for more details.
Reimplemented from PARTONS::GAM2ConvolCoeffFunctionModule.
void PARTONS::GAM2CFFStandard::setIEpsilon | ( | double | iEps | ) |
void PARTONS::GAM2CFFStandard::setPhiDep | ( | bool | phiDep | ) |
void PARTONS::GAM2CFFStandard::setReIm | ( | int | reim | ) |
void PARTONS::GAM2CFFStandard::setRunningAlphaStrongModule | ( | RunningAlphaStrongModule * | pRunningAlphaStrongModule | ) |
Set alphaS module.
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
static |
Unique ID to automatically register the class in the registry.
|
protected |
|
protected |
( Nc^2 - 1 ) / ( 2 Nc ) (colour)
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
Related alphaS module.
|
private |
|
private |
|
private |