Windows Port of ns-3 using Visual Studio
Note: This page is dated and kept only for historical reference; it has been replaced by ns-3 on Visual Studio 2012.
A project to extend NS3 functionality on Windows operating-systems (Specifically Visual Studio integration)
Project Goals
- To reduce or eliminate the need for CygWin to run NS3 on Windows operating-systems
- To expose native Windows API to NS3 developers
- To integrate NS3 into IDE's such as Visual Studio 2010
- To integrate NS3 into IDE's such as Visual Studio 2008 (Stretch Goal)
Development Plan
- Feasibility study and pilot implementation
- After the final commit from the ns-3 modularization project finalize folder structure and module list
- Review and commit changes for Windows onto ns-3.11
- Review copyrights,coding-style and documentation
- Build automated build framework
Current status
- The feasibility study was done .An unstable implementation built on ns-3.10 is available at #Software download (OBSOLETE)
- After the ns-3 modularization project a new unstable version is available, built on the ns-3-dev lineup
Software download
- Version (ns-3-Win2.0) built on ns-3-dev(dated 05/23/2011)
Download via mercurial: "hg clone http://code.nsnam.org/jabraham3/ns-3-win"
Changelog & Caveats:
- The ~30 modules of ns-3 can be built independently as projects within the master solution, saving time
- Instead of building all the examples within the solution, I have provided a facility to run only one example at a time.This is due to the fact that I wanted to reduce the changes required and considering the fact any user deals with 1 or 2 examples at most at any given time. (A Visual Studio solution provides only executable at any point)
- The project files will need to be downloaded via "mercurial"
- Optional features such as click,mpi,openflow can be built, however I have made these project files dormant. It is left to the end-user to enable them and point to the required include libraries to run its examples. I might provide instructions later on how to handle the optional features as time permits
- Any windows-based solution is always going to be a subset of the main ns-3 project and will have a reduced feature-set.
- This version is built on ns-3-dev rather than ns-3.10.
- The GUI MFC code is removed, as I prefer to maintain it separately.
The following are some of the missing features (some are excluded currently due to lack of time in porting them,some because they depend on third-party s/w and some can never be supported for windows)
- waf,Python-binding,Visualizer (portable). Note:Visual studio solution does not require waf at this point.
- watchdog.cc,wall-clock-synchronizer.cc,unix-system-wall-clock-ms.cc,unix-system-thread.cc,unix-system-condition.cc,unix-fd-reader.cc,int64x64-cairo.cc,int64x64-128.cc (can be sort of ported)
- config-store (portable)
- All NSC code (non-portable)
- SQL dependent code (portable)
- rocketfuel-topology-reader.cc (portable)
- Real-time simulator (????)
- lte-multiple-flows.cc (portable)
- main-test-sync.cc (portable)
- nms-p2p-* files (portable)
- Version (ns-3.10-Win-1.3) Alpha version built on ns-3-dev(dated 02/07/2011)
Download from here
Changelog & Caveats:
- This version caters to "Distributed simulation/MPI".
- A separate Visual Studio 2010 Solution file "ns-3-dev-MPI.sln" is provided in addition to the default "ns-3-dev.sln",
- "ns-3-dev-MPI.sln" is required to build "ns-dev" static libraries with MPI/Distributed simulation related code available.
- The MPI-related examples have an associated Makefile, to help build them.
- Distributed simulation is run with the aid of "Open MPI". As Open MPI's "mpirun" utility requires a console application, distributed-simulation needs to be a console app (i.e Windows GUI components won't be available).
- nms* examples are not included as they use "variable-length arrays" with are C99 features not supported on Visual C++.These examples might be made available in a future version.
Please visit the #Installation & Usage page for more details
- Version (ns-3.10-Win-1.2) Alpha version built on ns-3-dev(dated 02/07/2011)
Download from here
Download NetAnim for Windows from here
Changelog & Caveats:
- Examples under Animation are enabled
- A Windows port of NetAnim
- Possible memory-leak if "Stop" button is pressed before Simulation ends (Need a way to gracefully shutdown simulator in future versions).
- Version (ns-3.10-Win-1.1) Pilot/Limited feature/Alpha version built on ns-3-dev(dated 02/07/2011)
Download from here
Changelog & Caveats:
- More examples have been enabled,including wireless and wimax.However, the following examples are still excluded:
- examples/matrix-topology
- examples/mpi
- examples/realtime
- examples/tap
- examples/topology-read
- examples/emulation
- Missing code from Core simulator:
- tools
- test
- mpi
- cairo high-precision
- any animation related code
- tap-bridge
- emulation
- NSC
- realtime
- utils
- python bindings
- unix* and wall-clock-synchronization
- matrix topology reader
- buffer-test.cc
- This version contains a port of gsl_erfc from GSL 1.14, as Visual Studio does not provide erfc in the standard math libraries. The erfc(x) port has been tested for x ranging from 0 to 3.5
- Most of the contrib code is now included, except for code such as xml-config,config-store,sqlite*,gtk dependent code etc.
- High-precision cairo is not yet ported.
- OLSR model and helper are included, but olsr\test and olsr\examples are excluded as high-precision cairo is still not ported.
- This version fixes a major buffer-security bug in the first version (this is not related to the ns3 code).
- There should be zero linker errors & zero linker warnings in this version.
Installation & Usage
Follow instructions at Windows Port of ns-3 using Visual Studio Installation and Usage