SimpleVoipSender

Package: inet.applications.voip

SimpleVoipSender

simple module

C++ definition

Implements a simple VoIP source. It is a constant bitrate source, with talk spurt support added. Packets do not contain actual voice data. Connection setup/teardown is not modeled. The peer must be a ~SimpleVoipReceiver.

The source alternates between two states: talk and silence. The length the module spends in each state is controlled by the talkspurtDuration and silenceDuration parameters. In the talk state, the module acts as a CBR source, and sends packets of size talkPacketSize every packetizationInterval seconds to the destination over UDP. Silence is implicit: in the silence state, no packets are sent, and there is no explicit signaling of silence either.

Packets are of type SimpleVoipPacket. In addition to packet ID and timestamp, packets also contain a talkspurt ID and the total number of packets in the talkspurt to facilitate statistics on the receiver's side. (It allows the receiver to detect the loss of packets at the end of a talkspurt; a full talkspurt can still be lost unnoticed.)

The destination address/port, the local port, start and stop times can be set via parameters.

<b>Author:</b>: Adriano

Inheritance diagram

The following diagram shows inheritance relationships for this type. Unresolved types are missing from the diagram.

Extends

Name Type Description
SimpleModule simple module

Base module for all INET simple modules.

Parameters

Name Type Default value Description
displayStringTextFormat string ""

Determines the text that is written on top of the submodule, supports displaying pars, watches, and module-specific information

localPort int -1
destPort int
destAddress string
talkPacketSize int 40B

Size of talk packets in bytes

talkspurtDuration double weibull(1.423s, 0.824s)
silenceDuration double weibull(0.899s, 1.089s)
packetizationInterval double 20ms

Interval between sending voice packets

startTime double 0s

Time of start sending

stopTime double -1s

Time of end of sending, -1 means forever

Properties

Name Value Description
class SimpleVoipSender
display i=block/source

Gates

Name Direction Size Description
socketIn input
socketOut output

Source code

//
// Implements a simple VoIP source. It is a constant bitrate source, with
// talk spurt support added. Packets do not contain actual voice data.
// Connection setup/teardown is not modeled. The peer must be a
// ~SimpleVoipReceiver.
//
// The source alternates between two states: talk and silence. The length
// the module spends in each state is controlled by the `talkspurtDuration` and
// `silenceDuration` parameters. In the talk state, the module acts as a CBR source,
// and sends packets of size `talkPacketSize` every `packetizationInterval` seconds
// to the destination over UDP. Silence is implicit: in the silence state, no packets
// are sent, and there is no explicit signaling of silence either.
//
// Packets are of type `SimpleVoipPacket`. In addition to packet ID and timestamp,
// packets also contain a talkspurt ID and the total number of packets in the
// talkspurt to facilitate statistics on the receiver's side. (It allows the receiver
// to detect the loss of packets at the end of a talkspurt; a full talkspurt can still
// be lost unnoticed.)
//
// The destination address/port, the local port, start and stop times can be
// set via parameters.
//
// @author: Adriano
//
simple SimpleVoipSender extends SimpleModule like IApp
{
    parameters:
        @class(SimpleVoipSender);
        int localPort = default(-1);
        int destPort;
        string destAddress;
        int talkPacketSize @unit(B) = default(40B);     // Size of talk packets in bytes
        volatile double talkspurtDuration @unit(s) = default(weibull(1.423s, 0.824s));
        volatile double silenceDuration @unit(s) = default(weibull(0.899s, 1.089s));
        double packetizationInterval @unit(s) = default(20ms);   // Interval between sending voice packets
        double startTime @unit(s) = default(0s);   // Time of start sending
        double stopTime @unit(s) = default(-1s);  // Time of end of sending, -1 means forever

        @display("i=block/source");
    gates:
        input socketIn @labels(UdpCommand/up);
        output socketOut @labels(UdpCommand/down);
}

File: src/inet/applications/voip/SimpleVoipSender.ned