peersim中CDSimulator和EDSimulator部分代码案例分析

本文将详细分析peersim模拟器中的周期驱动CDSimulator和事件驱动EDSimulator的代码实现。在CDSimulator中,通过循环执行网络中的每个节点和协议的下一个周期操作;而在EDSimulator中,利用最小堆事件进行驱动,当遇到返回true的控制事件时结束当前循环。通过对这两个模拟器的代码案例分析,有助于理解peersim的工作原理。
摘要由CSDN通过智能技术生成

周期驱动CDSi代码案例分析:

for I = 1 to simulation.experimentsdo      //仿真实验从1开始

   createNetwork           //创建网络

   createprototype Node     //创建协议 节点

     forI = 1 to #protocol do   //协议号从1开始

         create protocol instance   //创建协议案例

   forj = 1 to network.size do  //网络大小从1开始

     cloneprototype Node into Network   //网络是由节点组成

   createcontrols(initializers,dynamics,observers) //监控(初始化,动态性,观测者)

   executeinitializers    //执行初始化

   fork = 1 to simulation.cycles do        //仿真周期从1开始

      forj = 1 to network.size do    //网络大小从1开始

        for p= 1 to #protocols  //网络大小从1开始

           execute Network.get(j).getProtocol(p).nextCycle( )  //在下一周期网络中第j个节点使用第p个协议

      executecontrols          //执行控制

      if (one control returned true) then   //如果控制返回true

        break

 

事件驱动EDSimulator代码案例分析:

for I = 1 to simulation.experimentsdo   //仿真实验从1开始

      initialize MinHeap events        //初始化最小堆事件

   

      createNetwork                //创建网络      

      createprotocol Node           // 创建协议 节点

              for I = 1 to #protocol do  //协议号从1开始

                    create protocol instance   //创建协议案例

      forj = 1 to network.size do     //网络大小从1开始

            clone prototype Node into Network //克隆协议节点加入到网络

      createcontrol (initializers,dynamics,observers)   //监控(初始化,动态性,观测者)

      executeinitializers   //执行初始化

     

      time =0    //时间为0

      while (time< simulation.endtime) do //当仿真时间没有到截至时间

            (node,pid,e)= events.getMin( ) ;   //获得MinHeap中的protocolID的节点

            Node.getProtocol(pid).processEvent(node,pid,event)  //获得事件中的protocolID节点

            If(event is a control that returned true) then   //如果控制事件返回true

           break    

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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。这个时候再运行,仿真就能正常结束了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值