File: BaseComposition.cpp

package info (click to toggle)
libstatgen 1.0.15-8
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,588 kB
  • sloc: cpp: 49,624; ansic: 1,408; makefile: 320; sh: 60
file content (92 lines) | stat: -rw-r--r-- 3,180 bytes parent folder | download | duplicates (4)
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
82
83
84
85
86
87
88
89
90
91
92
/*
 *  Copyright (C) 2010  Regents of the University of Michigan
 *
 *   This program is free software: you can redistribute it and/or modify
 *   it under the terms of the GNU General Public License as published by
 *   the Free Software Foundation, either version 3 of the License, or
 *   (at your option) any later version.
 *
 *   This program is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *   GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#include <iomanip>
#include "BaseComposition.h"

// Constructor
// Initialize the base to ascii map based on the specified maptype.
BaseComposition::BaseComposition():
   myBaseAsciiMap()
{
}


// Update the composition for the specified index with the specified character.
// Return false if the character is not a valid raw sequence character.
// Return true if it is valid.
bool BaseComposition::updateComposition(unsigned int rawSequenceCharIndex, 
                                        char baseChar)
{
   bool validIndex  = true;

   // Each time we return to index 0, reset the primer count in the base/ascii
   // map.
   if(rawSequenceCharIndex == 0)
   {
      myBaseAsciiMap.resetPrimerCount();
   }

   // Check to see if the vector size is already sized to include this 
   // index.  If it is not sized appropriately, add entries until it contains
   // the rawSequenceCharIndex.
   while(rawSequenceCharIndex >= myBaseCountVector.size())
   {
      // Add an entry of the base count array object to the vector.
      BaseCount baseCountEntry;
      myBaseCountVector.push_back(baseCountEntry);
   }

   // Get the base info for the specified character. 
   int baseIndex = myBaseAsciiMap.getBaseIndex(baseChar);
   
   // Increment the count for the given character.  This method returns false
   // if the character's index falls outside the range of the base array.
   // This relies on the myBaseAsciiMap indexes and the BaseCOunt object array
   // to use the same indexing values for valid bases.
   validIndex = 
      myBaseCountVector[rawSequenceCharIndex].incrementCount(baseIndex);
   
   // Return whether or not the specified character was valid.
   return(validIndex);
}


// Print the composition.
void BaseComposition::print()
{
   std::cout << std::endl << "Base Composition Statistics:" << std::endl;
   std::cout.precision(2);
   // This assumes the relationship between indexes that are printed
   // by a BaseCount object to be in a specific order based on ATGCN.
   std::cout << std::fixed << "Read Index" 
             << "\t%A" << "\t%C" << "\t%G" << "\t%T" << "\t%N" << "\tTotal Reads At Index" 
             << std::endl;
   for(unsigned int i = 0; i < myBaseCountVector.size(); i++)
   {
      std::cout << std::setw(10) << i << " ";
      myBaseCountVector[i].printPercent();
   }
   std::cout << std::endl;
}


// Clear the vector.
void BaseComposition::clear()
{
   myBaseCountVector.clear();
}