21 #include <ns3/object.h> 
   22 #include <ns3/simulator.h> 
   24 #include <ns3/packet.h> 
   25 #include <ns3/packet-burst.h> 
   26 #include <ns3/net-device.h> 
   28 #include <ns3/double.h> 
   29 #include <ns3/mobility-model.h> 
   30 #include <ns3/spectrum-phy.h> 
   31 #include <ns3/spectrum-propagation-loss-model.h> 
   32 #include <ns3/propagation-loss-model.h> 
   33 #include <ns3/propagation-delay-model.h> 
   34 #include <ns3/antenna-model.h> 
   35 #include <ns3/angles.h> 
   38 #include "single-model-spectrum-channel.h" 
   47 NS_OBJECT_ENSURE_REGISTERED (SingleModelSpectrumChannel);
 
   49 SingleModelSpectrumChannel::SingleModelSpectrumChannel ()
 
   67 SingleModelSpectrumChannel::GetTypeId (
void)
 
   70   static TypeId tid = 
TypeId (
"ns3::SingleModelSpectrumChannel")
 
   72     .AddConstructor<SingleModelSpectrumChannel> ()
 
   73     .AddAttribute (
"MaxLossDb",
 
   74                    "If a single-frequency PropagationLossModel is used, this value " 
   75                    "represents the maximum loss in dB for which transmissions will be " 
   76                    "passed to the receiving PHY. Signals for which the PropagationLossModel " 
   77                    "returns a loss bigger than this value will not be propagated to the receiver. " 
   78                    "This parameter is to be used to reduce " 
   79                    "the computational load by not propagating signals that are far beyond " 
   80                    "the interference range. Note that the default value corresponds to " 
   81                    "considering all signals for reception. Tune this value with care. ",
 
   83                    MakeDoubleAccessor (&SingleModelSpectrumChannel::m_maxLossDb),
 
   84                    MakeDoubleChecker<double> ())
 
   85     .AddTraceSource (
"PathLoss",
 
   86                      "This trace is fired " 
   87                      "whenever a new path loss value is calculated. The first and second parameters " 
   88                      "to the trace are pointers respectively to the TX and RX SpectrumPhy instances, " 
   89                      "whereas the third parameters is the loss value in dB. Note that the loss value " 
   90                      "reported by this trace is the single-frequency loss value obtained by evaluating " 
   91                      "only the TX and RX AntennaModels and the PropagationLossModel. In particular, note that " 
   92                      "SpectrumPropagationLossModel (even if present) is never used to evaluate the loss value " 
   93                      "reported in this trace. ",
 
  111   NS_LOG_FUNCTION (
this << txParams->psd << txParams->duration << txParams->txPhy);
 
  132   for (PhyList::const_iterator rxPhyIterator = 
m_phyList.begin ();
 
  136       if ((*rxPhyIterator) != txParams->txPhy)
 
  141           NS_LOG_LOGIC (
"copying signal parameters " << txParams);
 
  144           if (senderMobility && receiverMobility)
 
  146               double pathLossDb = 0;
 
  147               if (rxParams->txAntenna != 0)
 
  150                   double txAntennaGain = rxParams->txAntenna->GetGainDb (txAngles);
 
  151                   NS_LOG_LOGIC (
"txAntennaGain = " << txAntennaGain << 
" dB");
 
  152                   pathLossDb -= txAntennaGain;
 
  158                   double rxAntennaGain = rxAntenna->GetGainDb (rxAngles);
 
  159                   NS_LOG_LOGIC (
"rxAntennaGain = " << rxAntennaGain << 
" dB");
 
  160                   pathLossDb -= rxAntennaGain;
 
  165                   NS_LOG_LOGIC (
"propagationGainDb = " << propagationGainDb << 
" dB");
 
  166                   pathLossDb -= propagationGainDb;
 
  168               NS_LOG_LOGIC (
"total pathLoss = " << pathLossDb << 
" dB");    
 
  169               m_pathLossTrace (txParams->txPhy, *rxPhyIterator, pathLossDb);
 
  170               if ( pathLossDb > m_maxLossDb)
 
  175               double pathGainLinear = std::pow (10.0, (-pathLossDb) / 10.0);
 
  176               *(rxParams->psd) *= pathGainLinear;              
 
  194               uint32_t dstNode =  netDev->GetNode ()->GetId ();
 
  201                                    rxParams, *rxPhyIterator);
 
  260 SingleModelSpectrumChannel::GetSpectrumPropagationLossModel (
void)
 
#define NS_LOG_FUNCTION(parameters)
virtual void StartRx(Ptr< SpectrumSignalParameters > params)=0
Ptr< PropagationDelayModel > m_propagationDelay
virtual void AddRx(Ptr< SpectrumPhy > phy)
add a SpectrumPhy to a channel, so it can receive packets 
virtual void AddSpectrumPropagationLossModel(Ptr< SpectrumPropagationLossModel > loss)
#define NS_ASSERT(condition)
#define NS_LOG_COMPONENT_DEFINE(name)
Vector GetPosition(void) const 
virtual void DoDispose(void)
#define NS_LOG_FUNCTION_NOARGS()
static EventId Schedule(Time const &time, MEM mem_ptr, OBJ obj)
virtual void AddPropagationLossModel(Ptr< PropagationLossModel > loss)
virtual Ptr< NetDevice > GetDevice(uint32_t i) const 
Ptr< PropagationLossModel > m_propagationLoss
void StartRx(Ptr< SpectrumSignalParameters > params, Ptr< SpectrumPhy > receiver)
double CalcRxPower(double txPowerDbm, Ptr< MobilityModel > a, Ptr< MobilityModel > b) const 
virtual uint32_t GetNDevices(void) const 
static void ScheduleWithContext(uint32_t context, Time const &time, MEM mem_ptr, OBJ obj)
#define NS_LOG_LOGIC(msg)
Ptr< const TraceSourceAccessor > MakeTraceSourceAccessor(T a)
virtual void StartTx(Ptr< SpectrumSignalParameters > params)
Ptr< SpectrumPropagationLossModel > m_spectrumPropagationLoss
#define NS_ASSERT_MSG(condition, message)
Network layer to device interface. 
virtual void SetPropagationDelayModel(Ptr< PropagationDelayModel > delay)
Hold an floating point type. 
a unique identifier for an interface. 
TypeId SetParent(TypeId tid)
Time MicroSeconds(uint64_t us)
create ns3::Time instances in units of microseconds. 
Ptr< const SpectrumModel > m_spectrumModel