ボイドシミュレーター 戻る
対話型シミュレーター

ボイドシミュレーター — 群れの創発的挙動

分離・整列・結合という単純な3ルールだけで、画面上に魚群や鳥群のようなうねりが立ち上がります。重みをスライダーで動かし、捕食者や引力源も置きながら、群知能の不思議さを自分の手で確かめてください。

パラメータ設定
ボイド数
最大速度
視野半径
分離の重み
整列の重み
結合の重み
プリセット
表示オプション
インタラクション

クリック→天敵 / 右クリック→引力源

計算結果
100
ボイド数
平均速度
クラスター数
群れ

クリック: 天敵追加 / 右クリック: 引力源追加 / タップ長押し: 引力源

理論・主要公式

各ボイドは視野半径 $r$ 内の隣人に対して3つの力を計算する:

  • 分離 (Separation): $\mathbf{F}_s = -\sum_{j \in N_{sep}}\frac{\mathbf{r}_{ij}}{|\mathbf{r}_{ij}|^2}$
  • 整列 (Alignment): $\mathbf{F}_a = \langle \mathbf{v}_j \rangle - \mathbf{v}_i$
  • 結合 (Cohesion): $\mathbf{F}_c = \langle \mathbf{x}_j \rangle - \mathbf{x}_i$

最終加速度: $\mathbf{a}_i = w_s \mathbf{F}_s + w_a \mathbf{F}_a + w_c \mathbf{F}_c$

速度は $v_{max}$ でクランプ。端に達したら反対側から出現(トーラス空間)。

ボイドシミュレーターとは

🙋
「ボイド」って何ですか?ただの点が動いてるだけに見えるけど、どうして魚の群れみたいな複雑な動きが生まれるんですか?
🎓
大まかに言うと、各ボイドは「分離」「整列」「結合」のたった3つのルールに従って動く、賢い粒子なんだ。例えば、上のスライダーで「分離の重み」を0にしてみて。個体同士がぶつかり始めるでしょ?これが衝突回避の基本ルールだよ。
🙋
え、そうなんですか!でも、それぞれのルールの強さを変えると、動きが全然変わりますね。「整列」を強くすると軍隊みたいにピシッと揃う!これって実世界でも使われてるんですか?
🎓
その通り!実務ではCGの群衆シーン生成や、ゲームのNPCの集団AIに使われることが多いよ。CAEの世界では、粒子法シミュレーションの基礎としても重要だ。例えば、自動車の塗装シミュレーションで、塗料の飛沫粒子が互いに干渉しないように動くモデルに応用されたりするんだ。
🙋
CAEにも関係あるんですね!「視野半径」を非常に小さくすると、群れがバラバラになっちゃいました。これって、現実の生物でも視界が悪いと群れを維持できないということですか?
🎓
鋭いね!その通り、局所的な情報だけで大域的な秩序が生まれるのが「創発」の面白さだ。現場で多いのは、このアルゴリズムを拡張して、障害物回避のルールを追加したモデルだよ。パラメータをいじることで、自然な群れから整然とした隊列まで、様々な集団行動を再現できるんだ。

よくある質問

分離の重みを大きくすると個体間の距離が広がりバラバラになりやすく、整列を大きくすると一方向に揃った動きになります。結合を強めると密集した塊になりやすく、逆に弱めると群れが拡散します。
視野半径が小さいと各ボイドは近くの個体しか認識せず、群れが分裂しやすくなります。逆に大きいと遠くの個体の影響も受けるため、全体としてまとまりやすい大きな群れが形成されます。
境界条件が設定されていない場合、ボイドが画面外へ飛び出します。また、分離の重みが極端に小さいと衝突が発生し、計算が不安定になることがあります。必要に応じて反復境界や壁での反射を有効にしてください。
基本的な創発原理を理解するための教育・デモ用途に適しています。実際の生物の複雑な行動(障害物回避や捕食者応答など)を再現するには、追加のルールやパラメータ調整が必要です。

実世界での応用

コンピュータグラフィックス・ゲーム開発:映画やゲームで、自然な鳥の群れ、魚の群れ、あるいは群衆(ゾンビの大群など)のアニメーションを生成するために広く利用されています。個々のエージェントに複雑なAIを組み込む必要がなく、効率的に大規模な群集シーンを作成できます。

群ロボット工学:多数の自律ロボットを協調させて動作させる制御アルゴリズムの基礎として応用されます。例えば、災害現場での探索や、倉庫内での物品運搬を、ロボットの群れで行う研究が進められています。

粒子法シミュレーション(CAE):SPH(Smoothed Particle Hydrodynamics)法などの粒子ベースの流体解析では、粒子間の局所的な相互作用を計算します。ボイドアルゴリズムは、こうした粒子間の近傍探索と力の計算のプロトタイプとして教育上有効です。

群知能アルゴリズム(PSO):「粒子群最適化(Particle Swarm Optimization)」は、ボイドの概念を最適化問題に応用したものです。探索空間内の粒子(解の候補)が、自身の最良解と群れ全体の最良解の情報を共有しながら最適解に向かって移動し、工学的な設計最適化などに用いられます。

よくある誤解と注意点

まず、このシミュレーターを触り始めてよくあるのが「パラメータを極端にすればするほどリアルになる」という思い込みだ。例えば、分離・整列・結合の重みを全て最大にすると、かえって不自然な痙攣のような動きになる。実務では、生物の観察データや目的に応じてバランスが命。魚の群れを再現したいなら「整列」をやや強め、鳥の群れなら「結合」を少し弱めると良いことが多い。初期値のバランス(例えば 分離:1.5, 整列:1.0, 結合:1.0)を基準に微調整するのがコツだ。

次に、「視野半径」と「最大速度」の関係を見落とすミス。視野半径を広げても、個体の最大速度が低すぎると、情報は得られてもそれに反応して動き切れない。逆に速度が速すぎると制御が効かず群れが崩壊する。例えば、視野半径を50ピクセルに設定したら、最大速度はその5〜10%程度(2.5〜5.0ピクセル/ステップ)から始めて調整すると安定しやすい。

最後に、実装上の落とし穴。距離計算のコストを甘く見ないこと。素直に全粒子間の距離を毎ステップ計算すると、粒子数Nが1000を超えたあたりから急激に重くなる。実務では空間分割(空間グリッド法や四分木)で近傍探索を最適化するのが必須だ。また、力の計算時に隣人の数|N|が0の場合(誰も視野内にいない)の除算エラーにも要注意。その場合は各力をゼロベクトルとして扱うなどの処理が必要になる。

使い方ガイド

  1. ボイド数(boidCount)を1~500の範囲で設定。魚群シミュレーションでは150~200個が標準的な群集動作を示します
  2. 視認範囲(visualRange)を5~100ピクセルで調整。範囲が狭いほど局所的な相互作用が強まり、クラスター化が加速します
  3. 分離重み(sepWeight)と速度パラメータ(maxSpeed:2~8m/s相当)を同時に変更し、群れの凝集度と流動性のバランスを観察してください

具体的な計算例

航空機編隊形成のシミュレーション:ボイド数50、視認範囲60ピクセル、最大速度6.5m/s(実機ではマッハ0.2相当)、分離重み0.8で実行した場合、平均速度4.2m/sで3~4個の安定したクラスターが形成されます。分離重みを1.5に増加させると、個体間距離が平均8.3ピクセル拡大し、クラスター数は7個に分散。一方、整列ルール優位(重み3.0以上)では編隊が一体化し、平均速度が5.9m/sまで上昇します

実務での注意点