Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2026-06-02 08:51:46

0001 #ifndef DVCSCROSSSECTIONUUDVCSSUBPROC_H
0002 #define DVCSCROSSSECTIONUUDVCSSUBPROC_H
0003 
0004 /**
0005  * @file DVCSCrossSectionUUDVCSSubProc.h
0006  * @author Pawel Sznajder (IPNO)
0007  * @date November 25, 2016
0008  * @version 1.0
0009  */
0010 
0011 #include <string>
0012 
0013 #include "../../../../beans/gpd/GPDType.h"
0014 #include "../../../../beans/List.h"
0015 #include "../../../../utils/type/PhysicalType.h"
0016 #include "../DVCSObservable.h"
0017 
0018 namespace PARTONS {
0019 
0020 /**
0021  * @class DVCSCrossSectionUUDVCSSubProc
0022  * @brief Unpolarized cross-section for DVCS only.
0023  *
0024  * Unit: \f$\mathrm{nbarn}/\mathrm{GeV}^4\f$.
0025  */
0026 class DVCSCrossSectionUUDVCSSubProc: public DVCSObservable {
0027 
0028 public:
0029 
0030     /**
0031      * Unique ID to automatically register the class in the registry.
0032      */
0033     static const unsigned int classId;
0034 
0035     /**
0036      * Constructor.
0037      * @param className Name of class.
0038      */
0039     DVCSCrossSectionUUDVCSSubProc(const std::string &className);
0040 
0041     /**
0042      * Destructor.
0043      */
0044     virtual ~DVCSCrossSectionUUDVCSSubProc();
0045 
0046     virtual DVCSCrossSectionUUDVCSSubProc* clone() const;
0047 
0048 protected:
0049 
0050     /**
0051      * Copy constructor.
0052      * @param other Object to be copied.
0053      */
0054     DVCSCrossSectionUUDVCSSubProc(const DVCSCrossSectionUUDVCSSubProc &other);
0055 
0056     virtual PhysicalType<double> computeObservable(
0057             const DVCSObservableKinematic& kinematic,
0058             const List<GPDType>& gpdType);
0059 };
0060 
0061 } /* namespace PARTONS */
0062 
0063 #endif /* DVCSCROSSSECTIONUUDVCSSUBPROC_H */