8 #ifndef __SQPRIMARYVERTEXGEN_H__
9 #define __SQPRIMARYVERTEXGEN_H__
14 #include <TGeoManager.h>
61 static constexpr
double Z_MIN = -800.0;
62 static constexpr
double Z_MAX = 503.0;
95 void FindMaterialBoundaries(
const double xpos,
const double ypos,
const double z_min,
const double z_max,
int& n_b,
double* z_b);
98 void FindMaterialRange(
double& z1,
double& z2,
const std::string name,
const double xpos=0,
const double ypos=0);
111 TGeoManager* geoManager;
130 std::string material_mode;
Class to hold the profile of materials at a (x, y) beam position.
int findInteractingPiece(double rndm)
double accumulatedProbs[100]
std::vector< SQBeamlineObject > interactables
Class to generate the event vertex, based on the beam profile and the target+spectrometer materials g...
double getLuminosity()
get the relative luminosity on this target
int InitRun(TString filename)
double getPARatio()
get the proton/neutron ratio of the piece, must be called after generateVertex
void generateVtxPerp(double &x, double &y)
use the beam profile to generate vertex in X-Y plane
void fillMaterialProfile(MaterialProfile *prof, double xvtx, double yvtx)
fill material profile using initial x/y position
static double funcBeamProfile(double *val, double *par)
beam profile function
TVector3 generateVertex()
generate 3-D vertex position
int InitRun(PHCompositeNode *node)
Initialize at the begining of Run.