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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: blast_seg.h,v $
  4.  * PRODUCTION Revision 1000.1  2004/06/01 18:03:44  gouriano
  5.  * PRODUCTION PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.11
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. /* $Id: blast_seg.h,v 1000.1 2004/06/01 18:03:44 gouriano Exp $
  10.  * ===========================================================================
  11.  *
  12.  *                            PUBLIC DOMAIN NOTICE
  13.  *               National Center for Biotechnology Information
  14.  *
  15.  *  This software/database is a "United States Government Work" under the
  16.  *  terms of the United States Copyright Act.  It was written as part of
  17.  *  the author's offical duties as a United States Government employee and
  18.  *  thus cannot be copyrighted.  This software/database is freely available
  19.  *  to the public for use. The National Library of Medicine and the U.S.
  20.  *  Government have not placed any restriction on its use or reproduction.
  21.  *
  22.  *  Although all reasonable efforts have been taken to ensure the accuracy
  23.  *  and reliability of the software and data, the NLM and the U.S.
  24.  *  Government do not and cannot warrant the performance or results that
  25.  *  may be obtained by using this software or data. The NLM and the U.S.
  26.  *  Government disclaim all warranties, express or implied, including
  27.  *  warranties of performance, merchantability or fitness for any particular
  28.  *  purpose.
  29.  *
  30.  *  Please cite the author in any work or product based on this material.
  31.  *
  32.  * ===========================================================================
  33.  *
  34.  * Author:  Ilya Dondoshansky
  35.  *
  36.  */
  37. /** @file blast_seg.h
  38.  * SEG filtering functions. @todo FIXME: should this be combined with
  39.  * blast_filter/dust? Needs doxygen documentation and comments
  40.  */
  41. #ifndef __BLAST_SEG__
  42. #define __BLAST_SEG__
  43. #ifdef __cplusplus
  44. extern "C" {
  45. #endif
  46. #include <algo/blast/core/blast_def.h>
  47. /*--------------------------------------------------------------(structs)---*/
  48. typedef struct Alpha
  49.   {
  50.    Int4 alphabet;
  51.    Int4 alphasize;
  52.    double lnalphasize;
  53.    Int4* alphaindex;
  54.    unsigned char* alphaflag;
  55.    char* alphachar;
  56.   } Alpha;
  57. typedef struct SegParameters
  58.   {
  59.    Int4 window;
  60.    double locut;
  61.    double hicut;
  62.    Int4 period;
  63.    Int4 hilenmin;
  64.    Boolean overlaps; /* merge overlapping pieces if TRUE. */
  65.    Int4 maxtrim;
  66.    Int4 maxbogus;
  67.    Alpha* palpha;
  68.   } SegParameters;
  69. SegParameters* SegParametersNewAa (void);
  70. void SegParametersFree(SegParameters* sparamsp);
  71. Int2 SeqBufferSeg (Uint1* sequence, Int4 length, Int4 offset,
  72.                    SegParameters* sparamsp, BlastSeqLoc** seg_locs);
  73. #ifdef __cplusplus
  74. }
  75. #endif
  76. #endif /* !__BLAST_FILTER__ */