peersim-step3 两种仿真模式

http://blog.sina.com.cn/s/blog_70e9ecab0100nzzb.html

Peersim的两种仿真模式

 

PeerSim有两种仿真模式:Cycle-based模式和Event-Driven模式。各自的特点如下:

1、Cycle-based模式:

(1)基于peersim.cdsim包中的CDSimulator类

(2)简化、忽略了细节;

(3)扩展性非常好,最多可支持千万级别节点数;

(4)不支持传输层模拟( nodes和protocols直接对话);

(5)不支持并发处理

2、event-based模式

(1)基于peersim.edsim包中的EDSimulator类

(2)实用性强;

(3)支持传输层模拟;

(4)基于cycle-based模式开发的协议均可在event-based引擎下运行;

(5)效率不高,最多支持十万级别节点数;



http://blog.sina.com.cn/s/blog_70e9ecab0100o285.html

cycle-based模式比较简单,主要环节如下:

(1)读取配置文件

配置文件中包含所有涉及到的对象的模拟参数,是纯文本文件(例如config-flooding.txt),它的功能是定义了一些运行过程中的协议类、初始化类、控制类,以及一些常数。这个配置文件会被ParsedProperties解析出来,在运行过程中将定义的各种类进行实例化。

(2)模拟器根据配置文件建立起一个网络并初始化网络中的节点和节点中的协议

每个节点拥有相同的协议类型。节点和协议的实例是通过克隆来创建的,也就是说只用构造方法来创建一个实例,然后以这个实例为原型克隆出网络中其他节点。

(3)初始化,设置每个协议的初始状态

初始化阶段由Control对象控制运行,仅在实验开始时运行一次,在配置文件中,初始化的组件可由init前缀识别。

(4)调用所有组件

初始化完成后,Cycle-based引擎在每个周期调用所有组件一次,直到完成了指定的周期数,或者某个组件决定中止仿真为止。

默认情况下,所有对象都会在每个周期运行,但也可以配置一个protocol只在特定周期运行,例如令一个名为dnet的control对象仅在第5~10这六个周期运行,相关配置如下:

control.dnet.from 5

control.dnet.until 10

默认情况下组件运行的顺序是按字母顺序,也可用属性(include.control, include.protocol)来指定组件的运行顺序例如include.init rnd lin语句使得rnd组件先于lin运行。



http://blog.sina.com.cn/s/blog_70e9ecab0100oah4.html

event-driven mode

1、判断为EDSimulator类型

2、节点协议栈初始化

3、调用各初始化器(initilizer)的execute()方法

CDSchedule为初始化control,执行其execute()方法时加载CDProtocol类型协议的NextCycleEvent类型事件对象进栈,并排序

4、调用EDSimulator的scheduleControls()方法

加载非初始化的controls,初始化相应调度器ctrlShedules,将controls和ctrlschedules封装成control类型的事件。调用addControlEvent()方法将事件入堆并排序。

5、首先执行control类型的事件,或者NextCycleEvent类型事件

执行NextCycleEvent事件时执行CDProtocol中的nextCycle()方法,然后将下一个NextCycleEvent事件入堆并排序。

在执行nextCycle()方法时调用传输层的send()方法,(这里的send()方法用于实现节点间信息的交流。将消息封装成一个事件加入堆),即第三种事件:transport类型事件

6、在EDSimulator类中的循环判断while(!exit)将堆中的各类事件中按时间优先级调出来执行并加入新的事件入堆。

执行过程如图所示:

event-driven <wbr>mode



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Eclipse下PeerSim仿真(2010-07-24 14:21:16) 转载▼ 标签: 杂谈 Eclipse下PeerSim仿真 时间: 2010.06.25 23:00:00 标签: PeerSim ,Eclipse http://hi.baidu.com/bookpage/blog/item/1bc32a341a8f46bbd0a2d3c6.html ******************** Eclipse下PeerSim仿真 ******************** ------------------------ 本文参考: http://peersim.sourceforge.net/ http://blog.sina.com.cn/s/blog_453a60170100hyno.html http://hi.baidu.com/bookpage/blog/item/1bc32a341a8f46bbd0a2d3c6.html ------------------------ 0、关于PeerSim 主页:http://peersim.sourceforge.net/ 下载:http://sourceforge.net/projects/peersim/ P2P仿真软件,基于JAVA语言。 2004年发布0.0版,最新版本1.0.5发布于2009年9月29日。 1、安装JDK和Eclipse 网上很多资料,此处不多说。 关于JDK版本,没有找到相关说明,下载较新版本即可,如JDK1.6就可以。 Eclipse最新有一个Helios(太阳神)版。 2、示例(PeerSim的"hello world") (1)创建一个java project,命名为PeerSim。 (2)将下载的peersim-1.0.5.zip中的src目录下的文件都拷贝到工程主目录下的src目录下。 (3)将下载的peersim-1.0.5.zip中主目录下的jar文件拷贝到工程主目录下。 (4)添加libraries。Project--Properties--Java Build Path。 Add External JARs,将主目录下的jar文件都添加进去。 (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 解决方法: 在第6步,右键,Run as--Run Configurations,配置Classpath,使得User Entries中只保留djep-1.0.0.jar,peersim-1.0.5.jar,jep-2.3.0.jar,也就是删除peersim-doclet.jar。这个时候再运行,仿真就能正常结束了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值