object_splitinfo.hpp
上传用户:yhdzpy8989
上传日期:2007-06-13
资源大小:13604k
文件大小:6k
源码类别:

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: object_splitinfo.hpp,v $
  4.  * PRODUCTION Revision 1000.0  2004/04/12 17:33:54  gouriano
  5.  * PRODUCTION PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.3
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef NCBI_OBJMGR_SPLIT_OBJECT_SPLITINFO__HPP
  10. #define NCBI_OBJMGR_SPLIT_OBJECT_SPLITINFO__HPP
  11. /*  $Id: object_splitinfo.hpp,v 1000.0 2004/04/12 17:33:54 gouriano Exp $
  12. * ===========================================================================
  13. *
  14. *                            PUBLIC DOMAIN NOTICE
  15. *               National Center for Biotechnology Information
  16. *
  17. *  This software/database is a "United States Government Work" under the
  18. *  terms of the United States Copyright Act.  It was written as part of
  19. *  the author's official duties as a United States Government employee and
  20. *  thus cannot be copyrighted.  This software/database is freely available
  21. *  to the public for use. The National Library of Medicine and the U.S.
  22. *  Government have not placed any restriction on its use or reproduction.
  23. *
  24. *  Although all reasonable efforts have been taken to ensure the accuracy
  25. *  and reliability of the software and data, the NLM and the U.S.
  26. *  Government do not and cannot warrant the performance or results that
  27. *  may be obtained by using this software or data. The NLM and the U.S.
  28. *  Government disclaim all warranties, express or implied, including
  29. *  warranties of performance, merchantability or fitness for any particular
  30. *  purpose.
  31. *
  32. *  Please cite the author in any work or product based on this material.
  33. *
  34. * ===========================================================================
  35. *
  36. * Author:  Eugene Vasilchenko
  37. *
  38. * File Description:
  39. *   Application for splitting blobs withing ID1 cache
  40. *
  41. * ===========================================================================
  42. */
  43. #include <corelib/ncbistd.hpp>
  44. #include <corelib/ncbiobj.hpp>
  45. #include <objmgr/annot_selector.hpp> // for CAnnotName
  46. #include <objmgr/seq_id_handle.hpp>
  47. #include <memory>
  48. #include <map>
  49. #include <vector>
  50. #include <objmgr/split/id_range.hpp>
  51. #include <objmgr/split/size.hpp>
  52. BEGIN_NCBI_SCOPE
  53. class CObjectOStream;
  54. BEGIN_SCOPE(objects)
  55. class CSeq_entry;
  56. class CBioseq;
  57. class CBioseq_set;
  58. class CSeq_annot;
  59. class CSeq_feat;
  60. class CSeq_align;
  61. class CSeq_graph;
  62. class CID2S_Split_Info;
  63. class CID2S_Chunk_Id;
  64. class CID2S_Chunk;
  65. class CBlobSplitter;
  66. class CBlobSplitterImpl;
  67. struct SSplitterParams;
  68. class CAnnotObject_SplitInfo
  69. {
  70. public:
  71.     CAnnotObject_SplitInfo(void)
  72.         : m_ObjectType(0)
  73.         {
  74.         }
  75.     CAnnotObject_SplitInfo(const CSeq_feat& obj, double ratio);
  76.     CAnnotObject_SplitInfo(const CSeq_align& obj, double ratio);
  77.     CAnnotObject_SplitInfo(const CSeq_graph& obj, double ratio);
  78.     int m_ObjectType;
  79.     CConstRef<CObject> m_Object;
  80.     CSize m_Size;
  81.     CSeqsRange m_Location;
  82. };
  83. class CLocObjects_SplitInfo
  84. {
  85. public:
  86.     typedef vector<CAnnotObject_SplitInfo> TObjects;
  87.     typedef TObjects::const_iterator const_iterator;
  88.     void Add(const CAnnotObject_SplitInfo& obj);
  89.     CNcbiOstream& Print(CNcbiOstream& out) const;
  90.     bool empty(void) const
  91.         {
  92.             return m_Objects.empty();
  93.         }
  94.     size_t size(void) const
  95.         {
  96.             return m_Objects.size();
  97.         }
  98.     void clear(void)
  99.         {
  100.             m_Objects.clear();
  101.             m_Size.clear();
  102.             m_Location.clear();
  103.         }
  104.     const_iterator begin(void) const
  105.         {
  106.             return m_Objects.begin();
  107.         }
  108.     const_iterator end(void) const
  109.         {
  110.             return m_Objects.end();
  111.         }
  112.     TObjects m_Objects;
  113.     CSize m_Size;
  114.     CSeqsRange m_Location;
  115. };
  116. inline
  117. CNcbiOstream& operator<<(CNcbiOstream& out, const CLocObjects_SplitInfo& info)
  118. {
  119.     return info.Print(out);
  120. }
  121. class CSeq_annot_SplitInfo
  122. {
  123. public:
  124.     typedef map<CSeq_id_Handle, CLocObjects_SplitInfo> TSimpleLocObjects;
  125.     CSeq_annot_SplitInfo(void);
  126.     CSeq_annot_SplitInfo(const CSeq_annot_SplitInfo& base,
  127.                          const CLocObjects_SplitInfo& objs);
  128.     
  129.     void SetSeq_annot(int id, const CSeq_annot& annot,
  130.                       const SSplitterParams& params);
  131.     void Add(const CAnnotObject_SplitInfo& obj);
  132.     bool IsLandmark(const CAnnotObject_SplitInfo& obj) const;
  133.     CNcbiOstream& Print(CNcbiOstream& out) const;
  134.     static CAnnotName GetName(const CSeq_annot& annot);
  135.     static size_t CountAnnotObjects(const CSeq_annot& annot);
  136.     int m_Id;
  137.     CConstRef<CSeq_annot> m_Src_annot;
  138.     CAnnotName m_Name;
  139.     TSimpleLocObjects m_SimpleLocObjects;
  140.     CLocObjects_SplitInfo m_ComplexLocObjects;
  141.     CLocObjects_SplitInfo m_LandmarkObjects;
  142.     CSize m_Size;
  143.     CSeqsRange m_Location;
  144. };
  145. typedef CSeq_annot_SplitInfo::TSimpleLocObjects TSimpleLocObjects;
  146. inline
  147. CNcbiOstream& operator<<(CNcbiOstream& out, const CSeq_annot_SplitInfo& info)
  148. {
  149.     return info.Print(out);
  150. }
  151. class CBioseq_SplitInfo
  152. {
  153. public:
  154.     typedef map<CConstRef<CSeq_annot>, CSeq_annot_SplitInfo> TSeq_annots;
  155.     CBioseq_SplitInfo(void);
  156.     ~CBioseq_SplitInfo(void);
  157.     int m_Id;
  158.     CRef<CBioseq> m_Bioseq;
  159.     CRef<CBioseq_set> m_Bioseq_set;
  160.     TSeq_annots m_Seq_annots;
  161. };
  162. END_SCOPE(objects)
  163. END_NCBI_SCOPE
  164. /*
  165. * ---------------------------------------------------------------------------
  166. * $Log: object_splitinfo.hpp,v $
  167. * Revision 1000.0  2004/04/12 17:33:54  gouriano
  168. * PRODUCTION: IMPORTED [CATCHUP_003] Dev-tree R1.3
  169. *
  170. * Revision 1.3  2004/01/07 17:36:20  vasilche
  171. * Moved id2_split headers to include/objmgr/split.
  172. * Fixed include path to genbank.
  173. *
  174. * Revision 1.2  2003/11/26 23:04:59  vasilche
  175. * Removed extra semicolons after BEGIN_SCOPE and END_SCOPE.
  176. *
  177. * Revision 1.1  2003/11/12 16:18:31  vasilche
  178. * First implementation of ID2 blob splitter withing cache.
  179. *
  180. * ===========================================================================
  181. */
  182. #endif//NCBI_OBJMGR_SPLIT_OBJECT_SPLITINFO__HPP