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

#include <ConfigClasses.h>

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

Public Member Functions

 ExperimentConfig ()
 default constructor creates an empty config More...
 
 ExperimentConfig (const ExperimentConfig &a_config)
 copy constructor to ensure local map rebuild More...
 
ExperimentConfigoperator= (const ExperimentConfig &a_rhs)
 
void addOrgScints (std::vector< OrgScintInfo > a_orgScints)
 
void addInorgScints (std::vector< InorgScintInfo > a_inorgScints)
 
void addHPGEs (std::vector< HPGeInfo > a_HPGEs)
 
void addClovers (std::vector< CloverInfo > a_clovers)
 
void addOrgScint (OrgScintInfo a_orgScint)
 
void addMultiPMTOrgScint (MultiPMTOrgScintInfo a_orgScint)
 
void addInorgScint (InorgScintInfo a_inorgScint)
 
void addHPGE (HPGeInfo a_HPGE)
 
void addClover (CloverInfo a_clover)
 
void addDetLengths (std::map< DetType, double > a_lengthMap)
 
void addSourceInfo (std::string a_id, PointSourceInfo a_source)
 
void setRFOffset (DetectorCalib *a_offset)
 
void setRFCalibID (int a_ID)
 
void setRFPeriod (double a_RFPeriod)
 
void setTDCRes (double a_TDCRes)
 
void setRFFilter (bool a_doFilter)
 
void setRFSubPeriod (uint16_t a_triggerPeriod)
 
void translateCoordinates (double a_x, double a_y, double a_z)
 
bool isKnown (int a_modID, int a_ch) const
 returns true if the channel mod pair is known to the config More...
 
bool isKnownModule (int a_modID) const
 
const DetectorElementInfogetDetElInfo (int a_modID, int a_ch) const
 gets the detector element info given a modID and a channel More...
 
std::ostream & printLayout (std::ostream &a_stream) const
 prints the internal state of the class More...
 
DetType getDetType (int a_modID, int a_ch) const
 
int getDetID (int a_modID, int a_ch) const
 
const CloverInfogetCloverInfo (int a_modID, int a_ch) const
 
const CloverInfogetCloverInfo (int a_clovID) const
 
const std::vector< CloverInfo > & getCloverInfos () const
 
const OrgScintInfogetOrgScintInfo (int a_modID, int a_ch) const
 
const OrgScintInfogetOrgScintInfo (int a_orgScintID) const
 
const MultiPMTOrgScintInfogetMultiPMTOrgScintInfo (int a_modID, int a_ch) const
 
const MultiPMTOrgScintInfogetMultiPMTOrgScintInfo (int a_orgScintID) const
 
const InorgScintInfo getInorgScintInfo (int a_modID, int a_ch) const
 
const InorgScintInfo getInorgScintInfo (int a_inorgScintID) const
 
const HPGeInfo getHPGeInfo (int a_modID, int a_ch) const
 
const HPGeInfo getHPGeInfo (int a_hpgeID) const
 
std::vector< int > getDetIDList (DetType a_detType) const
 
double getRFOffset () const
 
double getRFCalibID () const
 
double getRFPeriod () const
 
double getTDCRes () const
 
bool getRFFilter () const
 
uint16_t getRFSubPeriod () const
 
double getRFModuleID ()
 
std::map< DetType, double > getDetectorLengths () const
 
void setTime (uint32_t a_t)
 
double detDistToOrig (DetType a_detType, int a_detID, int a_elementID=0) const
 
bool canDoTiming () const
 
bool canDoGainConversion () const
 
int getNumModules ()
 
void clearDet (DetType a_type)
 
virtual ~ExperimentConfig ()
 

Protected Member Functions

void rebuildMap ()
 

Protected Attributes

std::vector< OrgScintInfom_orgScints
 
std::vector< MultiPMTOrgScintInfom_PMTOrgScints
 
std::vector< InorgScintInfom_inorgScints
 
std::vector< HPGeInfom_HPGEs
 
std::vector< CloverInfom_clovers
 
std::map< std::string, PointSourceInfom_sourceInfo
 
std::map< int, std::map< int, std::pair< DetType, int > > > m_modChMap
 
std::map< DetType, double > m_detectorLengths
 lengths of the detectors for TOF calculation More...
 
DetectorCalibm_RFOffset
 RF offset to an EJ-309 detector [ns]. More...
 
int m_RFCalibDetID
 detector ID of RF offset More...
 
double m_RFPeriod
 
double m_TDCRes
 
bool m_rfFilter
 
uint16_t m_rfSubPeriod
 
OrgScintInfo m_defOrgScintInfo
 BCM data [uAmps]. More...
 
MultiPMTOrgScintInfo m_defMultiPMTOrgScintInfo
 
InorgScintInfo m_defInorgScintInfo
 
HPGeInfo m_defHPGeInfo
 
CloverInfo m_defCloverInfo
 
DetectorElementInfo m_defDetElementInfo
 

Detailed Description

this class is inteded to be a base class for the configuration information needed for analysis of multidetector nuclear experiments

Constructor & Destructor Documentation

◆ ExperimentConfig() [1/2]

ExperimentConfig::ExperimentConfig ( )

default constructor creates an empty config

◆ ExperimentConfig() [2/2]

ExperimentConfig::ExperimentConfig ( const ExperimentConfig a_config)

copy constructor to ensure local map rebuild

Here is the call graph for this function:

◆ ~ExperimentConfig()

ExperimentConfig::~ExperimentConfig ( )
virtual

Member Function Documentation

◆ addClover()

void ExperimentConfig::addClover ( CloverInfo  a_clover)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ addClovers()

void ExperimentConfig::addClovers ( std::vector< CloverInfo a_clovers)
Here is the call graph for this function:

◆ addDetLengths()

void ExperimentConfig::addDetLengths ( std::map< DetType, double >  a_lengthMap)
Here is the caller graph for this function:

◆ addHPGE()

void ExperimentConfig::addHPGE ( HPGeInfo  a_HPGE)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ addHPGEs()

void ExperimentConfig::addHPGEs ( std::vector< HPGeInfo a_HPGEs)
Here is the call graph for this function:

◆ addInorgScint()

void ExperimentConfig::addInorgScint ( InorgScintInfo  a_inorgScint)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ addInorgScints()

void ExperimentConfig::addInorgScints ( std::vector< InorgScintInfo a_inorgScints)
Here is the call graph for this function:

◆ addMultiPMTOrgScint()

void ExperimentConfig::addMultiPMTOrgScint ( MultiPMTOrgScintInfo  a_orgScint)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ addOrgScint()

void ExperimentConfig::addOrgScint ( OrgScintInfo  a_orgScint)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ addOrgScints()

void ExperimentConfig::addOrgScints ( std::vector< OrgScintInfo a_orgScints)
Here is the call graph for this function:

◆ addSourceInfo()

void ExperimentConfig::addSourceInfo ( std::string  a_id,
PointSourceInfo  a_source 
)
Here is the caller graph for this function:

◆ canDoGainConversion()

bool ExperimentConfig::canDoGainConversion ( ) const

this function tests if the experiment config to see if gain calibrations are present for all detectors present

◆ canDoTiming()

bool ExperimentConfig::canDoTiming ( ) const

this function tests the experiment config to see if it can produce timing calibrations for all detectors present

◆ clearDet()

void ExperimentConfig::clearDet ( DetType  a_type)

this function clears the vector corresponding to a given detector type useful in monte carlo construction of new configurations files

Here is the caller graph for this function:

◆ detDistToOrig()

double ExperimentConfig::detDistToOrig ( DetType  a_detType,
int  a_detID,
int  a_elementID = 0 
) const

this function uses the detector information to calculate the position of the detector with respect to the origin of the co-ordinate system being used for the experiment set a_elementID to Leaf ID for clovers

Here is the caller graph for this function:

◆ getCloverInfo() [1/2]

const CloverInfo & ExperimentConfig::getCloverInfo ( int  a_clovID) const

◆ getCloverInfo() [2/2]

const CloverInfo & ExperimentConfig::getCloverInfo ( int  a_modID,
int  a_ch 
) const
Here is the caller graph for this function:

◆ getCloverInfos()

const std::vector< CloverInfo > & ExperimentConfig::getCloverInfos ( ) const
Here is the caller graph for this function:

◆ getDetectorLengths()

std::map< DetType, double > ExperimentConfig::getDetectorLengths ( ) const

◆ getDetElInfo()

const DetectorElementInfo & ExperimentConfig::getDetElInfo ( int  a_modID,
int  a_ch 
) const

gets the detector element info given a modID and a channel

Here is the call graph for this function:

◆ getDetID()

int ExperimentConfig::getDetID ( int  a_modID,
int  a_ch 
) const
Here is the caller graph for this function:

◆ getDetIDList()

std::vector< int > ExperimentConfig::getDetIDList ( DetType  a_detType) const
Here is the caller graph for this function:

◆ getDetType()

DetType ExperimentConfig::getDetType ( int  a_modID,
int  a_ch 
) const
Here is the caller graph for this function:

◆ getHPGeInfo() [1/2]

const HPGeInfo ExperimentConfig::getHPGeInfo ( int  a_hpgeID) const

◆ getHPGeInfo() [2/2]

const HPGeInfo ExperimentConfig::getHPGeInfo ( int  a_modID,
int  a_ch 
) const
Here is the caller graph for this function:

◆ getInorgScintInfo() [1/2]

const InorgScintInfo ExperimentConfig::getInorgScintInfo ( int  a_inorgScintID) const

◆ getInorgScintInfo() [2/2]

const InorgScintInfo ExperimentConfig::getInorgScintInfo ( int  a_modID,
int  a_ch 
) const
Here is the caller graph for this function:

◆ getMultiPMTOrgScintInfo() [1/2]

const MultiPMTOrgScintInfo & ExperimentConfig::getMultiPMTOrgScintInfo ( int  a_modID,
int  a_ch 
) const

◆ getMultiPMTOrgScintInfo() [2/2]

const MultiPMTOrgScintInfo & ExperimentConfig::getMultiPMTOrgScintInfo ( int  a_orgScintID) const

◆ getNumModules()

int ExperimentConfig::getNumModules ( )

this function returns the number of modules present in the config which can be used for testing section in loop back trigger mode

◆ getOrgScintInfo() [1/2]

const OrgScintInfo & ExperimentConfig::getOrgScintInfo ( int  a_modID,
int  a_ch 
) const
Here is the caller graph for this function:

◆ getOrgScintInfo() [2/2]

const OrgScintInfo & ExperimentConfig::getOrgScintInfo ( int  a_orgScintID) const

◆ getRFCalibID()

double ExperimentConfig::getRFCalibID ( ) const
Here is the caller graph for this function:

◆ getRFFilter()

bool ExperimentConfig::getRFFilter ( ) const
Here is the caller graph for this function:

◆ getRFModuleID()

double ExperimentConfig::getRFModuleID ( )

!!!!!this currently assumes that the detector being used to calibrate !!!!against the rf is a

Here is the caller graph for this function:

◆ getRFOffset()

double ExperimentConfig::getRFOffset ( ) const
Here is the call graph for this function:
Here is the caller graph for this function:

◆ getRFPeriod()

double ExperimentConfig::getRFPeriod ( ) const
Here is the caller graph for this function:

◆ getRFSubPeriod()

uint16_t ExperimentConfig::getRFSubPeriod ( ) const
Here is the caller graph for this function:

◆ getTDCRes()

double ExperimentConfig::getTDCRes ( ) const
Here is the caller graph for this function:

◆ isKnown()

bool ExperimentConfig::isKnown ( int  a_modID,
int  a_ch 
) const

returns true if the channel mod pair is known to the config

Here is the caller graph for this function:

◆ isKnownModule()

bool ExperimentConfig::isKnownModule ( int  a_modID) const
Here is the caller graph for this function:

◆ operator=()

ExperimentConfig & ExperimentConfig::operator= ( const ExperimentConfig a_rhs)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ printLayout()

std::ostream & ExperimentConfig::printLayout ( std::ostream &  a_stream) const

prints the internal state of the class

Here is the call graph for this function:
Here is the caller graph for this function:

◆ rebuildMap()

void ExperimentConfig::rebuildMap ( )
protected
Here is the caller graph for this function:

◆ setRFCalibID()

void ExperimentConfig::setRFCalibID ( int  a_ID)
Here is the caller graph for this function:

◆ setRFFilter()

void ExperimentConfig::setRFFilter ( bool  a_doFilter)
Here is the caller graph for this function:

◆ setRFOffset()

void ExperimentConfig::setRFOffset ( DetectorCalib a_offset)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ setRFPeriod()

void ExperimentConfig::setRFPeriod ( double  a_RFPeriod)
Here is the caller graph for this function:

◆ setRFSubPeriod()

void ExperimentConfig::setRFSubPeriod ( uint16_t  a_triggerPeriod)
Here is the caller graph for this function:

◆ setTDCRes()

void ExperimentConfig::setTDCRes ( double  a_TDCRes)

◆ setTime()

void ExperimentConfig::setTime ( uint32_t  a_t)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ translateCoordinates()

void ExperimentConfig::translateCoordinates ( double  a_x,
double  a_y,
double  a_z 
)

this function translates the coordinate system off all detectors stored in the config

Here is the caller graph for this function:

Member Data Documentation

◆ m_clovers

std::vector<CloverInfo> ExperimentConfig::m_clovers
protected

◆ m_defCloverInfo

CloverInfo ExperimentConfig::m_defCloverInfo
protected

◆ m_defDetElementInfo

DetectorElementInfo ExperimentConfig::m_defDetElementInfo
protected

◆ m_defHPGeInfo

HPGeInfo ExperimentConfig::m_defHPGeInfo
protected

◆ m_defInorgScintInfo

InorgScintInfo ExperimentConfig::m_defInorgScintInfo
protected

◆ m_defMultiPMTOrgScintInfo

MultiPMTOrgScintInfo ExperimentConfig::m_defMultiPMTOrgScintInfo
protected

◆ m_defOrgScintInfo

OrgScintInfo ExperimentConfig::m_defOrgScintInfo
protected

BCM data [uAmps].

◆ m_detectorLengths

std::map<DetType, double> ExperimentConfig::m_detectorLengths
protected

lengths of the detectors for TOF calculation

◆ m_HPGEs

std::vector<HPGeInfo> ExperimentConfig::m_HPGEs
protected

◆ m_inorgScints

std::vector<InorgScintInfo> ExperimentConfig::m_inorgScints
protected

◆ m_modChMap

std::map<int , std::map<int, std::pair< DetType, int > > > ExperimentConfig::m_modChMap
protected

internal map for quickly referencing element info within the class gets rebuilt any time a detector element is added access is m_modChMap[modID][ch];

◆ m_orgScints

std::vector<OrgScintInfo> ExperimentConfig::m_orgScints
protected

◆ m_PMTOrgScints

std::vector<MultiPMTOrgScintInfo> ExperimentConfig::m_PMTOrgScints
protected

◆ m_RFCalibDetID

int ExperimentConfig::m_RFCalibDetID
protected

detector ID of RF offset

◆ m_rfFilter

bool ExperimentConfig::m_rfFilter
protected

◆ m_RFOffset

DetectorCalib* ExperimentConfig::m_RFOffset
protected

RF offset to an EJ-309 detector [ns].

◆ m_RFPeriod

double ExperimentConfig::m_RFPeriod
protected

◆ m_rfSubPeriod

uint16_t ExperimentConfig::m_rfSubPeriod
protected

◆ m_sourceInfo

std::map<std::string , PointSourceInfo> ExperimentConfig::m_sourceInfo
protected

◆ m_TDCRes

double ExperimentConfig::m_TDCRes
protected

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