Mercurial > hg > svcore
comparison data/model/Dense3DModelPeakCache.cpp @ 935:f960d67ce842 tonioni
Merge from branch warnfix_no_size_t
author | Chris Cannam |
---|---|
date | Wed, 18 Jun 2014 13:42:01 +0100 |
parents | 59e7fe1b1003 |
children | ece369c5bb68 |
comparison
equal
deleted
inserted
replaced
925:3efc20c59a94 | 935:f960d67ce842 |
---|---|
16 #include "Dense3DModelPeakCache.h" | 16 #include "Dense3DModelPeakCache.h" |
17 | 17 |
18 #include "base/Profiler.h" | 18 #include "base/Profiler.h" |
19 | 19 |
20 Dense3DModelPeakCache::Dense3DModelPeakCache(DenseThreeDimensionalModel *source, | 20 Dense3DModelPeakCache::Dense3DModelPeakCache(DenseThreeDimensionalModel *source, |
21 size_t columnsPerPeak) : | 21 int columnsPerPeak) : |
22 m_source(source), | 22 m_source(source), |
23 m_resolution(columnsPerPeak) | 23 m_resolution(columnsPerPeak) |
24 { | 24 { |
25 m_coverage.resize(1); // otherwise it is simply invalid | 25 m_coverage.resize(1); // otherwise it is simply invalid |
26 | 26 |
42 { | 42 { |
43 delete m_cache; | 43 delete m_cache; |
44 } | 44 } |
45 | 45 |
46 bool | 46 bool |
47 Dense3DModelPeakCache::isColumnAvailable(size_t column) const | 47 Dense3DModelPeakCache::isColumnAvailable(int column) const |
48 { | 48 { |
49 if (!m_source) return false; | 49 if (!m_source) return false; |
50 if (haveColumn(column)) return true; | 50 if (haveColumn(column)) return true; |
51 for (int i = m_resolution; i > 0; ) { | 51 for (int i = m_resolution; i > 0; ) { |
52 --i; | 52 --i; |
56 } | 56 } |
57 return true; | 57 return true; |
58 } | 58 } |
59 | 59 |
60 Dense3DModelPeakCache::Column | 60 Dense3DModelPeakCache::Column |
61 Dense3DModelPeakCache::getColumn(size_t column) const | 61 Dense3DModelPeakCache::getColumn(int column) const |
62 { | 62 { |
63 Profiler profiler("Dense3DModelPeakCache::getColumn"); | 63 Profiler profiler("Dense3DModelPeakCache::getColumn"); |
64 if (!m_source) return Column(); | 64 if (!m_source) return Column(); |
65 if (!haveColumn(column)) fillColumn(column); | 65 if (!haveColumn(column)) fillColumn(column); |
66 return m_cache->getColumn(column); | 66 return m_cache->getColumn(column); |
67 } | 67 } |
68 | 68 |
69 float | 69 float |
70 Dense3DModelPeakCache::getValueAt(size_t column, size_t n) const | 70 Dense3DModelPeakCache::getValueAt(int column, int n) const |
71 { | 71 { |
72 if (!m_source) return 0.f; | 72 if (!m_source) return 0.f; |
73 if (!haveColumn(column)) fillColumn(column); | 73 if (!haveColumn(column)) fillColumn(column); |
74 return m_cache->getValueAt(column, n); | 74 return m_cache->getValueAt(column, n); |
75 } | 75 } |
91 { | 91 { |
92 m_source = 0; | 92 m_source = 0; |
93 } | 93 } |
94 | 94 |
95 bool | 95 bool |
96 Dense3DModelPeakCache::haveColumn(size_t column) const | 96 Dense3DModelPeakCache::haveColumn(int column) const |
97 { | 97 { |
98 return column < m_coverage.size() && m_coverage.get(column); | 98 return column < (int)m_coverage.size() && m_coverage.get(column); |
99 } | 99 } |
100 | 100 |
101 void | 101 void |
102 Dense3DModelPeakCache::fillColumn(size_t column) const | 102 Dense3DModelPeakCache::fillColumn(int column) const |
103 { | 103 { |
104 Profiler profiler("Dense3DModelPeakCache::fillColumn"); | 104 Profiler profiler("Dense3DModelPeakCache::fillColumn"); |
105 | 105 |
106 if (column >= m_coverage.size()) { | 106 if (column >= (int)m_coverage.size()) { |
107 // see note in sourceModelChanged | 107 // see note in sourceModelChanged |
108 if (m_coverage.size() > 0) m_coverage.reset(m_coverage.size()-1); | 108 if (m_coverage.size() > 0) m_coverage.reset(m_coverage.size()-1); |
109 m_coverage.resize(column + 1); | 109 m_coverage.resize(column + 1); |
110 } | 110 } |
111 | 111 |
112 Column peak; | 112 Column peak; |
113 for (int i = 0; i < m_resolution; ++i) { | 113 for (int i = 0; i < int(m_resolution); ++i) { |
114 Column here = m_source->getColumn(column * m_resolution + i); | 114 Column here = m_source->getColumn(column * m_resolution + i); |
115 if (i == 0) { | 115 if (i == 0) { |
116 peak = here; | 116 peak = here; |
117 } else { | 117 } else { |
118 for (int j = 0; j < peak.size() && j < here.size(); ++j) { | 118 for (int j = 0; j < (int)peak.size() && j < (int)here.size(); ++j) { |
119 if (here[j] > peak[j]) peak[j] = here[j]; | 119 if (here[j] > peak[j]) peak[j] = here[j]; |
120 } | 120 } |
121 } | 121 } |
122 } | 122 } |
123 | 123 |