Difference between revisions of "GSOC2014Projects"

From Nsnam
Jump to: navigation, search
(bufferbloat-related models)
(IPv6 stack validation and improvements)
 
(27 intermediate revisions by 5 users not shown)
Line 4: Line 4:
 
* [http://en.flossmanuals.net/gsocmentoring/ GSoC Mentor guide]
 
* [http://en.flossmanuals.net/gsocmentoring/ GSoC Mentor guide]
 
* [http://en.flossmanuals.net/GSoCStudentGuide/ GSoC student guide]
 
* [http://en.flossmanuals.net/GSoCStudentGuide/ GSoC student guide]
* [[GSOC2013StudentGuide |ns-3's GSoC Student guide]]
+
* [[GSOC2014StudentGuide |ns-3's GSoC Student guide]]
 
* [[GSOCMentorGuide | ns-3's GSoC Mentor guide]]
 
* [[GSOCMentorGuide | ns-3's GSoC Mentor guide]]
 
* [[GSOCSelectionProcess | GSoC Student Selection Process]]
 
* [[GSOCSelectionProcess | GSoC Student Selection Process]]
* [[GSOC2013PatchRequirement | Patch Requirement Guidelines]]
+
* [[GSOC2014PatchRequirement | Patch Requirement Guidelines]]
* [[GSOC2013StudentApplicationTemplate |GSoC Student application template]]
+
* [[GSOC2014StudentApplicationTemplate |GSoC Student application template]]
* [[GSOC2013AcceptedProjects | GSoC 2013 Accepted Projects]]
+
* [[GSOC2013Projects |GSoC 2013 page]] | [[GSOC2013AcceptedProjects | GSoC 2013 Accepted Projects]]
 
* [[GSOC2012Projects |GSoC 2012 page]] | [[GSOC2012AcceptedProjects |GSoC 2012 Accepted Projects]]
 
* [[GSOC2012Projects |GSoC 2012 page]] | [[GSOC2012AcceptedProjects |GSoC 2012 Accepted Projects]]
 
* [[GSOC2011Projects |NSoC 2011 Ideas page]] | [[NSOC2011AcceptedProjects |NSoC 2011 Accepted Projects]]
 
* [[GSOC2011Projects |NSoC 2011 Ideas page]] | [[NSOC2011AcceptedProjects |NSoC 2011 Accepted Projects]]
Line 32: Line 32:
 
* August 18 - Coding ends
 
* August 18 - Coding ends
 
Full timeline is here: http://www.google-melange.com/gsoc/events/google/gsoc2014
 
Full timeline is here: http://www.google-melange.com/gsoc/events/google/gsoc2014
 
While discussions about ideas can be done earlier, please note that ns-3 will not receive an answer to its GSOC application before February 24.
 
  
 
== About the ns-3 project ==
 
== About the ns-3 project ==
Line 41: Line 39:
 
Users of ns-3 can construct simulations of computer networks using models of traffic generators, protocols such as TCP/IP, and devices and channels such as WiFi, and analyze or visualize the results.  Simulation plays a vital role in the research and education process, because of the ability for simulations to obtain reproducible results (particularly for wireless protocol design), scale to large networks, and study systems that have not yet been implemented.  A particular emphasis in ns-3 is the high degree of realism in the models (including frameworks for real application and kernel code) and integration of the tool with virtual machine environments and testbeds; we view that researchers need to move more effortlessly between simulation, testbeds, and live experiments, and ns-3 is designed to facilitate that.
 
Users of ns-3 can construct simulations of computer networks using models of traffic generators, protocols such as TCP/IP, and devices and channels such as WiFi, and analyze or visualize the results.  Simulation plays a vital role in the research and education process, because of the ability for simulations to obtain reproducible results (particularly for wireless protocol design), scale to large networks, and study systems that have not yet been implemented.  A particular emphasis in ns-3 is the high degree of realism in the models (including frameworks for real application and kernel code) and integration of the tool with virtual machine environments and testbeds; we view that researchers need to move more effortlessly between simulation, testbeds, and live experiments, and ns-3 is designed to facilitate that.
  
Our GSoC organizational admin is TBD and our backup org admin is [mailto:tomhend@u.washington.edu Tom Henderson].  The project has participated in past GSoCs during 2008-10 and 2012-13.
+
Our GSoC organizational admin is [mailto:tomhend@u.washington.edu Tom Henderson] and our backup org admin is [mailto:tpecorella@mac.com Tommaso Pecorella].  The project has participated in past GSoCs during 2008-10 and 2012-13.
  
Mentors will be paired with students based on the projects that are selected.  Mentors from companies are welcome, if the employer will permit the mentor sufficient time to perform the mentoring.  Prospective mentors should notify Lalith Suresh of interest.  Mentors familiar with ns-3 development practices will be preferred, to improve the chances of student code merge.
+
Mentors will be paired with students based on the projects that are selected.  Mentors from companies are welcome, if the employer will permit the mentor sufficient time to perform the mentoring.  Prospective mentors should notify Tom Henderson of interest.  Mentors familiar with ns-3 development practices will be preferred, to improve the chances of student code merge.
  
 
== ns-3 and other GSoC mentoring organisations ==
 
== ns-3 and other GSoC mentoring organisations ==
  
ns-3 is one of ~175 mentoring organizations, and at other organizations have posted project ideas related to ns-3 in the past. For instance, the Wiselib project has listed ns-3 integration as one of its project ideas at http://www.Wiselib.org/gsoc.
+
ns-3 is one of 190 mentoring organizations, and at other organizations have posted project ideas related to ns-3 in the past. For instance, the Wiselib project has listed ns-3 integration as one of its project ideas at http://www.Wiselib.org/gsoc.
  
 
Students interested in ns-3 and GSoC are also encouraged to explore whether other organizations might be a suitable mentoring organization for their project idea.  Please keep in mind, though, that the ns-3 project is not involved in the selection process for these other mentoring organizations, and you will have to apply there instead.
 
Students interested in ns-3 and GSoC are also encouraged to explore whether other organizations might be a suitable mentoring organization for their project idea.  Please keep in mind, though, that the ns-3 project is not involved in the selection process for these other mentoring organizations, and you will have to apply there instead.
Line 58: Line 56:
 
* Look through our ideas list below to see if you find a project that interests you.
 
* Look through our ideas list below to see if you find a project that interests you.
 
* Review the [http://www.nsnam.org/ns-3-19/documentation/ ns-3 tutorial] thoroughly, if you have not already done so.
 
* Review the [http://www.nsnam.org/ns-3-19/documentation/ ns-3 tutorial] thoroughly, if you have not already done so.
* Look through the [[GSOC2013StudentApplicationTemplate |GSoC Student application template]] to start preparing your proposal.
+
* Look through the [[GSOC2014StudentApplicationTemplate |GSoC Student application template]] to start preparing your proposal.
 
* Next, proceed to get in touch with the developers on the mailing list and refine your proposal.
 
* Next, proceed to get in touch with the developers on the mailing list and refine your proposal.
* In parallel, make sure you prepare a patch as per the [[GSOC2013PatchRequirement | Patch Requirement Guidelines]]. Your application to ns-3 will not be considered if you do not fulfill this requirement.
+
* In parallel, make sure you prepare a patch as per the [[GSOC2014PatchRequirement | Patch Requirement Guidelines]]. Your application to ns-3 will not be considered if you do not fulfill this requirement.
  
 
== Project Ideas ==
 
== Project Ideas ==
Line 87: Line 85:
 
= Project Ideas =
 
= Project Ideas =
  
Please see [[GSOC2013StudentGuide | last year's page]] for guidelines on how to create project ideas.
+
Please see [[GSOC2013Projects | last year's page]] for guidelines on how to create project ideas.
  
 
'''Note to students:''' These ideas are not listed in any priority order, and other project ideas not listed here are also encouraged.
 
'''Note to students:''' These ideas are not listed in any priority order, and other project ideas not listed here are also encouraged.
Line 101: Line 99:
 
* ''Recommended reading:''
 
* ''Recommended reading:''
 
** Unix Network Programming (Stevens) or equivalent
 
** Unix Network Programming (Stevens) or equivalent
 +
** Previous thread on this topic:  http://mailman.isi.edu/pipermail/ns-developers/2007-July/003136.html
 +
* ''Bonus points:'' How would you implement backpressure on the traffic generator?  See https://www.nsnam.org/bugzilla/show_bug.cgi?id=1006
  
 
===  ARP and NDisc cache visibility  ===
 
===  ARP and NDisc cache visibility  ===
Line 126: Line 126:
 
=== bufferbloat-related models ===
 
=== bufferbloat-related models ===
  
Mentors: [mailto:tomh@tomh.org Tom Henderson]
+
Mentors: [mailto:tomh@tomh.org Tom Henderson] [mailto:dave.taht@gmail.com Dave Taht]
  
 
'''bufferbloat models:''' [https://www.youtube.com/watch?v=-D-cJNtKwuw Bufferbloat] is an interesting contemporary research topic.  
 
'''bufferbloat models:''' [https://www.youtube.com/watch?v=-D-cJNtKwuw Bufferbloat] is an interesting contemporary research topic.  
Line 139: Line 139:
 
** [https://codereview.appspot.com/6463048/ ns-3 code review]
 
** [https://codereview.appspot.com/6463048/ ns-3 code review]
  
=== 802.15.4 Energy Model ===Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]* '''802.15.4 Energy Model:''' The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is not actually linked with the energy model. Hence it is not possible to simulate correctly the energy discharge of a Wireless Sensor Node correctly. The goal is to develop the missing classes needed to link the two modules, and to validate the results against the literature models.** ''Required Experience:'' C++, WSN** ''Bonus Experience:'' ns-3 Energy model** ''Interests:'' WSN, Battery discharge** ''Difficulty:'' easy** ''Recommended reading:''*** [http://www.sics.se/~adam/dunkels07softwarebased.pdf Software-based On-line Energy Estimation for Sensor Nodes] *** [http://cds.unibe.ch/research/pub_files/HBNH11.pdf On the Accuracy of Software-based Energy Estimation Techniques]*** [http://dunkels.com/adam/dunkels11contikimac.pdf The ContikiMAC Radio Duty Cycling Protocol]
+
=== 802.15.4 realistic MAC and Energy Model ===
 +
 
 +
Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]
 +
 
 +
'''802.15.4 realistic MAC and Energy Model:''' The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is not actually linked with the energy model. Moreover it does not model the radio interface sleep status. The current model assumes that the radio is always active. As a consequence, the MAC layer is quite simple, since it does not needs to guess when the receiver's radio interface is active.
 +
The goal of the project are:
 +
# Model the 4-state radio model (Sleep, Tx, Rx, Transitioning)
 +
# Develop one 'realistic' MAC model (the choice is left to the student)
 +
# Link the 4-state model with the Energy module.
 +
 
 +
* ''Required Experience:'' C++, WSN
 +
* ''Bonus Experience:'' ns-3 Energy model, lr-wpan module
 +
* ''Interests:'' WSN, Battery discharge
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** [http://www.sics.se/~adam/dunkels07softwarebased.pdf Software-based On-line Energy Estimation for Sensor Nodes]  
 +
** [http://cds.unibe.ch/research/pub_files/HBNH11.pdf On the Accuracy of Software-based Energy Estimation Techniques]
 +
** [http://dunkels.com/adam/dunkels11contikimac.pdf The ContikiMAC Radio Duty Cycling Protocol]
 +
 
 +
=== 802.15.4 Bootstrap ===
 +
 
 +
Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]
 +
 
 +
'''802.15.4 Bootstrap:''' The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is able to simulate an 802.15.4 network in ad-hoc mode, much like Contiki-os nodes do. An useful extension is to fully support the node bootstrap phase, including node association and beacon request/reply. The goal of the project is to enhance the lr-wpan module so to use beacons in the bootstrap phase along with network scanning and pan-id resolution for in-range coordinators.
 +
* ''Required Experience:'' C++, WSN
 +
* ''Bonus Experience:'' 802.15.4 standard
 +
* ''Interests:'' WSN
 +
* ''Difficulty:'' medium
 +
* ''Recommended reading:''
 +
** [http://standards.ieee.org/getieee802/download/802.15.4-2011.pdf 802.15.4 Standard]
 +
 
 +
 
 +
=== 802.15.4 Beacon-enabled mode ===
 +
 
 +
Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]
 +
 
 +
'''802.15.4 Beacon-enabled mode:''' The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is able to simulate an 802.15.4 network in ad-hoc mode, much like Contiki-os nodes do. Unlike Contiki-os, the model could benefit from supporting beacon-enabled mode of operation. The beacon-enabled mode is a fully slotted transmission mode, with guaranteed slots and bound performances, unlike the ad-hoc mode. This is especially important because the L3 routing protocols might be strongly affected by the lower-layer topology. Hence it is of paramount importance to be able to simulate both in ns-3. The goal of the project is to develop the new beacon-enabled MAC layer for the lr-wpan module.
 +
* ''Required Experience:'' C++, WSN
 +
* ''Bonus Experience:'' 802.15.4 standard
 +
* ''Interests:'' WSN
 +
* ''Difficulty:'' medium/hard
 +
* ''Recommended reading:''
 +
** [http://standards.ieee.org/getieee802/download/802.15.4-2011.pdf 802.15.4 Standard]
 +
 
 +
=== Neighbor Discovery Optimization for Low Power and Lossy Networks (6LoWPAN-nd) ===
 +
 
 +
Mentors:  [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]
 +
 
 +
'''6LoWPAN-nd implementation and testing:''' [https://datatracker.ietf.org/doc/rfc6775/ 6LoWPAN-nd] is novel protocol from IETF's [http://tools.ietf.org/wg/6lowpan/ LoWPAN WG]. The protocol aims at defining new and optimized methods to perform Neighbor Discovery and Node Bootstrap for Wireless Sensor Networks and it will be the counterpart of the 6LoWPAN IPv6 header compression strandard. 6LoWPAN-nd is not currently implemented in ns-3, while 6LoWPAN compression and 802.15.4 stacks are in advanced development status. In order to simulate a real Wireless Sensor Network 6LoWPAN-nd should be developed and tested.
 +
* ''Required Experience:'' C++, IPv6, RPL
 +
* ''Bonus Experience:'' WSN networking
 +
* ''Interests:'' WSN, IPv6, node bootstrap, efficient packet compression
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** [http://tools.ietf.org/html/rfc4919 RFC 4919] IPv6 over Low-Power Wireless Personal Area Networks (6LoWPANs): Overview, Assumptions, Problem Statement, and Goals
 +
** [https://datatracker.ietf.org/doc/rfc6775/ RFC 6775] Neighbor Discovery Optimization for Low Power and Lossy Networks
 +
 
 +
=== IPv6 stack validation and improvements ===
 +
 
 +
Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]
 +
 
 +
'''IPv6 stack validation and improvements:''' IPv6 use is going to increase dramatically in the next years. Various international projects are required to use IPv6 (e.g., EU FP7, EU 2020, etc.). Hence, simulations should be run on IPv6 rather than IPv4, and it is becoming an imperative action to have a reliable, full-featured IPv6 stack for ns-3. IPv6 stack for ns-3 works, but it lacks a number of interesting and useful features. A few missing features are (the list is not exhaustive):
 +
# <s>There is no [http://en.wikipedia.org/wiki/Path_MTU_discovery path MTU discovery] see also [http://tools.ietf.org/html/rfc1981 RFC 1981].</s> Added in 3.20
 +
# <s> Flow Monitor module does not work on the IPv6 stack.</s> Added in 3.20
 +
# FlowLabel header field is not currently used.
 +
# IPSec is not supported.
 +
The candidate should check the missing features and select a set to develop and test. A general test of the IPv6 stack to be done against a reference Linux implementation is a premium.
 +
* ''Required Experience:'' C++, TCP/IP networking
 +
* ''Bonus Experience:'' IPv6 protocols
 +
* ''Interests:'' IPv6 internetworking
 +
* ''Difficulty:'' easy / medium, depending on the features implemented
 +
* ''Recommended reading:''
 +
** [http://www.ietf.org/rfc/rfc4294.txt RFC 4294 - IPv6 Node Requirements]
 +
** [http://tools.ietf.org/html/rfc1981 RFC 1981 - Path MTU Discovery for IP version 6]
 +
** ns-3 Flowmon module documentation
 +
** [http://tools.ietf.org/html/rfc6437 RFC 6437 - IPv6 Flow Label Specification]
 +
** [http://tools.ietf.org/html/rfc4302 RFC 4302 - IP Authentication Header]
 +
** [http://tools.ietf.org/html/rfc4303 RFC 4303 - IP Encapsulating Security Payload (ESP)]
 +
 
 +
=== Multicast IPv6 traffic support ===
 +
 
 +
Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella]
 +
 
 +
'''Multicast IPv6 traffic:''' Multicast traffic support is of paramount importance for IPv6 networks. While Multicast traffic is used everyday with local addresses, and ns-3 is supporting it, MLDv2 and PIM are missing. As a consequence global multicast routes must be manually set in routers, which is cumbersome, error-prone and not suitable for realistic scenarios, where the users are joining/leaving multicast groups on the fly. The implementor will have to both modify the actual routing protocols so to enable dynamic multicast routes support and to actually develop the MLDv2 and/or the PIM protocol modules.
 +
* ''Required Experience:'' C++, IPv6,
 +
* ''Bonus Experience:'' Multicast routing protocols (MLDv2/IGMPv3 and PIM)
 +
* ''Interests:'' routing, multicast
 +
* ''Difficulty:'' medium/hard
 +
* ''Recommended reading:''
 +
** [http://www.h3c.com/portal/Products___Solutions/Products/Switches/H3C_S5500-SI_Series_Switches/White_Paper/200806/688942_57_0.htm Multicast Technology White Paper]
 +
** [http://www.alliedtelesis.co.nz/documentation/at9800/291/pdf/ipv6mu.pdf IPv6 Multicasting]
 +
** All the relevant RFCs (search in [http://www.rfc-editor.org/search/rfc_search.php RFC Editor search engine])
 +
 
 +
 
 +
=== Licklider Transmission Protocol (LTP) ===
 +
 
 +
 
 +
Mentors: [mailto:tommaso.pecorella@unifi.it Tommaso Pecorella] [mailto:luca.ronga@cnit.it Luca Ronga]
 +
 
 +
 
 +
'''ns-3-LTP''' Licklider Transmission Protocol (LTP)  is a point to point protocol for the use in deep space links. It have a number of interesting properties, mainly related to the constraints found in space links, like ultra-high round trip delay and so on. LTP is currenlty under revision as a proposed standard by the Consultative Committee for Space Data Systems (CCSDS), however its principles are well-known to the satellite networking community, RFCs and reference Linux implementations are available. An ns-3 implementation should comply with the already existing IETF specification and with the CCSDS one.
 +
* ''Required Experience:'' C++
 +
* ''Bonus Experience:'' Satellite and Deep Space networking
 +
* ''Interests:'' Deep Space networking
 +
* ''Difficulty:'' easy / medium
 +
* ''Recommended reading:''
 +
** [http://en.wikipedia.org/wiki/Licklider_Transmission_Protocol Licklider Transmission Protocol]
 +
** [http://tools.ietf.org/html/rfc5325 RFC 5325: Licklider Transmission Protocol—Motivation]
 +
** [http://tools.ietf.org/html/rfc5326 RFC 5326: Licklider Transmission Protocol—Specification]
 +
** [http://public.ccsds.org/sites/cwe/rids/Lists/CCSDS%207341R2/Attachments/734x1r2.pdf Licklider Transmission Protocol (LTP) for CCSDS]
 +
 
 +
 
 +
=== Inter-frequency measurement support for the LTE module ===
 +
 
 +
Mentors: [mailto:nbaldo@cttc.es Nicola Baldo] [mailto:mmiozzo@cttc.es Marco Miozzo]
 +
 
 +
* The ns-3 LTE module already allows to simulate LTE deployments where the base stations are placed at different carrier frequency; however, this is currently limited to static scenarios with no mobility, because only intra-frequency UE measurement are supported, and hence handover can only occur among cells at the same carrier frequency. The aim of this project is to develop  supports for inter-frequency UE measurements, so that it can be leveraged both for idle and connected node mobility.
 +
 
 +
* ''Required Experience:'' C++, LTE
 +
* ''Interests:'' Mobility Management in LTE
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** [http://www.nsnam.org/docs/release/3.19/models/html/lte-design.html#ue-rrc-measurements-model documentation of the UE Measurement model in the ns-3 LTE module]
 +
** 3GPP TS 36.331 section 5.5 Measurements
 +
** 3GPP TS 36.133, Section 8.2 UE Measurements Procedures in RRC_CONNECTED State
 +
 
 +
 
 +
=== LTE Fractional Frequency Reuse algorithms ===
 +
 
 +
Mentors: [mailto:nbaldo@cttc.es Nicola Baldo] [mailto:mmiozzo@cttc.es Marco Miozzo]
 +
 
 +
* The aim of this project is to develop a set of state-of-the-art Fractional Frequency Reuse algorithm implementations for the ns-3 LTE module. Interested students shall select a set of representative algorithms published in the scientific literature, and implement them in ns-3. The implementation shall be done within the LTE MAC Scheduler leveraging the X2 SON primitives.
 +
* ''Required Experience:'' C++, LTE
 +
* ''Interests:'' Self Organized Networks, HetNets, Inter Cell Interference Coordination
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** [http://www.nsnam.org/docs/release/3.19/models/html/lte-design.html#mac LTE MAC in ns-3]
 +
** [http://www.nsnam.org/docs/release/3.19/models/html/lte-design.html#x2-c-son-primitives LTE SON primitives in ns-3]
 +
** Thomas Novlan, Jeffrey G. Andrews, Illsoo Sohn, Radha Krishna Ganti,  Arunabha Ghosh, "Comparison of Fractional Frequency Reuse Approaches in the OFDMA Cellular Downlink"
 +
** Alexander L. Stolyar, Harish Viswanathan, "Self-organizing Dynamic Fractional Frequency Reuse for Best-Effort Traffic Through Distributed Inter-cell Coordination"
 +
** Heui-Chang Lee, Dong-Chan Oh, and Yong-Hwan Lee, "Mitigation of Inter-Femtocell Interference with Adaptive Fractional Frequency Reuse"
 +
** there are lots of other papers on this topic, please do your own research
 +
 
 +
 
 +
=== GPU acceleration for vector arithmetics in the spectrum module ===
 +
 
 +
Mentors:  [mailto:nbaldo@cttc.es Nicola Baldo] [mailto:mmiozzo@cttc.es Marco Miozzo]
 +
 
 +
* The ns-3 spectrum module does a lot of vector arithmetics which in the current ns-3 version are just run on the CPU. The aim of this project is to develop the necessary code to offload these calculations to a GPU in order to achieve a hopefully significant speedup in the simulation of scenarios relying on the spectrum model (e.g., including LTE scenarios).
 +
* ''Required Experience:'' C++
 +
* ''Bonus Experience:'' CUDA, OpenCL...
 +
* ''Interests:'' GPU acceleration
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** [http://www.nsnam.org/docs/models/html/spectrum.html ns-3 spectrum module documentation]
 +
** http://en.wikipedia.org/wiki/OpenCL
 +
** http://en.wikipedia.org/wiki/CUDA
 +
 
 +
 
 +
=== Carrier Aggregation support for the LTE module ===
 +
 
 +
Mentors: [mailto:mmiozzo@cttc.es Marco Miozzo] [mailto:nbaldo@cttc.es Nicola Baldo]
 +
 
 +
* The aim of this project is to bring the ns-3 LTE module closer to the LTE-A paradigm and, more in detail, consists of the introduction of the Carrier Aggregation (CA) functionality. The student will have to collect information from the 3GPP specification for what concerns the relevant EUTRA aspects. The implementation will involve mainly the physical, MAC and RRC layers.
 +
 
 +
* ''Required Experience:'' C++, LTE
 +
* ''Interests:'' LTE-A, HetNet
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** LTE-A HetNets using Carrier Aggregation, Nomor whitepaper [http://www.nomor.de/uploads/db/a3/dba3e71e617a0ab4b7d3821afd59cc5e/Newsletter_CA_HetNet_2013-06.pdf]
 +
** [http://www.nsnam.org/docs/release/3.19/models/html/lte-design.html]
 +
** 3GPP TS 36.211
 +
** 3GPP TS 36.213
 +
** 3GPP TS 36.331
 +
 
 +
 
 +
=== Support of RRC IDLE mode procedures for the LTE module ===
 +
 
 +
Mentors:  [mailto:nbaldo@cttc.es Nicola Baldo] [mailto:mmiozzo@cttc.es Marco Miozzo]
 +
 
 +
* The ns-3 LTE module currently supports a vast number of RRC CONNECTED mode procedures (e.g., handover, measurement reporting, etc), but has very limited support for RRC IDLE mode procedures (basically, only cell selection). The aim of this project is to 'close the circle' and provide full support for critical RRC IDLE mode procedures, such as PLMN selection, cell reselection, Tracking Area Update, Paging, etc.
 +
* ''Required Experience:'' C++, LTE
 +
* ''Interests:'' Mobility Management in LTE systems
 +
* ''Difficulty:'' hard
 +
* ''Recommended reading:''
 +
** 3GPP TS 36.304 [http://www.3gpp.org/DynaReport/36304.htm]
 +
** 3GPP TS 23.401, Section 5.3.3 ("Tracking Area Update Procedures") [http://www.3gpp.org/DynaReport/23401.htm]
 +
** 3GPP TS 36.331
 +
 
 +
 
 +
 
 +
=== Improve ns-3 support to sensor networks, RIOT adaptation ===
 +
 
 +
Mentors: [mailto:danielcamara@gmail.com Daniel Camara]
 +
 
 +
The wireless sensor networks field is a rising star in terms of research, the number of applications and problems related to it increases every day. In fact, a whole new set of other research fields rely heavily on wireless sensor networks. E.g. smart cities, internet of the things, vehicular networks and public safety networks . This project intends to improve the support of ns-3 to to sensor networks. RIOT[1][2] is a brand new operating system for wireless sensor networks. It has a series of interesting characteristics that makes it a perfect candidate to became THE standard OS for small sensor devices.
 +
 
 +
This project intends to enable the execution of several instances of RIOT OS, over the same machine, and link these instances using ns-3.  Why to simulate a sensor devices if we can emulate a whole network using a real sensor OS? Not only the simulations will be more realistic, but also we will be sure that the applications developed over this simulation environment will run seamless over real sensor nodes. The importance of this project is two folded. Without a shadow of a doubt it will be important and useful for the ns-3 community. However, up today RIOT still does not have a standard simulation environment. This project will provide RIOT users an invaluable access to the whole power of ns-3 simulations. It will be a tool that will be certainly used on all future developments and tests of RIOT.
 +
 
 +
 
 +
* ''Support:'' The RIOT developers are interested on this project, since it will make their life easier ;). This means we will have access to them and any doubts about the operating system itself ''should'' be fast addressed by them.
 +
 
 +
* ''Required Experience:'' C/C++
 +
* ''Interests:'' Sensor networks, simulation, operating systems
 +
* ''Difficulty:'' medium
 +
* ''Recommended reading:''
 +
** [1] E. Baccelli, O. Hahm, M. Wählisch, M. Günes, T. C. Schmidt, [http://hal.inria.fr/hal-00768685/ RIOT: One OS to Rule Them All in the IoT], INRIA Research Report N° 8176, Project-Team HiPERCOM, ISSN 0249-6399 ISRN INRIA/RR--8176--FR+ENG, December 2012
 +
** [2] RIOT OS web site, [http://riot-os.github.io/RIOT/ http://riot-os.github.io/RIOT/]
 +
** [3] Heiko Will, Kaspar Schleiser, Jochen Schiller, [http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.173.1862 A Real-Time Kernel for Wireless Sensor Networks Employed in Rescue Scenarios] The 4th IEEE International Workshop on Practical Issues In Building Sensor Network Applications (SenseApp 2009) Zürich, Switzerland; 20-23 October 2009
 +
 
 +
=== Port ns-3 components to Python 3.3 and improve Python code quality ===
 +
 
 +
Mentors: To be determined
 +
 
 +
Linux distributions in 2014 are expected to transition away from Python 2.7 support to Python 3.3 support.  Ubuntu 14.04 release is already planning a Python 3.3-only default.
 +
 
 +
ns-3 has several components that rely on Python, and not all are Python 3.3+ compatible.  This GSoC project would focus on updating our bindings generation process (pygccxml), PyViz visualizer, and wscript files (used by Waf) to support Python 3.3.  Regarding wscript files in particular, student should also propose a refactoring and reorganization to make them easier to maintain in the future.
 +
* ''Required Experience:'' C++ and Python
 +
* ''Interests:'' Python development
 +
* ''Difficulty:'' medium
 +
* ''Recommended reading:''  pygccxml:  http://sourceforge.net/projects/pygccxml/
 +
* ''Recommended reading:'' Discussion on ns-developers list:  http://mailman.isi.edu/pipermail/ns-developers/2014-March/011794.html
 +
 
 +
=== Time Synchronization Channel Hopping ===
 +
 
 +
Mentors:  Peter Kourzanov, Hong Li
 +
 
 +
The Internet of Things (IoT) needs extensive simulations to prove that the radios, the protocols, the middle-ware and the applications are up to the task of scaling technology both in numbers and in power consumption. One of the approaches to provide such scaling is represented by the IEEE 802.15.4 Low-Rate WPAN (LR-WPAN) and the subsequent 15.4e standards, including the Time Scheduled Channel Hopping (TSCH) part. 6TiSCH offers the Internet Protocol (IP) based solution for Open Systems Interconnect (OSI) layer 3-7, including an application layer (COAP).
 +
 
 +
The challenge of this task is to bring the implementation of 15.4 models in NS-3 to a level where existing components such as RPL, IPv6 and optionally CBOR/COAP can be evaluated on top of channel models present in NS-3. This entails adapting the preliminary LR-WPAN models to include 15.4e and validating the results using one of the commercially available 15.4 implementations.
 +
 
 +
* ''Required experience:'' C++
 +
* ''Bonus experience:'' Wireless Sensor Networks (WSN), Matlab
 +
* ''Interests:'' embedded, wireless, sensor networks
 +
* ''Difficulty:'' medium
 +
* ''Recommended reading:''
 +
** LR-WPAN [https://www.nsnam.org/wiki/Lr-wpan status page]
 +
** Preliminary LR-WPAN [http://code.nsnam.org/lr-wpan/ns-3-lr-wpan code] for ns-3
 +
** [http://en.wikipedia.org/wiki/IEEE_802.15.4 LR-WPAN] page on Wikipedia
 +
** [http://tools.ietf.org/wg/6tisch 6TiSCH] status pages
  
 
[[Category:GSoC]]
 
[[Category:GSoC]]

Latest revision as of 11:40, 11 October 2014

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

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

GSoC 2014 Ideas

This webpage highlights project ideas for ns-3's Google Summer of Code 2014 effort.

GSOC 2014 Timeline is:

  • February 3 - 20:00 UTC: Mentoring organizations can begin submitting applications to Google.
  • February 14 - 20:00 UTC: Mentoring organization application deadline.
  • February 24 - 20:00 UTC: List of accepted mentoring organizations published on the Google Summer of Code 2014 site.
  • February 24 - March 21: Would-be student participants discuss application ideas with mentoring organizations.
  • March 10 - 19:00 UTC: Student application period opens.
  • March 21 - 19:00 UTC: Student application deadline.
  • April 21 - 19:00 UTC: Student selections announced
  • May 19 - Coding begins
  • August 18 - Coding ends

Full timeline is here: http://www.google-melange.com/gsoc/events/google/gsoc2014

About the ns-3 project

ns-3 is a discrete-event network simulator, with a particular emphasis on network research and education.

Users of ns-3 can construct simulations of computer networks using models of traffic generators, protocols such as TCP/IP, and devices and channels such as WiFi, and analyze or visualize the results. Simulation plays a vital role in the research and education process, because of the ability for simulations to obtain reproducible results (particularly for wireless protocol design), scale to large networks, and study systems that have not yet been implemented. A particular emphasis in ns-3 is the high degree of realism in the models (including frameworks for real application and kernel code) and integration of the tool with virtual machine environments and testbeds; we view that researchers need to move more effortlessly between simulation, testbeds, and live experiments, and ns-3 is designed to facilitate that.

Our GSoC organizational admin is Tom Henderson and our backup org admin is Tommaso Pecorella. The project has participated in past GSoCs during 2008-10 and 2012-13.

Mentors will be paired with students based on the projects that are selected. Mentors from companies are welcome, if the employer will permit the mentor sufficient time to perform the mentoring. Prospective mentors should notify Tom Henderson of interest. Mentors familiar with ns-3 development practices will be preferred, to improve the chances of student code merge.

ns-3 and other GSoC mentoring organisations

ns-3 is one of 190 mentoring organizations, and at other organizations have posted project ideas related to ns-3 in the past. For instance, the Wiselib project has listed ns-3 integration as one of its project ideas at http://www.Wiselib.org/gsoc.

Students interested in ns-3 and GSoC are also encouraged to explore whether other organizations might be a suitable mentoring organization for their project idea. Please keep in mind, though, that the ns-3 project is not involved in the selection process for these other mentoring organizations, and you will have to apply there instead.

Getting started

For students interested in applying to ns-3 for GSOC, go through the following list to get started:

Project Ideas

The following are a list of project proposals from the ns-3 team for Google Summer of Code 2014. Applicants are however free to propose their own ideas. In addition, please note that these ideas are not limited to GSoC, anyone is welcome to work on them. Please email the ns-developers list if you have an idea that you'd like to work on. Applicants are encouraged to look over this list, pick one that especially interests them, think about it, and discuss potential approaches on the ns-developers list. Previous experience with the Google Summer of Code programmes suggest that the more you discuss and refine your proposal on the mailing list beforehand, the more stronger a proposal it will develop into, and the higher your chances of being accepted into the programme.

Each project idea within a particular priority has been tagged with the following properties:

  • Required Experience: Languages, concepts, or packages with which applicants must be familiar.
  • Bonus Experience: Other experience or familiarity which would be greatly helpful to applicants for this project.
  • Interests: Areas of particular relevance to this project, and an indicator of where successful students might apply their experiences coming out of this project.
  • Difficulty: easy, medium or difficult
  • Recommended reading: pointers to documentation, papers, specific bugs, etc.

Note that all of the projects require some experience and comfort with C++. Project ideas for which C++ is noted as a required experience will require more and deeper familiarity with the language. A similar notion applies to computer networking, BSD sockets, etc: Familiarity is strongly preferred, but is not required except where explicitly noted due to the topic being more advanced in that regard.

Guidelines for project ideas

For mentors who're adding project ideas to the list below, please ensure that:

  • The projects are sized such that there can be a code merge by the end of the coding period. The scope of the project should be such that it is very difficult to not have a code merge by the end of the summer.
  • The proposed projects are not too open-ended. That is, if the deliverables or a clear path to the same are not well understood, it is better kept outside GSOC.
  • There should be a clear merge path to one of the main project code repositories (ns-3-dev, ns-3-dce, bake) by the end of the summer, either because the patches directly apply or they directly apply to an ns-3 module that is in the process of merging with ns-3-dev.

Project Ideas

Please see last year's page for guidelines on how to create project ideas.

Note to students: These ideas are not listed in any priority order, and other project ideas not listed here are also encouraged.

Decouple traffic generators from sockets

Mentors: Tom Henderson Vedran Miletić

  • ns-3 uses applications that are part traffic generator, part socket-based application. The traffic generation part is not decoupled from the sockets API, making it hard to use applications over non-socket APIs such as future sensor networks. This project would work on a cleaner separation between traffic generator (OnOffApplication) and sockets.
  • Required Experience: C++, sockets API
  • Interests:
  • Difficulty: easy/medium
  • Recommended reading:
  • Bonus points: How would you implement backpressure on the traffic generator? See https://www.nsnam.org/bugzilla/show_bug.cgi?id=1006

ARP and NDisc cache visibility

Mentors: Tom Henderson Vedran Miletić

  • There is no API for reading and manipulating the IPv4 ARP and IPv6 Neighbor Discovery caches. Something similar to how PrintRoutes is done for IPv4 would be useful. Additional work on this project could focus on IP address handling for interfaces (bugs 757 and 760), and bug 187 (enabling perfect ARP).
  • Required Experience: C++
  • Interests: IPv4 and Ipv6
  • Difficulty: easy/medium
  • Recommended reading:
    • source code in src/internet, and the bugs mentioned above

INSTOOLS for ns-3

Mentors: Tom Henderson

INSTOOLS for ns-3: INSTOOLS is a software instrumentation package for GENI experiments. It logs a lot of artifacts of experiments, such as ARP and IP routing tables, Netflow graphs, etc, to databases. The aim of this project is to instrument ns-3 nodes to capture as much of this data as is applicable. A bonus is to try to integrate further with ProtoGENI and INSTOOLS such as making the ns-3 data archived just like it was a GENI experiment.

  • Required Experience: Familiarity with Linux networking and with C++ programming.
  • Bonus Experience: Experience with GENI and/or Emulab
  • Interests: Simulator tool development, integration with testbed experiments
  • Difficulty: Medium
  • Recommended Reading: http://groups.geni.net/geni/wiki/InstrumentationTools

bufferbloat-related models

Mentors: Tom Henderson Dave Taht

bufferbloat models: Bufferbloat is an interesting contemporary research topic. This project proposal is to develop models, examples, and visualizations around the bufferbloat problem. Some technical solutions include Linux Byte Queue Limits (BQL) and active queue management (AQM) techniques (we just have RED queues in ns-3-dev but no models yet for the others). Note: There is already some ns-3 code available (see below) but the authors have not updated it for a while; this or some recent ns-2 code could be a starting point. Also, work could be done on using actual Linux code in the ns-3 Direct Code Execution (DCE) project.

802.15.4 realistic MAC and Energy Model

Mentors: Tommaso Pecorella

802.15.4 realistic MAC and Energy Model: The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is not actually linked with the energy model. Moreover it does not model the radio interface sleep status. The current model assumes that the radio is always active. As a consequence, the MAC layer is quite simple, since it does not needs to guess when the receiver's radio interface is active. The goal of the project are:

  1. Model the 4-state radio model (Sleep, Tx, Rx, Transitioning)
  2. Develop one 'realistic' MAC model (the choice is left to the student)
  3. Link the 4-state model with the Energy module.

802.15.4 Bootstrap

Mentors: Tommaso Pecorella

802.15.4 Bootstrap: The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is able to simulate an 802.15.4 network in ad-hoc mode, much like Contiki-os nodes do. An useful extension is to fully support the node bootstrap phase, including node association and beacon request/reply. The goal of the project is to enhance the lr-wpan module so to use beacons in the bootstrap phase along with network scanning and pan-id resolution for in-range coordinators.

  • Required Experience: C++, WSN
  • Bonus Experience: 802.15.4 standard
  • Interests: WSN
  • Difficulty: medium
  • Recommended reading:


802.15.4 Beacon-enabled mode

Mentors: Tommaso Pecorella

802.15.4 Beacon-enabled mode: The lr-wpan model is an 802.15.4 PHY and MAC model currently in development. The model is able to simulate an 802.15.4 network in ad-hoc mode, much like Contiki-os nodes do. Unlike Contiki-os, the model could benefit from supporting beacon-enabled mode of operation. The beacon-enabled mode is a fully slotted transmission mode, with guaranteed slots and bound performances, unlike the ad-hoc mode. This is especially important because the L3 routing protocols might be strongly affected by the lower-layer topology. Hence it is of paramount importance to be able to simulate both in ns-3. The goal of the project is to develop the new beacon-enabled MAC layer for the lr-wpan module.

  • Required Experience: C++, WSN
  • Bonus Experience: 802.15.4 standard
  • Interests: WSN
  • Difficulty: medium/hard
  • Recommended reading:

Neighbor Discovery Optimization for Low Power and Lossy Networks (6LoWPAN-nd)

Mentors: Tommaso Pecorella

6LoWPAN-nd implementation and testing: 6LoWPAN-nd is novel protocol from IETF's LoWPAN WG. The protocol aims at defining new and optimized methods to perform Neighbor Discovery and Node Bootstrap for Wireless Sensor Networks and it will be the counterpart of the 6LoWPAN IPv6 header compression strandard. 6LoWPAN-nd is not currently implemented in ns-3, while 6LoWPAN compression and 802.15.4 stacks are in advanced development status. In order to simulate a real Wireless Sensor Network 6LoWPAN-nd should be developed and tested.

  • Required Experience: C++, IPv6, RPL
  • Bonus Experience: WSN networking
  • Interests: WSN, IPv6, node bootstrap, efficient packet compression
  • Difficulty: hard
  • Recommended reading:
    • RFC 4919 IPv6 over Low-Power Wireless Personal Area Networks (6LoWPANs): Overview, Assumptions, Problem Statement, and Goals
    • RFC 6775 Neighbor Discovery Optimization for Low Power and Lossy Networks

IPv6 stack validation and improvements

Mentors: Tommaso Pecorella

IPv6 stack validation and improvements: IPv6 use is going to increase dramatically in the next years. Various international projects are required to use IPv6 (e.g., EU FP7, EU 2020, etc.). Hence, simulations should be run on IPv6 rather than IPv4, and it is becoming an imperative action to have a reliable, full-featured IPv6 stack for ns-3. IPv6 stack for ns-3 works, but it lacks a number of interesting and useful features. A few missing features are (the list is not exhaustive):

  1. There is no path MTU discovery see also RFC 1981. Added in 3.20
  2. Flow Monitor module does not work on the IPv6 stack. Added in 3.20
  3. FlowLabel header field is not currently used.
  4. IPSec is not supported.

The candidate should check the missing features and select a set to develop and test. A general test of the IPv6 stack to be done against a reference Linux implementation is a premium.

Multicast IPv6 traffic support

Mentors: Tommaso Pecorella

Multicast IPv6 traffic: Multicast traffic support is of paramount importance for IPv6 networks. While Multicast traffic is used everyday with local addresses, and ns-3 is supporting it, MLDv2 and PIM are missing. As a consequence global multicast routes must be manually set in routers, which is cumbersome, error-prone and not suitable for realistic scenarios, where the users are joining/leaving multicast groups on the fly. The implementor will have to both modify the actual routing protocols so to enable dynamic multicast routes support and to actually develop the MLDv2 and/or the PIM protocol modules.


Licklider Transmission Protocol (LTP)

Mentors: Tommaso Pecorella Luca Ronga


ns-3-LTP Licklider Transmission Protocol (LTP) is a point to point protocol for the use in deep space links. It have a number of interesting properties, mainly related to the constraints found in space links, like ultra-high round trip delay and so on. LTP is currenlty under revision as a proposed standard by the Consultative Committee for Space Data Systems (CCSDS), however its principles are well-known to the satellite networking community, RFCs and reference Linux implementations are available. An ns-3 implementation should comply with the already existing IETF specification and with the CCSDS one.


Inter-frequency measurement support for the LTE module

Mentors: Nicola Baldo Marco Miozzo

  • The ns-3 LTE module already allows to simulate LTE deployments where the base stations are placed at different carrier frequency; however, this is currently limited to static scenarios with no mobility, because only intra-frequency UE measurement are supported, and hence handover can only occur among cells at the same carrier frequency. The aim of this project is to develop supports for inter-frequency UE measurements, so that it can be leveraged both for idle and connected node mobility.


LTE Fractional Frequency Reuse algorithms

Mentors: Nicola Baldo Marco Miozzo

  • The aim of this project is to develop a set of state-of-the-art Fractional Frequency Reuse algorithm implementations for the ns-3 LTE module. Interested students shall select a set of representative algorithms published in the scientific literature, and implement them in ns-3. The implementation shall be done within the LTE MAC Scheduler leveraging the X2 SON primitives.
  • Required Experience: C++, LTE
  • Interests: Self Organized Networks, HetNets, Inter Cell Interference Coordination
  • Difficulty: hard
  • Recommended reading:
    • LTE MAC in ns-3
    • LTE SON primitives in ns-3
    • Thomas Novlan, Jeffrey G. Andrews, Illsoo Sohn, Radha Krishna Ganti, Arunabha Ghosh, "Comparison of Fractional Frequency Reuse Approaches in the OFDMA Cellular Downlink"
    • Alexander L. Stolyar, Harish Viswanathan, "Self-organizing Dynamic Fractional Frequency Reuse for Best-Effort Traffic Through Distributed Inter-cell Coordination"
    • Heui-Chang Lee, Dong-Chan Oh, and Yong-Hwan Lee, "Mitigation of Inter-Femtocell Interference with Adaptive Fractional Frequency Reuse"
    • there are lots of other papers on this topic, please do your own research


GPU acceleration for vector arithmetics in the spectrum module

Mentors: Nicola Baldo Marco Miozzo

  • The ns-3 spectrum module does a lot of vector arithmetics which in the current ns-3 version are just run on the CPU. The aim of this project is to develop the necessary code to offload these calculations to a GPU in order to achieve a hopefully significant speedup in the simulation of scenarios relying on the spectrum model (e.g., including LTE scenarios).
  • Required Experience: C++
  • Bonus Experience: CUDA, OpenCL...
  • Interests: GPU acceleration
  • Difficulty: hard
  • Recommended reading:


Carrier Aggregation support for the LTE module

Mentors: Marco Miozzo Nicola Baldo

  • The aim of this project is to bring the ns-3 LTE module closer to the LTE-A paradigm and, more in detail, consists of the introduction of the Carrier Aggregation (CA) functionality. The student will have to collect information from the 3GPP specification for what concerns the relevant EUTRA aspects. The implementation will involve mainly the physical, MAC and RRC layers.
  • Required Experience: C++, LTE
  • Interests: LTE-A, HetNet
  • Difficulty: hard
  • Recommended reading:
    • LTE-A HetNets using Carrier Aggregation, Nomor whitepaper [1]
    • [2]
    • 3GPP TS 36.211
    • 3GPP TS 36.213
    • 3GPP TS 36.331


Support of RRC IDLE mode procedures for the LTE module

Mentors: Nicola Baldo Marco Miozzo

  • The ns-3 LTE module currently supports a vast number of RRC CONNECTED mode procedures (e.g., handover, measurement reporting, etc), but has very limited support for RRC IDLE mode procedures (basically, only cell selection). The aim of this project is to 'close the circle' and provide full support for critical RRC IDLE mode procedures, such as PLMN selection, cell reselection, Tracking Area Update, Paging, etc.
  • Required Experience: C++, LTE
  • Interests: Mobility Management in LTE systems
  • Difficulty: hard
  • Recommended reading:
    • 3GPP TS 36.304 [3]
    • 3GPP TS 23.401, Section 5.3.3 ("Tracking Area Update Procedures") [4]
    • 3GPP TS 36.331


Improve ns-3 support to sensor networks, RIOT adaptation

Mentors: Daniel Camara

The wireless sensor networks field is a rising star in terms of research, the number of applications and problems related to it increases every day. In fact, a whole new set of other research fields rely heavily on wireless sensor networks. E.g. smart cities, internet of the things, vehicular networks and public safety networks . This project intends to improve the support of ns-3 to to sensor networks. RIOT[1][2] is a brand new operating system for wireless sensor networks. It has a series of interesting characteristics that makes it a perfect candidate to became THE standard OS for small sensor devices.

This project intends to enable the execution of several instances of RIOT OS, over the same machine, and link these instances using ns-3. Why to simulate a sensor devices if we can emulate a whole network using a real sensor OS? Not only the simulations will be more realistic, but also we will be sure that the applications developed over this simulation environment will run seamless over real sensor nodes. The importance of this project is two folded. Without a shadow of a doubt it will be important and useful for the ns-3 community. However, up today RIOT still does not have a standard simulation environment. This project will provide RIOT users an invaluable access to the whole power of ns-3 simulations. It will be a tool that will be certainly used on all future developments and tests of RIOT.


  • Support: The RIOT developers are interested on this project, since it will make their life easier ;). This means we will have access to them and any doubts about the operating system itself should be fast addressed by them.

Port ns-3 components to Python 3.3 and improve Python code quality

Mentors: To be determined

Linux distributions in 2014 are expected to transition away from Python 2.7 support to Python 3.3 support. Ubuntu 14.04 release is already planning a Python 3.3-only default.

ns-3 has several components that rely on Python, and not all are Python 3.3+ compatible. This GSoC project would focus on updating our bindings generation process (pygccxml), PyViz visualizer, and wscript files (used by Waf) to support Python 3.3. Regarding wscript files in particular, student should also propose a refactoring and reorganization to make them easier to maintain in the future.

Time Synchronization Channel Hopping

Mentors: Peter Kourzanov, Hong Li

The Internet of Things (IoT) needs extensive simulations to prove that the radios, the protocols, the middle-ware and the applications are up to the task of scaling technology both in numbers and in power consumption. One of the approaches to provide such scaling is represented by the IEEE 802.15.4 Low-Rate WPAN (LR-WPAN) and the subsequent 15.4e standards, including the Time Scheduled Channel Hopping (TSCH) part. 6TiSCH offers the Internet Protocol (IP) based solution for Open Systems Interconnect (OSI) layer 3-7, including an application layer (COAP).

The challenge of this task is to bring the implementation of 15.4 models in NS-3 to a level where existing components such as RPL, IPv6 and optionally CBOR/COAP can be evaluated on top of channel models present in NS-3. This entails adapting the preliminary LR-WPAN models to include 15.4e and validating the results using one of the commercially available 15.4 implementations.

  • Required experience: C++
  • Bonus experience: Wireless Sensor Networks (WSN), Matlab
  • Interests: embedded, wireless, sensor networks
  • Difficulty: medium
  • Recommended reading: