peersim学习-循环驱动:如何写协议(1)

peersim学习-循环驱动:如何写协议(1)
2011-08-22 10:41

循环驱动模式的协议只要继承CDProtocol就OK了,peersim会在每一个cycle里在每个节点上执行nextCycle()方法;

为了获取邻接信息,必须配置IdleProtocol( implements Protocol, Linkable),这个协议是peersim.core中的核心代码。


上图是linkable接口的方法,在IdleProtocol中实现;主要作用是添加获取邻接节点,使用很广泛,在初始化时,如构建拓扑图,协议实现中都有使用。

Linkable linkable = (Linkable) node.getProtocol(linkableID)获取IdleProtocol对象(IdleProtocol实现于linkable接口)。


上面是peersim实现cdsim的类,对于循环驱动协议只需要使用者实现CDProtocol接口就OK了:

1)CDSimulator,中是主要的cdsim实现的过程;

2)CDState,设置和获取当前的cycle即时间;

3)DeamonProtocol,这不是一个真正的protocol,提供一个可以在任何时候运行control类的方法,设置step控制运行时间。

4)FullNextCycle,每个cycle时,控制协议运行(运行协议的nextCycle方法)和更新CDState的状态。

5)NextCycle,与FullNextCycle作用一样,由private static final String PAR_NOMAIN = "simulation.nodefaultcycle";配置使用NextCycle还是FullNextCycle。NextCycle的灵活性要比FullNextCycle好,为精通的使用者使用。

6)Shuffle,顾名思义就是打乱节点在数组中的位置。

下图是CDSIM的主要过程,protocol类封装成FullNextCycle和配置的control类一起运行。

01publicclassAverageFunctionextendsSingleValueHolderimplementsCDProtocol{

02 /**
03 *Createsanew{@linkexample.aggregation.AverageFunction}protocol
04 *instance.
05 *
06 *@paramprefix
07 *thecomponentprefixdeclaredintheconfigurationfile.
08 */
09 publicAverageFunction(Stringprefix){
10 super(prefix);
11}
12
13 /**
14 *Usinganunderlying{@linkLinkable}protocolchosesaneighborand
15 *performsavariancereductionstep.
16 *
17 *@paramnode
18 *thenodeonwhichthiscomponentisrun.
19 *@paramprotocolID
20 *theidofthisprotocolintheprotocolarray.
21 */
22 public voidnextCycle(Nodenode, intprotocolID){
23 intlinkableID=FastConfig.getLinkable(protocolID);
24Linkablelinkable=(Linkable)node.getProtocol(linkableID);
25 if(linkable.degree()> 0){
26Nodepeer=linkable.getNeighbor(CommonState.r.nextInt(linkable
27.degree()));
28
29 //Failurehandling
30 if(!peer.isUp())
31 return;
32
33AverageFunctionneighbor=(AverageFunction)peer
34.getProtocol(protocolID);
35 doublemean=( this.value+neighbor.value)/ 2;
36 this.value=mean;
37neighbor.value=mean;
38}
39}
40

41}

看看源码中的这个示例,这个协议实现用gossip获取整个网络中节点平均值,每一个cycle,每个节点和自己的邻居求平局值。nextCycle方法是每个cycle在每个节点中运行的。以上就是主要的CDSIM的主要过程和编程方法。

转自: http://hi.baidu.com/dlutwuwei/blog/item/6bf79059be2db2c59c82049d.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值