SOCIS2014Projects

From Nsnam
Jump to: navigation, search

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

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

SOCIS 2014 Ideas

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

SOCIS 2014 Timeline is:

  • April 2014: program starts, mentoring organizations can start applying.
  • 15/04/14: mentoring organizations application deadline (11pm UTC).* May 2014: mentoring organizations are announced, students can start applying.* 15/05/2014: students application deadline* June-August 2014: 3-months coding period

Full timeline is here:http://sophia.estec.esa.int/socis2014/?q=timeline

While discussions about ideas can be done earlier, please note that ns-3 will not receive an answer to its SOCIS application before May.

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.

ns-3 has been in development since 2005 and has been making quarterly releases since June 2008 (our last release was ns-3.10 in January 2011). ns-3 is replacing the popular ns-2 tool which was developed in the 1997-2000 timeframe but became out of date and unmaintained. The tool is coming into wide use; our web server logged almost 51,000 successful downloads of our released software between January 2011 and January 2012, and we have a users mailing list of about 2392 members now averaging 574 posts per month. The code base has a total of 113 authors and 25 maintainers.

Our SOCIS organizational admin is Tommaso Pecorella and our backup org admin is To be Defined. The project has participated in GSoCs during 2008-10, 2012-13, and 2013-14. It never participated to SOCIS.

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 Tommaso Pecorella of interest. Mentors familiar with ns-3 development practices will be preferred, to improve the chances of student code merge.

Getting started

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

  • Read the official Student Participant Agreement.
  • Read SOCS FAQ. In particular:
  • Look through our ideas list below to see if you find a project that interests you.
  • Review the ns-3 tutorial thoroughly, if you have not already done so.
  • Look through the GSoC Student application template to start preparing your proposal. The actual SOCIS student application form is not yet available, but we assume they'll be quite smilar.
  • 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 Patch Requirement Guidelines. Your application to ns-3 will not be considered if you do not fulfill this requirement.

Project Ideas

The following are a list of project proposals from the ns-3 team for ESA Summer of Code in Space 2014. Applicants are however free to propose their own ideas. In addition, please note that these ideas are not limited to SOCIS, 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.

Due to the SOCIS focus, only space-related ideas can be considered.

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.
  • The projects are related to Space applications and technologies.

Project Ideas

Satellite Mobility Model

Mentors: Tommaso Pecorella Luca Ronga

  • ns-3-SatMobility Satellite communications are affected by satellite and user's mobility. In order to simulate a channel, it is of paramount importance to know the satellite(s) mobility (orbits) and user's mobility (mostly statistical properties to simulate the sky's portions seen by the user). The goal of the idea is to provide a framework to easily define a single satellite or a constellation movement pattern and the user's properties according to a predefined scenario (e.g., urban, hills, mountain, etc.). The framework should come with pre-defined well-known satellite constellations, e.g., GALILEO, GPS, Inmarsat, etc.). The model should also provide an easy way to define the satellite footprints (Satellite-fixed and Earth-fixed footprints is a plus). The model should extend the ns-3 mobility model, and should also be able to provide triggers to enable/disable satellite links (e.g., Inter-satellite links).
    • Required Experience: C++
    • Bonus Experience: Satellite constellations
    • Interests: Satellite visibility, satellite networking
    • Difficulty: easy / medium
    • Recommended reading:

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.

GNSS Broadcast Services

Mentors: Luca Ronga Tommaso Pecorella

  • ns3-gnss-broadcast The European Galileo navigation system incorporates broadcasting functionalities that enable a new set of space-related services. The project aims at realizing a detailed network model of the data broadcasting component embedded in the Galileo system. The model should take into account the geographical position of the user, the instantaneous position of Galileo satellites and the relevant propagation parameters for the space-to-user data link available within the Galileo services. This idea is related to the Satellite Mobility Model. However, in this case the needed mobility model will only thave to cover the GALILEO orbits.

DVB-RCS2 Random Access Methods

Mentors: Alberto Gotta Manlio Bacco Pietro Cassarà

  • DVB-RCS2 Random Access Methods DVB-RCS2 SAT - Random access methods introduce a lower connection delay compared to dedicated methods. Such methods, however, are less efficient in regards to bandwidth usage than dedicated access mecanisms and less reliable in overloaded network conditions. The implementation of a DVB-RCS2-compliant random and dedicated TDMA methods aims at investigating the potential to improve the performance of short elastic data flows in regards to transmission delay, over random access methods for DVB-RCS2 that is currently under development. Although DVB-RCS2 has not been designed for random access methods, this project open interesting deployment perspectives in terms of land mobile satellite, SCADA, and machine to machine communication protocols.

Port of ns-2 satellite code

Mentor: Tom Henderson

ns-2 has support for geostationary and low-earth-orbiting (e.g. Iridium) satellites, and some simple Aloha models. See below for the link to the ns-2 documentation. This project would be involved with porting the code from ns-2 to ns-3; the port is expected to involve integrating the geo-centric mobility necessary (most of ns-3 is cartesian coordinates, for example). Once this is accomplished, perhaps other satellite models could be added (TDMA, bandwidth-on-demand, DVB-RCS, etc.).

  • Required Experience: C++
  • Bonus Experience: ns-2, ns-3, satellite networking
  • Difficulty: easy/medium
  • Recommended reading:


TCP Versions for Satellite communications

Mentor: Tommaso Pecorella TCP is the most common transport protocol over the Internet. In theseyears, Tcp performance issues over link with high BDP (like satellite'sones) has been found; various Tcp variants, which aims to fix the issuesand to improve throughput, fairness and friendliness have been proposed(TCP Peach, TCP Noordwijk, TCP Hybla, and various other TCP models, likeCubic).ns-3 implementations of these models will help researcher and users todevelop more effective solutions, comparing them with the existing ones.

  • Required Experience: C++
  • Bonus Experience: TCP Congestion Control in Linux or other OSes
  • Difficulty: easy/medium
  • Recommended reading:
    • Tcp Peach
    • Tcp Noordwijk
    • Tcp Cubic
    • Tcp Hybla
    • Tcp/Ip Illustrated, Vol. 2: The implementation