blob: 4072227048bfc299051ff74615ba595a60d67829 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
FF::Sys.new('Alignment', priority: 50) do
group_velocity = [0.0,0.0]
boids_count = FF::Cmp::Boids.each.to_a.count
FF::Cmp::Boids.each do |boid|
group_velocity[0] += boid.vx
group_velocity[1] += boid.vy
end
FF::Cmp::Boids.each do |boid_update|
move_boid = group_velocity.dup
move_boid[0] -= boid_update.vx
move_boid[1] -= boid_update.vy
move_boid[0] /= boids_count - 1.0
move_boid[1] /= boids_count - 1.0
boid_update.cx += (move_boid[0] - boid_update.vx) / $config.alignment
boid_update.cy += (move_boid[1] - boid_update.vy) / $config.alignment
end
end
|