BundleCollector.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 "simlpy/interpreter_defs.h"
00032 
00033 #include "BundleCollector.h"
00034 #include "pydtn/WrapNode.h"
00035 #include "pydtn/Statistics.h"
00036 
00037 using namespace StoreProfile;
00038 
00039 BundleCollector::BundleCollector( std::ostream& s ) :
00040    m_stream(s)
00041 {
00042 }
00043 
00044 BundleCollector::~BundleCollector()
00045 {
00046 }
00047 
00048 void
00049 BundleCollector::operator()( const WrapNode& wn ) const
00050 {
00051    Stat storedData;
00052    Stat storedAcks;
00053    Stat queuedData;
00054    Stat queuedAcks;
00055 
00056    DTN::BundlePointer itr = wn.cachedVolatile();
00057    for ( ; ! itr.isNull() ; itr = itr.next() )
00058    {
00059       const DTN::Bundle* b = itr.repr()->bundle();
00060       size_t length = b->size();
00061       if ( 0 != b )
00062       {
00063          if ( DTN::Bundle::kACK & b->type() )
00064          {
00065             queuedAcks.add( length );
00066          }
00067          else
00068          {
00069             queuedData.add( length );
00070          }
00071       }
00072    }
00073 
00074    itr = wn.cachedPersistent();
00075    for ( ; ! itr.isNull() ; itr = itr.next() )
00076    {
00077       const DTN::Bundle* b = itr.repr()->bundle();
00078       size_t length = b->size();
00079       if ( 0 != b )
00080       {
00081          if ( DTN::Bundle::kACK & b->type() )
00082          {
00083             storedAcks.add( length );
00084          }
00085          else
00086          {
00087             storedData.add( length );
00088          }
00089       }
00090    }
00091 
00092    m_stream << wn.addrString() << " "
00093             << "qd: " << queuedData.n() << " " << queuedData.s() << " "
00094             << "qa: " << queuedAcks.n() << " " << queuedAcks.s() << " "
00095             << "sd: " << storedData.n() << " " << storedData.s() << " "
00096             << "sa: " << storedAcks.n() << " " << storedAcks.s() << std::endl;
00097 }

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