Source code for simulator.generators.DtnFileBroadcaster

import numpy as np
from simulator.core.DtnBundle import Bundle
from simulator.generators.DtnAbstractGenerator import DtnAbstractGenerator

[docs]class DtnFileBroadcaster(DtnAbstractGenerator): def initialize(self): # Get generator properties self.file_sz = self.props.size # in [bits] self.tstart = self.props.tstart # in [sec] from start of simulation. self.nodes = list(self.env.nodes.keys()) self.nodes.remove(self.parent.nid) # Get bundle properties self.data_type = self.props.data_type self.bundle_sz = self.props.bundle_size self.bundle_lat = self.props.bundle_TTL self.critical = self.props.critical self.repeat = self.props.repeat self.wait = self.props.wait # Get origin for all bundles self.orig = self.parent.nid # Compute how many bundles to generate self.Nbnd = int(np.ceil(self.file_sz / self.bundle_sz)) # Run generator self.env.process(self.run()) def run(self): # Wait until it is time to start this flow yield self.env.timeout(self.tstart) # Send file as many times as needed for i in range(self.repeat): # Since DTN does not have multi-cast routing, just create # copies of bundle to destination for destination in self.nodes: # Send as many bundles as needed for j in range(self.Nbnd): # Create a new bundle and record it new_bundle = Bundle(self.env, self.orig, destination, self.data_type, self.bundle_sz, self.bundle_lat, self.critical, fid=(self.orig, destination, self.fid, i, j), TTL=self.bundle_lat) # Monitor the new bundle creation self.monitor_new_bundle(new_bundle) # Log the new bundle creation self.disp('{} is created at node {}', new_bundle, self.parent.nid) # Schedule routers of bundle self.parent.forward(new_bundle) # Wait for a while before sending the file again yield self.env.timeout(self.wait)
[docs] def predicted_data_vol(self): return len(self.nodes)*self.bundle_sz*self.repeat