设为首页收藏本站

最大的系统仿真与系统优化公益交流社区

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 4529|回复: 3

[求助] 关于CarryDrop model的一个问题

  [复制链接]
发表于 2012-3-4 17:00:49 | 显示全部楼层 |阅读模式
在CarryDrop model中那个spreadmoney方法里,哪一句是用来随机撒钱的啊?程序代码如下,我看到了随机选取坐标,并将该坐标对应的空间格内的值转换为数值,关键在于这个值貌似始终为0,不知道怎么把它修改掉的?哪一句是生成不为0的值的?
9 I5 j9 u3 E6 m& l' V* m/ R        public void spreadmoney(int m){
5 a4 q  N$ l7 y% A- ~                for(int i=0;i<m;i++){
! R4 T( }0 \9 }                        int x = (int)(Math.random()*(moneyspace.getSizeX()));4 @" }, G- X" l9 K
                        int y = (int)(Math.random()*(moneyspace.getSizeY()));
8 F" X  Q3 y2 S  ]$ g
- w2 ?2 b0 A% y* X6 V                        int I;7 ~9 l% B0 }3 J, M- u) ^
                        if(moneyspace.getObjectAt(x,y)!=null                                I = ((Integer)moneyspace.getObjectAt(x,y)).intValue();
$ H; p' O2 P4 Y                        }/ N; \+ ]* ]0 x1 ?
                        else{
  P1 x$ z* K  {2 t2 s' ?: o                                I = 0;8 e3 c7 l" V) s. g
                        }
* h) e# G& n. D  N$ v3 q0 B  }                        moneyspace.putObjectAt(x, y, new Integer(I+1));                              }0 {5 d- m0 g* P' ^
        }
 楼主| 发表于 2012-3-6 09:15:08 | 显示全部楼层
代码帖的有点乱,怎么都没人能帮忙看看呢?       / Z8 o6 b# `( r; g
       public void spreadmoney(int m){
3 Q# ^" i7 G1 B! b& q                for(int i=0;i<m;i++){
9 S) O* J+ A1 v* T0 g8 s( b                        int x = (int)(Math.random()*(moneyspace.getSizeX()));$ Q5 p1 _, h: ~
                        int y = (int)(Math.random()*(moneyspace.getSizeY()));5 f! c2 r+ Z$ L
! }; R$ ^) B9 b1 H8 l
                        int I;
1 R6 e% v) ^; h3 I3 m% I                        if(moneyspace.getObjectAt(x,y)!=null                                ( U8 b6 j2 g4 S3 x4 g8 x9 k
                        I = ((Integer)moneyspace.getObjectAt(x,y)).intValue();/ Z! A' B+ L& O: f% y* R
                        }# w% r) N( T1 O
                        else{
+ J5 _# H3 M) p% l                                I = 0;% N/ w/ r* b& R
                        }
4 G3 [( Z( y4 v/ S                        moneyspace.putObjectAt(x, y, new Integer(I+1));                              }8 A0 V8 P1 r6 V  c1 y/ R: y4 z
        }
 楼主| 发表于 2012-3-6 11:25:15 | 显示全部楼层
还有,当两个agent碰到一起了,到底是谁抢走了谁的钱呢?从程序上真的没看明白
 楼主| 发表于 2012-3-10 15:35:24 | 显示全部楼层
至今没人解答,这个论坛太失败了,还是我自己找出答案吧,不知道对不对。
# ~" b: j1 ?. R第一个问题的钱其实是随机在40*40的格子中选择了1000个格子,每个格子里假设有1块钱,只要agent经过这个格子,如果没人来过,就认为拣了1块钱。
% _) \5 g: P7 M# w( i$ A7 f- L; [第二个问题的答案来自于schedule的execute方法中有个shuffle方法,重新随机调整了每一轮agent的执行次序,根据执行次序的不同而判断是谁先进入了这个格子,从而得知后来的就要交钱了。

点评

e, 没人回答你不代表论坛失败。。。做这块的本来人就少,而且刚好看过捡钱这个例子的人也不多。  发表于 2012-3-15 17:29
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|Archiver|手机版|SimulWay 道于仿真   

GMT+8, 2025-10-10 05:49 , Processed in 0.024599 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表