mate_pair.hpp

来自「ncbi源码」· HPP 代码 · 共 267 行

HPP
267
字号
/* * =========================================================================== * PRODUCTION $Log: mate_pair.hpp,v $ * PRODUCTION Revision 1000.0  2004/06/01 19:55:32  gouriano * PRODUCTION PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.5 * PRODUCTION * =========================================================================== */#ifndef GUI_OBJUTILS___MATE_PAIR__HPP#define GUI_OBJUTILS___MATE_PAIR__HPP/*  $Id: mate_pair.hpp,v 1000.0 2004/06/01 19:55:32 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:  Vlad Lebedev * * File Description: *   CLayoutMatePair -- utility class to layout mate pairs (a special type of *      pairwise alignments and hold a set of CLayoutPWAlign */#include <corelib/ncbiobj.hpp>#include <gui/gui.hpp>#include <gui/objutils/layout.hpp>#include <gui/objutils/pw_alignment.hpp>#include <objects/seqalign/Seq_align.hpp>/** @addtogroup GUI_OBJUTILS * * @{ */BEGIN_NCBI_SCOPEclass NCBI_GUIOBJUTILS_EXPORT CLayoutMatePair : public CLayoutObject{public:    typedef vector< CRef<CLayoutPWAlign> > TAlignList;        // ctors    CLayoutMatePair(const TAlignList& aligns);    // Access the alignment as a CObject    const CObject* GetObject(TSeqPos pos) const;    bool HasObject(const CObject* obj) const;    bool IsSelected(const CLayoutPWAlign* pw_aln) const;        // Access the alignments's remapped location    const objects::CSeq_loc& GetLocation(void) const;    const TAlignList&        GetSeqAligns() const;    // retrieve the type of this object    EType GetType() const;    // matepair specifics    // library information    enum ELibraryId {        eLibrary_NotSet = -1,        eLibrary_NotFound = 0    };    size_t GetLibraryId() const;    // matepair errors    enum EErrorType {        // no error found (initial state)        eError_NotSet = -1,        // no error        eError_NoError = 0,        // the mate is not aligned with the correct otientation        eError_Orientation = 1,        // the mate aligns to multiple locations        eError_NonUnique = 2,        // the mate is not in the expected distance range        eError_Distance = 3    };    EErrorType GetError() const;    //    // pure virtual requirements    //        // Comparators    bool LessByPos (const CLayoutObject& obj) const;    bool LessBySize(const CLayoutObject& obj) const;protected:    TAlignList              m_SeqAligns;    CRef<objects::CSeq_loc> m_Location;    // parsed matepair library (-1 = not set, 0 = not found)    int m_LibraryId;    // parsed mate pair error code    EErrorType m_ErrorType;        // store the selected object (if any)    mutable vector<const CObject*> m_ObjSel;};inlinebool CLayoutMatePair::LessByPos(const CLayoutObject& obj) const{    TSeqRange r0 = GetLocation().GetTotalRange();    TSeqRange r1 = obj.GetLocation().GetTotalRange();    return (r0.GetFrom() < r1.GetFrom());}inlinebool CLayoutMatePair::LessBySize(const CLayoutObject& obj) const{    TSeqRange r0 = GetLocation().GetTotalRange();    TSeqRange r1 = obj.GetLocation().GetTotalRange();    return (r0.GetLength() < r1.GetLength());}inlinebool CLayoutMatePair::HasObject(const CObject* obj) const{    ITERATE(TAlignList, iter, m_SeqAligns)    {        if ( (*iter)->HasObject(obj) ) {            m_ObjSel.push_back(obj);            return true;        }    }    return false;}inlinebool CLayoutMatePair::IsSelected(const CLayoutPWAlign* pw_aln) const{    ITERATE(vector<const CObject*>, iter, m_ObjSel) {        if (pw_aln->HasObject(*iter))            return true;    }    return false;}            inlineconst CLayoutMatePair::TAlignList&CLayoutMatePair::GetSeqAligns(void) const{    return m_SeqAligns;}inlineconst objects::CSeq_loc& CLayoutMatePair::GetLocation(void) const{    return *m_Location;}inlinesize_t CLayoutMatePair::GetLibraryId() const{    return m_LibraryId;}inlineCLayoutMatePair::EErrorType CLayoutMatePair::GetError() const{    return m_ErrorType;}inlineCLayoutMatePair::EType CLayoutMatePair::GetType() const{    return eMatepair;}END_NCBI_SCOPE/* @} *//* * =========================================================================== * $Log: mate_pair.hpp,v $ * Revision 1000.0  2004/06/01 19:55:32  gouriano * PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.5 * * Revision 1.5  2004/05/14 14:24:47  dicuccio * Added new pure virtual requirement on CLayoutObject(): GetType(), returns enum * defined in CLayoutObject * * Revision 1.4  2004/05/10 18:24:29  dicuccio * Added identification of mate pair library and error codes * * Revision 1.3  2004/05/03 13:34:54  dicuccio * FIxed include guards, doxygen groups * * Revision 1.2  2004/05/03 12:41:35  dicuccio * Fixed #includes and export specifiers * * Revision 1.1  2004/04/30 11:52:53  dicuccio * Split out from gui/utils * * Revision 1.6  2004/04/20 19:15:04  dicuccio * Converted to store a set of pairwise alignments * * Revision 1.5  2004/04/16 14:27:17  dicuccio * Added doxygen module tag * * Revision 1.4  2004/04/15 12:57:43  lebedev * Changed GetObject to return NULL or const pointer based on given position * * Revision 1.3  2004/04/12 16:49:02  dicuccio * Redesign CLayoutMatePair - use alignment manager internally, store a set of * alignments * * Revision 1.2  2004/04/07 12:39:09  dicuccio * Formatting changes * * Revision 1.1  2004/04/05 16:10:06  lebedev * Initial revision * * =========================================================================== */#endif  // GUI_OBJUTILS___MATE_PAIR__HPP

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?