Public Member Functions | Static Public Member Functions | Public Attributes | Protected Member Functions | Friends | List of all members
AP_tree Class Reference

#include <AP_Tree.hxx>

Inheritance diagram for AP_tree:
Inheritance graph
Collaboration diagram for AP_tree:
Collaboration graph

Public Member Functions

 AP_tree (AP_tree_root *troot)
 DEFINE_TREE_ACCESSORS (AP_tree_root, AP_tree)
void compute_tree () FINAL_OVERRIDE
void recompute_and_write_folding ()
unsigned count_leafs () const
unsigned get_leaf_count () const OVERRIDE
void load_subtree_info ()
int colorize (GB_HASH *hashptr)
void uncolorize ()
virtual void insert (AP_tree *new_brother)
virtual void initial_insert (AP_tree *new_brother, AP_tree_root *troot)
virtual AP_treeREMOVE ()
void swap_sons () OVERRIDE
GB_ERROR cantMoveNextTo (AP_tree *new_brother)
virtual void moveNextTo (AP_tree *new_brother, AP_FLOAT rel_pos)
GB_ERROR tree_write_tree_rek (GBDATA *gb_tree)
int get_linewidth () const
void set_linewidth (int width)
void reset_linewidth ()
void set_linewidth_recursive (int width)
float get_angle () const
void set_angle (float angle)
void reset_angle ()
void buildLeafList (AP_tree **&list, long &num)
GB_ERROR move_group_to (AP_tree *new_group) __ATTR__USERESULT
bool is_folded_group () const
bool is_inside_folded_group () const
void mark_duplicates ()
const charmark_long_branches (double min_rel_diff, double min_abs_diff, double &found_max_abs_diff)
const charmark_deep_leafs (int min_depth, double min_rootdist, int &found_max_depth, double &found_max_rootdist)
double mark_degenerated_branches (double degeneration_factor)
const charanalyse_distances ()
void justify_branch_lenghs (GBDATA *gb_main)
void relink_tree (GBDATA *gb_main, void(*relinker)(GBDATA *&ref_gb_node, char *&ref_name, GB_HASH *organism_hash), GB_HASH *organism_hash)
void reset_subtree_spreads ()
void reset_subtree_angles ()
void reset_subtree_linewidths ()
void reset_subtree_layout ()
bool hasName (const char *Name) const
bool has_correct_mark_flags () const
ShadedValue update_subtree_information (const group_scaling &gscaling)
- Public Member Functions inherited from ARB_seqtree
 ARB_seqtree (ARB_seqtree_root *root)
 DEFINE_TREE_ACCESSORS (ARB_seqtree_root, ARB_seqtree)
void calcTreeInfo (ARB_tree_info &info)
bool is_upper_son () const
bool is_lower_son () const
AP_sequenceget_seq ()
const AP_sequenceget_seq () const
AP_sequenceset_seq (AP_sequence *sequence)
bool hasSequence () const
void mark_subtree ()
bool contains_marked_species ()
- Public Member Functions inherited from TreeNode
bool is_leaf () const
void markAsLeaf ()
 DEFINE_READ_ACCESSORS (TreeNode *, get_father, father)
 DEFINE_READ_ACCESSORS (TreeNode *, get_leftson, leftson)
 DEFINE_READ_ACCESSORS (TreeNode *, get_rightson, rightson)
bool is_son_of (const TreeNode *Father) const
bool is_leftson () const
bool is_rightson () const
bool is_inside (const TreeNode *subtree) const
bool is_ancestor_of (const TreeNode *descendant) const
bool in_same_branch_as (const TreeNode *other) const
bool in_other_branch_than (const TreeNode *other) const
const TreeNodeancestor_common_with (const TreeNode *other) const
TreeNodeancestor_common_with (TreeNode *other)
bool is_son_of_root () const
GBT_LEN get_branchlength () const
void set_branchlength (GBT_LEN newlen)
GBT_LEN get_branchlength_unrooted () const
void set_branchlength_unrooted (GBT_LEN newlen)
GBT_LEN sum_child_lengths () const
GBT_LEN root_distance () const
GBT_LEN intree_distance_to (const TreeNode *other) const
void remove_bootstrap ()
GB_ERROR apply_aci_to_remarks (const char *aci, const GBL_call_env &callEnv)
void reset_branchlengths ()
void scale_branchlengths (double factor)
void bootstrap2branchlen ()
void branchlen2bootstrap ()
GBT_RemarkType parse_bootstrap (double &bootstrap) const
const charget_remark () const
const SmartCharPtr & get_remark_ptr () const
bool is_inner_node_with_remark () const
void use_as_remark (const SmartCharPtr &newRemark)
void set_remark (const char *newRemark)
void set_bootstrap (double bootstrap)
void remove_remark ()
bool has_no_remark () const
bool has_valid_root_remarks () const
 TreeNode (TreeRoot *root)
TreeNodefixDeletedSon ()
void unlink_from_DB ()
void announce_tree_constructed ()
void forget_origin ()
void forget_relatives ()
TreeRootget_tree_root () const
const TreeNodeget_root_node () const
TreeNodeget_root_node ()
bool is_root_node () const
virtual void set_root ()
TreeNodeget_brother ()
const TreeNodeget_brother () const
bool has_group_info () const
TreeNodekeelTarget ()
const TreeNodekeelTarget () const
bool keelsDownGroup (const TreeNode *toSon) const
void unkeelGroup ()
int keeledStateInfo () const
void setKeeledState (int keeledState)
bool is_normal_group () const
bool is_keeled_group () const
bool is_clade () const
const charget_group_name () const
const TreeNodefind_parent_with_groupInfo (bool skipKeeledBrothers=false) const
TreeNodefind_parent_with_groupInfo (bool skipKeeledBrothers=false)
const TreeNodefind_parent_clade () const
TreeNodefind_parent_clade ()
int calc_clade_level () const
int count_clades () const
void rotate_subtree ()
void reorder_tree (TreeOrder mode)
TreeNodefindLeafNamed (const char *wantedName)
GBT_LEN reset_length_and_bootstrap ()
void multifurcate ()
void set_branchlength_preserving (GBT_LEN new_len)
void multifurcate_whole_tree (const multifurc_limits &below)
- Public Member Functions inherited from Noncopyable
 Noncopyable ()

Static Public Member Functions

static void set_tree_shader (AP_TreeShader *new_shader)
static const AP_TreeShaderget_tree_shader ()
- Static Public Member Functions inherited from TreeNode
static void destroy (TreeNode *that)
static void destroy (TreeNode *that, TreeRoot *root)

Public Attributes

AP_tree_members gr
- Public Attributes inherited from TreeNode
GBT_LEN leftlen
GBT_LEN rightlen

Protected Member Functions

 ~AP_tree () OVERRIDE
- Protected Member Functions inherited from ARB_seqtree
AP_sequencetake_seq ()
void replace_seq (AP_sequence *sequence)
 ~ARB_seqtree () OVERRIDE
- Protected Member Functions inherited from TreeNode
TreeNode *& self_ref ()
void unlink_from_father ()
void swap_node_info (TreeNode *other, bool ofKeeledGroups)
void fixKeeledOrientation ()
void set_tree_root (TreeRoot *new_root)
bool at_root () const
virtual ~TreeNode ()
void destroy ()
void destroy (TreeRoot *viaRoot)


class AP_tree_root

Detailed Description

Definition at line 210 of file AP_Tree.hxx.

Constructor & Destructor Documentation

AP_tree::~AP_tree ( )
AP_tree::AP_tree ( AP_tree_root troot)

Definition at line 285 of file AP_Tree.hxx.

References AP_tree_members::clear().

Member Function Documentation

AP_tree::DEFINE_TREE_ACCESSORS ( AP_tree_root  ,
void AP_tree::compute_tree ( )
void AP_tree::recompute_and_write_folding ( )
unsigned AP_tree::count_leafs ( ) const

Definition at line 840 of file AP_Tree.cxx.

References TreeNode::is_leaf().

Referenced by buildLeafList(), and NTREE_move_tree_info().

unsigned AP_tree::get_leaf_count ( ) const

Implements TreeNode.

Reimplemented in FINAL_TYPE< SEQTYPE >.

Definition at line 298 of file AP_Tree.hxx.

References AP_tree_members::leaf_sum.

void AP_tree::load_subtree_info ( )

Definition at line 454 of file AP_Tree.cxx.

References TreeNode::is_leaf().

int AP_tree::colorize ( GB_HASH hashptr)
void AP_tree::uncolorize ( )

Definition at line 306 of file AP_Tree.hxx.

References compute_tree().

Referenced by MP_close_main(), and MP_normal_colors_in_tree().

void AP_tree::insert ( AP_tree new_brother)
void AP_tree::initial_insert ( AP_tree new_brother,
AP_tree_root troot 
AP_tree * AP_tree::REMOVE ( )
void AP_tree::swap_sons ( )

Reimplemented from TreeNode.

Definition at line 312 of file AP_Tree.hxx.

References ap_assert, TreeNode::is_leaf(), AP_tree_members::swap_son_layout(), and TreeNode::swap_sons().

GB_ERROR AP_tree::cantMoveNextTo ( AP_tree new_brother)

Definition at line 338 of file AP_Tree.cxx.

References error(), TreeNode::father, TreeNode::is_inside(), and NULp.

void AP_tree::moveNextTo ( AP_tree new_brother,
AP_FLOAT  rel_pos 
GB_ERROR AP_tree::tree_write_tree_rek ( GBDATA gb_tree)
GB_ERROR AP_tree::relink ( )
int AP_tree::get_linewidth ( ) const
void AP_tree::set_linewidth ( int  width)
void AP_tree::reset_linewidth ( )

Definition at line 328 of file AP_Tree.hxx.

References tree_defaults::LINEWIDTH, and set_linewidth().

Referenced by reset_subtree_layout(), and reset_subtree_linewidths().

void AP_tree::set_linewidth_recursive ( int  width)

Definition at line 1601 of file AP_Tree.cxx.

References TreeNode::is_leaf(), and set_linewidth().

Referenced by BranchLinewidthScaler::do_scale().

float AP_tree::get_angle ( ) const

Definition at line 331 of file AP_Tree.hxx.

References TreeNode::is_root_node().

void AP_tree::set_angle ( float  angle)

Definition at line 332 of file AP_Tree.hxx.

References TreeNode::father, TreeNode::get_brother(), get_father(), and TreeNode::is_root_node().

Referenced by reset_angle().

void AP_tree::reset_angle ( )

Definition at line 342 of file AP_Tree.hxx.

References tree_defaults::ANGLE, and set_angle().

Referenced by reset_subtree_angles(), and reset_subtree_layout().

void AP_tree::buildLeafList ( AP_tree **&  list,
long num 

Definition at line 933 of file AP_Tree.cxx.

References ap_assert, count_leafs(), and NULp.

Referenced by AP_tree_root::remove_leafs().

GB_ERROR AP_tree::move_group_to ( AP_tree new_group)
bool AP_tree::is_folded_group ( ) const
bool AP_tree::is_inside_folded_group ( ) const

Definition at line 1640 of file AP_Tree.cxx.

References TreeNode::father, get_father(), is_folded_group(), and TreeNode::is_leaf().

Referenced by NT_jump_cb().

void AP_tree::mark_duplicates ( )
const char * AP_tree::mark_long_branches ( double  min_rel_diff,
double  min_abs_diff,
double &  found_max_abs_diff 
const char * AP_tree::mark_deep_leafs ( int  min_depth,
double  min_rootdist,
int found_max_depth,
double &  found_max_rootdist 
double AP_tree::mark_degenerated_branches ( double  degeneration_factor)

Definition at line 1496 of file AP_Tree.cxx.

References ap_mark_degenerated().

Referenced by BranchWindow::markDegeneratedBranches().

const char * AP_tree::analyse_distances ( )

Definition at line 1461 of file AP_Tree.cxx.

References EdgeDistances::get_report().

void AP_tree::justify_branch_lenghs ( GBDATA gb_main)

Definition at line 1559 of file AP_Tree.cxx.

References ap_just_tree_rek(), and ta.

Referenced by NT_justify_branch_lenghs().

void AP_tree::relink_tree ( GBDATA gb_main,
void(*)(GBDATA *&ref_gb_node, char *&ref_name, GB_HASH *organism_hash)  relinker,
GB_HASH organism_hash 

Definition at line 1575 of file AP_Tree.cxx.

References relink_tree_rek(), and ta.

Referenced by NT_pseudo_species_to_organism().

void AP_tree::reset_subtree_spreads ( )

Definition at line 1619 of file AP_Tree.cxx.

References gr, TreeNode::is_leaf(), and AP_tree_members::reset_child_spread().

void AP_tree::reset_subtree_angles ( )

Definition at line 1626 of file AP_Tree.cxx.

References TreeNode::is_leaf(), and reset_angle().

void AP_tree::reset_subtree_linewidths ( )

Definition at line 1630 of file AP_Tree.cxx.

References TreeNode::is_leaf(), and reset_linewidth().

void AP_tree::reset_subtree_layout ( )

Definition at line 1634 of file AP_Tree.cxx.

References TreeNode::is_leaf(), reset_angle(), and reset_linewidth().

void AP_tree::set_tree_shader ( AP_TreeShader new_shader)

Definition at line 704 of file AP_Tree.cxx.

References AP_TreeShader::init().

Referenced by NT_install_treeShader().

static const AP_TreeShader* AP_tree::get_tree_shader ( )

Definition at line 372 of file AP_Tree.hxx.

Referenced by NT_configure_treeShader().

bool AP_tree::hasName ( const char Name) const

Definition at line 374 of file AP_Tree.hxx.

References TreeNode::name.

bool AP_tree::has_correct_mark_flags ( ) const

Definition at line 670 of file AP_Tree.cxx.

References gr, TreeNode::is_leaf(), and AP_tree_members::mark_sum.

ShadedValue AP_tree::update_subtree_information ( const group_scaling gscaling)

Friends And Related Function Documentation

friend class AP_tree_root

Definition at line 283 of file AP_Tree.hxx.

Member Data Documentation

AP_tree_members AP_tree::gr

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