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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: sequtil_manip.hpp,v $
  4.  * PRODUCTION Revision 1000.0  2003/10/29 15:35:57  gouriano
  5.  * PRODUCTION PRODUCTION: IMPORTED [ORIGINAL] Dev-tree R1.1
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef UTIL_SEQUTIL___SEQUTIL_MANIP__HPP
  10. #define UTIL_SEQUTIL___SEQUTIL_MANIP__HPP
  11. /*  $Id: sequtil_manip.hpp,v 1000.0 2003/10/29 15:35:57 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:  Mati Shomrat
  37.  *
  38.  * File Description:
  39.  *      Various sequnce manipulations
  40.  */   
  41. #include <corelib/ncbistd.hpp>
  42. #include <corelib/ncbistr.hpp>
  43. #include <vector>
  44. #include <util/sequtil/sequtil.hpp>
  45. BEGIN_NCBI_SCOPE
  46. /////////////////////////////////////////////////////////////////////////////
  47. //
  48. // Sequence Manipulations
  49. //
  50. class NCBI_XUTIL_EXPORT CSeqManip
  51. {
  52. public:
  53.     // types
  54.     typedef CSeqUtil::TCoding   TCoding;
  55.  
  56.     // Reverse
  57.     static SIZE_TYPE Reverse(const string& src, TCoding src_coding,
  58.                              TSeqPos pos, TSeqPos length,
  59.                              string& dst);
  60.     static SIZE_TYPE Reverse(const vector<char>& src, TCoding src_coding,
  61.                              TSeqPos pos, TSeqPos length,
  62.                              vector<char>& dst);
  63.     static SIZE_TYPE Reverse(const char* src, TCoding src_coding,
  64.                              TSeqPos pos, TSeqPos length,
  65.                              char* dst);
  66.     // Complement
  67.     static SIZE_TYPE Complement(const string& src, TCoding src_coding,
  68.                                 TSeqPos pos, TSeqPos length,
  69.                                 string& dst);
  70.     static SIZE_TYPE Complement(const vector<char>& src, TCoding src_coding,
  71.                                 TSeqPos pos, TSeqPos length,
  72.                                 vector<char>& dst);
  73.     static SIZE_TYPE Complement(const char* src, TCoding src_coding,
  74.                                 TSeqPos pos, TSeqPos length,
  75.                                 char* dst);
  76.     // Reverse + Complement
  77.     // place result in an auxiliary container
  78.     static SIZE_TYPE ReverseComplement(const string& src, TCoding src_coding,
  79.                                        TSeqPos pos, TSeqPos length,
  80.                                        string& dst);
  81.     static SIZE_TYPE ReverseComplement(const vector<char>& src, TCoding src_coding,
  82.                                        TSeqPos pos, TSeqPos length,
  83.                                        vector<char>& dst);
  84.     static SIZE_TYPE ReverseComplement(const char* src, TCoding src_coding,
  85.                                        TSeqPos pos, TSeqPos length,
  86.                                        char* dst);
  87.     // in place operation
  88.     static SIZE_TYPE ReverseComplement(string& src, TCoding src_coding,
  89.                                 TSeqPos pos, TSeqPos length);
  90.     static SIZE_TYPE ReverseComplement(vector<char>& src, TCoding src_coding,
  91.                                 TSeqPos pos, TSeqPos length);
  92.     static SIZE_TYPE ReverseComplement(char* src, TCoding src_coding,
  93.                                 TSeqPos pos, TSeqPos length);
  94. };
  95. END_NCBI_SCOPE
  96. #endif  /* UTIL_SEQUTIL___SEQUTIL_MANIP__HPP */
  97.  /*
  98. * ===========================================================================
  99. *
  100. * $Log: sequtil_manip.hpp,v $
  101. * Revision 1000.0  2003/10/29 15:35:57  gouriano
  102. * PRODUCTION: IMPORTED [ORIGINAL] Dev-tree R1.1
  103. *
  104. * Revision 1.1  2003/10/08 13:29:23  shomrat
  105. * Initial version.
  106. *
  107. *
  108. * ===========================================================================
  109. */