author | Nicola Baldo <nbaldo@cttc.es> |
Tue, 24 Jan 2012 13:38:59 +0100 | |
changeset 8578 | 50484f99be63 |
parent 8560 | 729a6248d9d3 |
child 8605 | 55a01da4a323 |
permissions | -rw-r--r-- |
8560
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
1 |
/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */ |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
2 |
/* |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
3 |
* Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC) |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
4 |
* |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
5 |
* This program is free software; you can redistribute it and/or modify |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
6 |
* it under the terms of the GNU General Public License version 2 as |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
8 |
* |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
9 |
* This program is distributed in the hope that it will be useful, |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
12 |
* GNU General Public License for more details. |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
13 |
* |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
14 |
* You should have received a copy of the GNU General Public License |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
15 |
* along with this program; if not, write to the Free Software |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
16 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
17 |
* |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
18 |
* Author: Manuel Requena <manuel.requena@cttc.es> |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
19 |
* Nicola Baldo <nbaldo@cttc.es> |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
20 |
*/ |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
21 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
22 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
23 |
#include "ns3/core-module.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
24 |
#include "ns3/network-module.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
25 |
#include "ns3/mobility-module.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
26 |
#include "ns3/lte-module.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
27 |
#include "ns3/config-store.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
28 |
#include "ns3/spectrum-module.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
29 |
//#include "ns3/gtk-config-store.h" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
30 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
31 |
using namespace ns3; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
32 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
33 |
int main (int argc, char *argv[]) |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
34 |
{ |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
35 |
CommandLine cmd; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
36 |
cmd.Parse (argc, argv); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
37 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
38 |
// to save a template default attribute file run it like this: |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
39 |
// ./waf --command-template="%s --ns3::ConfigStore::Filename=input-defaults.txt --ns3::ConfigStore::Mode=Save --ns3::ConfigStore::FileFormat=RawText" --run src/lte/examples/lena-first-sim |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
40 |
// |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
41 |
// to load a previously created default attribute file |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
42 |
// ./waf --command-template="%s --ns3::ConfigStore::Filename=input-defaults.txt --ns3::ConfigStore::Mode=Load --ns3::ConfigStore::FileFormat=RawText" --run src/lte/examples/lena-first-sim |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
43 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
44 |
ConfigStore inputConfig; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
45 |
inputConfig.ConfigureDefaults (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
46 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
47 |
// Parse again so you can override default values from the command line |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
48 |
cmd.Parse (argc, argv); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
49 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
50 |
Ptr<LteHelper> lteHelper = CreateObject<LteHelper> (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
51 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
52 |
// Uncomment to enable logging |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
53 |
//lteHelper->EnableLogComponents (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
54 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
55 |
// Create Nodes: eNodeB and UE |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
56 |
NodeContainer enbNodes; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
57 |
NodeContainer ueNodes; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
58 |
enbNodes.Create (1); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
59 |
ueNodes.Create (1); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
60 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
61 |
// Install Mobility Model |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
62 |
MobilityHelper mobility; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
63 |
mobility.SetMobilityModel ("ns3::BuildingsMobilityModel"); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
64 |
mobility.Install (enbNodes); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
65 |
mobility.SetMobilityModel ("ns3::BuildingsMobilityModel"); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
66 |
mobility.Install (ueNodes); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
67 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
68 |
// Create Devices and install them in the Nodes (eNB and UE) |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
69 |
NetDeviceContainer enbDevs; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
70 |
NetDeviceContainer ueDevs; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
71 |
// Default scheduler is PF, uncomment to use RR |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
72 |
//lteHelper->SetSchedulerType ("ns3::RrFfMacScheduler"); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
73 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
74 |
enbDevs = lteHelper->InstallEnbDevice (enbNodes); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
75 |
ueDevs = lteHelper->InstallUeDevice (ueNodes); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
76 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
77 |
// Attach a UE to a eNB |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
78 |
lteHelper->Attach (ueDevs, enbDevs.Get (0)); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
79 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
80 |
// Activate an EPS bearer |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
81 |
enum EpsBearer::Qci q = EpsBearer::GBR_CONV_VOICE; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
82 |
EpsBearer bearer (q); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
83 |
lteHelper->ActivateEpsBearer (ueDevs, bearer, EpcTft::Default ()); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
84 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
85 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
86 |
// Configure Radio Environment Map (REM) output |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
87 |
// for LTE-only simulations always use /ChannelList/0 which is the downlink channel |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
88 |
Ptr<RadioEnvironmentMapHelper> remHelper = CreateObject<RadioEnvironmentMapHelper> (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
89 |
remHelper->SetAttribute ("ChannelPath", StringValue ("/ChannelList/0")); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
90 |
remHelper->SetAttribute ("OutputFile", StringValue ("rem.out")); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
91 |
remHelper->SetAttribute ("XMin", DoubleValue (-400.0)); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
92 |
remHelper->SetAttribute ("XMax", DoubleValue (400.0)); |
8578
50484f99be63
REM helper deactivates PHYs instead of removing, and exit when done by default
Nicola Baldo <nbaldo@cttc.es>
parents:
8560
diff
changeset
|
93 |
remHelper->SetAttribute ("XRes", UintegerValue (40)); |
8560
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
94 |
remHelper->SetAttribute ("YMin", DoubleValue (-300.0)); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
95 |
remHelper->SetAttribute ("YMax", DoubleValue (300.0)); |
8578
50484f99be63
REM helper deactivates PHYs instead of removing, and exit when done by default
Nicola Baldo <nbaldo@cttc.es>
parents:
8560
diff
changeset
|
96 |
remHelper->SetAttribute ("YRes", UintegerValue (30)); |
8560
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
97 |
remHelper->SetAttribute ("Z", DoubleValue (0.0)); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
98 |
remHelper->Install (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
99 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
100 |
// here's a minimal gnuplot script that will plot the above: |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
101 |
// |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
102 |
// set view map; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
103 |
// set term x11; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
104 |
// set xlabel "X" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
105 |
// set ylabel "Y" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
106 |
// set cblabel "SINR (dB)" |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
107 |
// plot "rem.out" using ($1):($2):(10*log10($4)) with image |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
108 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
109 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
110 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
111 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
112 |
Simulator::Stop (Seconds (0.020)); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
113 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
114 |
Simulator::Run (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
115 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
116 |
//GtkConfigStore config; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
117 |
//config.ConfigureAttributes (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
118 |
|
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
119 |
Simulator::Destroy (); |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
120 |
return 0; |
729a6248d9d3
added support to generate Radio Environment Maps
Nicola Baldo <nbaldo@cttc.es>
parents:
diff
changeset
|
121 |
} |