A Discrete-Event Network Simulator
Home
Tutorials ▼
English
Documentation ▼
Installation
Manual
Models
Contributing
Wiki
Development ▼
API Docs
Issue Tracker
Merge Requests
API
Loading...
Searching...
No Matches
phy-tx-stats-calculator.h
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2011 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
3
*
4
* SPDX-License-Identifier: GPL-2.0-only
5
*
6
* Author: Jaume Nin <jnin@cttc.es>
7
* modified by: Marco Miozzo <mmiozzo@cttc.es>
8
* Convert MacStatsCalculator in PhyTxStatsCalculator
9
*/
10
11
#ifndef PHY_TX_STATS_CALCULATOR_H_
12
#define PHY_TX_STATS_CALCULATOR_H_
13
14
#include "
lte-stats-calculator.h
"
15
16
#include "ns3/lte-common.h"
17
#include "ns3/nstime.h"
18
#include "ns3/uinteger.h"
19
20
#include <fstream>
21
#include <string>
22
23
namespace
ns3
24
{
25
26
/**
27
* @ingroup lte
28
*
29
* Takes care of storing the information generated at PHY layer regarding
30
* transmission. Metrics saved are:
31
*
32
* - Timestamp (in seconds)
33
* - Frame index
34
* - Subframe index
35
* - C-RNTI
36
* - MCS for transport block 1
37
* - Size of transport block 1
38
* - MCS for transport block 2 (0 if not used)
39
* - Size of transport block 2 (0 if not used)
40
*/
41
class
PhyTxStatsCalculator
:
public
LteStatsCalculator
42
{
43
public
:
44
/**
45
* Constructor
46
*/
47
PhyTxStatsCalculator
();
48
49
/**
50
* Destructor
51
*/
52
~PhyTxStatsCalculator
()
override
;
53
54
// Inherited from ns3::Object
55
/**
56
* Register this type.
57
* @return The object TypeId.
58
*/
59
static
TypeId
GetTypeId
();
60
61
/**
62
* Set the name of the file where the UL Tx PHY statistics will be stored.
63
*
64
* @param outputFilename string with the name of the file
65
*/
66
void
SetUlTxOutputFilename
(std::string outputFilename);
67
68
/**
69
* Get the name of the file where the UL RX PHY statistics will be stored.
70
* @return the name of the file where the UL RX PHY statistics will be stored
71
*/
72
std::string
GetUlTxOutputFilename
();
73
74
/**
75
* Set the name of the file where the DL TX PHY statistics will be stored.
76
*
77
* @param outputFilename string with the name of the file
78
*/
79
void
SetDlTxOutputFilename
(std::string outputFilename);
80
81
/**
82
* Get the name of the file where the DL TX PHY statistics will be stored.
83
* @return the name of the file where the DL TX PHY statistics will be stored
84
*/
85
std::string
GetDlTxOutputFilename
();
86
87
/**
88
* Notifies the stats calculator that an downlink transmission has occurred.
89
* @param params Trace information regarding PHY transmission stats
90
*/
91
void
DlPhyTransmission
(
PhyTransmissionStatParameters
params);
92
93
/**
94
* Notifies the stats calculator that an uplink transmission has occurred.
95
* @param params Trace information regarding PHY transmission stats
96
*/
97
void
UlPhyTransmission
(
PhyTransmissionStatParameters
params);
98
99
/**
100
* trace sink
101
*
102
* @param phyTxStats
103
* @param path
104
* @param params
105
*/
106
static
void
DlPhyTransmissionCallback
(
Ptr<PhyTxStatsCalculator>
phyTxStats,
107
std::string path,
108
PhyTransmissionStatParameters
params);
109
110
/**
111
* trace sink
112
*
113
* @param phyTxStats
114
* @param path
115
* @param params
116
*/
117
static
void
UlPhyTransmissionCallback
(
Ptr<PhyTxStatsCalculator>
phyTxStats,
118
std::string path,
119
PhyTransmissionStatParameters
params);
120
121
private
:
122
/**
123
* When writing DL TX PHY statistics first time to file,
124
* columns description is added. Then next lines are
125
* appended to file. This value is true if output
126
* files have not been opened yet
127
*/
128
bool
m_dlTxFirstWrite
;
129
130
/**
131
* When writing UL TX PHY statistics first time to file,
132
* columns description is added. Then next lines are
133
* appended to file. This value is true if output
134
* files have not been opened yet
135
*/
136
bool
m_ulTxFirstWrite
;
137
138
/**
139
* DL TX PHY statistics output trace file
140
*/
141
std::ofstream
m_dlTxOutFile
;
142
143
/**
144
* UL TX PHY statistics output trace file
145
*/
146
std::ofstream
m_ulTxOutFile
;
147
};
148
149
}
// namespace ns3
150
151
#endif
/* PHY_TX_STATS_CALCULATOR_H_ */
ns3::LteStatsCalculator::LteStatsCalculator
LteStatsCalculator()
Constructor.
Definition
lte-stats-calculator.cc:25
ns3::PhyTxStatsCalculator::m_ulTxFirstWrite
bool m_ulTxFirstWrite
When writing UL TX PHY statistics first time to file, columns description is added.
Definition
phy-tx-stats-calculator.h:136
ns3::PhyTxStatsCalculator::SetDlTxOutputFilename
void SetDlTxOutputFilename(std::string outputFilename)
Set the name of the file where the DL TX PHY statistics will be stored.
Definition
phy-tx-stats-calculator.cc:79
ns3::PhyTxStatsCalculator::SetUlTxOutputFilename
void SetUlTxOutputFilename(std::string outputFilename)
Set the name of the file where the UL Tx PHY statistics will be stored.
Definition
phy-tx-stats-calculator.cc:67
ns3::PhyTxStatsCalculator::m_dlTxFirstWrite
bool m_dlTxFirstWrite
When writing DL TX PHY statistics first time to file, columns description is added.
Definition
phy-tx-stats-calculator.h:128
ns3::PhyTxStatsCalculator::DlPhyTransmissionCallback
static void DlPhyTransmissionCallback(Ptr< PhyTxStatsCalculator > phyTxStats, std::string path, PhyTransmissionStatParameters params)
trace sink
Definition
phy-tx-stats-calculator.cc:160
ns3::PhyTxStatsCalculator::PhyTxStatsCalculator
PhyTxStatsCalculator()
Constructor.
Definition
phy-tx-stats-calculator.cc:24
ns3::PhyTxStatsCalculator::m_ulTxOutFile
std::ofstream m_ulTxOutFile
UL TX PHY statistics output trace file.
Definition
phy-tx-stats-calculator.h:146
ns3::PhyTxStatsCalculator::DlPhyTransmission
void DlPhyTransmission(PhyTransmissionStatParameters params)
Notifies the stats calculator that an downlink transmission has occurred.
Definition
phy-tx-stats-calculator.cc:91
ns3::PhyTxStatsCalculator::GetDlTxOutputFilename
std::string GetDlTxOutputFilename()
Get the name of the file where the DL TX PHY statistics will be stored.
Definition
phy-tx-stats-calculator.cc:85
ns3::PhyTxStatsCalculator::m_dlTxOutFile
std::ofstream m_dlTxOutFile
DL TX PHY statistics output trace file.
Definition
phy-tx-stats-calculator.h:141
ns3::PhyTxStatsCalculator::UlPhyTransmission
void UlPhyTransmission(PhyTransmissionStatParameters params)
Notifies the stats calculator that an uplink transmission has occurred.
Definition
phy-tx-stats-calculator.cc:125
ns3::PhyTxStatsCalculator::GetUlTxOutputFilename
std::string GetUlTxOutputFilename()
Get the name of the file where the UL RX PHY statistics will be stored.
Definition
phy-tx-stats-calculator.cc:73
ns3::PhyTxStatsCalculator::GetTypeId
static TypeId GetTypeId()
Register this type.
Definition
phy-tx-stats-calculator.cc:46
ns3::PhyTxStatsCalculator::UlPhyTransmissionCallback
static void UlPhyTransmissionCallback(Ptr< PhyTxStatsCalculator > phyTxStats, std::string path, PhyTransmissionStatParameters params)
trace sink
Definition
phy-tx-stats-calculator.cc:184
ns3::PhyTxStatsCalculator::~PhyTxStatsCalculator
~PhyTxStatsCalculator() override
Destructor.
Definition
phy-tx-stats-calculator.cc:31
ns3::Ptr
Smart pointer class similar to boost::intrusive_ptr.
Definition
ptr.h:67
ns3::TypeId
a unique identifier for an interface.
Definition
type-id.h:49
lte-stats-calculator.h
ns3
Every class exported by the ns3 library is enclosed in the ns3 namespace.
ns3::PhyTransmissionStatParameters
PhyTransmissionStatParameters structure.
Definition
lte-common.h:177
src
lte
helper
phy-tx-stats-calculator.h
Generated on Fri Oct 24 2025 18:44:47 for ns-3 by
1.13.2