A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
lte-test-uplink-sinr.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Manuel Requena <manuel.requena@cttc.es>
18 * Modified by Marco Miozzo <mmiozzo@ctt.es>
19 * Extend to Data and SRS frames
20 */
21
22#ifndef LTE_TEST_UPLINK_SINR_H
23#define LTE_TEST_UPLINK_SINR_H
24
25#include "ns3/spectrum-value.h"
26#include "ns3/test.h"
27
28using namespace ns3;
29
30/**
31 * \ingroup lte-test
32 *
33 * \brief Test 1.2 SINR calculation in uplink
34 */
36{
37 public:
39};
40
41/**
42 * \ingroup lte-test
43 *
44 * \brief Test generation of SINR in the uplink. Test schedules the signal and the interference
45 * signals and it evaluates if the obtained value for SINR corresponds to the theoretical value
46 * in given conditions.
47 */
49{
50 public:
51 /**
52 * Constructor
53 *
54 * \param sv1 spectrum value 1
55 * \param sv2 spectrum value 2
56 * \param sinr the SINR
57 * \param name the reference name
58 */
62 std::string name);
64
65 private:
66 void DoRun() override;
67
68 Ptr<SpectrumValue> m_sv1; ///< the spectrum value #1
69 Ptr<SpectrumValue> m_sv2; ///< the spectrum value #2
70 Ptr<const SpectrumModel> m_sm; ///< the spectrum model
71 Ptr<SpectrumValue> m_expectedSinr; ///< the expected SINR
72};
73
74/**
75 * \ingroup lte-test
76 *
77 * \brief In this test one signal will be of interest, i.e., the
78 * SRS of the first signal will have the same CellId of the
79 * receiving PHY; the others will have a different
80 * CellId and hence will be the interfering signals. The test
81 * checks whether the SINR of the signal correspond to the
82 * theoretical value.
83 */
85{
86 public:
87 /**
88 * Constructor
89 *
90 * \param sv1 spectrum value 1
91 * \param sv2 spectrum value 2
92 * \param sinr the SINR
93 * \param name the reference name
94 */
98 std::string name);
100
101 /**
102 * Callback to be connected to an LteChunkProcessor to collect the reported SINR
103 *
104 * \param sinr
105 */
106 void ReportSinr(const SpectrumValue& sinr);
107
108 private:
109 void DoRun() override;
110
111 Ptr<SpectrumValue> m_sv1; ///< the spectrum value #1
112 Ptr<SpectrumValue> m_sv2; ///< the spectrum value #2
113 Ptr<const SpectrumModel> m_sm; ///< the spectrum model
114
115 Ptr<SpectrumValue> m_expectedSinr; ///< the expected SINR
116 Ptr<SpectrumValue> m_actualSinr; ///< the actual SINR
117};
118
119#endif /* LTE_TEST_UPLINK_SINR_H */
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Set of values corresponding to a given SpectrumModel.
encapsulates test code
Definition: test.h:1061
A suite of tests to run.
Definition: test.h:1268
Every class exported by the ns3 library is enclosed in the ns3 namespace.