From: guigues Date: Mon, 9 Feb 2009 10:09:50 +0000 (+0000) Subject: *** empty log message *** X-Git-Tag: EED.02Oct2009~205 X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=commitdiff_plain;h=d244f1f9e0b34bc47b1fe25eb266a5cf9cb52f04;p=creaImageIO.git *** empty log message *** --- diff --git a/src2/creaImageIOIndexedHeap.txx b/src2/creaImageIOIndexedHeap.txx new file mode 100644 index 0000000..b5b5753 --- /dev/null +++ b/src2/creaImageIOIndexedHeap.txx @@ -0,0 +1,235 @@ +/* + +*/ +/*! \file + \brief Code of IndexedHeap +*/ +//============================================================================ +template +std::ostream& operator << (std::ostream& s, const IndexedHeap& t) +{ + s << "["; + for (int i=0; i +IndexedHeap::IndexedHeap ( const CT& comp, const IT& index ) + : m_c(&comp), m_i(&index) +{} +//=========================================================== + + +//=========================================================== +template +void IndexedHeap::set( const CT& comp ) +{ + m_c = ∁ +} +//=========================================================== + +//=========================================================== +template +void IndexedHeap::set ( const IT& index ) +{ + m_i = &index; +} +//=========================================================== + + +//=========================================================== +template +int IndexedHeap::insert(T t) +{ + m_p.push_back(t); + (*m_i)(t) = size()-1; + return upsort(size()-1); +} +//=========================================================== + +//=========================================================== +template +T& IndexedHeap::top() +{ + // lglASSERT( size() > 0) + return m_p.front(); +} +//=========================================================== + + +//=========================================================== +template +const T& IndexedHeap::top() const +{ + // lglASSERT( size() > 0) + return m_p.front(); +} +//=========================================================== + +//=========================================================== +template +T IndexedHeap::remove_top() +{ + // lglASSERT( size() > 0 ) + T f(m_p[0]); + (*m_i)(f) = -1; + T last = m_p.back(); + m_p.pop_back(); + if (m_p.size()>0) + { + m_p[0] = last; + (*m_i)(last) = 0; + downsort(0); + } + return f; +} +//============================================================================ + + + +//============================================================================ +template +T IndexedHeap::remove(int n) +{ + // lglASSERT ( (n>=0)&&(n0) + { + m_p[n] = last; + (*m_i)(last) = n; + downsort(n); + } + return f; +} +//============================================================================ + + +//============================================================================ +template +void IndexedHeap::clear() +{ + for (typename std::vector::iterator i=m_p.begin(); i!=m_p.end(); ++i) + { + (*m_i)(*i)=-1; + } + m_p.clear(); +} +//============================================================================ + + +//============================================================================ +template +int IndexedHeap::father( int i) const +{ + return ((i-1)/2); +} +//============================================================================ + +//============================================================================ +template +int IndexedHeap::rightson( int i) const +{ + return (i*2+2); +} +//============================================================================ + +//============================================================================ +template +int IndexedHeap::leftson( int i) const +{ + return (i*2+1); +} +//============================================================================ + +//============================================================================ +template +void IndexedHeap::swap(int i, int j) +{ + T tmp = m_p[i]; + m_p[i] = m_p[j]; + m_p[j] = tmp; + // update indices + (*m_i)(m_p[i]) = i; + (*m_i)(m_p[j]) = j; +} +//============================================================================ + + + +//============================================================================ +template +int IndexedHeap::upsort(int i) +{ + //if (i==0) return i; + int j = father(i); + while ((i>0)&&(*m_c)(m_p[i],m_p[j])) + { + swap(i,j); + i = j; + j = father(j); + } + return i; +} +//============================================================================ + + +//============================================================================ +template +int IndexedHeap::downsort(int i) +{ + do + { + + unsigned int ls = leftson(i); + if (ls