00001 #ifndef NGALIGN_MERGE_ALIGNER__HPP 00002 #define NGALIGN_MERGE_ALIGNER__HPP 00003 00004 /* $Id: merge_aligner.hpp 172137 2009-10-01 14:38:07Z boukn $ 00005 * =========================================================================== 00006 * 00007 * PUBLIC DOMAIN NOTICE 00008 * National Center for Biotechnology Information 00009 * 00010 * This software/database is a "United States Government Work" under the 00011 * terms of the United States Copyright Act. It was written as part of 00012 * the author's official duties as a United States Government employee and 00013 * thus cannot be copyrighted. This software/database is freely available 00014 * to the public for use. The National Library of Medicine and the U.S. 00015 * Government have not placed any restriction on its use or reproduction. 00016 * 00017 * Although all reasonable efforts have been taken to ensure the accuracy 00018 * and reliability of the software and data, the NLM and the U.S. 00019 * Government do not and cannot warrant the performance or results that 00020 * may be obtained by using this software or data. The NLM and the U.S. 00021 * Government disclaim all warranties, express or implied, including 00022 * warranties of performance, merchantability or fitness for any particular 00023 * purpose. 00024 * 00025 * Please cite the author in any work or product based on this material. 00026 * 00027 * =========================================================================== 00028 * 00029 * Authors: Nathan Bouk 00030 * 00031 * File Description: 00032 * 00033 */ 00034 00035 #include <corelib/ncbistd.hpp> 00036 #include <corelib/ncbiobj.hpp> 00037 #include <objects/seqloc/Na_strand.hpp> 00038 00039 #include <objects/seqloc/Seq_loc.hpp> 00040 #include <objects/seqloc/Seq_id.hpp> 00041 #include <objmgr/scope.hpp> 00042 #include <algo/blast/api/blast_types.hpp> 00043 #include <algo/blast/api/bl2seq.hpp> 00044 #include <algo/blast/api/blast_options_handle.hpp> 00045 #include <algo/blast/api/blast_nucl_options.hpp> 00046 #include <objects/seqalign/Seq_align.hpp> 00047 #include <objects/seqalign/Seq_align_set.hpp> 00048 #include <objects/seqalign/Dense_seg.hpp> 00049 00050 #include <algo/blast/api/blast_types.hpp> 00051 #include <algo/blast/api/blast_options_handle.hpp> 00052 #include <algo/blast/api/sseqloc.hpp> 00053 00054 #include <algo/align/ngalign/ngalign_interface.hpp> 00055 00056 BEGIN_NCBI_SCOPE 00057 00058 BEGIN_SCOPE(objects) 00059 class CScope; 00060 class CSeq_align; 00061 class CSeq_align_set; 00062 class CSeq_id; 00063 class CDense_seg; 00064 END_SCOPE(objects) 00065 00066 00067 00068 class CMergeAligner : public IAlignmentFactory 00069 { 00070 public: 00071 CMergeAligner(int Threshold) : m_Threshold(Threshold) { ; } 00072 00073 TAlignResultsRef GenerateAlignments(objects::CScope& Scope, 00074 ISequenceSet* QuerySet, 00075 ISequenceSet* SubjectSet, 00076 TAlignResultsRef AccumResults); 00077 00078 private: 00079 00080 CRef<objects::CSeq_align_set> 00081 x_MergeAlignments(CQuerySet& QueryAligns, objects::CScope& Scope); 00082 00083 int m_Threshold; 00084 }; 00085 00086 00087 END_NCBI_SCOPE 00088 00089 #endif 00090 00091
1.4.6
Modified on Wed Dec 09 08:17:25 2009 by modify_doxy.py rev. 173732