9 #include <reconstruction/modules/CDCDedxPID/CDCDedxScanModule.h> 
   10 #include <reconstruction/modules/CDCDedxPID/LineHelper.h> 
   12 #include <reconstruction/dataobjects/CDCDedxTrack.h> 
   13 #include <reconstruction/dataobjects/DedxConstants.h> 
   15 #include <cdc/geometry/CDCGeometryPar.h> 
   16 #include <vxd/geometry/GeoCache.h> 
   18 #include <genfit/MaterialEffects.h> 
   20 #include <boost/shared_ptr.hpp> 
   21 #include <boost/make_shared.hpp> 
   36   setDescription(
"Extract dE/dx and corresponding log-likelihood from fitted tracks and hits in the CDC, SVD and PXD.");
 
   51   if (!genfit::MaterialEffects::getInstance()->isInitialized()) {
 
   52     B2FATAL(
"Need to have  SetupGenfitExtrapolationModule in path before this one");
 
   70   boost::shared_ptr<CDCDedxTrack> dedxTrack = boost::make_shared<CDCDedxTrack>();
 
   72   for (
int i = 0; i < 56; ++i) {
 
   78     const TVector3 wireDir = (wirePosB - wirePosF).
Unit();
 
   84     double cellHeight = outer - inner;
 
   85     double topHeight = outer - wirePosF.Perp();
 
   86     double bottomHeight = wirePosF.Perp() - inner;
 
   87     double topHalfWidth = M_PI * outer / nWires;
 
   88     double bottomHalfWidth = M_PI * inner / nWires;
 
   89     double cellHalfWidth = M_PI * wirePosF.Perp() / nWires;
 
   98     for (
int j = 0; j < 100; ++j) {
 
   99       for (
int k = 0; k < 100; ++k) {
 
  100         double doca = j * cellHalfWidth / 50.0 - cellHalfWidth;
 
  101         double entAng = k * M_PI / 100.0 - M_PI_2;
 
  104         double cellR = 2 * cellHalfWidth / cellHeight;
 
  106         if (std::abs(2 * 
atan(1) - std::abs(entAng)) < 0.01)tana = 100 * (entAng / std::abs(entAng)); 
 
  108         double docaRS = doca * 
std::sqrt((1 + cellR * cellR * tana * tana) / (1 + tana * tana));
 
  109         double entAngRS = 
std::atan(tana / cellR);
 
  112         double celldx = c.dx(doca, entAng);
 
  113         if (!c.isValid()) 
continue;
 
  115         dedxTrack->addHit(0, 0, i, doca, docaRS, entAng, entAngRS, 0, 0, 0.0, celldx, 0.0, cellHeight, cellHalfWidth, 0, 0.0, 0.0, 1.0, 1.0,
 
  116                           1.0, 0, 0.0, 0.0, 0.0);
 
  126   B2INFO(
"CDCDedxScanModule exiting");
 
virtual void initialize() override
Initialize the module.
virtual void event() override
This method is called for each event.
CDCDedxScanModule()
Default constructor.
StoreArray< CDCDedxTrack > m_dedxArray
array of output dE/dx tracks
virtual void terminate() override
End of the event processing.
virtual ~CDCDedxScanModule()
Destructor.
The Class for CDC Geometry Parameters.
const B2Vector3D wireForwardPosition(uint layerId, int cellId, EWirePosition set=c_Base) const
Returns the forward position of the input sense wire.
const B2Vector3D wireBackwardPosition(uint layerId, int cellId, EWirePosition set=c_Base) const
Returns the backward position of the input sense wire.
unsigned nWiresInLayer(int layerId) const
Returns wire numbers in a layer.
const double * innerRadiusWireLayer() const
Returns an array of inner radius of wire layers.
static CDCGeometryPar & Instance(const CDCGeometry *=nullptr)
Static method to get a reference to the CDCGeometryPar instance.
const double * outerRadiusWireLayer() const
Returns an array of outer radius of wire layers.
A class to hold the geometry of a cell.
A collection of classes that are useful for making a simple path length correction to the dE/dx measu...
void setDescription(const std::string &description)
Sets the description of the module.
static GeoCache & getInstance()
Return a reference to the singleton instance.
REG_MODULE(arichBtest)
Register the Module.
double sqrt(double a)
sqrt for double
double atan(double a)
atan for double
double tan(double a)
tan for double
Abstract base class for different kinds of events.