# # NEPI, a framework to manage network experiments # Copyright (C) 2014 INRIA # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License version 2 as # published by the Free Software Foundation; # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . # from nepi.execution.attribute import Attribute, Flags, Types from nepi.execution.trace import Trace, TraceAttr from nepi.execution.resource import ResourceManager, clsinit_copy, \ ResourceState from nepi.resources.ns3.ns3propagationlossmodel import NS3BasePropagationLossModel @clsinit_copy class NS3FriisPropagationLossModel(NS3BasePropagationLossModel): _rtype = "ns3::FriisPropagationLossModel" @classmethod def _register_attributes(cls): attr_frequency = Attribute("Frequency", "The carrier frequency (in Hz) at which propagation occurs (default is 5.15 GHz).", type = Types.Double, default = "5.15e+09", allowed = None, range = None, flags = Flags.Reserved | Flags.Construct) cls._register_attribute(attr_frequency) attr_systemloss = Attribute("SystemLoss", "The system loss", type = Types.Double, default = "1", allowed = None, range = None, flags = Flags.Reserved | Flags.Construct) cls._register_attribute(attr_systemloss) attr_minloss = Attribute("MinLoss", "The minimum value (dB) of the total loss, used at short ranges. Note: ", type = Types.Double, default = "0", allowed = None, range = None, flags = Flags.Reserved | Flags.Construct) cls._register_attribute(attr_minloss) @classmethod def _register_traces(cls): pass def __init__(self, ec, guid): super(NS3FriisPropagationLossModel, self).__init__(ec, guid) self._home = "ns3-friis-propagation-loss-model-%s" % self.guid