MultiNodeStatistics.cc

00001 // Copyright 2008 Michael Marsh, University of Maryland.
00002 //
00003 // This file is part of pydtn.
00004 //
00005 // pydtn is free software: you can redistribute it and/or modify
00006 // it under the terms of the GNU General Public License as published by
00007 // the Free Software Foundation, either version 3 of the License, or
00008 // (at your option) any later version.
00009 //
00010 // pydtn is distributed in the hope that it will be useful,
00011 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00012 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00013 // GNU General Public License for more details.
00014 //
00015 // You should have received a copy of the GNU General Public License
00016 // along with pydtn.  If not, see <http://www.gnu.org/licenses/>.
00017 //
00018 // The views and conclusions contained in the software and documentation
00019 // are those of the authors and should not be interpreted as representing
00020 // official policies, either expressed or implied, of the University
00021 // of Maryland.
00022 //
00023 // pydtn extends and embeds the Python interpreter, which is
00024 // Copyright 2001-2006 Python Software Foundation, All Rights Reserved,
00025 // and is released under the PSF License Agreement.
00026 //
00027 // RANLUX random number generation uses the Boost library,
00028 // Copyright 1994-2006 by various authors (details in individual files),
00029 // which is released under the Boost Software License, Version 1.0.
00030 
00031 #include "MultiNodeStatistics.h"
00032 #include "dtn/Node.h"
00033 
00034 #include <iostream>
00035 
00036 MultiNodeStatistics::MultiNodeStatistics() :
00037    Statistics(0)
00038 {
00039 }
00040 
00041 unsigned long int
00042 MultiNodeStatistics::used() const
00043 {
00044    unsigned long int total = 0;
00045    NodeList::const_iterator itr = m_nodes.begin();
00046    NodeList::const_iterator end = m_nodes.end();
00047    for ( ; itr != end ; ++itr )
00048    {
00049       if ( 0 != *itr )
00050       {
00051          total += (*itr)->usedPersistentCap();
00052       }
00053    }
00054 
00055    return total;
00056 }
00057 
00058 unsigned long int
00059 MultiNodeStatistics::capacity() const
00060 {
00061    unsigned long int total = 0;
00062    NodeList::const_iterator itr = m_nodes.begin();
00063    NodeList::const_iterator end = m_nodes.end();
00064    for ( ; itr != end ; ++itr )
00065    {
00066       if ( 0 != *itr )
00067       {
00068          total += (*itr)->persistentCap();
00069       }
00070    }
00071 
00072    return total;
00073 }
00074 
00075 double
00076 MultiNodeStatistics::maxUsed() const
00077 {
00078    double retval = 0;
00079    NodeList::const_iterator itr = m_nodes.begin();
00080    NodeList::const_iterator end = m_nodes.end();
00081    for ( ; itr != end ; ++itr )
00082    {
00083       if ( 0 != *itr )
00084       {
00085          if ( (*itr)->persistentCap() > 0 )
00086          {
00087             double f =
00088                (double)((*itr)->usedPersistentCap()) / (*itr)->persistentCap();
00089             if ( f > retval ) retval = f;
00090          }
00091       }
00092    }
00093 
00094    return retval;
00095 }
00096 
00097 void
00098 MultiNodeStatistics::persistentStore( const DTN::Bundle& b )
00099 {
00100    NodeList::const_iterator itr = m_nodes.begin();
00101    NodeList::const_iterator end = m_nodes.end();
00102    for ( ; itr != end ; ++itr )
00103    {
00104       if ( 0 != *itr )
00105       {
00106          unsigned long int cap  = (*itr)->persistentCap();
00107          unsigned long int used = (*itr)->usedPersistentCap();
00108          if ( used >= cap )
00109          {
00110             m_since.setExhausted();
00111             m_total.setExhausted();
00112             return;
00113          }
00114       }
00115    }
00116 }
00117 
00118 void
00119 MultiNodeStatistics::addNode( DTN::Node* n )
00120 {
00121    if ( 0 == n ) return;
00122    m_nodes.push_back( n );
00123 }

Generated on Mon Mar 24 11:15:46 2008 for Pydtn Simulator by  doxygen 1.5.4