640 likes | 744 Views
The Design of XML-Based Model and Experiment Description Languages for Network Simulation. Andrew Hallagan Bucknell University Dept. of Computer Science Luiz Felipe Perrone , Advisor April 26, 2011. 3 General Network Types. Clockwise from top: hardwired, wireless, and ad-hoc networks.
E N D
The Design of XML-Based Model and Experiment Description Languages for Network Simulation Andrew Hallagan Bucknell University Dept. of Computer Science Luiz Felipe Perrone, Advisor April 26, 2011
3 General Network Types Clockwise from top: hardwired, wireless, and ad-hoc networks
Nodes 3 General Network Types Clockwise from top: hardwired, wireless, and ad-hoc networks
Channels 3 General Network Types Clockwise from top: hardwired, wireless, and ad-hoc networks
Communication Between Nodes Breaking a message up into packets.
Communication Between Nodes Breaking a message up into packets.
Communication Between Nodes Breaking a message up into packets.
System Experiment with a model of the system Experiment with the actual system Physical model Mathematical model Analytical solution Simulation Ways to Study a System Source: Averill M. Law, Simulation, Modeling & Analysis
System Experiment with a model of the system Experiment with the actual system Costly, disruptive Physical model Mathematical model Analytical solution Simulation Ways to Study a System Source: Averill M. Law, Simulation, Modeling & Analysis
System Experiment with a model of the system Experiment with the actual system Costly, disruptive Physical model Mathematical model Not applicable Analytical solution Simulation Ways to Study a System Source: Averill M. Law, Simulation, Modeling & Analysis
d = v∙t System Experiment with a model of the system Experiment with the actual system Costly, disruptive Physical model Mathematical model Not applicable Analytical solution Simulation Ways to Study a System Source: Averill M. Law, Simulation, Modeling & Analysis
System Experiment with a model of the system Experiment with the actual system Costly, disruptive Physical model Mathematical model Not applicable Analytical solution Simulation Ways to Study a System Difficult, if not impossible Source: Averill M. Law, Simulation, Modeling & Analysis
X-position = f(SPEED, ANGLE) Y-position = g(SPEED, ANGLE) SPEED ~ N(SPEED_MEAN, 3.0) ANGLE ~ U(0, ANGLE_BOUND) Model Inputs • SPEED_MEAN • ANGLE_BOUND A Simple Mobility Model The horizontal and vertical positions of the node are a function of SPEED and ANGLE, which are random variables distributed Normally and Uniformly, respectively.
Model Description X-position = f(SPEED, ANGLE) Y-position = g(SPEED, ANGLE) SPEED ~ N(SPEED_MEAN, 3.0) ANGLE ~ U(0, ANGLE_BOUND) Model Inputs • SPEED_MEAN • ANGLE_BOUND A Simple Mobility Model The horizontal and vertical positions of the node are a function of SPEED and ANGLE, which are random variables distributed Normally and Uniformly, respectively.
Factor Levels ANGLE_BOUND 15 30 45 60 SPEED_MEAN 2.0 3.0 4.0
Design Matrix ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 SPEED_MEAN 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0
Design Matrix ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 SPEED_MEAN 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0 design point
Design Matrix ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 SPEED_MEAN 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0
Design Matrix Experiment Description ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 SPEED_MEAN 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0 2.0 3.0 4.0
Network Complexities Bandwidth, physical distance, network traffic, etc.
Network Complexities Scale.
Network Complexities Physical surroundings.
Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-2 Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-3 ns-2 Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-3 ns-2 Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-3 ns-2 GloMoSim Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-3 CSIM ns-2 GloMoSim Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-3 CSIM ns-2 SWAN GloMoSim Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
ns-3 CSIM ns-2 SWAN Matlab GloMoSim Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
Recap • Networks are complex. • Modeling is difficult. • Experimentation isn’t straight-forward. • Mistakes in this process have led to credibility issues in network simulation.
Solution: Automation • Automation provides guidance that helps increase credibility of published research. • Automate the modeling and experiment design processes. • Validate experiments at multiple levels.
“[The Department of Energy] must continue the development of next generation complex networked systems that are more secure, less brittle to unexpected events, and more controllable. For these emerging efforts to be successful, it is essential that a firm intellectual foundation be provided for understanding and simulating large-scale networks.” Motivation for Network Simulation Research Source: J. M. Brase and D. L. Brown, Modeling, Simulation and Analysis of Complex Networked Systems. White paper.
SAFE Simulation Automation Framework for Experiments
ns-3 CSIM ns-2 SWAN Matlab GloMoSim Various simulator engines Researchers have a number of simulator engines to choose from, including ns-2, ns-3, OPNET, CSIM, GloMoSim and MATLAB.
High-level view of the SAFE architecture. My work is concerned with the Model Description and Experiment Description inputs to this framework (in the yellow boxes).
High-level view of the SAFE architecture. My work is concerned with the Model Description and Experiment Description inputs to this framework (in the yellow boxes).
<html:ahref="http://www.google.com">Link to Google</a> Attribute Element content Attribute value Closing tag Namespace prefix Opening tag An HTML “anchor” element. This piece of HTML is valid XML. It is an a tag with an attribute href. The value of the href attribute is a URL string and the content of the a tag is the “Link to Google” string.
ANGLE_BOUND SPEED_MEAN NEDL Functionality Provide ways to list experimental factors.
<nedl:factorlist> <nedl:factor>SPEED_MEAN</nedl:factor> <nedl:factor>ANGLE_BOUND</nedl:factor> </nedl:factorlist> A NEDL “factorlist” element The “factorlist” element lists all of the factor names referenced throughout the rest of the NEDL document.
ANGLE_BOUND 15 30 45 60 SPEED_MEAN 2.0 3.0 4.0 NEDL Functionality Provide ways to list associated level values for each factor.
“Use the values 3, 17, and 9.” ANGLE_BOUND 15 30 45 60 SPEED_MEAN 2.0 3.0 4.0 NEDL Functionality Provide ways to list associated level values for each factor.
<nedl:memberof> <nedl:factor>SPEED_MEAN</nedl:factor> <nedl:listid>speed-values</nedl:listid> </nedl:memberof> <nedl:levellistid="speed-values"> <nedl:level>3</nedl:level> <nedl:level>17</nedl:level> <nedl:level>9</nedl:level> </nedl:levellist> A NEDL “memberof” element The “memberof” element associates a factor with a list of level values. The name was inspired by the terminology used to describe mathematical sets.
“Use values of the form 5∙x + 2, where 0 ≤ x ≤ 9” ANGLE_BOUND 15 30 45 60 SPEED_MEAN 2.0 3.0 4.0 NEDL Functionality Provide ways to list associated level values for each factor.
<nedl:sequence> <nedl:factor>SPEED_MEAN</nedl:factor> <nedl:test>EQUALS</nedl:test> <nedl:lconst>2</nedl:lconst> <nedl:op>PLUS</nedl:op> <nedl:rexpr> <nedl:lconst>5</nedl:lconst> <nedl:op>MULT</nedl:op> <nedl:rvar>x</nedl:rvar> </nedl:rexpr> <nedl:where> <nedl:range> <nedl:var>x</nedl:var> <nedl:lo>0</nedl:lo> <nedl:hi>9</nedl:hi> <nedl:delta>1</nedl:delta> </nedl:range> </nedl:where> </nedl:sequence> A NEDL “sequence” element The “sequence” element associates a factor with a sequence of level values. The sequence expression is built up using constants, variables, and further expression elements.
SPEED_MEAN 2.0 3.0 4.0 • 2.0 • 3.0 • 4.0 • 2.0 • 3.0 • 4.0 • 2.0 • 3.0 • 4.0 ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 NEDL Functionality Provide ways to “prune” design points from the experiment space.
SPEED_MEAN 2.0 3.0 4.0 • 2.0 • 3.0 • 4.0 • 2.0 • 3.0 • 4.0 • 2.0 • 3.0 • 4.0 ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 “Remove the specific design point where ANGLE_BOUND = 15 and SPEED_MEAN = 3.0.” NEDL Functionality Provide ways to “prune” design points from the experiment space.
<nedl:exclusionrestriction> <nedl:settingfactor="ANGLE_BOUND" level="15"/> <nedl:settingfactor="SPEED_MEAN" level="3"/> </nedl:exclusionrestriction> A NEDL “exclusionrestriction” element The “exclusionrestriction” element specifies a whole or partial design point which should not be included in the final experiment space.
SPEED_MEAN 2.0 3.0 4.0 • 2.0 • 3.0 • 4.0 • 2.0 • 3.0 • 4.0 • 2.0 • 3.0 • 4.0 ANGLE_BOUND 15 15 15 30 30 30 45 45 45 60 60 60 “Remove any design points where SPEED_MEAN = 4.0.” NEDL Functionality Provide ways to “prune” design points from the experiment space.