Package: inet.queueing.classifier
MarkovClassifier
simple moduleImplements a packet classifier using a Markov process that has as many states as output gates the classifier has. The output gate for a given packet is determined by the current state of the Markov process.
Inheritance diagram
The following diagram shows inheritance relationships for this type. Unresolved types are missing from the diagram.
Used in
| Name | Type | Description |
|---|---|---|
| MarkovClassifierTutorialStep | network | (no description) |
Extends
| Name | Type | Description |
|---|---|---|
| PacketClassifierBase | simple module |
Base module for various packet classifier modules. Derived modules must implement a single packet classifier function which determines the index of the output gate for the next pushed packet. |
Parameters
| Name | Type | Default value | Description |
|---|---|---|---|
| displayStringTextFormat | string | "classified %p pk (%l)\ncurrent state: %s" |
Determines the text that is written on top of the submodule, supports displaying pars, watches, and module-specific information |
| reverseOrder | bool | false | |
| clockModule | string | "" |
Relative path of a module that implements IClock(1,2); optional |
| initialState | int | 0 |
The index of the start state of the Markov process |
| transitionProbabilities | string |
The transition matrix (N x N) of the Markov process, specified as a list of probabilities |
|
| waitIntervals | string |
The amount of time the Markov process stays in a given state, a list of intervals (N) indexed by the state |
Properties
| Name | Value | Description |
|---|---|---|
| class | MarkovClassifier | |
| display | i=block/classifier |
Gates
| Name | Direction | Size | Description |
|---|---|---|---|
| in | input | ||
| out [ ] | output |
Signals
| Name | Type | Unit | Description |
|---|---|---|---|
| packetPushed | inet::Packet |
Statistics
| Name | Title | Source | Record | Unit | Interpolation Mode | Description |
|---|---|---|---|---|---|---|
| packetLengths | packet lengths | packetLength(packetPushed) | sum, histogram, vector | b | none |
the statistical value is the length of the classified packet |
| dataRate | data rate | throughput(packetPushed) | vector | bps | linear |
the statistical value is the data rate of the classified packets |
| packets | packets | packetPushed | count | pk |
the statistical value is the classified packet |
Source code
// // Implements a packet classifier using a Markov process that has // as many states as output gates the classifier has. The output gate for // a given packet is determined by the current state of the Markov process. // simple MarkovClassifier extends PacketClassifierBase like IPacketClassifier { parameters: displayStringTextFormat = default("classified %p pk (%l)\ncurrent state: %s"); string clockModule = default(""); // Relative path of a module that implements IClock; optional int initialState = default(0); // The index of the start state of the Markov process string transitionProbabilities; // The transition matrix (N x N) of the Markov process, specified as a list of probabilities string waitIntervals; // The amount of time the Markov process stays in a given state, a list of intervals (N) indexed by the state @class(MarkovClassifier); }File: src/inet/queueing/classifier/MarkovClassifier.ned