File: mutscan_preprocess.hpp

package info (click to toggle)
staden 2.0.0%2Bb11-5
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 21,568 kB
  • sloc: ansic: 240,605; tcl: 65,360; cpp: 12,854; makefile: 11,201; sh: 2,952; fortran: 2,033; perl: 63; awk: 46
file content (76 lines) | stat: -rw-r--r-- 1,945 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
/*
 * Copyright (c) Medical Research Council 2002. 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 _MUTSCAN_PREPROCESS_HPP_
#define _MUTSCAN_PREPROCESS_HPP_



#include <mutlib.h>           // For mutlib types
#include <array.hpp>          // For SimpleArray object
#include <matrix.hpp>         // For SimpleMatrix object
#include <trace.hpp>          // For Trace object



/**
   Preprocesses the trace ready for further analysis by mutscan. One preprocessor
   object is used for each trace.
*/
class MutScanPreprocessor
{
 public:
   // Constructor/Destructor
   MutScanPreprocessor() { }
  ~MutScanPreprocessor() { }



 public:
   // Data
   SimpleMatrix<int> Peak;           // 5*SAMPLES peak matrix, value=amplitude, last row is logical OR of all peaks for every base
   NumericArray<int> Noise;          // 1*SAMPLES noise vector
   NumericArray<int> PeakCount;      // 4*1 peak count for each row of Peak
   int               PeakCountMax;   // Maximum number of peaks for all 4-bases
   double            SearchWindow;   // Search window in samples, derrived from trace stats
   int               PeakInterval;   // Peak interval mode



 public:
   // Services
   mutlib_result_t Execute( mutscan_t* ms, Trace& t, int n, int left, int right );



 private:
   // Helpers
   void Init();
   void CountPeaks();
   void PeakClip();
   void PeakSpacing();
   void EstimateNoiseFloor( Trace& t, int n );
   void PeakFind( Trace& t, int left, int right );



 private:
   // Data
   double m_nNoiseThreshold[2];
};



#endif