A Discrete-Event Network Simulator
API
tv-spectrum-transmitter-helper.h
Go to the documentation of this file.
1 /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2 /*
3  * Copyright (c) 2014 University of Washington
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation;
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17  *
18  * Author: Benjamin Cizdziel <ben.cizdziel@gmail.com>
19  */
20 
21 #ifndef TV_SPECTRUM_TRANSMITTER_HELPER_H
22 #define TV_SPECTRUM_TRANSMITTER_HELPER_H
23 
24 #include <ns3/spectrum-value.h>
25 #include <ns3/spectrum-phy.h>
26 #include <ns3/spectrum-channel.h>
27 #include <ns3/antenna-model.h>
28 #include <ns3/spectrum-signal-parameters.h>
29 #include <ns3/mobility-model.h>
30 #include <ns3/net-device.h>
31 #include <ns3/net-device-container.h>
32 #include <ns3/node-container.h>
33 #include <ns3/non-communicating-net-device.h>
34 #include <ns3/random-variable-stream.h>
35 #include <ns3/tv-spectrum-transmitter.h>
36 #include "ns3/object-factory.h"
37 
39 
40 namespace ns3
41 {
42 
68 {
69 
70 public:
71  friend class ::TvHelperDistributionTestCase;
72 
76  enum Region
77  {
81  };
82 
86  enum Density
87  {
91  };
92 
94  virtual ~TvSpectrumTransmitterHelper ();
95 
102 
109  void SetAttribute (std::string name, const AttributeValue &val);
110 
127 
149  Region region,
150  uint16_t channelNumber);
151 
177 
206  Region region,
207  uint16_t channelNumber);
208 
215  int64_t AssignStreams (int64_t streamNum);
216 
251  void CreateRegionalTvTransmitters (Region region,
252  Density density,
253  double originLatitude,
254  double originLongitude,
255  double maxAltitude,
256  double maxRadius);
257 
258 
259 private:
261 
279  std::list<int> GenerateRegionalTransmitterIndices (const double startFrequencies[],
280  const int startFrequenciesLength,
281  Density density);
282 
306  int GetRandomNumTransmitters (Density density, uint32_t numChannels);
307 
320  std::list<int> transmitterIndicesToCreate,
321  std::list<Vector> transmitterLocations);
322 
325 
326 };
327 
328 } // namespace ns3
329 
330 #endif /* TV_SPECTRUM_TRANSMITTER_HELPER_H */
This test verifies the accuracy of the private GetRandomNumTransmitters() method in the TvSpectrumT...
Hold a value for an Attribute.
Definition: attribute.h:69
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
Instantiate subclasses of ns3::Object.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:74
Helper class which uses TvSpectrumTransmitter class to create customizable TV transmitter(s) that tra...
std::list< int > GenerateRegionalTransmitterIndices(const double startFrequencies[], const int startFrequenciesLength, Density density)
Generates random indices of given region frequency array (ignoring indices referring to invalid chann...
void SetChannel(Ptr< SpectrumChannel > c)
Set the spectrum channel for the device(s) to transmit on.
NetDeviceContainer InstallAdjacent(NodeContainer nodes)
Set up and start the TV Transmitter's transmission on the spectrum channel.
Density
density of location that TV transmitters are being set up in
void InstallRandomRegionalTransmitters(Region region, std::list< int > transmitterIndicesToCreate, std::list< Vector > transmitterLocations)
Installs each randomly generated regional TV transmitter.
Region
geographical region that TV transmitters are being set up in
int GetRandomNumTransmitters(Density density, uint32_t numChannels)
Randomly generates the number of TV transmitters to be created based on given density and number of p...
Ptr< UniformRandomVariable > m_uniRand
Object to generate uniform random numbers.
int64_t AssignStreams(int64_t streamNum)
Assigns the stream number for the uniform random number generator to use.
ObjectFactory m_factory
Object factory for attribute setting.
void CreateRegionalTvTransmitters(Region region, Density density, double originLatitude, double originLongitude, double maxAltitude, double maxRadius)
Generates and installs (starts transmission on the spectrum channel) a random number of TV transmitte...
void SetAttribute(std::string name, const AttributeValue &val)
Set attribute for each TvSpectrumTransmitter instance to be created.
NetDeviceContainer Install(NodeContainer nodes)
Set up and start the TV Transmitter's transmission on the spectrum channel.
Ptr< SpectrumChannel > m_channel
Pointer to spectrum channel object.
nodes
Definition: first.py:32
Every class exported by the ns3 library is enclosed in the ns3 namespace.
int density
Make a probability density histogram.