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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: splign_formatter.hpp,v $
  4.  * PRODUCTION Revision 1000.0  2004/06/01 18:11:23  gouriano
  5.  * PRODUCTION PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.7
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef ALGO_ALIGN_SPLIGN_FORMATTER__HPP
  10. #define ALGO_ALIGN_SPLIGN_FORMATTER__HPP
  11. /* $Id: splign_formatter.hpp,v 1000.0 2004/06/01 18:11:23 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:  Yuri Kapustin
  37. *
  38. * File Description:
  39. *   Splign formatter
  40. */
  41. #include <algo/align/splign/splign.hpp>
  42. #include <objects/seqalign/Seq_align_set.hpp>
  43. #include <objects/seqalign/Dense_seg.hpp>
  44. BEGIN_NCBI_SCOPE
  45. class NCBI_XALGOALIGN_EXPORT CSplignFormatter: public CObject
  46. {
  47. public:
  48.     CSplignFormatter(const CSplign& splign);
  49.     // setters
  50.     void SetSeqIds(const string& id1, const string& id2) {
  51.         m_QueryId = id1;
  52.         m_SubjId = id2;
  53.     }
  54.     string AsText(void) const;
  55.     CRef<objects::CSeq_align_set> AsSeqAlignSet(void) const;
  56. private:
  57.     const CSplign*    m_splign;
  58.     string            m_QueryId, m_SubjId;
  59.     CRef<objects::CSeq_align> x_Compartment2SeqAlign(
  60.                                const vector<size_t>& boxes,
  61.                                const vector<string>& transcripts,
  62.                                const vector<CNWAligner::TScore>& scores) const;
  63.     void x_Exon2DS(const size_t* box, const string& trans,
  64.                    objects::CDense_seg* pds) const;
  65. };
  66. END_NCBI_SCOPE
  67. /*
  68.  * ===========================================================================
  69.  *
  70.  * $Log: splign_formatter.hpp,v $
  71.  * Revision 1000.0  2004/06/01 18:11:23  gouriano
  72.  * PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.7
  73.  *
  74.  * Revision 1.7  2004/05/04 15:23:44  ucko
  75.  * Split splign code out of xalgoalign into new xalgosplign.
  76.  *
  77.  * Revision 1.6  2004/04/30 15:00:32  kapustin
  78.  * Support ASN formatting
  79.  *
  80.  * Revision 1.5  2004/04/23 14:36:24  kapustin
  81.  * Initial revision
  82.  *
  83.  *
  84.  * ===========================================================================
  85.  */
  86. #endif