21#ifndef LTE_TEST_DOWNLINK_FR_H 
   22#define LTE_TEST_DOWNLINK_FR_H 
   24#include "ns3/lte-spectrum-value-helper.h" 
   26#include "ns3/spectrum-test.h" 
   27#include "ns3/spectrum-value.h" 
   29#include <ns3/lte-rrc-sap.h> 
   72                  std::vector<bool> availableDlRb,
 
   73                  std::vector<bool> availableUlRb);
 
   88    void DoRun() 
override;
 
  127                      std::string schedulerType,
 
  128                      uint16_t dlBandwidth,
 
  129                      uint16_t ulBandwidth,
 
  130                      uint8_t dlSubBandOffset,
 
  131                      uint16_t dlSubBandwidth,
 
  132                      uint8_t ulSubBandOffset,
 
  133                      uint16_t ulSubBandwidth,
 
  134                      std::vector<bool> availableDlRb,
 
  135                      std::vector<bool> availableUlRb);
 
  139    void DoRun() 
override;
 
  178                        std::string schedulerType,
 
  179                        uint16_t dlBandwidth,
 
  180                        uint16_t ulBandwidth,
 
  181                        uint16_t dlCommonSubBandwidth,
 
  182                        uint8_t dlEdgeSubBandOffset,
 
  183                        uint16_t dlEdgeSubBandwidth,
 
  184                        uint16_t ulCommonSubBandwidth,
 
  185                        uint8_t ulEdgeSubBandOffset,
 
  186                        uint16_t ulEdgeSubBandwidth,
 
  187                        std::vector<bool> availableDlRb,
 
  188                        std::vector<bool> availableUlRb);
 
  192    void DoRun() 
override;
 
  261                     double expectedPower,
 
  262                     std::vector<bool> expectedDlRb);
 
  278    void DoRun() 
override;
 
  317    void DoRun() 
override;
 
  338    void DoRun() 
override;
 
  359    void DoRun() 
override;
 
  380    void DoRun() 
override;
 
  401    void DoRun() 
override;
 
Lte Distributed Ffr Area Test Case.
~LteDistributedFfrAreaTestCase() override
void DoRun() override
Implementation to actually run this TestCase.
Lte Enhanced Ffr Area Test Case.
void DoRun() override
Implementation to actually run this TestCase.
~LteEnhancedFfrAreaTestCase() override
Test frequency reuse algorithm by teleporting UEs to different parts of area and checking if the freq...
Time m_teleportTime
the teleport time
bool m_usedWrongUlRbg
used wrong UL RBG?
std::vector< bool > m_expectedDlRb
the expected DL per RB
void SimpleTeleportUe(uint32_t x, uint32_t y)
Simple teleport UE function.
uint16_t m_ulBandwidth
the UL bandwidth
uint16_t m_dlBandwidth
the DL bandwidth
std::vector< bool > m_expectedUlRb
expected UL per RB
void UlDataRxStart(Ptr< const SpectrumValue > spectrumValue)
UL data receive start function.
void TeleportUe2(Ptr< Node > ueNode, uint32_t x, uint32_t y, double expectedPower, std::vector< bool > expectedDlRb)
Teleport UE 2 function.
void DlDataRxStart(Ptr< const SpectrumValue > spectrumValue)
DL data receive start function.
double m_expectedUlPower
expected UL power
~LteFrAreaTestCase() override
std::string m_schedulerType
the scheduler type
void SetUlExpectedValues(double expectedPower, std::vector< bool > expectedDlRb)
Set UL expected values function.
bool m_usedWrongUlPower
used wrong UL power?
double m_expectedDlPower
the expected DL power
void SetDlExpectedValues(double expectedPower, std::vector< bool > expectedDlRb)
Set DL expected values function.
bool m_usedWrongDlRbg
used wrong DL RBG?
void TeleportUe(uint32_t x, uint32_t y, double expectedPower, std::vector< bool > expectedDlRb)
Teleport UE function.
Ptr< MobilityModel > m_ueMobility
the UE mobility model
bool m_usedWrongDlPower
used wrong DL power?
void DoRun() override
Implementation to actually run this TestCase.
Test frequency reuse algorithm.
void DlDataRxStart(Ptr< const SpectrumValue > spectrumValue)
DL data receive start function.
~LteFrTestCase() override
uint32_t m_userNum
the number of UE nodes
void UlDataRxStart(Ptr< const SpectrumValue > spectrumValue)
UL data receive start function.
void DoRun() override
Implementation to actually run this TestCase.
uint16_t m_dlBandwidth
the DL bandwidth
uint16_t m_ulBandwidth
the UL bandwidth
bool m_usedMutedDlRbg
used muted DL RBG?
std::vector< bool > m_availableDlRb
the available DL for each RB
std::vector< bool > m_availableUlRb
the available UL for each RB
bool m_usedMutedUlRbg
used muted UL RBG?
Test the fractional frequency reuse algorithms.
LteFrequencyReuseTestSuite()
TestSuite.
Test hard frequency reuse algorithm.
uint8_t m_dlSubBandOffset
the DL subband offset
uint8_t m_ulSubBandwidth
UL subband offset.
uint8_t m_ulSubBandOffset
UL subband offset.
void DoRun() override
Implementation to actually run this TestCase.
uint8_t m_dlSubBandwidth
the DL subband width
~LteHardFrTestCase() override
std::string m_schedulerType
the scheduler type
Lte Soft Ffr Area Test Case.
void DoRun() override
Implementation to actually run this TestCase.
~LteSoftFfrAreaTestCase() override
Lte Soft Fr Area Test Case.
void DoRun() override
Implementation to actually run this TestCase.
~LteSoftFrAreaTestCase() override
void DoRun() override
Implementation to actually run this TestCase.
~LteStrictFrAreaTestCase() override
Test strict frequency reuse algorithm.
uint16_t m_ulCommonSubBandwidth
UL common subbandwidth.
void DoRun() override
Implementation to actually run this TestCase.
uint16_t m_dlCommonSubBandwidth
DL common subbandwidth.
~LteStrictFrTestCase() override
uint8_t m_dlEdgeSubBandOffset
DL edge subband offset.
uint8_t m_ulEdgeSubBandOffset
UL edge subband offset.
std::string m_schedulerType
scheduler type
uint16_t m_dlEdgeSubBandwidth
DL edge subbandwidth.
uint16_t m_ulEdgeSubBandwidth
UL edge subbandwidth.
Keep track of the current position and velocity of an object.
Smart pointer class similar to boost::intrusive_ptr.
Simulation virtual time values and global simulation resolution.
Every class exported by the ns3 library is enclosed in the ns3 namespace.