Release 2.0
Overview
ndnSIM 2.0 is a new release of NS-3 based Named Data Networking (NDN)
simulator that went through extensive refactoring and rewriting. The key
new features of the new version:
- ndnSIM no longer re-implements basic NDN primitives and directly
uses implementation from ndn-cxx library (NDN C++ library with
eXperimental eXtensions).
- All NDN forwarding and management is implemented directly using
source code of Named Data Networking Forwarding Daemon (NFD). The
current code is based on a22a2172611b1cb93b2e2f53d9d5da122b384f3e
commit of NFD repository.
Note RIB Manager is not yet available in ndnSIM.
- Packet format changed to the NDN packet format.
- Code style changes to conform to ndn-cxx Code Style and Coding
Guidelines This change also includes renaming of the header and
source files: *.h -> *.hpp, *.cc -> *.cpp
- ndnSIM now uses C++11.
New Features
- Integration with NFD codebase:
- A realistic behavior is added to the simulations.
- Forwarding plane extensions can be used in both ndnSIM simulations
and real NFD deployment.
- Per namespace forwarding strategies for different namespaces (one
strategy per namespace).
- New examples:
- ndn-load-balancer
- ndn-grid-multiple-strategies
- ndn-different-strategy-per-prefix
- Basic examples using python bindings: ndn-simple.py and ndn-grid.py
- Use of the the full-featured NDN packet format.
- Full-featured support for Interest selectors.
- Full-featured crypto operations can be simulated (disabled by
default).
- FibHelper to manage FIB entries.
- StrategyChoiceHelper to manage per-namespace forwarding strategy
selection.
Changes
- HopCount tracing now includes only one way network-level hop count
(e.g., the number of physical links traversed by a packet).
Previously, this tracing was round-trip and included applications
hops.
- Python bindings have changed and, due to limitations of pybindgen,
currently cover a smaller subset of C++ code (Task #2341).
- LinkControlHelper now uses ErrorRate to simulate link
failure/recovery. Previously it was relying on Up/Down flag on NDN
level.
- The Face abstraction of NFD is now used.
Bug fixes
- Fix processing files with customized LossRate or Queue model in
AnnotatedTopologyReader Bug #2354.
Removals
- PyNDN emulation
- (temporarily) ApiFace. Will be replaced with emulation of ndn-cxx
ndn::Face in future releases (Issue #2370).
- (temporarily) UdpFace, TcpFace (Issue #2371).
- Limits, LimitsWindow, LimitsRate.
- PIT, FIB with "replacement" policies.
- Old deprecated packet formats.
« Previous fa3b3d3 Small modification of car2car example by Alexander Afanasyev · 12 years ago 34a177c Merge remote-tracking branch 'git.irl/car2car' by Alexander Afanasyev · 12 years ago a3295ab Change the LOG type of CcnxConsumer and CcnxProducer by Lucas · 12 years ago 18750bb Adding highway-mobility + CCNx scenario (vanet-ccnx.cc) by Alexander Afanasyev · 12 years ago 64b8536 Add car2car-wifi scenario by Lucas · 12 years ago 7e71c75 Adding IPv4 rate tracer by Alexander Afanasyev · 12 years ago ed78b63 New scenario to see details of reaction on congestion. Small change in AnnotatedTopologyReader API by Alexander Afanasyev · 12 years ago 812f7ab Adding one more scenario to compute shortest paths after failure by Alexander Afanasyev · 12 years ago 1ec705f Adding initial code to implement limited (by time) retransmission in CcnxConsumer by Alexander Afanasyev · 12 years ago b8f5139 Don't double RTO on timeout (only for NACKs) by Alexander Afanasyev · 12 years ago f410daf Making progress report only every 5 seconds by Alexander Afanasyev · 12 years ago 1e9348f CcnxConsumer doubles timeout upon NACK and Timout by Alexander Afanasyev · 12 years ago 6c67838 Finalizing LinkFailure scenario by Alexander Afanasyev · 12 years ago ef05655 OSPF metric bug in BaseExperiment. Moving ApplyOSPFMetric to the right place by Alexander Afanasyev · 12 years ago 17acc11 Removing hijacker app. Hijacking is implemented now by changing face states by Alexander Afanasyev · 12 years ago 8e0d281 Moving around path weight tagging. Now CcnxFace owns metric field, which is used for tagging. by Alexander Afanasyev · 12 years ago 6bff0df Finalizing PathWeight tracing by Alexander Afanasyev · 12 years ago e9c9d72 Change in CcnxApp API. Now callbacks also contain pointer of original by Alexander Afanasyev · 12 years ago b7ad232 One more change in Consumer API. Now there are more consumers and they by Alexander Afanasyev · 12 years ago 94cebd0 CcnxConsumerCbr now is really CBR (no randomization). by Alexander Afanasyev · 12 years ago 2c069b9 shortest path calculation added by Ilya Moiseenko · 12 years ago 4d66de5 Repair critical bug in CcnxConsumer. Due to accidental commenting out a by Alexander Afanasyev · 12 years ago b762684 Update of BlackholeSprint scenario. Extending CcnxStackHelper API by Alexander Afanasyev · 12 years ago 1067197 Merge remote-tracking branch 'git.irl/ilya' by Alexander Afanasyev · 12 years ago 2063c88 link failure and blackhole scenarios seem to work by Ilya Moiseenko · 12 years ago 06b42ec Enabling TCP window tracing (there is a trick to do it with by Alexander Afanasyev · 13 years ago e4c2ece Tracing window size in CcnxConsumerWindow by Alexander Afanasyev · 13 years ago e1a065d Removing legacy examples. Moving test application to `test' folder by Alexander Afanasyev · 13 years ago f9d8fbe Combining NDN and TCP scenarios in congestion-pop.cc (to make sure by Alexander Afanasyev · 13 years ago 94f2350 Merge remote-tracking branch 'git.irl/master' by Alexander Afanasyev · 13 years ago 359bfb7 Implementing window-based CCNx consumer. Adding RTO estimation. by Alexander Afanasyev · 13 years ago 98a7cfc Merge remote-tracking branch 'git.irl/master' by Ilya Moiseenko · 13 years ago 46bdc7c 4 scenarios by Ilya Moiseenko · 13 years ago 029d38d Creating a pure virtual class CcnxConsumer. CcnxConsumerCbr now by Alexander Afanasyev · 13 years ago c4f8828 Correcting GlobalRouting lookups. Adding Ipv4SeqsAppTracer by Alexander Afanasyev · 13 years ago 36d5c2a Temp commit by Alexander Afanasyev · 13 years ago 1d2642a Congestion for Sprint-POP scenario (half-working) by Alexander Afanasyev · 13 years ago 3183b5a Adding sequence number tracer by Alexander Afanasyev · 13 years ago b3e4b85 Separating ccnx-tracers into separate files. by Alexander Afanasyev · 13 years ago c86c283 Rate recorder trace helper by Alexander Afanasyev · 13 years ago 5beb35a Modifying SpringMobilityModel to make all nodes readjust after even one by Alexander Afanasyev · 13 years ago 011b859 Implementing Poisson Process for consumer requests (exponential distribution for inter-arrival times) by Alexander Afanasyev · 13 years ago 4975f73 Slight API change. Now there is only one CcnxAppHelper that can create all CcnxApps by Alexander Afanasyev · 13 years ago 120bf31 When giving up PIT entry, remove all outgoing interests. Otherwise, by Alexander Afanasyev · 13 years ago 8f5a9bb Rescanned bindings. Slight change in input format for AnnotatedTopology by Alexander Afanasyev · 13 years ago 141d131 Implementing CcnxTraceHelper (only aggregate traces for now) by Alexander Afanasyev · 13 years ago c9dc5d9 Merge remote-tracking branch 'git.irl/Ilya' by Alexander Afanasyev · 13 years ago f8fd590 Adding example of how to do tracing by Alexander Afanasyev · 13 years ago 6f5e8fa Synthetic topology by Ilya Moiseenko · 13 years ago bdc0d98 Enabling app-layer tracing by Alexander Afanasyev · 13 years ago 816de83 Tracing by Ilya Moiseenko · 13 years ago 7dbdcaf Adding SpringMobilityModel to adjust positions of nodes in large topologies by Alexander Afanasyev · 13 years ago ae3b7c3 Simplified and unified implementation of RocketfuelWeightReader by Alexander Afanasyev · 13 years ago a174aa5 Repair regression in CcnxFib. by Alexander Afanasyev · 13 years ago 66e6fd7 Processing the original format of Abilene topology file by Alexander Afanasyev · 13 years ago 0777f1c Merge remote-tracking branch 'git.irl/Ilya' by Alexander Afanasyev · 13 years ago 91b496a Visualization for abilene by Ilya Moiseenko · 13 years ago 4a5c2c1 Implementing notion of default routes (useful for Flooding scenarios) by Alexander Afanasyev · 13 years ago 8633d5d An update for AnnotatedTopologyReader and examples that use this reader by Alexander Afanasyev · 13 years ago 7e14efa Annotated topology reader now reads coordinates by Ilya Moiseenko · 13 years ago 09ac899 Sprint Reader now reads latencies from a separate file by Ilya Moiseenko · 13 years ago 3406f3e Correction of examples to reflect latest changes in CcnxStackHelper API by Alexander Afanasyev · 13 years ago 09374c0 Merge remote-tracking branch 'git.irl/Ilya' by Alexander Afanasyev · 13 years ago 58d2667 Abilene and sprint topologies by Ilya Moiseenko · 13 years ago 23d2b54 Repair two critical bug with Interest/NACK processing by Alexander Afanasyev · 13 years ago e67a97f Correcting bug with NACK processing by Alexander Afanasyev · 13 years ago c39f0b4 Finalizing interest limits. Now everything seem to work. by Alexander Afanasyev · 13 years ago 1145314 Enable limits options in CcnxStackHelper by Alexander Afanasyev · 13 years ago 9d313d4 Add NACK processing by Alexander Afanasyev · 13 years ago 19426ef Making everything compile. Now everything seems to work, but more by Alexander Afanasyev · 13 years ago a5bbe0e Correcting everything to the stage that everything compiles by Alexander Afanasyev · 13 years ago a46844b Correcting bugs with cleaning timeouts in PIT/RIT/ContentStore by Alexander Afanasyev · 13 years ago 795f9b5 More debug by Alexander Afanasyev · 13 years ago d02a5d6 Adding several corrections. Most important is fixing regression in ccnb-parser-block.cc by Alexander Afanasyev · 13 years ago 19dbcf3 unit test edited by Ilya Moiseenko · 13 years ago 176ed06 Modifying ccnx-grid example to work with support of the latest FIB populating by Alexander Afanasyev · 13 years ago a4e3f85 Merge remote-tracking branch 'git.irl/Ilya' by Alexander Afanasyev · 13 years ago 52e9aa9 Finishing with FIB initialization based on IPv4 global routing controller by Alexander Afanasyev · 13 years ago b2fc8a3 ccnx grid dump commit by Ilya Moiseenko · 13 years ago c3188b9 examples corrections by Ilya Moiseenko · 13 years ago 3ba44e5 Implementation of Ipv4GlobalRoutingUnroderedNexthops to manage multiple by Alexander Afanasyev · 13 years ago 3875a4b Working implementation and example of Ipv4GlobalRoutingOrderedNexthops by Alexander Afanasyev · 13 years ago 82b8eea ccnx-grid example corrections by Ilya Moiseenko · 13 years ago c926604 Ccnx-grid example by Ilya Moiseenko · 13 years ago beceb36 Update ccnx-routing-simple example by Alexander Afanasyev · 13 years ago 5b43386 Adding non-working example by Alexander Afanasyev · 13 years ago 6851632 Ccnx-test update which includes Producer App by Ilya Moiseenko · 13 years ago 25f7d4d Flooding forwarding strategy added by Ilya Moiseenko · 13 years ago c5a23e2 Many corrections to face/local-face/net-device-face/fib/pit. Now by Alexander Afanasyev · 13 years ago 09595dd Merge remote-tracking branch 'git.irl/master' by Alexander Afanasyev · 13 years ago fa4e263 Pcap example added by Ilya Moiseenko · 13 years ago a67e28c Adding RIT, PIT, FIB, and CS to ccnx-l3-protocol. Some small by Alexander Afanasyev · 13 years ago e91ab75 ContentObject and Interest serialization and deserialization seem to by Alexander Afanasyev · 13 years ago 85a3bca Debugging and resolving problems with interest serialization/deserialization by Alexander Afanasyev · 13 years ago 7407704 interest header example by Ilya Moiseenko · 13 years ago 2bd1bc3 Refactoring of Name::Components into CcnxNameComponents by Ilya Moiseenko · 13 years ago fccdb9e Implementing RIT (also using Boost.MultiIndex) by Alexander Afanasyev · 13 years ago 3715619 Merge remote-tracking branch 'git.irl/master' by Alexander Afanasyev · 13 years ago 7dd43be Annotated topology reader refactoring. Now example is cleaner. by Ilya Moiseenko · 13 years ago 0ab833e Solving compilation problems, adding more comments. Modified ccnx-test example by Alexander Afanasyev · 13 years ago Next »