File: caller_snr.cpp

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 (55 lines) | stat: -rw-r--r-- 1,386 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
/*
 * 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.
 *
 */



#include <cmath>                       // For std::log10()
#include <caller_snr.hpp>



void SNRCaller::MakeCall( Trace& Tr, int nPos )
{
   call_t Signal[4];


   // Load in data
   m_nPosition         = nPos;
   Signal[0].Index     = 0;
   Signal[0].Amplitude = Tr[0][nPos];
   Signal[1].Index     = 1;
   Signal[1].Amplitude = Tr[1][nPos];
   Signal[2].Index     = 2;
   Signal[2].Amplitude = Tr[2][nPos];
   Signal[3].Index     = 3;
   Signal[3].Amplitude = Tr[3][nPos];



   // Sort into ascending order of amplitude
   SortAscending( Signal );



   // Compute SNR=confidence, based on 1st and 2nd highest trace levels
   // S/N (db) = 20*log(s/n).
   //
   double S = static_cast<double>( Signal[3].Amplitude );
   double N = static_cast<double>( Signal[2].Amplitude );
   if( N <= 0.0 )
       N = 1.0;
   m_nRatio = S / N;
   m_nSNR   = 20.0 * std::log10( m_nRatio );
}