9 #ifndef QWTRACKINGTREE_H
10 #define QWTRACKINGTREE_H
26 #include "boost/filesystem/operations.hpp"
27 #include "boost/filesystem/path.hpp"
28 namespace bfs = boost::filesystem;
94 const string& filename,
101 const string& filename,
108 const string& filename,
165 #endif // QWTRACKINGTREE_H
treenode * fFather
Father node: the main entry point to the tree.
int _readtree(FILE *file, shorttree *stb, shortnode **father, int32_t tlayers)
Recursive method to read the concise treesearch database from disk.
QwTrackingTreeRegion * inittree(const string &filename, int levels, int tlayer, double width, QwDetectorInfo *detector, bool regenerate)
A container for the pattern databases for each detector region.
int consistent(treenode *testnode, int level, QwDetectorInfo *detector)
Determines whether the pattern is geometrically possible.
unsigned int & fNumWires
Number of wires in a region 3 VDC group.
void PrintHashTable() const
Print the hash table.
int fNumPatterns
Number of valid patterns in the tree.
treenode * _inittree(int32_t tlayer, QwDetectorInfo *detector)
Recursive method to initialize and generate the treesearch database.
Definition of nodenode which links treenodes to their siblings.
void Print(const Option_t *options=0) const
Print the full tree and hash table.
unsigned int fHashSize
Length of the hash table (as member field)
QwTrackingTreeRegion * readtree(const string &filename, int levels, int tlayers, double rwidth, bool skipreading)
void SetDebugLevel(const int debuglevel)
Set the debug level.
void PrintTree() const
Print the full tree.
Creates and manages the treesearch pattern database.
Definition of a shortnode, the short version of a nodenode.
treenode * nodeexists(nodenode *nd, treenode *tr)
Definition of a treenode which contains the bits that make up a tree pattern.
double fMaxSlope
Maximum allowed slope for tracks in this detector.
void SetGeometry(const QwGeometry &geometry)
Definition of virtual base class for all tracking elements.
long writetree(const string &filename, treenode *tn, int levels, int tlayers, double width)
This function initializes the output file. It then calls the iterative _writetree function to fill th...
QwGeometry fGeometry
Detector (or set of detectors) represented by this search tree.
Collection of QwDetectorInfo pointers that specifies an experimental geometry.
virtual ~QwTrackingTree()
Destructor.
int _writetree(treenode *tn, FILE *fp, int32_t tlayers)
Recursive method for pulling in the concise treesearch search database.
static const std::string fgTreeDir
Name of the tree directory (in $QWSCRATCH), as static member field.
treenode * existent(treenode *node, int hash)
Search for a node in the search tree.
void marklin(treenode *father, int level, QwDetectorInfo *detector)
Recursively generate the treesearch pattern database.
unsigned int & fNumPlanes
Number of planes in the region 2 HDCs.
A nodenode is used as a pointer which links treenodes to their siblings.
A treenode contains the bits that make up a tree pattern.
int fMaxRef
Maximum number of references in the cached tree file.
unsigned int fNumLayers
Number of detector planes.
QwTrackingTree(unsigned int numlayers)
Default constructor.
Virtual base class for all tracking elements.
void SetMaxSlope(const double maxslope)
Set the maximum allowed slope.