/usr/include/opal/rtp/metrics.h is in libopal-dev 3.10.10~dfsg2-2.1build2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 | /*
* metrics.h
*
* E-Model implementation
*
* Open Phone Abstraction Library (OPAL)
*
* Copyright (c) 2010 Universidade Federal do Amazonas
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* Contributor(s): ______________________________________.
*
* $Revision: 27699 $
* $Author: rjongbloed $
* $Date: 2012-05-24 20:35:37 -0500 (Thu, 24 May 2012) $
*/
#ifndef OPAL_RTP_METRICS_H
#define OPAL_RTP_METRICS_H
#ifdef P_USE_PRAGMA
#pragma interface
#endif
#include <opal/buildopts.h>
#if OPAL_RTCP_XR
#include <rtp/rtp.h>
#include <list>
class RTP_Session;
class RTP_DataFrame;
///////////////////////////////////////////////////////////////////////////////
// RTCP-XR - VoIP Metrics Report Block
/**This is a class used to calculate voice quality metrics acording to the
E-Model, proposed by ITU-T G.107 recomendation.
*/
class RTCP_XR_Metrics
{
protected:
RTCP_XR_Metrics(
float Ie,
float Bpl,
float lookAheadTime,
PINDEX payloadSize,
unsigned payloadBitrate
);
public:
static RTCP_XR_Metrics * Create(const RTP_DataFrame & frame);
~RTCP_XR_Metrics();
enum PacketEvent {
PACKET_RECEIVED,
PACKET_DISCARDED,
PACKET_LOST
};
enum PeriodType {
GAP, /* a period of low packet losses and/or discards */
BURST, /* a period of a high proportion of packet losses and/or discards */
};
/* A period of time, which can be a burst or a gap */
typedef struct TimePeriod {
PeriodType type;
PTimeInterval duration;
} TimePeriod;
/**A period of time, used to calculate an average Id, needed to compute the R factor.
Id factor represents the impairments caused by delay.
*/
typedef struct IdPeriod {
PTimeInterval duration;
float Id;
} IdPeriod;
/**A period of time, used to calculate an average Ie, needed to compute the R factor.
Ie factor represents the impairments caused by low bit-rate codecs.
*/
typedef struct IePeriod {
PeriodType type;
PTimeInterval duration;
float Ieff;
} IePeriod;
enum QualityType {
LQ, /* Listening Quality, not include the effects of delay */
CQ /* Conversational Quality, include the effects of delay */
};
/**Set the jitter buffer delay.
This must be called to obtain the Id parameter.
*/
void SetJitterDelay(
DWORD delay ///< The jitter buffer delay in milliseconds
);
/**Called when a packet is received.
*/
void OnPacketReceived();
/**Called when a packet is discarded.
*/
void OnPacketDiscarded();
/**Called when a packet is lost.
*/
void OnPacketLost();
/**Called when several packets are lost.
*/
void OnPacketLost(
DWORD dropped ///< Number of lost packets.
);
/**Called when a Sender Report is receveid.
*/
void OnRxSenderReport(
PUInt32b lsr, ///< "Last SR" field of the received SR.
PUInt32b dlsr ///< "Delay since the last SR" field of the received SR.
);
/**Get the fraction of RTP packets lost since the beginning of the reception.
*/
BYTE GetLossRate();
/**Get the fraction of RTP packets discarded since the beginning of the reception.
*/
BYTE GetDiscardRate();
/**Get the fraction of RTP packets lost/discarded within burst periods since
the beginning of the reception.
*/
BYTE GetBurstDensity();
/**Get the fraction of RTP packets lost/discarded within gap periods since
the beginning of the reception.
*/
BYTE GetGapDensity();
/**Get the mean duration, in milliseconds, of burst periods since the
beginning of the reception.
*/
PUInt16b GetBurstDuration();
/**Get the mean duration, in milliseconds, of gap periods since the beginning
of the reception.
*/
PUInt16b GetGapDuration();
/**Get the most recently calculated round trip time between RTP interfaces,
expressed in millisecond.
*/
PUInt16b GetRoundTripDelay ();
/**Get the most recently estimated end system delay, expressed in millisecond.
*/
PUInt16b GetEndSystemDelay();
/**Get the R factor for the current RTP session, expressed in the range of 0 to 100.
*/
BYTE RFactor();
/**Get the estimated MOS score for listening quality of the current RTP session,
expressed in the range of 10 to 50.
This metric not includes the effects of delay.
*/
BYTE MOS_LQ();
/**Get the estimated MOS score for conversational quality of the current RTP session,
expressed in the range of 10 to 50.
This metric includes the effects of delay.
*/
BYTE MOS_CQ();
// Internal functions
void InsertExtendedReportPacket(
unsigned sessionID,
DWORD syncSourceOut,
RTP_Session::JitterBufferPtr jitter, // Note do not make JitterBufferPtr a reference, needs to be a copy
RTP_ControlFrame & report
);
static RTP_Session::ExtendedReportArray
BuildExtendedReportArray(const RTP_ControlFrame & frame, PINDEX offset);
protected:
/**Given the following definition of states:
state 1 = received a packet during a gap;
state 2 = received a packet during a burst;
state 3 = lost a packet during a burst;
state 4 = lost a isolated packet during a gap.
This function models the transitions of a Markov chain with the states above.
*/
void markov(
PacketEvent event ///< Event triggered
);
/**Reset the counters used for the Markov chain
*/
void ResetCounters();
/**Get the R factor for the current RTP session, expressed in the range of 0 to 100.
*/
BYTE RFactor(
QualityType qt ///< Listening or Conversational quality
);
/**Get the R factor at the end of the RTP session, expressed in the range of 0 to 100.
*/
BYTE EndOfCallRFactor();
/**Get the estimated MOS score for the current RTP session,
expressed in the range of 1 to 5.
*/
float MOS(
QualityType qt ///< Listening or Conversational quality
);
/**Get the estimated MOS score at the end of the RTP session,
expressed in the range of 1 to 5.
*/
float EndOfCallMOS();
/**Get instantaneous Id factor.
*/
float IdFactor();
/**Get a ponderated value of Id factor.
*/
float GetPonderateId();
/**Get instantaneous Ieff factor.
*/
float Ieff(
PeriodType type ///< The type of period (burst or gap).
);
/**Get a value of Ie factor at the end of the RTP session.
*/
float GetEndOfCallIe();
/**Get a ponderated value of Ie factor.
*/
float GetPonderateIe();
/**Create a a burst or gap period.
*/
TimePeriod createTimePeriod(
PeriodType type, ///< The type of period (burst or gap).
PTime beginTimestamp, ///< Beginning of period timestamp.
PTime endTimestamp ///< End of period timestamp.
);
/**Create a period of time with an Id value associated.
*/
IdPeriod createIdPeriod(
PTime beginTimestamp, ///< Beginning of period timestamp.
PTime endTimestamp ///< End of period timestamp.
);
/**Create a period of time with an Ie value associated.
*/
IePeriod createIePeriod(
TimePeriod timePeriod ///< Period of time to calculate the Ie.
);
/* data associated with the payload */
float m_Ie; /* equipment impairment factor for the codec utilized */
float m_Bpl; /* robustness factor for the codec utilized */
float m_lookAheadTime; /* codec lookahead time */
PINDEX m_payloadSize;
unsigned m_payloadBitrate;
DWORD m_gmin; /* gap threshold */
DWORD m_lostInBurst; /* number of lost packets within the current burst */
DWORD m_packetsReceived; /* packets received since the beggining of the reception */
DWORD m_packetsSinceLastLoss; /* packets received since the last loss or discard event */
DWORD m_packetsLost; /* packets lost since the beggining of the reception */
DWORD m_packetsDiscarded; /* packets discarded since the beggining of the receptions */
DWORD m_srPacketsReceived; /* count of SR packets received */
DWORD m_packetsReceivedInGap; /* packets received within gap periods */
DWORD m_packetsLostInGap; /* packets lost within gap periods */
DWORD m_packetsReceivedInBurst; /* packets received within burst periods */
DWORD m_packetsLostInBurst; /* packets lost within burst periods */
/**Given the following definition of states:
state 1 = received a packet during a gap;
state 2 = received a packet during a burst;
state 3 = lost a packet during a burst;
state 4 = lost a isolated packet during a gap.
Variables below correspond to state transition counts.
To reset these counters, call the ResetCounters() function.
*/
DWORD c5;
DWORD c11;
DWORD c13;
DWORD c14;
DWORD c22;
DWORD c23;
DWORD c31;
DWORD c32;
DWORD c33;
/* variables to calculate round trip delay */
PTime m_lsrTime;
PTimeInterval m_dlsrTime;
PTime m_arrivalTime;
DWORD m_jitterDelay; /* jitter buffer delay, in milliseconds */
float m_lastId; /* last Id calculated */
float m_lastIe; /* last Ie calculated */
std::list<TimePeriod> m_timePeriods;
std::list<IePeriod> m_iePeriods;
std::list<IdPeriod> m_idPeriods;
PeriodType m_currentPeriodType; /* indicates if we are within a gap or burst */
PTime m_periodBeginTimestamp; /* timestamp of the beginning of the gap or burst period */
PTime m_lastLossTimestamp; /* timestamp of the last loss */
PTime m_lastLossInBurstTimestamp; /* timestamp of the last loss within a burst period */
PTime m_lastJitterBufferChangeTimestamp; /* timestamp of the last change in jitter buffer size */
};
#endif // OPAL_RTCP_XR
#endif // OPAL_METRICS_H
/////////////////////////////////////////////////////////////////////////////
|