Difference between revisions of "Current Development"

From Nsnam
Jump to: navigation, search
(LTE)
(CSMA model)
 
(167 intermediate revisions by 11 users not shown)
Line 1: Line 1:
 
{{TOC}}
 
{{TOC}}
  
On this page, we will try to maintain pointers to current ns-3 development work, and post some suggested project ideas.  If you are interested in collaborating on one of these projects, please do not hesitate to contact the individuals identified.
+
On this page, we will try to summarize current ns-3 development work.  If you are interested in collaborating on one of these projects, or reviewing work by others, please do not hesitate to contact the individuals identified, or the [mailto:tomh@tomh.org page maintainer].
  
Much of the current activity is centered around the current release, which is now ns-3.10 due in early 2011.  The release page should list code that is under active review for merging.
+
There are a few other places to look for current activity on ns-3 development:
 +
* the current release page will list code under consideration for merging, and bugs being worked.  The next release, [[Ns-3.30 | ns-3.30 release]], is not yet scheduled.
 +
* we should have entries for all of our known bugs in the [http://www.nsnam.org/bugzilla Bugzilla] bug tracker.
 +
* [[Related_Projects | Related projects]] list some active and past projects that are associated with ns-3.
 +
* We maintain a suggested [[Project_Ideas | project ideas]] page for people interested in trying to start something new, or finish off some existing work.
 +
* We conduct [https://groups.google.com/forum/?fromgroups#!forum/ns-3-reviews code review discussions] on the Google Group 'ns-3-reviews'
  
'''[[Ns-3.10 | ns-3.10 release page]]'''
+
= How to get involved =
  
If you are new to ns-3 and want to contribute, please read these guidelines:  [http://www.nsnam.org/contributing.html Contributing to ns-3] and review the information on this page below.
+
ns-3 always can use more time and assistance from contributors of all skill levels.  One of the best ways to learn a tool is to try to get involved in its development processes, even if it is as simple as pointing out stale information or documentation on our web pages. Ideas on how to get started are on our [[Project_Ideas | project ideas]] page.
  
'''Note:''' ns-3 developers sometimes hang out on IRC at #ns-3 at irc.freenode.net. 
+
If you are new to ns-3 and want to contribute code, please read these guidelines:  [http://www.nsnam.org/developers/contributing-code/ Contributing to ns-3] and review the information on this page below.  
  
We conduct many of our reviews at http://codereview.appspot.com. 
+
'''Note:''' ns-3 developers sometimes hang out on IRC at #ns-3 at irc.freenode.net.  [http://colabti.org/irclogger/irclogger_logs/ns-3 IRC logs]
  
= Reviews requested for ns-3 merge =
+
Also, please check out the [[Nsnam:Current events | Current events]] page to learn of upcoming events for ns-3.
  
The ns-3.10 page has the most recent list of things under review for merge.
+
= Code reviews =
  
== GSOC ==
+
All new code (other than maintenance code committed directly by a module's maintainer) goes through a public code review.  The process is described [http://www.nsnam.org/developers/contributing-code/code-reviews/ here].  This page is devoted to listing code reviews that have been publicly announced.
  
We have several Google Summer of Code projects under current review:
+
Currently open code reviews should be also tagged in our bug trackerhttps://www.nsnam.org/bugzilla/buglist.cgi?query_format=advanced&resolution=---&short_desc=code%20review&short_desc_type=allwordssubstr
* LTEhttp://codereview.appspot.com/1869054/show
+
* Underwater Networking:  http://codereview.appspot.com/1743057
+
* Click routing:  http://codereview.appspot.com/1690056
+
* OpenFlow integration:  http://codereview.appspot.com/1872049/show
+
  
== TCP refactoring ==
+
Some older code reviews can be found here (some of these have been included in ns-3, some are still pending):
  
* ''code location'': http://codereview.appspot.com/1702042/show
+
* '''Mobility service interface (revised)'''
* ''reviewer(s)''Tom Henderson, Josh Pelkey
+
** Code review: https://codereview.appspot.com/265730044/
* ''status''candidate for early merge to ns-3 after the ns-3.9 release
+
** Wiki pagehttps://www.nsnam.org/wiki/RoutesMobilityModel
 +
** Repohttps://bitbucket.org/TiagoCerqueira/routesmobilitymodel/overview
  
== Vehicular Ad Hoc Networks (VANET) ==
+
* '''LR-WPAN Contiki MAC''' (and updated energy model code)
 +
** Code review:  https://codereview.appspot.com/254120043/
  
* ''code location'': http://codereview.appspot.com/179068
+
* '''Lr-Wpan Energy Model'''
* ''reviewer(s)'':  Mathieu Lacage
+
** Code review: <s>https://codereview.appspot.com/249560043/</s> See above contiki mac review
* ''status'':  waiting for more reviews
+
  
== MPLS ==
+
* '''SiFT'''
 +
** Code review:  https://codereview.appspot.com/246310044/
  
* ''Submitted by'': Andrey Churin
+
* '''Collector classes for Data collection framework'''
* ''code location'': http://code.google.com/p/ns3-mpls/
+
** Code review:  http://codereview.appspot.com/245260043
* ''alternate code location'':  http://codereview.appspot.com/850045/show  (Andrey recommends to look at the repo instead)
+
* ''reviewer(s)'':  None
+
* ''status'':  Requested review on 11 April.
+
  
== Chord/DHash DHT ==
+
* '''Ipv6 for LTE module'''
 +
** Announce: http://mailman.isi.edu/pipermail/ns-developers/2015-April/012680.html
 +
** Code review:  https://codereview.appspot.com/234000043/
  
* ''Submitted by'': Harjot Gill
+
* '''Propagation loss model for Teraherz channels'''
* ''code location:'' http://codereview.appspot.com/180107/show
+
** Code review: https://codereview.appspot.com/197290043/  
* ''reviewers:'' Mathieu Lacage, Tom Henderson
+
* ''background:'' http://mailman.isi.edu/pipermail/ns-developers/2009-December/007222.html
+
* ''status:'' Dormant for a while
+
  
== TCP Vegas ==
+
* '''Obstacle shadowing model'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2015-February/012536.html
 +
** Code review:  https://codereview.appspot.com/201200043
  
* ''Submitted by:'' Juan Pablo Poujade
+
* ''' 802.15.4e TSCH model'''
* ''code location:'' http://mailman.isi.edu/pipermail/ns-developers/2010-February/007419.html
+
** Announce: http://mailman.isi.edu/pipermail/ns-developers/2015-January/012459.html
* ''reviewers:'' none officially
+
** Code review: https://codereview.appspot.com/194960043/ and https://codereview.appspot.com/192220043/
* ''status:'' Waiting for guidance on how TCP congestion control variants will be implemented in general
+
  
== API and functionality for marking TOS bytes in packets ==
+
* ''' WifiMac Weighted Fair Queue '''
 +
** Announce: https://groups.google.com/forum/#!topic/ns-3-reviews/7LYDuv1d8ss
 +
** Code review: https://codereview.appspot.com/180690043/
  
* ''Submitted by:'' Antti Makela
+
* '''CSMA backoff improvements'''
* ''code location:'' http://www.nsnam.org/bugzilla/show_bug.cgi?id=897
+
** Announce: http://mailman.isi.edu/pipermail/ns-developers/2014-July/012113.html
* ''reviewer(s):'' None
+
** Code review: https://codereview.appspot.com/109450044/
* ''status:'' Need to consider whether this fits into the Linux netfilter support that is planned
+
  
= Build system and project infrastructure =
+
* '''LEAR extension for DSR'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2014-April/011933.html
 +
** <s>Code review:  https://codereview.appspot.com/85630046/</s>
 +
** Note:  new code review issue posted 8 May:  https://codereview.appspot.com/96130043/
  
== Modular build and package management ==
+
* '''TCP CUBIC'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2014-April/011939.html
 +
** Code review:  https://codereview.appspot.com/87740043
  
This issue is being tracked (requirements and wish list) on [[App_Store_Technical_Requirements | this page]]
+
* '''Next steps with Object Stop/Start'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2014-February/011764.html
 +
** Code review:  http://codereview.appspot.com/66990047
  
== State of Doxygen ==
+
* '''NetSh (simulation helper)'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2014-February/011742.html
 +
** Code review:  none yet.
 +
 +
* '''WDM module'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2014-February/011758.html
 +
** Code review:  none yet.
  
Plan to file a P1 blocker on thie release to bring Doxygen into compliance (no errors, no warnings for missing documentation).
+
* '''DAMA environment'''
 +
** Announce:  http://mailman.isi.edu/pipermail/ns-developers/2014-January/011715.html
  
== Buildbots ==
+
* '''Energy model access via Config system'''
 +
** Announce (January 3, 2014): http://mailman.isi.edu/pipermail/ns-developers/2014-January/011660.html
 +
** Code review:  https://codereview.appspot.com/39820045
  
Status:  Josh Pelkey is going to debug current buildbots
+
* '''DTN Bundle Protocol'''
* investigate hooking code coverage (lcov) into the report
+
** Announce (December 23, 2013):  http://mailman.isi.edu/pipermail/ns-developers/2013-December/011616.html
* investigate how the whole buildbot farm may be made available to a maintainer to test out a non-ns-3-dev repo.   
+
** Code review: https://codereview.appspot.com/38130049/
  
== Code contribution guidance ==
+
* '''PGBR routing protocol and extension of topology-read module'''
 +
** Announce (Oct 21, 2013): http://mailman.isi.edu/pipermail/ns-developers/2013-October/011455.html
 +
** Code review:  https://codereview.appspot.com/15530043/
 +
** Status:  Needs reviews
  
Tom took action item to simplify and clarify the project code contribution guidelines (for people wishing to contribute new code to ns-3).
+
* '''UAN WOSS'''
 +
** Announce (Oct 14, 2013): http://mailman.isi.edu/pipermail/ns-developers/2013-October/011446.html
 +
** Code review:  https://codereview.appspot.com/14677043/
 +
** Status:  Needs reviews
  
== Samples directory ==
+
* '''Epidemic routing'''
 +
** Announce (Sept 24, 2013): http://mailman.isi.edu/pipermail/ns-developers/2013-September/011426.html
 +
** Code review:  https://codereview.appspot.com/13831049/
 +
** Status:  Author responding to latest review comments.
  
Consider cleanup and move of samples/ directory to examples/?
+
Some older code reviews can be found here:  http://www.nsnam.org/wiki/Ns-3.18#additional_new_feature_reviews
  
== Documentation ==
+
Also:
 +
* '''TDMA'''
 +
** Code review: https://codereview.appspot.com/4747046/
 +
* '''Simple wireless'''
 +
** Code review:  https://codereview.appspot.com/1587041/show
 +
* '''Ipv4 Route Output refactoring'''
 +
** Code review: https://codereview.appspot.com/5661044/
 +
** Bug tracker issue:  https://www.nsnam.org/bugzilla/show_bug.cgi?id=1111
  
Considering to refactor documentation to split the existing manual into a model library and a software core reference manual, to add a lighter-weight tutorial, and to add a "cookbook" of howtos for common ns-3 tasks.
+
= Roadmap =
  
== Website ==
+
See the [[ns-3.30]] page for the current release planning and roadmap.
  
Status:  We are looking for a nicely themed static front page for the project, similar to other open source projects (e.g. http://www.pfsense.org).  It should be easily maintainable (editable) via mercurial or a simple open-source content management system.  Some people have suggested migration of content to Trac wiki, but no action taken on this.
+
= Current development for main trunk of ns-3 =
  
= Other ongoing development projects =
+
This section is intended to list items that people are working on, to avoid duplicated efforts and to promote collaboration.
  
== Google Summer of Code 2010 ==
+
== Wi-Fi 802.11ax support ==
  
Please see [[GSOC2010AcceptedProjects]] page.  GSOC 2010 has completed and we will now be aiming to merge all project code during ns-3.10 open development phase.
+
Sebastien Deronne has been adding 11ax rates and support for information elements (HeOperation, HeCapabilities).  He recently added a 'HeConfiguration' object to store 11ax configuration items. He is next planning to refactor the WifiPreamble class to more cleanly add support for HE-SIG-A fields.
  
== NSF Frameworks for ns-3 ==
+
A team at UW is working on spatial reuse features (Non-SRG OBSS_PD level) and next plans to work on MU-OFDMA aspects.  The UW team is collaborating with Stefano Avallone who is working on MU-OFDMA and plans to publicly develop on his 'wifi-next' branch: https://github.com/stavallo/ns-3-dev-git/tree/wifi-next 
  
Please see [[NSF_Frameworks]] page.
+
Development is planned based  on the spec framework https://mentor.ieee.org/802.11/dcn/15/11-15-0132-17-00ax-spec-framework.docx).
 +
 
 +
Others are welcome to list their work in progress here regarding 802.11ax, to reduce duplicated effort and encourage collaboration.  Contact one of the above maintainers if interested.
 +
 
 +
== WiFi models ==
 +
 
 +
Wi-Fi maintainer [mailto:sebastien.deronne@gmail.com Sebastien Deronne] and others are currently working on the following list of extensions to ns-3 WiFi models:
 +
* WiFi channel scanning (Tom Henderson and Muhammad Iqbal)
 +
* Minstrel-Blues rate control (Matias Richart)
 +
* 802.11ad support (Hany Assasa and Sébastien Deronne)
 +
* 802.11ah support (Le Tian and Sébastien Deronne)
 +
* 802.11ax features (see above)
 +
* Rohan Patidar and Tom Henderson are preparing for code review a new OFDM error model based on link-to-system mapping and fast fading channels (see WNS3 2017 paper on this topic for more information)
 +
 
 +
The following additional work is recommended (contributions from others are recommended); contact Sebastien to coordinate:
 +
* 802.11n/ac beamforming support
 +
* 802.11ac MU-MIMO support
 +
* 802.11 HCF/HCCA
 +
* Any other 802.11n/ac missing feature
 +
 
 +
== AQM and ECN ==
 +
 
 +
Last updated:  Dec. 2017
 +
 
 +
Stefano Avallone is working on:
 +
 
 +
- introduce other qdiscs: fifo, prio and token bucket (Surya’s GSoC). Finish off HHF (the other qdisc Surya worked on).
 +
 
 +
- merge a few pending code reviews which implement other qdiscs (REM, BLUE, PI, PI2) and add ECN support to CoDel and PIE.
 +
 
 +
- help Pasquale and Tommaso to merge the netmap netdevice (SOCIS)
 +
 
 +
- if time permits, implement the Diffserv to IEEE 802.11 mapping as defined by draft-ietf-tsvwg-ieee-802-11-09
 +
 
 +
== CSMA model ==
 +
 
 +
This was a feature goal for ns-3.23 release, but has slipped (further input wanted).
 +
 
 +
There has been discussion in the June 2014 timeframe about improving this model:
 +
* https://mailman.isi.edu/pipermail/ns-developers/2014-June/011864.html
 +
* https://mailman.isi.edu/pipermail/ns-developers/2014-June/011931.html
 +
 
 +
Some previous code reviews:
 +
 
 +
* https://codereview.appspot.com/109450044/
 +
* https://codereview.appspot.com/187880044/
 +
 
 +
Latest patch:
 +
* https://www.nsnam.org/bugzilla/show_bug.cgi?id=2354
 +
 
 +
These improvements have been recommended:
 +
# Implement backoff counter decrement as a function of line state (''see this [https://codereview.appspot.com/109450044/ initial code review]'')
 +
# Divide CSMA implementation between CSMA/CD & CSMA/CA (which are totally different)
 +
# Implement a distance system (not the same propagation delay for every nodes); see Vedran Miletić's work [https://codereview.appspot.com/5314055/#ps3002 code review issue]  
 +
# Audit the ns-3 examples to find instances where CSMA is being used with inappropriate link delay (where multiple access may perform very suboptimally)
 +
 
 +
= Past development efforts =
 +
<pre style="color: red">
 +
Most of these activities are now dormant or concluded and some of the information is stale. 
 +
We are keeping here as a placeholder until this section can be cleaned up.
 +
</pre>
  
 
== ns-3 core ==
 
== ns-3 core ==
Line 115: Line 208:
 
* ''ns-developers post'':  http://mailman.isi.edu/pipermail/ns-developers/2009-July/006197.html
 
* ''ns-developers post'':  http://mailman.isi.edu/pipermail/ns-developers/2009-July/006197.html
 
* ''code location'':  http://code.nsnam.org/guillaume/ns-3-multithreading/
 
* ''code location'':  http://code.nsnam.org/guillaume/ns-3-multithreading/
* ''status'': ns-3.10 merge?
+
* ''status'': ns-3.11 merge?
 
+
=== Synchronized emulation ===
+
 
+
* ''code location'': None posted yet
+
* ''background'':  http://mailman.isi.edu/pipermail/ns-developers/2009-July/006198.html
+
* ''status'':  contact Elias Weingartner
+
  
 
=== Linux namespaces and ns-3 ===
 
=== Linux namespaces and ns-3 ===
Line 127: Line 214:
 
* ''summary'':  Tom Goff has contributed code and documentation about how to use ns-3 with Linux namespaces.
 
* ''summary'':  Tom Goff has contributed code and documentation about how to use ns-3 with Linux namespaces.
 
* ''code location'':  See the below wiki page.
 
* ''code location'':  See the below wiki page.
* ''background'':  http://www.nsnam.org/wiki/index.php/HOWTO_use_Linux_namespaces_with_ns-3
+
* ''background'':  [[HOWTO use Linux namespaces with ns-3]]
* ''status'':  Craig Dowell is presently working on integration of this capability with the [http://cs.itd.nrl.navy.mil/work/core/index.php CORE network emulator]. Some form of this will likely be merged with ns-3 in the future. 
+
* ''status'':  A version of this was merged to the latest [http://cs.itd.nrl.navy.mil/work/core/ CORE network emulator] release.
  
 
== Device and channel models ==
 
== Device and channel models ==
 +
=== Optical network: WDM, PON and RoF ===
 +
See [[Optical network models]].
  
 
=== Miscellaneous wifi enhancements ===
 
=== Miscellaneous wifi enhancements ===
Line 143: Line 232:
 
* ''code location'': http://codereview.appspot.com/62054
 
* ''code location'': http://codereview.appspot.com/62054
 
* ''reviewer(s)'':  TBD
 
* ''reviewer(s)'':  TBD
* ''status'':
+
* ''status'': reimplemented in a more general way, see [[Object Start Stop Specification]]
  
=== 802.11 model extensions ===
+
=== Wireless Interference (Jamming) Model ===
  
There are several efforts ongoing to extend the ns-3 Wifi model.
+
* ''summary'': [http://www.ee.washington.edu/research/nsl/faculty/radha/ Network Security Lab (NSL)], University of Washington, Seattle has begun work on a wireless interference (jamming) model for ns3. The goal is to to enable researchers to use ns3 to study jamming and its mitigation methods.
 +
* ''wiki page'': [[NS-3 wireless jamming model]]
 +
* ''code location'': http://codereview.appspot.com/1055041/show
 +
* ''status'': Public review.
  
==== Harmonization with ns-2 802.11 Ext models ====
+
=== Vehicular Ad Hoc Networks (VANET) ===
* ''summary'': ns-2.33 added a new 802.11 model with much more detailed channel modeling.  An effort has been started to port over reusable components from that implementation to ns-3's wifi model, while reusing already implemented basic components. The goal is a harmonization of the 802.11 models of ns-2 and ns-3. Leading aim is to support research on vehicular networks. Planned near-term features:
+
** Equalizing PHY models including capture effects, user-definable coding rates (e.g. 5.9 GHz from 802.11p)
+
** EDCA QoS extensions of 802.11e
+
* Already finished features:
+
** Nakagami/Rayleigh propagation loss model
+
* ''ns-developers post'': http://mailman.isi.edu/pipermail/ns-developers/2008-November/004936.html
+
* ''code location'': http://idlebox.net/2008/ns-3-wifi/code/ns-3-wifiex/
+
* ''status'':  under current active development.  Time frame till this is completed: 4-5 month.
+
  
==== 802.11n ====
+
* ''summary'': Michele Weigle's group is working on VANET and has posted a patch for review in the past, but has taken it off the table for ns-3 merge consideration until more work is done.
 +
* ''code location'': None publicly posted at this time.
  
* ''summary'':  University of Florence (LART lab) has begun work on an 802.11n model for ns3. The main goal is to simulate the frame aggregation feature.  In the future, they aim to implement the High Throughput terminal behaviour with MIMO technology.  They plan to add, to ns-3's 802.11 model, the following 802.11n features:
+
=== Wireless Sensor Networks (i.e., 802.15.4 + 6LoWPAN + RPL) ===
** Frame Aggregation
+
** Block ACK
+
** HCF (EDCA and support for HCCA)
+
** TXOP
+
** HT terminal (also with protection modes)
+
** MIMO
+
Also interested to verify the 11n terminal throughput when are associated terminal of a/b/g standards.
+
* Already finished features (in ns-3.5):
+
** HCF, TXOP, Frame Aggregation
+
* Merged for ns-3.8:
+
** Block ACK
+
* ''code location'': http://code.nsnam.org/mirko/ns-3-80211n
+
* ''status'':  Frame aggregation and block ack merged already; Tommaso Pecorella announced his lab's next steps [http://mailman.isi.edu/pipermail/ns-developers/2010-August/008303.html here]
+
  
=== Wireless Interference (Jamming) Model ===
+
Tommaso Pecorella announced his plans [http://mailman.isi.edu/pipermail/ns-developers/2010-August/008304.html here]
  
* ''summary'': [http://www.ee.washington.edu/research/nsl/faculty/radha/ Network Security Lab (NSL)], University of Washington, Seattle has begun work on a wireless interference (jamming) model for ns3. The goal is to to enable researchers to use ns3 to study jamming and its mitigation methods.
+
Current status is:
* ''wiki page'': http://www.nsnam.org/wiki/index.php/NS-3_wireless_jamming_model
+
* RPL implementation (storing, multicast): 5th refactoring going on. Moving responsibility to ParentSet and MeasureCollectors for metrics other than HC.
* ''code location'': http://codereview.appspot.com/1055041/show
+
** RPL is based on [http://tools.ietf.org/wg/roll/ ROLL RFCs and drafts]
* ''status'': Public review.
+
** Objective functions implemented are of0 and minrank-hysteresis-of
 +
* 6LoWPAN has been merged in ns-3-dev and will be included in ns-3.19.
 +
* 802.15.4 will rely on the lr-wpan module (currently being implemented by Boeing).
 +
** A patch to the lr-wpan code to enable its use with 6LoWPAN (and the full IPv6 stack) has been created. The patch adds a number of functionalities to the module and will be either included in lr-wpan or provided as a separate patch.
  
=== ns-3, 802.15.4 + 6LoWPAN ===
+
A wiki page will be created before 3.19 release to explain in detail the current implemented functionalities, the models limitations, the work status and provide a guide to setup a simple simulation.
  
* ''status'':  Tommaso Pecorella announced his plans [http://mailman.isi.edu/pipermail/ns-developers/2010-August/008304.html here]
+
Boeing is working on lr-wpan (IEEE 802.15.4-2006) support; details [[lr-wpan | here]].
  
 
=== LTE ===
 
=== LTE ===
  
Several developers expressed their interest in enhancing the LTE code developed within the GSoC 2010:
+
In addition to the LENA project above, several developers expressed their interest in enhancing the LTE code initially developed within the GSoC 2010:
* Nicola Baldo and Marco Miozzo (CTTC) [http://mailman.isi.edu/pipermail/ns-developers/2010-November/008461.html announced] to be working on the following:
+
 
** adding UL link adaptation
+
** modeling inter-cell interference
+
** reworking the RRM/scheduling API
+
 
* Leo Razoumov [http://mailman.isi.edu/pipermail/ns-developers/2010-November/008467.html announced] possible interest in the following contributions:
 
* Leo Razoumov [http://mailman.isi.edu/pipermail/ns-developers/2010-November/008467.html announced] possible interest in the following contributions:
 
** MIMO
 
** MIMO
Line 203: Line 275:
 
** scheduling
 
** scheduling
 
** AMC
 
** AMC
* Marco Mezzavilla and his group (DEI, University of Padova) [http://mailman.isi.edu/pipermail/ns-developers/2010-November/008483.html announced] interest in working on the following:
+
* Marco Mezzavilla and his group (DEI, University of Padova) [http://mailman.isi.edu/pipermail/ns-developers/2010-November/008483.html announced] interest in working on the following, and have posted a repository in February 2011 [http://mailman.isi.edu/pipermail/ns-developers/2011-February/008653.html details here]:
 
** MAC layer
 
** MAC layer
 
** mobility
 
** mobility
 
** traffic modelization
 
** traffic modelization
 
** MIMO
 
** MIMO
 +
* Sandra Frei [http://mailman.isi.edu/pipermail/ns-developers/2011-July/009195.html announced] that a group is working on Evolved Packet System (EPS) support
 +
** GTPv1-U (for the user plane)
 +
** GTPv2-C (for the control plane)
 +
** Diameter: Supported use cases: default- and dedicated bearer establishment
 +
** NAS (ESM, EMM) A combined initial attach with a default bearer establishment. Dedicated bearer establishment
 +
** X2AP HO without SGW relocation. Endmarker messages are not supported
 +
** PMIPv6: PBU/PBA, LMA, MAG
  
 
== Link layer ==
 
== Link layer ==
Line 213: Line 292:
 
=== 802.21 media independent handover ===
 
=== 802.21 media independent handover ===
  
* ''wiki page'': http://www.nsnam.org/wiki/index.php/NS-3_MIH_implementation
+
* ''wiki page'': [[NS-3 MIH implementation]]
 
* ''code location'':  http://code.nsnam.org/salumu/ns-3-mih/
 
* ''code location'':  http://code.nsnam.org/salumu/ns-3-mih/
 
* ''status'': Dormant-- no merge plans announced.
 
* ''status'': Dormant-- no merge plans announced.
 +
 +
== MPLS ==
 +
 +
* ''Submitted by'': Andrey Churin
 +
* ''code location'': http://code.google.com/p/ns-3-shop/
 +
* ''reviewer(s)'':  None
 +
* ''status'':  Project has moved to Google hosting. 
  
 
== Network layer ==
 
== Network layer ==
  
=== IPv6 for ns-3 ===
+
=== API and functionality for marking TOS bytes in packets ===
  
* ''summary'': Ipv6 support for ns-3
+
* ''Submitted by:'' Antti Makela
* ''ns-developers post'': http://mailman.isi.edu/pipermail/ns-developers/2008-June/004283.html
+
* ''code location:'' http://www.nsnam.org/bugzilla/show_bug.cgi?id=897
* ''code location'': hg clone https://svnet.u-strasbg.fr/hg/ns-3-ipv6-2nd/
+
* ''reviewer(s):'' None
* ''status'': ns-3.3 contains the first merge (Ipv6Address) of this code. ns-3.7 and ns-3.8 will continue to add featuresHere is a tentative roadmap: http://mailman.isi.edu/pipermail/ns-developers/2009-July/006211.html
+
* ''status:'' Need to consider whether this fits into the Linux netfilter support that is planned
 +
 
 +
=== DSR routing ===
 +
 
 +
* ''Submitted by:'' Yufei Cheng
 +
* ''status:'' Announced here:  http://mailman.isi.edu/pipermail/ns-developers/2010-December/008496.html
 +
 
 +
=== DSDV routing ===
 +
 
 +
* ''Submitted by:'' Hemanth Narra
 +
* ''code location:'' http://codereview.appspot.com/1668042/show
 +
* ''status:'' Announced here:  http://mailman.isi.edu/pipermail/ns-developers/2010-December/008496.html
 +
 
 +
== Transport layer ==
 +
 
 +
=== TCP Vegas ===
 +
 
 +
* ''Submitted by:'' Juan Pablo Poujade
 +
* ''code location:'' http://mailman.isi.edu/pipermail/ns-developers/2010-February/007419.html
 +
* ''reviewers:'' none officially
 +
* ''status:'' Waiting for guidance on how TCP congestion control variants will be implemented in general
 +
 
 +
=== Multipath TCP for ns-3.29 and ns-3.8 ===
 +
 
 +
An ns-3 implementation for [https://datatracker.ietf.org/doc/rfc6824// MPTCP] (Multipath TCP). This implementation is compatible with the current ns-3 release ns-3.29.
 +
 
 +
* ''Submitted by:'' Kashif Nadeem
 +
* ''code location:'' https://github.com/Kashif-Nadeem/ns-3-dev-git
 +
* ''MPTCP patch here'' https://codereview.appspot.com/369810043/
 +
 
 +
 
 +
NS-3 module for [http://datatracker.ietf.org/wg/mptcp/charter/ MPTCP] (Multipath TCP). The current release is compatible with 3.8 version of NS-3.
 +
A check of the compatibility with the latest version is needed.
 +
 
 +
* ''Submitted by:''  Bachir CHIHANI
 +
* ''code location:'' http://code.google.com/p/mptcp-ns3/
  
 
== Application layer ==
 
== Application layer ==
  
== Chord/DHash DHT ==
+
=== Chord/DHash DHT ===
  
* ''code location'': http://code.nsnam.org/gillh/ns-3-chord
+
* ''Submitted by'': Harjot Gill
* ''reviewers'': (none yet)
+
* ''code location:'' http://codereview.appspot.com/180107/show
* ''background'': http://mailman.isi.edu/pipermail/ns-developers/2009-December/007222.html
+
* ''reviewers:'' Mathieu Lacage, Tom Henderson
 +
* ''background:'' http://mailman.isi.edu/pipermail/ns-developers/2009-December/007222.html
 +
* ''status:'' Dormant for a while
  
 
=== Synchronous posix/sockets API ===
 
=== Synchronous posix/sockets API ===
Line 244: Line 367:
  
 
* ''summary'': port of quagga routing to ns-3
 
* ''summary'': port of quagga routing to ns-3
* ''wiki page'': http://www.nsnam.org/wiki/index.php/Real_World_Application_Integration
+
* ''wiki page'': [[Real World Application Integration]]
 
* ''code location'': http://code.nsnam.org/lj/quagga-porting/
 
* ''code location'': http://code.nsnam.org/lj/quagga-porting/
 
* ''status'':  Was developed by Liu Jian, Google Summer of Code.  Portions of this code are planned for a future release (ns-3.8 or later) when ns-3-simu is merged.
 
* ''status'':  Was developed by Liu Jian, Google Summer of Code.  Portions of this code are planned for a future release (ns-3.8 or later) when ns-3-simu is merged.
Line 255: Line 378:
 
* ''background'':  http://mailman.isi.edu/pipermail/ns-developers/2009-June/006144.html
 
* ''background'':  http://mailman.isi.edu/pipermail/ns-developers/2009-June/006144.html
  
== Visualization for ns-3 ==
+
=== Pastry ===
 +
 
 +
* ''Summary:'' An implementation of [http://www.freepastry.org/ Pastry] within ns-3. Including some experimental key-based routing API.
 +
* ''Developers:'' Robert Nitsch and Dominic Scheurer ([https://www.tu-darmstadt.de/ Technische Universität Darmstadt]).
 +
* ''Code location:'' https://bitbucket.org/r_nitsch/ns-3-pastry/ (old repository: <nowiki>https://bitbucket.org/r_nitsch/libpastry/</nowiki>)
 +
* ''Doxygen documentation:'' http://libpastry.robertnitsch.de
 +
* ''Status:''
 +
** 2012-01-22: Re-integrated the code into ns-3 source tree (ns-3.13).
 +
** Mostly finished.
 +
** Node arrival process needs some tweaking.
 +
** Review needed. (We're going to request one as soon as we're ready.)
 +
 
 +
== Visualization ==
  
 
Jeremy Norman and the iNSpect team have posted some plans for a visualization library for ns-3:
 
Jeremy Norman and the iNSpect team have posted some plans for a visualization library for ns-3:
 
* http://mailman.isi.edu/pipermail/ns-developers/2008-March/003777.html
 
* http://mailman.isi.edu/pipermail/ns-developers/2008-March/003777.html
 
* http://mailman.isi.edu/pipermail/ns-developers/2008-November/004914.html
 
* http://mailman.isi.edu/pipermail/ns-developers/2008-November/004914.html
 
Gustavo Carneiro is working on a NS-3 Python visualization tool called [[PyViz|NS-3 PyViz]].
 
  
 
George Riley has made a [[NetAnim | prototype animator]] for PointToPoint links.
 
George Riley has made a [[NetAnim | prototype animator]] for PointToPoint links.
Line 269: Line 402:
 
Hagen Paul Pfeifer is working on a MANET visualizer http://nv.dev.jauu.net/
 
Hagen Paul Pfeifer is working on a MANET visualizer http://nv.dev.jauu.net/
  
== Graphical simulation builder ==
+
=== Graphical simulation builder ===
  
 
Pierre Weiss and Sebastien Vincent have written an [[Ns3Generator| ns-3 scenario generator]] in Qt.   
 
Pierre Weiss and Sebastien Vincent have written an [[Ns3Generator| ns-3 scenario generator]] in Qt.   
 
* http://mailman.isi.edu/pipermail/ns-developers/2010-May/007998.html
 
* http://mailman.isi.edu/pipermail/ns-developers/2010-May/007998.html
 
* Mercurial download:  http://svnet.u-strasbg.fr/hg/ns-3-generator/
 
* Mercurial download:  http://svnet.u-strasbg.fr/hg/ns-3-generator/
 +
 +
=== NetExplorer ===
 +
 +
[http://code.google.com/p/ns-3-shop/wiki/NetExplorer | NetExplorer] is Gnome/Gtk network animation tool for NS-3.
  
 
== Miscellaneous ==  
 
== Miscellaneous ==  
Line 285: Line 422:
  
 
* ''summary'': ns-3 extensions for parallelization
 
* ''summary'': ns-3 extensions for parallelization
* ''wiki page'': http://www.nsnam.org/wiki/index.php/Parallel_Simulations
+
* ''wiki page'': [[Parallel Simulations]]
 
* ''code location'': http://code.nsnam.org/pfeifer/ns-3-para/
 
* ''code location'': http://code.nsnam.org/pfeifer/ns-3-para/
 
* ''status'':  dormant since 2008 Google Summer of Code
 
* ''status'':  dormant since 2008 Google Summer of Code
  
 +
=== Delay Box for ns-3 ===
 +
 +
Matt Crinklaw is working on a port of ns-2 DelayBox to ns-3.
 +
* ''summary'':  http://www.isi.edu/nsnam/ns/doc/node247.html  (from ns-2 documentation)
 +
* ''code location'':  http://freehg.org/u/mlaw
 +
* ''status'':  No status update recently.  Dormant.
  
 
=== Simulation Configuration and State Detection ===
 
=== Simulation Configuration and State Detection ===
Line 296: Line 439:
 
[[SimulationConfiguration | Simulation Configuration]]
 
[[SimulationConfiguration | Simulation Configuration]]
  
=== Delay Box for ns-3 ===
+
= Build system and project infrastructure =
  
Matt Crinklaw is working on a port of ns-2 DelayBox to ns-3.
+
== Modular build and package management ==
* ''summary'':  http://www.isi.edu/nsnam/ns/doc/node247.html  (from ns-2 documentation)
+
* ''code location'':  http://freehg.org/u/mlaw
+
* ''status'':  No status update recently.  Dormant.
+
  
= Suggested projects =
+
This issue is being tracked (requirements and wish list) on [[App_Store_Technical_Requirements | this page]]
  
== 2010 Google Summer of Code Project Ideas ==
+
== State of Doxygen ==
  
We have posted some project ideas for [http://code.google.com/soc/ Google Summer of Code].  However, these ideas are not limited to the Google program.
+
Need to bring Doxygen into compliance (no errors, no warnings for missing documentation).
  
'''[[GSOC2010Projects | Project ideas here]]'''
+
== Buildbots ==
  
== Path MTU discovery and fragmentation for IPv4 stacks ==
+
* investigate hooking code coverage (lcov) into the report
 +
* investigate how the whole buildbot farm may be made available to a maintainer to test out a non-ns-3-dev repo. 
  
There is no [http://en.wikipedia.org/wiki/Path_MTU_discovery path MTU discovery] implemented for IPv4.  This, combined with lack of fragmentation, makes guessing the end-to-end MTU imperative for ns-3 simulations.  We would welcome a contribution that introduced path MTU discovery and IPv4 fragmentation to ns-3.  Note that there is fragmentation support in the [http://yans.inria.fr/yans/ yans simulator] that may be of use; contact Mathieu Lacage for more information. 
+
== Code contribution guidance ==
  
== Removing traffic generation from applications class ==
+
Tom took action item to simplify and clarify the project code contribution guidelines (for people wishing to contribute new code to ns-3).
 +
 
 +
== Samples directory ==
 +
 
 +
Consider cleanup and move of samples/ directory to examples/?
 +
 
 +
== Documentation ==
 +
 
 +
Considering to refactor documentation to split the existing manual into a model library and a software core reference manual, to add a lighter-weight tutorial, and to add a "cookbook" of howtos for common ns-3 tasks.
 +
 
 +
== Website ==
  
#* ''summary'': Proposed decoupling to generalize applications
+
Status: INRIA is organizing some updates to the website.
#* ''ns-developers post'': http://mailman.isi.edu/pipermail/ns-developers/2007-July/003136.html
+
#* ''code location'': http://code.nsnam.org/laprisee/ns-3-mp/
+
#* ''status'':  Was under discussion in the summer.
+
#:
+

Latest revision as of 18:50, 30 September 2020

Main Page - Current Development - Developer FAQ - Tools - Related Projects - Project Ideas - Summer Projects

Installation - Troubleshooting - User FAQ - HOWTOs - Samples - Models - Education - Contributed Code - Papers

On this page, we will try to summarize current ns-3 development work. If you are interested in collaborating on one of these projects, or reviewing work by others, please do not hesitate to contact the individuals identified, or the page maintainer.

There are a few other places to look for current activity on ns-3 development:

  • the current release page will list code under consideration for merging, and bugs being worked. The next release, ns-3.30 release, is not yet scheduled.
  • we should have entries for all of our known bugs in the Bugzilla bug tracker.
  • Related projects list some active and past projects that are associated with ns-3.
  • We maintain a suggested project ideas page for people interested in trying to start something new, or finish off some existing work.
  • We conduct code review discussions on the Google Group 'ns-3-reviews'

How to get involved

ns-3 always can use more time and assistance from contributors of all skill levels. One of the best ways to learn a tool is to try to get involved in its development processes, even if it is as simple as pointing out stale information or documentation on our web pages. Ideas on how to get started are on our project ideas page.

If you are new to ns-3 and want to contribute code, please read these guidelines: Contributing to ns-3 and review the information on this page below.

Note: ns-3 developers sometimes hang out on IRC at #ns-3 at irc.freenode.net. IRC logs

Also, please check out the Current events page to learn of upcoming events for ns-3.

Code reviews

All new code (other than maintenance code committed directly by a module's maintainer) goes through a public code review. The process is described here. This page is devoted to listing code reviews that have been publicly announced.

Currently open code reviews should be also tagged in our bug tracker: https://www.nsnam.org/bugzilla/buglist.cgi?query_format=advanced&resolution=---&short_desc=code%20review&short_desc_type=allwordssubstr

Some older code reviews can be found here (some of these have been included in ns-3, some are still pending):

Some older code reviews can be found here: http://www.nsnam.org/wiki/Ns-3.18#additional_new_feature_reviews

Also:

Roadmap

See the ns-3.30 page for the current release planning and roadmap.

Current development for main trunk of ns-3

This section is intended to list items that people are working on, to avoid duplicated efforts and to promote collaboration.

Wi-Fi 802.11ax support

Sebastien Deronne has been adding 11ax rates and support for information elements (HeOperation, HeCapabilities). He recently added a 'HeConfiguration' object to store 11ax configuration items. He is next planning to refactor the WifiPreamble class to more cleanly add support for HE-SIG-A fields.

A team at UW is working on spatial reuse features (Non-SRG OBSS_PD level) and next plans to work on MU-OFDMA aspects. The UW team is collaborating with Stefano Avallone who is working on MU-OFDMA and plans to publicly develop on his 'wifi-next' branch: https://github.com/stavallo/ns-3-dev-git/tree/wifi-next

Development is planned based on the spec framework https://mentor.ieee.org/802.11/dcn/15/11-15-0132-17-00ax-spec-framework.docx).

Others are welcome to list their work in progress here regarding 802.11ax, to reduce duplicated effort and encourage collaboration. Contact one of the above maintainers if interested.

WiFi models

Wi-Fi maintainer Sebastien Deronne and others are currently working on the following list of extensions to ns-3 WiFi models:

  • WiFi channel scanning (Tom Henderson and Muhammad Iqbal)
  • Minstrel-Blues rate control (Matias Richart)
  • 802.11ad support (Hany Assasa and Sébastien Deronne)
  • 802.11ah support (Le Tian and Sébastien Deronne)
  • 802.11ax features (see above)
  • Rohan Patidar and Tom Henderson are preparing for code review a new OFDM error model based on link-to-system mapping and fast fading channels (see WNS3 2017 paper on this topic for more information)

The following additional work is recommended (contributions from others are recommended); contact Sebastien to coordinate:

  • 802.11n/ac beamforming support
  • 802.11ac MU-MIMO support
  • 802.11 HCF/HCCA
  • Any other 802.11n/ac missing feature

AQM and ECN

Last updated: Dec. 2017

Stefano Avallone is working on:

- introduce other qdiscs: fifo, prio and token bucket (Surya’s GSoC). Finish off HHF (the other qdisc Surya worked on).

- merge a few pending code reviews which implement other qdiscs (REM, BLUE, PI, PI2) and add ECN support to CoDel and PIE.

- help Pasquale and Tommaso to merge the netmap netdevice (SOCIS)

- if time permits, implement the Diffserv to IEEE 802.11 mapping as defined by draft-ietf-tsvwg-ieee-802-11-09

CSMA model

This was a feature goal for ns-3.23 release, but has slipped (further input wanted).

There has been discussion in the June 2014 timeframe about improving this model:

Some previous code reviews:

Latest patch:

These improvements have been recommended:

  1. Implement backoff counter decrement as a function of line state (see this initial code review)
  2. Divide CSMA implementation between CSMA/CD & CSMA/CA (which are totally different)
  3. Implement a distance system (not the same propagation delay for every nodes); see Vedran Miletić's work code review issue
  4. Audit the ns-3 examples to find instances where CSMA is being used with inappropriate link delay (where multiple access may perform very suboptimally)

Past development efforts

Most of these activities are now dormant or concluded and some of the information is stale.   
We are keeping here as a placeholder until this section can be cleaned up.

ns-3 core

Multi-threaded simulation implementation for multicore

Linux namespaces and ns-3

Device and channel models

Optical network: WDM, PON and RoF

See Optical network models.

Miscellaneous wifi enhancements

Patch to pause and resume an interface

Wireless Interference (Jamming) Model

Vehicular Ad Hoc Networks (VANET)

  • summary: Michele Weigle's group is working on VANET and has posted a patch for review in the past, but has taken it off the table for ns-3 merge consideration until more work is done.
  • code location: None publicly posted at this time.

Wireless Sensor Networks (i.e., 802.15.4 + 6LoWPAN + RPL)

Tommaso Pecorella announced his plans here

Current status is:

  • RPL implementation (storing, multicast): 5th refactoring going on. Moving responsibility to ParentSet and MeasureCollectors for metrics other than HC.
    • RPL is based on ROLL RFCs and drafts
    • Objective functions implemented are of0 and minrank-hysteresis-of
  • 6LoWPAN has been merged in ns-3-dev and will be included in ns-3.19.
  • 802.15.4 will rely on the lr-wpan module (currently being implemented by Boeing).
    • A patch to the lr-wpan code to enable its use with 6LoWPAN (and the full IPv6 stack) has been created. The patch adds a number of functionalities to the module and will be either included in lr-wpan or provided as a separate patch.

A wiki page will be created before 3.19 release to explain in detail the current implemented functionalities, the models limitations, the work status and provide a guide to setup a simple simulation.

Boeing is working on lr-wpan (IEEE 802.15.4-2006) support; details here.

LTE

In addition to the LENA project above, several developers expressed their interest in enhancing the LTE code initially developed within the GSoC 2010:

  • Leo Razoumov announced possible interest in the following contributions:
    • MIMO
    • PHY model abstractions
    • scheduling models
    • mobility and traffic models
  • Giuseppe Piro and his group (DEE, Politecnico di Bari) announced the intent to continue with the development of the LTE module, focusing mainly on the following MAC layer aspects:
    • RRM
    • scheduling
    • AMC
  • Marco Mezzavilla and his group (DEI, University of Padova) announced interest in working on the following, and have posted a repository in February 2011 details here:
    • MAC layer
    • mobility
    • traffic modelization
    • MIMO
  • Sandra Frei announced that a group is working on Evolved Packet System (EPS) support
    • GTPv1-U (for the user plane)
    • GTPv2-C (for the control plane)
    • Diameter: Supported use cases: default- and dedicated bearer establishment
    • NAS (ESM, EMM) A combined initial attach with a default bearer establishment. Dedicated bearer establishment
    • X2AP HO without SGW relocation. Endmarker messages are not supported
    • PMIPv6: PBU/PBA, LMA, MAG

Link layer

802.21 media independent handover

MPLS

Network layer

API and functionality for marking TOS bytes in packets

DSR routing

DSDV routing

Transport layer

TCP Vegas

Multipath TCP for ns-3.29 and ns-3.8

An ns-3 implementation for MPTCP (Multipath TCP). This implementation is compatible with the current ns-3 release ns-3.29.


NS-3 module for MPTCP (Multipath TCP). The current release is compatible with 3.8 version of NS-3. A check of the compatibility with the latest version is needed.

Application layer

Chord/DHash DHT

Synchronous posix/sockets API

real-world application integration

ns-3-simu sockopt patches

Pastry

Visualization

Jeremy Norman and the iNSpect team have posted some plans for a visualization library for ns-3:

George Riley has made a prototype animator for PointToPoint links.

Joe Kopena is working on what he calls a "decorator" http://code.nsnam.org/tjkopena/

Hagen Paul Pfeifer is working on a MANET visualizer http://nv.dev.jauu.net/

Graphical simulation builder

Pierre Weiss and Sebastien Vincent have written an ns-3 scenario generator in Qt.

NetExplorer

| NetExplorer is Gnome/Gtk network animation tool for NS-3.

Miscellaneous

L2 Ethernet switch module

Parallel simulations (2008)

Delay Box for ns-3

Matt Crinklaw is working on a port of ns-2 DelayBox to ns-3.

Simulation Configuration and State Detection

In order to configure simulations across multiple, probably virtualized, machines a large amount of configuration must be performed in order to construct the component systems. The oppportunity for human error to creep in during this process renders it essentially manually unworkable for all but the simplest topologies. Craig Dowell is thinking about how to address this problem.

Simulation Configuration

Build system and project infrastructure

Modular build and package management

This issue is being tracked (requirements and wish list) on this page

State of Doxygen

Need to bring Doxygen into compliance (no errors, no warnings for missing documentation).

Buildbots

  • investigate hooking code coverage (lcov) into the report
  • investigate how the whole buildbot farm may be made available to a maintainer to test out a non-ns-3-dev repo.

Code contribution guidance

Tom took action item to simplify and clarify the project code contribution guidelines (for people wishing to contribute new code to ns-3).

Samples directory

Consider cleanup and move of samples/ directory to examples/?

Documentation

Considering to refactor documentation to split the existing manual into a model library and a software core reference manual, to add a lighter-weight tutorial, and to add a "cookbook" of howtos for common ns-3 tasks.

Website

Status: INRIA is organizing some updates to the website.