HeavyTailBundleMaker.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 #include "simlpy/interpreter_hooks.h"
00033 
00034 #include "HeavyTailBundleMaker.h"
00035 #include "WrapNode.h"
00036 #include "MockBundle.h"
00037 #include "BundleEvent.h"
00038 #include "simlpy/Clock.h"
00039 #include "simlpy/SimulationException.h"
00040 
00041 HeavyTailBundleMaker::HeavyTailBundleMaker( WrapNode* source,
00042                                             WrapNode* destination,
00043                                             const DTN::ByteString& app,
00044                                             unsigned int size,
00045                                             double alpha ) :
00046    m_source( source ),
00047    m_destination( destination ),
00048    m_app( app ),
00049    m_size( size ),
00050    m_alpha( alpha )
00051 {
00052    if ( 0 == m_source ) throw SimulationException( __FILE__ , __LINE__ );
00053    if ( 0 == m_destination ) throw SimulationException( __FILE__ , __LINE__ );
00054 }
00055 
00056 HeavyTailBundleMaker::~HeavyTailBundleMaker()
00057 {
00058 }
00059 
00060 void
00061 HeavyTailBundleMaker::generate()
00062 {
00063    Time now = Clock::time();
00064    Time expire = now + m_source->bundleLifetime();
00065    double r = prng();
00066    double lr = -1.0 * ::log(r) / m_alpha;
00067    double x = ::exp(lr);
00068    long int size = (long int) ::floor(m_size*x);
00069    DTN::Bundle* b = new MockBundle( m_source->node().nextSeq(),
00070                                     m_source->addr(),
00071                                     m_destination->addr(),
00072                                     size,
00073                                     now.tv,
00074                                     expire.tv,
00075                                     DTN::Bundle::kData,
00076                                     m_app );
00077    Clock::schedule( new BundleEvent(m_source,m_source,now,now,b,true) );
00078 }

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