peerSim配置文件解析

13 篇文章 0 订阅

【转自:http://blog.sina.com.cn/s/blog_70e9ecab0100o28l.html

PeerSim的配置文件 ※

配置文件的功能是定义一些协议类、控制类、初始化类以及一些常数,这个配置文件会被ParsedProperties解析出来,在运行过程中将定义的各种类进行实例化。

配置文件是一个明文文本文件,扩展名为*.txt,基本由一些字符型键值对来表示java中的java.util.Properties。

调用配置文件可用以下方式:

(1)命令行:java peersim.Simulator config_file.txt

(2)在“run configurations”的“program arguments”中填入配置文件的名字

(3)main方法中使用语句:String args[]={“example/config_flooding.txt”}

配置实例解读:

# PEERSIM EXAMPLE 1             //表示注释

02

03  random.seed 1234567890      //定义随机数种子

04 simulation.cycles 30         //定义周期数,如果有该参数表示使用Cycle- based模式,如果此处为simulation.endtime则表示使用Event-driven插入

05

06 control.shf Shuffle          //Shuffle类用来打乱每个周期节点的顺序,这个类只对Cycle-based类型的仿真起作用

07

08 network.size 50000           //定义网络大小,50000个节点

09

10 protocol.lnk IdleProtocol    //定义一个名为lnk的IdleProtocol协议组件,IdleProtocol包含在peersim包内,IdleProtocol是存储邻居节点链路的一个静态容器,在进行静态拓扑建模的时候尤其有用,这个协议的唯一功能是作为其它协议的邻居信息的源,它没有实现CDProtocol接口但实现了Linkable接口,Linkable接口提供了到邻居节点的链路。

 

11

12 protocol.avg example.aggregation.AverageFunction //定义一个名为avg的AverageFunction协议组件,用于计算平均值。AverageFunction是聚集协议的求平均数版本。它的参数(linkable)是很重要的,aggregation协议需要与邻居节点交流但是本身没有邻居节点列表。它能应用于任何覆盖网络;定义覆盖网的协议栈应当在这里指定,参数linkable的值是实现了Linkable接口的协议的类名(在这里是IdleProtocol)。

13 protocol.avg.linkable lnk    //avg的参数linkable的值是lnk(实现Linkable接口的IdleProtocol类协议)

14  //声明3个初始化器

15 init.rnd WireKOut            //定义一个名为rnd的WireKOut的初始化器,WireKOut进行的是对静态覆盖网的布线,节点以度数k随机地与其它节点相连

16 init.rnd.protocol lnk        //rnd的protocol参数的值是lnk

17 init.rnd.k 20                //rnd的k参数的值为20

18 

19 init.peak example.aggregation.PeakDistributionInitializer //定义一个名为peak的peak分布初始化组件,peak分布将用0初始化所有节点的值,除了取得value参数的那个节点。

20 init.peak.value 10000        //peak的value参数值为10000

21 init.peak.protocol avg       //peak的protocol参数值为avg

22

 

23 init.lin LinearDistribution   //定义一个名为lin的线性分布初始化器,线性分布则代表节点拥有一个线性增加的值。

24 init.lin.protocol avg        //

 

25 init.lin.max 100             //

26 init.lin.min 1               //

 

27

28 # you can change this to select the peak initializer instead

29  include.init rnd lin              //使用peak还是linear分布是由include.init属性来决定的(29行),它指定了选择哪个初始化器。这个属性也定义了组件运行的顺序,注意默认的顺序(即如果没有include属性),是根据字母排序的,对于protocol和control的include属性也是如此。

30

31  control.avgo example.aggregation.AverageObserver //定义一个名为avgo的control组件用来监测平均值计算

32 control.avgo.protocol avg

注意:

定义组件的格式:

<protocol|init|control>.string_id [full_path_]classname

定义组件参数的格式:

<protocol|init|control>.string_id.parameter_name

每个组件有一个名字,例如lnk,如果是协议组件,该名字由PeerSim引擎与一个数值型索引号(protocol ID)映射起来,这个索引号不会出现在配置文件中,但在模拟过程中访问协议时非常必要。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验经验: 1、安装JDK和Eclipse 网上很多资料,此处不多说。 关于JDK版本,没有找到相关说明,下载较新版本即可,如JDK1.6就可以。 Eclipse最新有一个Helios(太阳神)版。 2、示例(PeerSim的"hello world") (1)创建一个java project,命名为PeerSim。 (2)将下载的peersim-1.0.5.zip的src目录下的文件(注意:将scr目录下的peersim和example这两个文件拷贝到scr目录下,而不是将它们的上级文件scr拷贝到scr目录下那样就会出现错误,因为那样两个scr的名字重了,肯定会出错,而是将peersim的scr的下级文件拷贝到java文件的scr文件下)都拷贝到工程主目录下的src目录下。 (3)将下载的peersim-1.0.5.zip主目录下的jar文件拷贝到工程主目录下。 (4)添加libraries。Project--Properties--Java Build Path--Libraries-- Add External JARs(add jars),将主目录下的jar文件(4个,djep-1.0.0.jar, jep2.3.0.jar, peersim1.0.5.jar,peersimdclet.jar)都添加进去。Libraries才是程序运行所需要的配置文件,所以先要放在主目录下,然后再将它放在properties的Libraries,这样程序才能运行。 (5)编写仿真配置文件。这里使用peersim-1.0.5的example目录下的config-example1.txt。将这个txt文件拷贝到工程主目录下。 (6)运行,在Eclipse的Package Explore栏找到这个txt文件,右键,Run as--Run Configurations。 Main:在Name输入Application名称,比如PeerSimApp;在main class输入peersim.Simulator,或者搜索之。 Arguments:在Program arguments输入config-example1.txt,也就是配置文件。配置一下配置文件的名字。要不程序找不到。 (7)第6步完成之后,点击运行,会出现错误: peersim.config.IllegalParameterException: Parameter "protocol.lnk": The class peersim.core.IdleProtocol appears more than once in the classpath; please check your classpath to avoid duplications. At peersim.config.ConfigContainer.getClazz:582 解决方法: Project--Properties--Java Build Path--Libraries使得Libraries(因为Libraries配置文件既不能多也不能少)只保留djep-1.0.0.jar,,jep-2.3.0.jar,也就是删除peersim-doclet.jar,peersim-1.0.5.jar(在Libraries删除而不是在主目录删除,因为运行所需的配置都是在Libraries完成,主目录都保留就可以了,与程序运行的配置无关)。这个时候再运行,仿真就能正常结束了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值