设为首页收藏本站

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

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 6575|回复: 1

[交流] 看看这段代码的问题

[复制链接]
发表于 2008-4-10 16:36:43 | 显示全部楼层 |阅读模式
我的模型,原意是使得每五个turtle成一个矩形,这些矩形随机散布在一定范围内。
; Y/ E0 T) y# }$ }1 s! ^. w" L+ d1 w0 r
但是运行结果所有的矩形重叠在一起,只显示一个矩形。请大家帮忙看看。2 L/ U3 Q$ i$ p1 A( }5 W6 {; ?  e) Q8 ^
" c" L  m+ S( `' V, s! L/ t# |$ X6 |
turtles-own [a b c d k f g h
  Y! c9 ^7 \& s, f; B  x y     ;; these are the leaf-turtle's offsets relative to center-turtle
& s- f# W9 r8 @  f7 E]
7 R3 ~* N( j9 b. ~+ z6 sto new
0 X) l7 U+ l. e8 W9 k  ca  D* \/ x% Y: |. p2 T# t7 ^
  crt 5 * num_of_building
3 e" o1 V; n: S/ @' n# A  ask turtles [ifelse (remainder who 5 = 0) [set color red][set color blue]]
/ B' l  e6 g6 V* q3 b  scatter     ;;keep center-turtle random positions
( u' |% E- v: f2 Y% b5 t; ~  unit_plan   ;;make up the building plan
: A6 b! t7 c- [( g. yend
2 r3 V" |) [+ q+ U* i4 f" lto scatter, m% B; k$ [* V7 t8 o
ask turtles with [remainder who 5 = 0]; x+ `9 h0 h% O/ _7 \7 ~9 y' _" @/ Q( I
[
5 H1 C5 `6 M( o$ \' t9 yset xcor xcor - 6 + random-float 153 f, m( b7 U9 K
set ycor ycor - 6 + random-float 150 r0 [& i. i4 M9 g
]
3 T) r4 \7 T& N% H" M5 [end
- t% m- m; |# Ito unit_plan * Y* G9 |  S! u) X1 o9 X* e
ask turtles [
* u4 G+ a. k  |$ s! pif (remainder who 5 = 1) [set a who # d/ S) B4 E  D$ k
                          set x ( 0 - Wid / 2 )
6 {5 R# E# S4 Y: e6 y" T                          set y  Dep / 2 ]
7 q$ s3 x. m! c; ^9 s8 S; N5 J           set b  int (a / 5) * 55 ]% ?5 p# u' i7 M
    setxy ( xcor-of turtle b + x )
: P" v8 A, y, H8 F          ( ycor-of turtle b + y ); W# b9 d2 K* ?: U; {; y
if (remainder who 5 = 2) [set c who
: B: D  s4 Q) W7 m! m                          set x ( 0 - Wid / 2 )   n8 n/ _  \  d* z2 R4 @0 n# b
                          set y (0 - Dep / 2 )  ]" q! z% M. N4 \8 [* {  y
                          set d int (c / 5) * 57 h: {4 }% @- z" S" C0 C3 H( H9 q
   setxy   ( xcor-of turtle d + x )( m, Z4 p& \$ K% \9 |+ n
           (ycor-of turtle d + y ) 8 N! f" B) D/ E4 H$ e  G, ~4 R
         
) Z7 \3 g9 ~* [. x; h0 m9 ?: n            
8 S) q  Y( J2 bif (remainder who 5 = 3) [set k who
; R7 Z3 B5 m$ Z4 F8 m  q: z5 ~                          set x( Wid / 2)  ! d" z: X+ v2 ^, N
                          set y (0 - Dep / 2 ) ]) `( i9 w1 A+ {# m+ M3 U, K
                          set f int (k / 5) * 5
. Q( C0 L( e3 f+ D' u  setxy   ( xcor-of turtle f + x )
$ {" W4 e8 C" G7 [6 l. m           (ycor-of turtle f + y )
% n2 O% v' D, E" C# Y           
$ S9 P1 v6 X' ?7 _1 [5 B           
# }; B$ O% a8 L3 X$ A. Vif (remainder who 5 = 4) [set g who8 a, F2 K/ x7 X8 e& m5 D8 n3 j5 K
                          set x Wid / 2
! Y5 x+ Z1 I8 g* f" M                          set y  Dep / 2 ]
2 m  ~* D; @  r, U9 M                          set h  int (g / 5) * 5  u+ ^2 D( Z3 x% k0 U
  setxy   ( xcor-of turtle h + x )& B" q' Q4 U6 ~0 u8 m3 d% c8 y
           (ycor-of turtle h + y )
# O- @0 c" u. j9 D$ @5 x                          3 u; K! f* B; k
                          
" c0 M1 c) e! n5 @$ s                          ]
4 p' f( D% s, L- c+ }% d6 Z& O" dend
; @2 X  B5 V0 ]* r" Q% T( N: M9 Z+ `3 [
[ 本帖最后由 etamina 于 2008-4-10 16:41 编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
 楼主| 发表于 2008-4-11 13:26:12 | 显示全部楼层
已经解决了,
1 C) j9 M, K. ]1 z2 Z5 h应该是
1 R( n1 P6 ~/ `, Zask turtles [
- v, G  [( w7 f- f9 u8 u0 c' ^& I/ ?; uif (remainder who 5 = 1) [set x ( 0 - Wid / 2 ) 1 L0 _0 o$ e. _* `+ ^8 j) I; `3 g4 D
                          set y  Dep / 2 4 o, W% W! n, I: U  W2 V4 a) q
           set b  int (who / 5) * 5
0 w2 _' r7 g- V; T6 L0 M  Q$ f    setxy ( xcor-of turtle b + x )& M$ j4 ^3 X7 O  B! _
          ( ycor-of turtle b + y )]]* ~1 n/ j4 h  r5 d2 u( k( l
end
) O7 x/ l& U6 Q# t9 l- h之前有个括号位置不对没发现
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-10-30 11:02 , Processed in 0.028260 second(s), 15 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

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