Berkeley Nuclear Data Software
Public Member Functions | Protected Member Functions | List of all members
GenesisPhysEventAna Class Reference

#include <GenesisPhysEventAna.h>

Inheritance diagram for GenesisPhysEventAna:
Inheritance graph
[legend]
Collaboration diagram for GenesisPhysEventAna:
Collaboration graph
[legend]

Public Member Functions

 GenesisPhysEventAna ()
 
vector< TH1 * > getCloverGammaSpectra ()
 
vector< TH2 * > getNeutronAngularDist ()
 returns neutron angular distribution vs. LY, E_n from TOF, E_g More...
 
vector< TH2 * > getNeutronAngularDist (double a_gammaEnergy, double a_width=2)
 
vector< TH2 * > getNeutronEnergyVsTimeSinceRF (double a_gammaEnergy, double a_width)
 
vector< TH2 * > getLightVsTimeSinceRF (double a_gammaEnergy, double a_width)
 
vector< TH2 * > getNeutronTOFvsInorgGammaEnergy (string a_configFile, double a_enThreshold=.2)
 
void getScintScintPlots (std::string a_fileName="scintScint_Fe56_eDepVsTof.root", double a_EgamCut=.2)
 
void buildOutEnOutEdep (std::string a_fileName="outEnOutEdep_hists.root", double a_gammaEnergy=-1)
 
void scintScintCoinAna (std::string a_configFileName, std::string a_outFileName="scintScintCoins_hists.root")
 
void scintHPGeCoinAna (std::string a_configFileName, std::string a_outFileName="scintHPGeCoins_hists.root")
 
void makeGammaNeutronAnglePlots (string a_configFile)
 
- Public Member Functions inherited from PostProcBase< GenesisCalibratedEvent >
 PostProcBase ()
 defualt constructor puts class into a working state More...
 
virtual int addFile (string a_filename)
 
virtual int addFilesFromDirectory (string a_dir, string a_ext)
 
virtual int loadEvent (int a_eventNumber)
 loads a specified event into memory More...
 
virtual int fileNotLoaded ()
 tests if a file is loaded and prinst a message if not More...
 
virtual int clearFileState ()
 
virtual std::ostream & printState (std::ostream &a_stream=std::cout)
 
virtual ~PostProcBase ()
 
TChain * getTrees ()
 danger danger, use this if you know what you are doing. More...
 

Protected Member Functions

void setTreeName ()
 enforces that a tree name function can be set in a child class More...
 
void setBranchName ()
 enforces that a branch name function can be set in a child class More...
 

Additional Inherited Members

- Protected Attributes inherited from PostProcBase< GenesisCalibratedEvent >
TChain * m_trees
 for associating the trees from files More...
 
string m_treeName
 for storing the name of the tree More...
 
string m_branchName
 for storing the name of the branch More...
 
GenesisCalibratedEventm_currentEvent
 for storing the current event More...
 
vector< string > m_loadedFiles
 for storing a list of loaded files More...
 
bool m_hasFile
 flag for wheter a file has been loaded More...
 

Detailed Description

this class in intended to provide the accumulation of physics events stored in the GenesisCalibratedEvent class into histograms or graphs for further analysis. It inherits from PostProcBase to handle file and memory management of the TTree the event is stored in

Constructor & Destructor Documentation

◆ GenesisPhysEventAna()

GenesisPhysEventAna::GenesisPhysEventAna ( )

Member Function Documentation

◆ buildOutEnOutEdep()

void GenesisPhysEventAna::buildOutEnOutEdep ( std::string  a_fileName = "outEnOutEdep_hists.root",
double  a_gammaEnergy = -1 
)
Here is the call graph for this function:

◆ getCloverGammaSpectra()

vector< TH1 * > GenesisPhysEventAna::getCloverGammaSpectra ( )
Here is the call graph for this function:

◆ getLightVsTimeSinceRF()

vector< TH2 * > GenesisPhysEventAna::getLightVsTimeSinceRF ( double  a_gammaEnergy,
double  a_width 
)
Here is the call graph for this function:

◆ getNeutronAngularDist() [1/2]

vector< TH2 * > GenesisPhysEventAna::getNeutronAngularDist ( )

returns neutron angular distribution vs. LY, E_n from TOF, E_g

Here is the call graph for this function:

◆ getNeutronAngularDist() [2/2]

vector< TH2 * > GenesisPhysEventAna::getNeutronAngularDist ( double  a_gammaEnergy,
double  a_width = 2 
)

return neutron angular dist gated on gamma ray of specified energy [keV] 2D angle vs LY and E_n from NTOF takes events with energy = a_gammaEnergy +/- a_width

Here is the call graph for this function:

◆ getNeutronEnergyVsTimeSinceRF()

vector< TH2 * > GenesisPhysEventAna::getNeutronEnergyVsTimeSinceRF ( double  a_gammaEnergy,
double  a_width 
)

secondary neutron energy vs. time since RF in coincidence with a gamma ray of certain energy (+/- width) [keV] hard coded to look at orgScint detID<16

Here is the call graph for this function:

◆ getNeutronTOFvsInorgGammaEnergy()

vector< TH2 * > GenesisPhysEventAna::getNeutronTOFvsInorgGammaEnergy ( string  a_configFile,
double  a_enThreshold = .2 
)

returns 2D histogram of neutron energy vs gamma energy for inorg scint gammas hard-coded to look at orgScint ID<16, uses same energy threshold for all orgScints

hard coded to only look at DetID's [0,15]

require neutron/inorgScint coincidence

using same energy threshold for all detectors

Here is the call graph for this function:

◆ getScintScintPlots()

void GenesisPhysEventAna::getScintScintPlots ( std::string  a_fileName = "scintScint_Fe56_eDepVsTof.root",
double  a_EgamCut = .2 
)

looks for events with 2 OrgScint events looks for gamma and neutron in that event a_EgamCut is cut on light in "gamma" detector saves file with: plots of time-since-last-rf (using detected gamma time) vs. eDep plot of time-since-last-rf vs En (from TOF with gamma as start time) above plots are made for each neutron detector plot of detector angle vs. En (from TOF) plot of gamma detector ID vs. neutron detector ID

Here is the call graph for this function:

◆ makeGammaNeutronAnglePlots()

void GenesisPhysEventAna::makeGammaNeutronAnglePlots ( string  a_configFile)
Here is the call graph for this function:

◆ scintHPGeCoinAna()

void GenesisPhysEventAna::scintHPGeCoinAna ( std::string  a_configFileName,
std::string  a_outFileName = "scintHPGeCoins_hists.root" 
)

Eventually make these getters & setters or a config file or something

Right now, GenCalibratedEvent is only handling events with one clover detect

Here is the call graph for this function:

◆ scintScintCoinAna()

void GenesisPhysEventAna::scintScintCoinAna ( std::string  a_configFileName,
std::string  a_outFileName = "scintScintCoins_hists.root" 
)

WIP /// This operates on calibratedEventTree files Builds n/g coincidences in the scintillators, making cuts on:

  • Gamma must arrive before neutron (positive scattered TOF)
  • Min & max scattered TOF (based on min and max scattered energy for your experiment, calculated using detector distances)
  • Min & max incident TOF (based on min and max incident energy for your experiment)
  • The first hit in the conicidence – the gamma – is determined from PSD, and then the second hit – the neutron – is determined from PSD if it's above the threshold for good PSD; otherwise, for lower energies, by its TOF so that you can probe to lower energies
  • Will be added: Energy deposited in the target, to within some uncertainty (only your target's specific energy states will make sense)
  • Will be added: Incident & scattered energies for a coincidence must make sense (total is greater than max energy, makes sense for target threshold energy) The following histograms are created and stored in a file you specify as an argument, for events that pass all these cuts (unless otherwise indicated):
  • Scattered neutron TOF (1D) (filled if scatter TOF is logical)
  • Neutron light yield (1D) (filled if scatter TOF is logical)
  • Scattered neutron energy from TOF
  • Time since RF for the neutron
  • Incident energy from TOF
  • Energy deposited in the target (from incident & scattered energies, from TOFs)
  • Incident neutron energy from TOF, per selected excited state (with some uncertainty bounds)

Eventually make these getters & setters or a config file or something

Here is the call graph for this function:

◆ setBranchName()

void GenesisPhysEventAna::setBranchName ( )
protectedvirtual

enforces that a branch name function can be set in a child class

Implements PostProcBase< GenesisCalibratedEvent >.

◆ setTreeName()

void GenesisPhysEventAna::setTreeName ( )
protectedvirtual

enforces that a tree name function can be set in a child class

Implements PostProcBase< GenesisCalibratedEvent >.


The documentation for this class was generated from the following files: