📄 phy_node.hpp
字号:
/* * =========================================================================== * PRODUCTION $Log: phy_node.hpp,v $ * PRODUCTION Revision 1000.0 2004/04/12 17:53:38 gouriano * PRODUCTION PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.4 * PRODUCTION * =========================================================================== */#ifndef ALGO_PHY_TREE___PHY_NODE__HPP#define ALGO_PHY_TREE___PHY_NODE__HPP/* $Id: phy_node.hpp,v 1000.0 2004/04/12 17:53:38 gouriano Exp $ * =========================================================================== * * PUBLIC DOMAIN NOTICE * National Center for Biotechnology Information * * This software/database is a "United States Government Work" under the * terms of the United States Copyright Act. It was written as part of * the author's official duties as a United States Government employee and * thus cannot be copyrighted. This software/database is freely available * to the public for use. The National Library of Medicine and the U.S. * Government have not placed any restriction on its use or reproduction. * * Although all reasonable efforts have been taken to ensure the accuracy * and reliability of the software and data, the NLM and the U.S. * Government do not and cannot warrant the performance or results that * may be obtained by using this software or data. The NLM and the U.S. * Government disclaim all warranties, express or implied, including * warranties of performance, merchantability or fitness for any particular * purpose. * * Please cite the author in any work or product based on this material. * * =========================================================================== * * Authors: Josh Cherry * * File Description: Things for representing and manipulating * phylogenetic trees * */#include <corelib/ncbistd.hpp>#include <corelib/ncbi_tree.hpp>BEGIN_NCBI_SCOPE/// Data contained at each node of a phylogenetic tree.////// Holds a label (string), a distance (double), and an integer id./// Distance may not be set; IsSetDist() reports whether it is./// id == -1 indicates that the id is not set.class NCBI_XALGOPHYTREE_EXPORT CPhyNodeData{public: CPhyNodeData(void) : m_Id(-1), m_DistSet(false) { } int GetId(void) const {return m_Id;} void SetId(int id) {m_Id = id;} /// Is the distance set? bool IsSetDist(void) const {return m_DistSet;} /// Return the distance; does NOT check whether it's really set. double GetDist(void) const {return m_Dist;} void SetDist(double dist) {m_Dist = dist; m_DistSet = true;} /// Make it no longer set. void ResetDist(void) {m_DistSet = false; m_Dist = 0;} const string& GetLabel(void) const {return m_Label;} void SetLabel(const string& label) {m_Label = label;} string& SetLabel(void) {return m_Label;}private: int m_Id; double m_Dist; bool m_DistSet; string m_Label;};typedef CTreeNode<CPhyNodeData> TPhyTreeNode;/// Newick format outputNCBI_XALGOPHYTREE_EXPORTCNcbiOstream& operator<<(CNcbiOstream& os, const TPhyTreeNode& tree);/// Nexus format output (Newick with some stuff around it).////// tree_name gets put in the file.NCBI_XALGOPHYTREE_EXPORTvoid WriteNexusTree(CNcbiOstream& os, const TPhyTreeNode& tree, const string& tree_name = "the_tree");/// Newick but without the terminal ';'NCBI_XALGOPHYTREE_EXPORTvoid PrintNode(CNcbiOstream& os, const TPhyTreeNode& node);/// Newick format input.////// Uses flex/bison lexer/parser.NCBI_XALGOPHYTREE_EXPORTTPhyTreeNode *ReadNewickTree(CNcbiIstream& is);END_NCBI_SCOPE/* * =========================================================================== * $Log: phy_node.hpp,v $ * Revision 1000.0 2004/04/12 17:53:38 gouriano * PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.4 * * Revision 1.4 2004/02/11 21:50:23 jcherry * Added Nexus format output * * Revision 1.3 2004/02/11 17:54:43 jcherry * Added parser for Newick format tree files * * Revision 1.2 2004/02/10 17:02:29 dicuccio * Formatting changes. Added export specifiers * * Revision 1.1 2004/02/10 15:15:57 jcherry * Initial version * * =========================================================================== */#endif // ALGO_PHY_TREE___PHY_NODE__HPP
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -