Skip to content

Releases: Unipisa/Simu5G

Simu5G 1.4.2

27 Nov 07:58

Choose a tag to compare

This is primarily a bugfix release.

  • Pdcp: Fixed Dual Connectivity bug where separate PDCP entities were
    incorrectly created for LTE and NR legs of a Split Bearer instead of using a
    single shared entity. This fix breaks RLC-UM packet loss statistics which
    (incorrectly) inferred packet loss from PDCP sequence numbers.

  • RlcUm: Removed packet loss statistics that incorrectly relied on PDCP sequence
    numbers (PDCP sequences are not contiguous in Dual Connectivity setups)

  • PacketFlowManager: Renamed to PacketFlowObserver, updated NED documentation.

  • Statistics collection refined, e.g. remove recording "sum" and/or "mean" where
    it does not make sense; use new "rateavg" filter for computing average
    throughput.

  • Binder: New utility functions: isGNodeB(), getUeNodeId().

  • Apps: Added sequence numbers to VoIP and VoD packet names, to facilitate
    tracing with Qtenv.

  • NED documentation: Added content to simu5g-index.ned including version number
    and WHATSNEW.

Simu5G 1.4.1-SDAP

06 Oct 15:18

Choose a tag to compare

Compatible with OMNeT++ 6.2.0 and INET 4.5.4.

This specialized branch release introduces SDAP protocol support, multiple DRBs
and advanced QoS capabilities to Simu5G for enhanced 5G network simulations.
Please note that future main releases may not include these features or may
incorporate them in a different form, as the primary development focus remains
on architectural refactoring and foundational improvements. The changes were
contributed by Mohamed Seliem (University College Cork), with improvements by
Andras Varga (OMNeT++ Core Team).

Reference paper: "QoS-Aware Proportional Fairness Scheduling for Multi-Flow 5G
UEs: A Smart Factory Perspective". Mohamed Seliem, Utz Roedig, Cormac Sreenan,
Dirk Pesch. IEEE MSWiM, 2025.

New Features:

  • Added an SDAP protocol implementation with reflexive QoS capabilities (NrSdap
    and ReflectiveQosTable modules). Available using the NRUeSdap (UE) and
    gNodeBSdap (gNodeB) node types that contain the NRNicUeSdap and NRNicEnbSdap
    NIC types, respectively.

  • DRB (Data Radio Bearer) support with multi-QFI/QoS handling for realistic 5G
    bearer management simulations. This feature is available using NRUeDrb (UE)
    and gNodeBDrb (gNodeB) node types that contain the NRNicUeDrb and NRNicEnbDrb
    NIC types, respectively. It can be configured using the numDrbs parameter.
    QFI-to-DRB mappings can be defined in a context file (see SDAP's
    qfiContextFile parameter) with 5QI parameters and QoS requirements.

  • QoSAwareScheduler with QFI-based Proportional Fair scheduling using QfiContextManager.
    Enable QoS scheduling with LteMacEnb.schedulingDisciplineDl/Ul="QOS_PF".

  • Better representation of compressed headers in PDCP. (Note that header compression is
    disabled by default; enable using PDCP's headerCompressedSize parameter.)

  • New example simulations: simulations/nr/standalone/omnetpp_sdap.ini and omnetpp_drb.ini,
    each with Standalone, VoIP-DL, and VoIP-UL configurations demonstrating SDAP functionality
    and multi-DRB support with QoS-aware scheduling.

Simu5G 1.4.1

06 Oct 14:37

Choose a tag to compare

This is a minor update that brings further refactoring of the C++ code for clarity,
improvements in the C++ interface of the Binder module, and some minor bug fixes.
These improvements were contributed by Andras Varga (OMNeT++ Core Team).

Notable changes:

  • Binder: Partial rationalization of the C++ interface, via
    renaming/replacing/removing methods. See the git history for changes.

  • Updated IP addresses in the IPv4 configuration files: use 10.x.x.x
    addresses for the Core Network, and 192.168.x.x addresses for external
    addresses

  • Visual improvement: node IDs are now displayed over module icons

  • In MEC, do not use module IDs for bgAppId, deviceAppId and other IDs, and do
    not encode module ID into module names. That practice made simulations brittle
    for regression testing via fingerprints.

  • PDCP: Eliminated tweaking of srcId/destId in FlowControlInfo when sending
    downlink packets over the X2 link in a Dual-Connectivity setup.

  • Various additional fixes and changes to improve code quality.

Simu5G 1.4.0

18 Sep 13:45

Choose a tag to compare

Compatible with OMNeT++ 6.2.0 and INET 4.5.4.

This release marks an important milestone in the ongoing transformation of
Simu5G. While not introducing behavioral changes, this intermediate release
focuses on restructuring the codebase to improve clarity, safety, and
maintainability. Major updates include a reorganized directory structure,
enforcing a consistent naming convention, making make packets more easily
inspectable, and refactoring of parts of the C++ code to pave the way for
changes in future versions. Although the release is not source-compatible with
previous versions, existing simulations will continue to work unchanged once
adjusted to follow the various rename operations. These improvements were
contributed by Andras Varga (OMNeT++ Core Team).

Renames:

  • Sources are now under src/simu5g/ instead of just src/, so that C++ includes
    start with "simu5g/". This helps identifying Simu5G includes when Simu5G is
    used as a dependency of other projects.

  • Some folders were moved inside the source tree to a more logical location. For
    example, the simu5g/nodes/mec/ subtree was promoted to simu5g/mec/.

  • Several source folders were renamed to more closely follow the all-lowercase
    convention. For example, mec/UALCMP/ became mec/ualcmp/, and mec/MECPlatform
    became just mec/platform.

  • Several classes were renamed to ensure that only the first letters of acronyms
    are uppercase. For example, MECHost became MecHost.

  • Several parameters were renamed to enforce camelcase names. For example,
    bs_noise_figure became bsNoiseFigure, and fading_paths became numFadingPaths.
    If you have existing Simu5G simulations, review the ini files carefully and
    update the parameter assignments accordingly. (Caveat: Assignment lines that
    refer to the old names will be simply ignored by the simulation -- there is no
    error message for that!)

  • The PdcpRrc modules were renamed to just Pdcp. Likewise, pdcpRrc submodules
    in NIC compound modules became pdcp.

Further refactoring:

  • Several protocol header classes, while defined in msg files, contained heavy
    customization in C++ code, including the addition of new fields. Since the
    writing of those classes, the message compiler in OMNeT++ gained enough
    features so that most of the customizations were no longer needed, and the
    desired effect could be achieved in msg files only. This refactoring has the
    benefit of making packets more inspectable from Qtenv, and packet contents can
    now be serialized using parsimPack (useful for more thorough fingerprint
    tests).

  • MacCid is a central data type that pairs an LCID with a nodeId to uniquely
    identify a logical channel. It used to be a packed integer, and now it was
    turned into a C++ class with separate fields for the node ID and LCID and with
    accessor methods, for increased type safety.

  • carrierFrequency used to be a variable of the type double throughout the
    codebase. The type was changed to GHz (using INET's units.h) for increased
    type safety. This also helped identifying a bug in certain channel models
    (LteRealisticChannelModel, BackgroundCellChannelModel) where a double
    representing GHz instead of Hz was used in computing path loss, resulting
    in underestimated path loss values.

  • Binder received several WATCHes for increased transparency in Qtenv, and
    an overhaul of a subset of its API and internal data structures.

  • In the Pdcp modules, the unused EUTRAN_RRC_Sap port (and associated handling
    code) was removed.

  • Refactoring of internals in several protocol modules, including MAC, PDCP and
    RLC implementations.

Simu5G 1.3.1

19 Sep 13:12

Choose a tag to compare

This is a minor update for Simu5G-1.3.0. In addition to fixing regressions
in the previous release and making some cosmetic improvements, the main highlight
of this release is the revamp of the fingerprint test suite, which now provides
a more comprehensive safety net against future regressions. Changes in this
release were contributed by Andras Varga (OMNeT++ Core Team).

Changes:

  • Example simulations: Marked abstract configs as such (abstract=true) in omnetpp.ini files
  • FlowControlInfo's MacNodeId fields are now properly shown in Qtenv object inspectors
  • Replaced EV_ERROR << lines with throwing cRuntimeError
  • TrafficLightController: fixed startState NED parameter (also changed type from int to string)
  • Fingerprints: CSV files merged into simulations.csv, added missing simulations,
    standardized on the set of fingerprints computed (tplx, ~tNl, sz), translated
    gen_runallexamples.py into Python and improved it

Fix regressions in v1.3.0:

  • MECResponseApp: fixed wrong @class annotation
  • BackgroundScheduler: fix "binder_ not initialized" error
  • MecRequestForegroundApp, MecRequestBackgroundGeneratorApp: add back lost parameter defaults
  • BackgroundCellTrafficManager: fix "Not implemented" thrown from getBackloggedUeBytesPerBlock()
  • tutorials/nr/omnetpp.ini: fix missing unit for txPower parameter (dBm)

Simu5G 1.3.0

06 Feb 16:35

Choose a tag to compare

  • Compatible with OMNeT++ 6.1.0 and INET 4.5.4
  • New modules: MultiUEMECApp, MecRnisTestApp, UeRnisTestApp
  • Added NED documentation for modules
  • Increased reusability of modules via changes such as replacing hardcoded module
    paths in the C++ code with NED parameters (binderModule, macModule, etc.), and
    elimination of ancestorPar() calls by introducing local parameters instead.
  • Other NED adjustments, such as removal of unused NED parameters and splitting
    NED files to have one module per file. See doc/NED-changes.txt for details.
  • Extensive C++ modernization, and adaption of more OMNeT++ best practices.
  • Various bug fixes.

Simu5G 1.2.3

10 Jan 11:12

Choose a tag to compare

5G NewRadio and LTE/LTE-A user-plane simulation model.

Version: 1.2.3

This release is compatible with OMNeT++ 6.1 and INET 4.5 (tested on Ubuntu 24.04/24.10 and macOS Ventura)

Simu5G 1.2.2

19 Apr 10:18

Choose a tag to compare

5G NewRadio and LTE/LTE-A user-plane simulation model.

Version: 1.2.2

This release is compatible with OMNeT++ 6.0.1 and INET 4.5 (tested on Ubuntu 22.04 and macOS Ventura)

Simu5G 1.2.1

19 Jul 14:34

Choose a tag to compare

5G NewRadio and LTE/LTE-A user-plane simulation model.

Version: 1.2.1

This release is compatible with OMNeT++ 6.0 and INET 4.4.0.
Tested on Ubuntu 20.04.

This minor release includes:

  • modifications to support the latest versions of OMNeT++ 6.0 and INET v4.4.0 (many thanks to Prof. Lars Wischhof, Munich University of Applied Sciences, for his contribution)
  • some refactoring of simulation and emulation folders
  • bug fixing

Simu5G 1.2.0

30 Aug 12:56

Choose a tag to compare

5G NewRadio and LTE/LTE-A user-plane simulation model.

Version: 1.2.0

This release is compatible with OMNeT++ 6.0 (pre10 and pre11) and INET 4.3.2.
Tested on:

  • Ubuntu 16.04, 18.04 & 20.04;
  • macOS Catalina;
  • Windows 7.

This release includes:

  • Modelling of ETSI MEC entities (thanks to Alessandro Noferi, University of Pisa);
  • Support to real-time emulation capabilities (Linux OS only);
  • Modelling of background cells and background UEs for larger scale simulations and emulations;
  • Several bug fixes.