A Discrete-Event Network Simulator
Home
Tutorials ▼
English
Docs ▼
Wiki
Manual
Models
Develop ▼
API
Bugs
API
delay-jitter-estimation.cc
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2007 INRIA
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
* Authors: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
19
*/
20
21
#include "
delay-jitter-estimation.h
"
22
#include "ns3/tag.h"
23
#include "ns3/simulator.h"
24
#include "ns3/string.h"
25
26
namespace
ns3
{
27
33
class
DelayJitterEstimationTimestampTag
:
public
Tag
34
{
35
public
:
36
DelayJitterEstimationTimestampTag
();
37
42
static
TypeId
GetTypeId
(
void
);
43
virtual
TypeId
GetInstanceTypeId
(
void
)
const
;
44
45
virtual
uint32_t
GetSerializedSize
(
void
)
const
;
46
virtual
void
Serialize
(
TagBuffer
i)
const
;
47
virtual
void
Deserialize
(
TagBuffer
i);
48
virtual
void
Print
(std::ostream &os)
const
;
49
54
Time
GetTxTime
(
void
)
const
;
55
private
:
56
Time
m_creationTime
;
57
};
58
59
DelayJitterEstimationTimestampTag::DelayJitterEstimationTimestampTag
()
60
: m_creationTime (
Simulator
::
Now
())
61
{
62
}
63
64
TypeId
65
DelayJitterEstimationTimestampTag::GetTypeId
(
void
)
66
{
67
static
TypeId
tid =
TypeId
(
"anon::DelayJitterEstimationTimestampTag"
)
68
.
SetParent
<
Tag
> ()
69
.SetGroupName(
"Network"
)
70
.AddConstructor<
DelayJitterEstimationTimestampTag
> ()
71
.AddAttribute (
"CreationTime"
,
72
"The time at which the timestamp was created"
,
73
TimeValue
(
Time
(0)),
74
MakeTimeAccessor
(&
DelayJitterEstimationTimestampTag::m_creationTime
),
75
MakeTimeChecker
())
76
;
77
return
tid;
78
}
79
TypeId
80
DelayJitterEstimationTimestampTag::GetInstanceTypeId
(
void
)
const
81
{
82
return
GetTypeId
();
83
}
84
85
uint32_t
86
DelayJitterEstimationTimestampTag::GetSerializedSize
(
void
)
const
87
{
88
return
8;
89
}
90
void
91
DelayJitterEstimationTimestampTag::Serialize
(
TagBuffer
i)
const
92
{
93
i.
WriteU64
(
m_creationTime
.
GetTimeStep
());
94
}
95
void
96
DelayJitterEstimationTimestampTag::Deserialize
(
TagBuffer
i)
97
{
98
m_creationTime
= TimeStep (i.
ReadU64
());
99
}
100
void
101
DelayJitterEstimationTimestampTag::Print
(std::ostream &os)
const
102
{
103
os <<
"CreationTime="
<<
m_creationTime
;
104
}
105
Time
106
DelayJitterEstimationTimestampTag::GetTxTime
(
void
)
const
107
{
108
return
m_creationTime
;
109
}
110
111
DelayJitterEstimation::DelayJitterEstimation
()
112
: m_jitter (
Time
(0)),
113
m_transit (
Time
(0))
114
{
115
}
116
void
117
DelayJitterEstimation::PrepareTx
(
Ptr<const Packet>
packet)
118
{
119
DelayJitterEstimationTimestampTag
tag;
120
packet->
AddByteTag
(tag);
121
}
122
void
123
DelayJitterEstimation::RecordRx
(
Ptr<const Packet>
packet)
124
{
125
DelayJitterEstimationTimestampTag
tag;
126
bool
found;
127
found = packet->
FindFirstMatchingByteTag
(tag);
128
if
(!found)
129
{
130
return
;
131
}
132
133
// Variable names from
134
// RFC 1889 Appendix A.8 ,p. 71,
135
// RFC 3550 Appendix A.8, p. 94
136
137
Time
r_ts = tag.
GetTxTime
();
138
Time
arrival =
Simulator::Now
();
139
Time
transit = arrival - r_ts;
140
Time
delta = transit -
m_transit
;
141
m_transit
= transit;
142
143
// floating jitter version
144
// m_jitter += (Abs (delta) - m_jitter) / 16;
145
146
// int variant
147
m_jitter
+=
Abs
(delta) - ( (
m_jitter
+ TimeStep (8)) / 16 );
148
}
149
150
Time
151
DelayJitterEstimation::GetLastDelay
(
void
)
const
152
{
153
return
m_transit
;
154
}
155
uint64_t
156
DelayJitterEstimation::GetLastJitter
(
void
)
const
157
{
158
// floating jitter version
159
// return m_jitter.GetTimeStep ();
160
161
// int variant
162
return
(
m_jitter
/ 16).GetTimeStep ();
163
}
164
165
}
// namespace ns3
ns3::TypeId
a unique identifier for an interface.
Definition:
type-id.h:59
ns3::MakeTimeChecker
Ptr< const AttributeChecker > MakeTimeChecker(const Time min, const Time max)
Helper to make a Time checker with bounded range.
Definition:
time.cc:533
ns3::DelayJitterEstimationTimestampTag::GetTxTime
Time GetTxTime(void) const
Get the Transmission time stored in the tag.
Definition:
delay-jitter-estimation.cc:106
ns3::Simulator::Now
static Time Now(void)
Return the current simulation virtual time.
Definition:
simulator.cc:195
ns3
Every class exported by the ns3 library is enclosed in the ns3 namespace.
ns3::DelayJitterEstimationTimestampTag::GetSerializedSize
virtual uint32_t GetSerializedSize(void) const
Definition:
delay-jitter-estimation.cc:86
ns3::TypeId::SetParent
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Definition:
type-id.cc:923
ns3::Time::GetTimeStep
int64_t GetTimeStep(void) const
Get the raw time value, in the current resolution unit.
Definition:
nstime.h:416
ns3::Ptr< const Packet >
ns3::Now
Time Now(void)
create an ns3::Time instance which contains the current simulation time.
Definition:
simulator.cc:287
ns3::DelayJitterEstimationTimestampTag
Tag to perform Delay and Jitter estimations.
Definition:
delay-jitter-estimation.cc:34
ns3::DelayJitterEstimation::m_transit
Time m_transit
Relative transit time for the previous packet.
Definition:
delay-jitter-estimation.h:78
ns3::DelayJitterEstimationTimestampTag::GetInstanceTypeId
virtual TypeId GetInstanceTypeId(void) const
Get the most derived TypeId for this Object.
Definition:
delay-jitter-estimation.cc:80
ns3::Tag
tag a set of bytes in a packet
Definition:
tag.h:37
ns3::Abs
int64x64_t Abs(const int64x64_t &value)
Absolute value.
Definition:
int64x64.h:205
ns3::Time
Simulation virtual time values and global simulation resolution.
Definition:
nstime.h:104
ns3::DelayJitterEstimationTimestampTag::Print
virtual void Print(std::ostream &os) const
Definition:
delay-jitter-estimation.cc:101
ns3::DelayJitterEstimationTimestampTag::Deserialize
virtual void Deserialize(TagBuffer i)
Definition:
delay-jitter-estimation.cc:96
ns3::DelayJitterEstimationTimestampTag::m_creationTime
Time m_creationTime
The time stored in the tag.
Definition:
delay-jitter-estimation.cc:56
ns3::DelayJitterEstimation::RecordRx
void RecordRx(Ptr< const Packet > packet)
Definition:
delay-jitter-estimation.cc:123
ns3::DelayJitterEstimation::m_jitter
Time m_jitter
Jitter estimation.
Definition:
delay-jitter-estimation.h:77
ns3::DelayJitterEstimationTimestampTag::Serialize
virtual void Serialize(TagBuffer i) const
Definition:
delay-jitter-estimation.cc:91
ns3::Simulator
Control the scheduling of simulation events.
Definition:
simulator.h:69
ns3::DelayJitterEstimationTimestampTag::GetTypeId
static TypeId GetTypeId(void)
Get the type ID.
Definition:
delay-jitter-estimation.cc:65
ns3::TimeValue
AttributeValue implementation for Time.
Definition:
nstime.h:1353
ns3::DelayJitterEstimation::GetLastJitter
uint64_t GetLastJitter(void) const
The jitter is calculated using the RFC 1889 (RTP) jitter definition.
Definition:
delay-jitter-estimation.cc:156
ns3::Packet::FindFirstMatchingByteTag
bool FindFirstMatchingByteTag(Tag &tag) const
Finds the first tag matching the parameter Tag type.
Definition:
packet.cc:939
delay-jitter-estimation.h
ns3::TagBuffer
read and write tag data
Definition:
tag-buffer.h:52
ns3::DelayJitterEstimation::DelayJitterEstimation
DelayJitterEstimation()
Definition:
delay-jitter-estimation.cc:111
ns3::Packet::AddByteTag
void AddByteTag(const Tag &tag) const
Tag each byte included in this packet with a new byte tag.
Definition:
packet.cc:912
ns3::DelayJitterEstimation::GetLastDelay
Time GetLastDelay(void) const
Definition:
delay-jitter-estimation.cc:151
ns3::DelayJitterEstimation::PrepareTx
static void PrepareTx(Ptr< const Packet > packet)
Definition:
delay-jitter-estimation.cc:117
ns3::TagBuffer::ReadU64
uint64_t ReadU64(void)
Definition:
tag-buffer.cc:134
ns3::DelayJitterEstimationTimestampTag::DelayJitterEstimationTimestampTag
DelayJitterEstimationTimestampTag()
Definition:
delay-jitter-estimation.cc:59
ns3::MakeTimeAccessor
Ptr< const AttributeAccessor > MakeTimeAccessor(T1 a1)
Create an AttributeAccessor for a class data member, or a lone class get functor or set method.
Definition:
nstime.h:1354
ns3::TagBuffer::WriteU64
void WriteU64(uint64_t v)
Definition:
tag-buffer.cc:102
src
network
helper
delay-jitter-estimation.cc
Generated on Fri Oct 1 2021 17:03:28 for ns-3 by
1.8.20