#include <SmiScenarioTree.hpp>
Public Member Functions | |
Iterators | |
std::vector< T >::iterator | treeBegin () |
begin More... | |
std::vector< T >::iterator | treeEnd () |
end More... | |
std::vector< T > & | wholeTree () |
whole tree More... | |
std::vector< T >::iterator | scenBegin (int s) |
scenario iterators TODO: native code for these iterators that does not depend on copying. More... | |
std::vector< T >::iterator | scenEnd (int s) |
begin More... | |
Query members | |
SmiTreeNode< T > * | getRoot () |
Get root node. More... | |
SmiTreeNode< T > * | getLeaf (int scn) |
Get leaf node. More... | |
SmiTreeNode< T > * | find (unsigned int scenario, int stage) |
Get node identified by scenario/stage. More... | |
int | getNumScenarios () |
get number of scenarios More... | |
SmiTreeNode< T > * | find (std::vector< int > &label) |
Get node identified by longest match to array of labels. More... | |
SmiTreeNode< T > * | find (int *label, unsigned int sz) |
Get node identified by longest match to array of labels. More... | |
std::vector< T > & | getScenario (int scenario) |
Get vector of node data for given scenario. More... | |
Tree modification members | |
int | addPathtoLeaf (int brscenario, int stage, std::vector< T > &pathdata, unsigned int start=0) |
Add new path from branching node to leaf. More... | |
void | setChildLabels (SmiTreeNode< T > *n, std::vector< int > labels) |
Set child labels. More... | |
int | addPathtoLeaf (std::vector< int > &labels, std::vector< T > &pathdata) |
Add new path using labels to find branching node. More... | |
SmiTreeNode< T > * | addNodesToTree (SmiTreeNode< T > *parent, int scenario, std::vector< T > &pathdata, int start) |
Add new path from branching node to leaf. More... | |
Constructors, destructors and major modifying methods | |
SmiScenarioTree () | |
Default Constructor creates an empty scenario tree. More... | |
virtual | ~SmiScenarioTree () |
Destructor. More... | |
Private Attributes | |
std::vector< T > | node_data |
std::vector< T > | scen_data |
std::vector< SmiTreeNode< T > * > | leaf_ |
SmiTreeNode< T > * | root_ |
Definition at line 196 of file SmiScenarioTree.hpp.
|
inline |
Default Constructor creates an empty scenario tree.
Definition at line 393 of file SmiScenarioTree.hpp.
|
inlinevirtual |
Destructor.
Definition at line 399 of file SmiScenarioTree.hpp.
|
inline |
begin
Definition at line 206 of file SmiScenarioTree.hpp.
|
inline |
end
Definition at line 210 of file SmiScenarioTree.hpp.
|
inline |
whole tree
Definition at line 214 of file SmiScenarioTree.hpp.
|
inline |
scenario iterators TODO: native code for these iterators that does not depend on copying.
Definition at line 221 of file SmiScenarioTree.hpp.
|
inline |
begin
Definition at line 226 of file SmiScenarioTree.hpp.
|
inline |
Get root node.
Definition at line 236 of file SmiScenarioTree.hpp.
|
inline |
Get leaf node.
Definition at line 241 of file SmiScenarioTree.hpp.
|
inline |
Get node identified by scenario/stage.
Definition at line 246 of file SmiScenarioTree.hpp.
|
inline |
get number of scenarios
Definition at line 256 of file SmiScenarioTree.hpp.
|
inline |
Get node identified by longest match to array of labels.
Definition at line 261 of file SmiScenarioTree.hpp.
|
inline |
Get node identified by longest match to array of labels.
Definition at line 274 of file SmiScenarioTree.hpp.
|
inline |
Get vector of node data for given scenario.
Definition at line 289 of file SmiScenarioTree.hpp.
|
inline |
Add new path from branching node to leaf.
The branching node is the one belonging to "brscenario" at depth "stage". Length of incoming "pathdata" vector is leaf->depth() - stage. Responsibility for memory management of SmiTreeNodeData elements is assigned to SmiScenarioTree. SmiTreeNodeData elements must be created with "new" operator.
Definition at line 322 of file SmiScenarioTree.hpp.
|
inline |
Set child labels.
Definition at line 339 of file SmiScenarioTree.hpp.
|
inline |
Add new path using labels to find branching node.
The length of the incoming path is leaf.depth(). Responsibility for memory management of SmiTreeNodeData elements is assigned to SmiScenarioTree. SmiTreeNodeData elements must be created with "new" operator.
Definition at line 353 of file SmiScenarioTree.hpp.
|
inline |
Add new path from branching node to leaf.
The branching node is the one belonging to "brscenario" at depth "stage". Length of incoming "pathdata" vector is leaf->depth() - stage. Responsibility for memory management of SmiTreeNodeData elements is assigned to SmiScenarioTree. SmiTreeNodeData elements must be created with "new" operator.
Definition at line 372 of file SmiScenarioTree.hpp.
|
private |
Definition at line 405 of file SmiScenarioTree.hpp.
|
private |
Definition at line 406 of file SmiScenarioTree.hpp.
|
private |
Definition at line 407 of file SmiScenarioTree.hpp.
|
private |
Definition at line 408 of file SmiScenarioTree.hpp.