File: basecall.hpp

package info (click to toggle)
staden 2.0.0%2Bb11-2
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 21,228 kB
  • ctags: 22,407
  • sloc: ansic: 240,603; tcl: 65,360; cpp: 12,854; makefile: 11,202; sh: 2,952; fortran: 2,033; perl: 63; awk: 46
file content (81 lines) | stat: -rw-r--r-- 1,754 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/*
 * Copyright (c) Medical Research Council 2001. All rights reserved.
 *
 * Permission to use, copy, modify and distribute this software and its
 * documentation for any purpose is hereby granted without fee, provided that
 * this copyright and notice appears in all copies.
 *
 * This file was written as part of the Staden Package at the MRC Laboratory
 * of Molecular Biology, Hills Road, Cambridge, CB2 2QH, United Kingdom.
 *
 * MRC disclaims all warranties with regard to this software.
 *
 */



#ifndef _MUTLIB_BASECALL_HPP_
#define _MUTLIB_BASECALL_HPP_


#include <cstddef>   // For size_t

// Useful structure
typedef struct
{
   int a;
   int b;

}mutlib_pair_t;



class BaseCall
{
/*
   Used to record and manipulate all base call information.
*/
 public:
   // Original data
   int Call;                     // 0=A, 1=C, 2=G, 3=T
   int Position;                 // Base position in samples
   int Amplitude;                // Size of peak
   int Confidence;               // In phred units

   // New Data
   int PeakCall;                 // 0=A, 1=C, 2=G, 3=T
   int PeakPosition[4];          // Centre points for each peak in samples
   int PeakAmplitude[4];         // 0=A, 1=C, 2=G, 3=T
   int PeakWidth[4];             // Useful measure of peak quality



 public:
   // Constructors
   BaseCall();
   BaseCall( int a, int c, int g, int t );
   BaseCall( int call, int pos, int conf=-1 );



 public:
   // Services
   char AsCharacter() const;
   int  PeakCount() const;
   bool PeakPresent() const;
   int  PeakOfRank( int n );
   int  PeakOfRankAsIndex( int n );



 private:
   // Helpers
   void Init();
   int  Rank( std::size_t n, bool bIndex ) const;
   void Swap( mutlib_pair_t& a, mutlib_pair_t& b ) const;
};



#endif