「Continuous Collision Detection」を編集中
この編集を取り消せます。 下記の差分を確認して、本当に取り消していいか検証してください。よろしければ変更を保存して取り消しを完了してください。
最新版 | 編集中の文章 | ||
1行目: | 1行目: | ||
− | + | 連続的衝突判定(英語:Continuous Collision Detection、通称:CCD)とは、物理演算などの当たり判定で「突き抜け」を抑制する方法の総称である。 | |
様々な[[アルゴリズム]]が考案されているが完璧なものはない。 | 様々な[[アルゴリズム]]が考案されているが完璧なものはない。 | ||
− | |||
==概要== | ==概要== | ||
− | [[ゲーム]]や[[物理演算]]など[[コンピューター]] | + | [[ゲーム]]や[[物理演算]]など[[コンピューター]]上で物体の移動を計算する場合、どうしても「離散的な移動(1フレームごとに飛び飛びに移動)」となる。 |
[[ファイル:Continuous collision detection 1.png|none|frame]] | [[ファイル:Continuous collision detection 1.png|none|frame]] | ||
− | + | 物体の移動は1フレームごとの移動量を足し算する感じだが、この際に1フレームの移動量が大きすぎる当たり判定に失敗して壁などを突き抜ける現象が発生する。 | |
[[ファイル:Continuous collision detection 2.png|none|frame]] | [[ファイル:Continuous collision detection 2.png|none|frame]] | ||
15行目: | 14行目: | ||
==解決策:フレームレートを上げる== | ==解決策:フレームレートを上げる== | ||
− | 最強の解決方法は「[[フレームレート]] | + | 最強の解決方法は「[[フレームレート]]を限界まで上げる」ことである。フレームレートを上げれば「1フレームでの移動量」も減るので結果として突き抜けも減る。 |
実際に[[スーパーコンピューター]]などでの非リアルタイムな物理シュミレーションではこの方法が採用されている。 | 実際に[[スーパーコンピューター]]などでの非リアルタイムな物理シュミレーションではこの方法が採用されている。 | ||
ただ[[ゲーム]]などのようにリアルタイム性が求められる場合には限度がある。 | ただ[[ゲーム]]などのようにリアルタイム性が求められる場合には限度がある。 | ||
+ | |||
[[パソコン]]でも[[PhysX]]や[[Bullet]]などは[[GPGPU]]を使って高速化することで「物理演算のフレームレート」を上げる方法が考案されているが、それでも結構厳しい。 | [[パソコン]]でも[[PhysX]]や[[Bullet]]などは[[GPGPU]]を使って高速化することで「物理演算のフレームレート」を上げる方法が考案されているが、それでも結構厳しい。 | ||
+ | |||
[[社畜PC]]や[[スマートフォン]]などのしょぼい[[CPU]]での計算は絶望的に厳しいのは言うまでもない。 | [[社畜PC]]や[[スマートフォン]]などのしょぼい[[CPU]]での計算は絶望的に厳しいのは言うまでもない。 | ||
28行目: | 29行目: | ||
[[ファイル:Swept shape.png|frame|none]] | [[ファイル:Swept shape.png|frame|none]] | ||
− | + | この方法は直線的な移動にしか対応できないという欠点がある。ピンボールのフリッパーのような回転運動には対応できない。 | |
==解決策:投機的CCD== | ==解決策:投機的CCD== |