Package: inet.examples.rtp.unicast
RTPNetwork
network(no description)
Usage diagram
The following diagram shows usage relationships between types. Unresolved types are missing from the diagram.
Properties
| Name | Value | Description |
|---|---|---|
| isNetwork |
Unassigned submodule parameters
| Name | Type | Default value | Description |
|---|---|---|---|
| sender.status.initialStatus | string | "UP" |
TODO @signal, @statistic |
| sender.pcapRecorder.verbose | bool | true |
whether to log packets on the module output |
| sender.pcapRecorder.pcapFile | string | "" |
the PCAP file to be written |
| sender.pcapRecorder.fileFormat | string | "pcapng" | |
| sender.pcapRecorder.snaplen | int | 65535 |
maximum number of bytes to record per packet |
| sender.pcapRecorder.dumpBadFrames | bool | true |
enable dump of frames with hasBitError |
| sender.pcapRecorder.moduleNamePatterns | string | "wlan[*] eth[*] ppp[*]" |
space-separated list of sibling module names to listen on |
| sender.pcapRecorder.sendingSignalNames | string | "packetSentToLower" |
space-separated list of outbound packet signals to subscribe to |
| sender.pcapRecorder.receivingSignalNames | string | "packetReceivedFromLower" |
space-separated list of inbound packet signals to subscribe to |
| sender.pcapRecorder.dumpProtocols | string | "ethernetmac ppp ieee80211mac" |
space-separated list of protocol names as defined in the Protocol class |
| sender.pcapRecorder.packetFilter | object | "*" |
which packets are considered, matches all packets by default |
| sender.pcapRecorder.helpers | string | "" |
usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper" |
| sender.pcapRecorder.alwaysFlush | bool | false |
flush the pcapFile after each write to ensure that all packets are captured in case of a crash |
| sender.pcapRecorder.displayStringTextFormat | string | "rec: %n pks" | |
| sender.interfaceTable.displayAddresses | bool | false |
whether to display IP addresses on links |
| sender.cb.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| sender.cb.forwardServiceRegistration | bool | true | |
| sender.cb.forwardProtocolRegistration | bool | true | |
| sender.bl.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| sender.bl.forwardServiceRegistration | bool | true | |
| sender.bl.forwardProtocolRegistration | bool | true | |
| sender.li.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| sender.li.forwardServiceRegistration | bool | true | |
| sender.li.forwardProtocolRegistration | bool | true | |
| sender.eth.bitrate | double | ||
| sender.nl.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| sender.nl.forwardServiceRegistration | bool | true | |
| sender.nl.forwardProtocolRegistration | bool | true | |
| sender.tn.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| sender.tn.forwardServiceRegistration | bool | true | |
| sender.tn.forwardProtocolRegistration | bool | true | |
| sender.at.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| sender.at.forwardServiceRegistration | bool | true | |
| sender.at.forwardProtocolRegistration | bool | true | |
| sender.rtpApp.commonName | string |
the common name (CNAME) of this host |
|
| sender.rtpApp.sessionEnterDelay | double |
delay before starts a new session |
|
| sender.rtpApp.transmissionStartDelay | double |
delay before start transmission (related to "sender module created") |
|
| sender.rtpApp.transmissionStopDelay | double |
delay before stops transmission (related to "start transmission") |
|
| sender.rtpApp.sessionLeaveDelay | double |
delay before leave session (related to "file transmission finished/stopped" or "session entered" when fileName is "") |
|
| sender.rtp.interfaceTableModule | string |
The path to the InterfaceTable module |
|
| sender.rtp.routingTableModule | string | ||
| sender.rtcp.interfaceTableModule | string |
The path to the InterfaceTable module |
|
| receiver.status.initialStatus | string | "UP" |
TODO @signal, @statistic |
| receiver.pcapRecorder.verbose | bool | true |
whether to log packets on the module output |
| receiver.pcapRecorder.pcapFile | string | "" |
the PCAP file to be written |
| receiver.pcapRecorder.fileFormat | string | "pcapng" | |
| receiver.pcapRecorder.snaplen | int | 65535 |
maximum number of bytes to record per packet |
| receiver.pcapRecorder.dumpBadFrames | bool | true |
enable dump of frames with hasBitError |
| receiver.pcapRecorder.moduleNamePatterns | string | "wlan[*] eth[*] ppp[*]" |
space-separated list of sibling module names to listen on |
| receiver.pcapRecorder.sendingSignalNames | string | "packetSentToLower" |
space-separated list of outbound packet signals to subscribe to |
| receiver.pcapRecorder.receivingSignalNames | string | "packetReceivedFromLower" |
space-separated list of inbound packet signals to subscribe to |
| receiver.pcapRecorder.dumpProtocols | string | "ethernetmac ppp ieee80211mac" |
space-separated list of protocol names as defined in the Protocol class |
| receiver.pcapRecorder.packetFilter | object | "*" |
which packets are considered, matches all packets by default |
| receiver.pcapRecorder.helpers | string | "" |
usable PcapRecorder::IHelper helpers for accept packettype and store/convert packet as specified linktype currently available: "inet::AckingMacToEthernetPcapRecorderHelper" |
| receiver.pcapRecorder.alwaysFlush | bool | false |
flush the pcapFile after each write to ensure that all packets are captured in case of a crash |
| receiver.pcapRecorder.displayStringTextFormat | string | "rec: %n pks" | |
| receiver.interfaceTable.displayAddresses | bool | false |
whether to display IP addresses on links |
| receiver.cb.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| receiver.cb.forwardServiceRegistration | bool | true | |
| receiver.cb.forwardProtocolRegistration | bool | true | |
| receiver.bl.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| receiver.bl.forwardServiceRegistration | bool | true | |
| receiver.bl.forwardProtocolRegistration | bool | true | |
| receiver.li.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| receiver.li.forwardServiceRegistration | bool | true | |
| receiver.li.forwardProtocolRegistration | bool | true | |
| receiver.eth.bitrate | double | ||
| receiver.nl.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| receiver.nl.forwardServiceRegistration | bool | true | |
| receiver.nl.forwardProtocolRegistration | bool | true | |
| receiver.tn.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| receiver.tn.forwardServiceRegistration | bool | true | |
| receiver.tn.forwardProtocolRegistration | bool | true | |
| receiver.at.displayStringTextFormat | string | "processed %p pk (%l)" |
determines the text that is written on top of the submodule |
| receiver.at.forwardServiceRegistration | bool | true | |
| receiver.at.forwardProtocolRegistration | bool | true | |
| receiver.rtpApp.commonName | string |
the common name (CNAME) of this host |
|
| receiver.rtpApp.sessionEnterDelay | double |
delay before starts a new session |
|
| receiver.rtpApp.transmissionStartDelay | double |
delay before start transmission (related to "sender module created") |
|
| receiver.rtpApp.transmissionStopDelay | double |
delay before stops transmission (related to "start transmission") |
|
| receiver.rtpApp.sessionLeaveDelay | double |
delay before leave session (related to "file transmission finished/stopped" or "session entered" when fileName is "") |
|
| receiver.rtp.interfaceTableModule | string |
The path to the InterfaceTable module |
|
| receiver.rtp.routingTableModule | string | ||
| receiver.rtcp.interfaceTableModule | string |
The path to the InterfaceTable module |
|
| configurator.minLinkWeight | double | 1E-3 | |
| configurator.configureIsolatedNetworksSeparatly | bool | false | |
| configurator.config | xml | xml(" |
XML configuration parameters for IP address assignment and adding manual routes |
| configurator.assignAddresses | bool | true |
assign IP addresses to all interfaces in the network |
| configurator.assignUniqueAddresses | bool | true |
avoid using the same address and raise an error if not possible |
| configurator.assignDisjunctSubnetAddresses | bool | true |
avoid using the same address prefix and netmask on different links when assigning IP addresses to interfaces |
| configurator.addStaticRoutes | bool | true |
add static routes to the routing tables of all nodes to route to all destination interfaces (only where applicable; turn off when config file contains manual routes) |
| configurator.addDefaultRoutes | bool | true |
add default routes if all routes from a source node go through the same gateway (used only if addStaticRoutes is true) |
| configurator.addSubnetRoutes | bool | true |
add subnet routes instead of destination interface routes (only where applicable; used only if addStaticRoutes is true) |
| configurator.addDirectRoutes | bool | true |
add direct routes (i.e. directly connected interfaces) to the routing table (used only if addStaticRoutes is true) |
| configurator.optimizeRoutes | bool | true |
optimize routing tables by merging routes, the resulting routing table might route more packets than the original (used only if addStaticRoutes is true) |
| configurator.dumpTopology | bool | false |
print extracted network topology to the module output |
| configurator.dumpLinks | bool | false |
print recognized network links to the module output |
| configurator.dumpAddresses | bool | false |
print assigned IP addresses for all interfaces to the module output |
| configurator.dumpRoutes | bool | false |
print configured and optimized routing tables for all nodes to the module output |
| configurator.dumpConfig | string | "" |
write configuration into the given config file that can be fed back to speed up subsequent runs (network configurations) |
Source code
network RTPNetwork { types: channel ethernet extends ned.DatarateChannel { parameters: delay = normal(0.00015s, 0.00005s); datarate = 10Mbps; ber = 0.00001; } submodules: sender: RtpHost { parameters: profileName = "inet.transportlayer.rtp.RtpAvProfile"; destinationAddress = "receiver"; portNumber = 5004; bandwidth = 8000; @display("p=250,100"); } receiver: RtpHost { parameters: profileName = "inet.transportlayer.rtp.RtpAvProfile"; destinationAddress = "sender"; portNumber = 5004; bandwidth = 8000; @display("p=400,100"); } configurator: Ipv4NetworkConfigurator { @display("p=100,100;is=s"); } connections: sender.pppg++ <--> ethernet <--> receiver.pppg++; }File: examples/rtp/unicast/unicast.ned