人生にゲームをプラスするメディア

【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか

ゲームビジネス 開発

【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
  • 【CEDEC 2014】突然のPS4版開発決定、『龍が如く』の縦マルチはいかにして実現されたか
今年2月22日にPS4/PS3で発売された『龍が如く 維新』。元々はPS3向けに開発され、PS4の予定は無かったそうです。突然のPS4版の開発決定からチームはどう動いたのか。本作のフレームワーク統括を務めたセガ第1CS研究開発部 第1リードプログラムセクション リードプログラマーの厚考氏が語りました。

「龍が如く」シリーズは、単一チームで開発が行われながら、ほぼ毎年新作が発売されている日本では稀有なフランチャイズです。最新作の『龍が如く 維新』では技術的な目標として(1)PS Vitaとの連携 (2)ミニゲームのネットワークマルチプレイ対応 (3)街中の人の動きの向上 (4)可変フレームレート化 といった内容が掲げられましたが、当初はPS4版は計画されていなかったそうです。

最初の打診があったのは2013年春のこと。「PS3版から遅れても構わないのでHD版を作れないか?」とチームに打診があったそうです。当時はPS4は年末発売だと考えられていて、チームでもPS3版の後、本体の発売から2、3カ月後に用意しよう、というような雰囲気だったそうです。

技術的な検証が行われましたが、64bitになっている点、グラフィックスAPIの世代の違い、PS3版がまだ開発中である点、などを除けば、性能的にはPS4の方が圧倒的に上であり、何より開発がPCベースで行われていたという点が安心材料でした。従って、まずPCでDirectX11/64bitのバージョンを開発し、それをPS4に移植するという流れが採用され、「なんとかなるだろう」という雰囲気で開発が始まったそうです。

PS4に着手したのは6月初旬。当初は厚氏が一人で携わり、PCで、DirectX11/64bit環境で動作する形に移植が行われました。PS3はDirectX9ベースですが、DirectX11になることで幾つかの命令が廃止されていて、変更する必要があったそうです。また64bit化においては、長年32bit環境でしか開発が行われてこなかったため、誤っているコードでも、32bit環境であれば意図せず動作が行えてしまう、というケースが散見されたそうで、これを潰すために、コンパイラの警告レベルを最大にして修正を行っていったそうです。

シェーダーモデルも3.0から5.0に変更されていて、その関係で実現できていたものが落ちてしまった部分が幾つかあったそう。PS3ではシェーダーの静的分岐を擬似的に実現していましたが、PS4ではパフォーマンスに余裕があったことから動的分岐に変更。テクスチャ構文の変更もあり、膨大なファイル数を書き換える必要がありましたが、実装の大半が共通ファイル部だったため、事無きを得たそうです。

7月中旬にはPS4版をPS3版と同時に発売することが決定。スケジュールがタイトになりましたが、下旬になってようやくPC版が初めて起動。一部シェーディングが崩れるなどの不具合はありましたが概ね問題なかったそうです。これをPS4に移植するわけですが、コンパイラがMicrosoft Visual C++からClangに変わるため、MS拡張を意図せず使用していた部分で不都合があったほか。PS4とPCではlongのサイズが異なるというような躓きもあったそうです。

初めて動いたPC版(ただしイメージ)


ただし、早くも8月初旬にはPS4版が起動する状態になり、PCからの移植では10日前後を要したという結果でした。ここまで厚氏が単独で作業に取り組んでいましたが、ようやく増員があり、本格的にチューニングに取り組むことになります。動作には成功したものの、25fps前後しかパフォーマンスが出なかったからです。

ジョブの実行時間を分析したところ、4つのワーカーが動作しているうち、描画コマンド作成が全体の80%を占めていて(PS3版は30%程度)、ボトルネックになっていることが分かりました。PS3では長年の最適化の結果、かなり軽量化が進んでいたそうです。

描画コマンドの作成に大きなコストがかかっていることが判明


PS4版の最適化では可能な場合、描画を結合することでドローコールを削減したり、PS3では定数バッファの制限を受けていたスキンモデルを再構成してPS4に最適化を実施。これらの工夫で約10%の軽量化が出来たそうです。

しかし、この時期にPS4版を発売することを正式に発表されました。するとPS4版に対する期待が高まり、何かしらの要素を追加する必要に迫られました。そしてチームではゲーム内容をいじることなくプログラム作業で実現できる60fpsの実現を決めます。当時はまだ40fps程度しか出ておらず、30fpsであれば十分な形になっていましたが、大きなチャレンジが課されることとなりました。

約60%の改善は「絶望的」(厚氏)として、並列化に取り組むことになります。20ほどあった描画パスを4スレッド化すことで50%程度の劇的な改善が見られました。さらに処理の粒度にはばらつきがあり、不透明なOPAQUEの処理が重くボトルネックになっていることが分かりました。この処理を更に分割して並列化することで更に20%が改善。

こうした最適化の結果、描画にかかける時間は34mmから14mmまで改善。11月7日に60fpsを見事達成することができました。

最適化の結果


その後は更なるチューニングを行い、ファイル読み込み時に瞬間的なフレームレートの低下が見られたため、この処理を別スレッドに移したほか、パフォーマンスに余裕が出来たため、遠方のモデルを高精細なものに差し替えました。また、メモリが大量に余っていたため、モーションやテクスチャの圧縮率を下げ、それでも余ったメモリは全てファイルキャッシュに使い、実に2.5GBのファイルキャッシュで快適なロードを実現することができました。

遠方のキャラクターモデルを向上


厚氏はプロジェクトを振り返り、「かなり厳しいスケジュールでしたが、幾つかの好条件もありました。そして何より、優秀なスタッフに恵まれ、世代を超えたマルチプラットフォームを実現することができました」と話しました。

ゲーム内容としてはPS4とPS3で異なる点がない『龍が如く 維新』ですが、60fpsであり、モーションやテクスチャの品質が大幅に改善されていること、ロード時間もほぼ無いという、エンジニアリングの観点からゲームを大幅に改善することに成功した事例と言えそうです。
《土本学》

編集部おすすめの記事

特集

ゲームビジネス アクセスランキング

  1. 美少女に応援&罵倒されながらダイエットできるVRゲーム、Steamに登場!

    美少女に応援&罵倒されながらダイエットできるVRゲーム、Steamに登場!

  2. フロム・ソフトウェア1DAYインターンシップに潜入!最前線のデザイナーが学生にアドバイス

    フロム・ソフトウェア1DAYインターンシップに潜入!最前線のデザイナーが学生にアドバイス

  3. VR空間でプラモ作りを楽しもう! 『Monzo VR』12月12日リリース

    VR空間でプラモ作りを楽しもう! 『Monzo VR』12月12日リリース

  4. ゲーム開発をワンストップでサポートする シリコンスタジオ寺田健彦社長インタビュー

  5. VR歩行デバイス「Omni」米国外からの予約がすべてキャンセルに―払い戻しを実施

  6. 【GTMF2013】ヤマハによるアミューズメント向け次世代 GPU と開発環境

  7. この夏をモンハングッズで乗り切れ!「蚊取りプーギー」「ステンレスマグ」「アイルー占い1.5」登場!

  8. 【CEDEC 2010】ファイナンス&マネージメント みずほキャピタル逸見圭朗氏による「続・ゲーム企業の資金調達」

  9. 【特集】『東方Project』商業・海外展開の裏側、その背景には時代の変化が

  10. 【レポート】「ボトムズ」の筐体型VRゲーム『バトリング野郎』の再現度が“むせる”ほど高い!鉄の棺桶を実際に体験

アクセスランキングをもっと見る

オススメの記事だホ!

page top