1. はじめに
Replication Graphは4.20で追加されたNetworkに関するパフォーマンスを改善するための機能の1つです。この機能については、公式ブログやTitchのライブストリームでも説明されていますのでそちらもご参考ください。本記事ではReplication Graphの使い方やフレームワークに関する内容について記載しています。
検証には4.21.1を利用しています。
2. 概要
Replication Graphの機能を要約すると以下の通りとなります。
[主な機能]
・Replicationを効率的に行うことでCPUパフォーマンスを改善
・ノードグラフは容易に拡張/追加が可能
・デバッグ機能やバジェットを調整するための機能/設定が多数
これらの詳しい内容に関しては後の章で説明します。ドキュメントに記載されている事項を要約すると、Fortnite Battle RoyaleではReplicationを行う50000体のActorを効率的に処理することでCPUパフォーマンスを抑制しているとあります。50000体のActorのパフォーマンスを改善と切り出すと非常に有用な機能のように思われがちですが、もちろん機能を利用する上での注意点もあります。
[注意点]
・多くのActorを扱う際に効果を発揮します
・ノードグラフとは依存関係を持つことを指しBlueprint Nodeのようなものではない
・Pluginを有効にするだけではパフォーマンスは良くならない
・多くのActorを扱う際に効果を発揮します ・ノードグラフとは依存関係を持つことを指しBlueprint Nodeのようなものではない ・Pluginを有効にするだけではパフォーマンスは良くならない注意点の詳細
Replication Graphは多数のActorのReplicationを効率的に行うものです。Networkを利用しないケースは当然ながら効果がありません。また、Actorの数が少ない場合は大きなパフォーマンスの改善につながることはないので、単にネットワークのパフォーマンスを考慮する(RPCを多用しない、NetUpdateFrequencyやNetCullDistaneSquaredを調整する)だけでも問題ありません。
Replication GraphはNode Graphを組み合わせて構築しますが、Blueprint NodeのようなノードベースのUIが存在するわけではありません。全てのNode GraphはC++でのみ作成、拡張することができます。
Replication Graphはカスタマイズすることを前提としているため、プロジェクトにおいて必ずサブクラスを作成して必要なコードを追加する必要があります。単にPluginを有効にするだけでは機能しません。プロジェクトで拡張するにあたっては、サンプルのShooterGameのコードが参考になるため、こちらの理解を深めてから拡張されることをお勧めします。
3. 使い方
Replication Graphを有効にして機能を利用するための方法を以下に記載します。
[使い方]
① Pluginを有効にする
② ReplicationGraphを継承したカスタムクラスを作成してノードを追加
③ ReplicationDriverクラスに作成したカスタムクラスの定義を追加
① Pluginを有効にする (4.21ではDefaultで無効) ② ReplicationGraphを継承したカスタムクラスを作成してノードを追加 ③ ReplicationDriverクラスに作成したカスタムクラスの定義を追加使い方の詳細
EditorのPlugins(もしくは.uprojectファイル)から"Replication Graph"のPluginを有効にします。4.21ではDefaultで無効になっています。
サブクラスとしてUReplicationGraphを継承したクラスを作成します。UCLASS(transient, config=Engine)
class UShooterReplicationGraph :public UReplicationGraph
DefaultEngine.iniに②で作成したクラスの定義を追加します。[/Script/OnlineSubsystemSteam.SteamNetDriver]
ReplicationDriverClassName="/Script/ShooterGame.ShooterReplicationGraph"
4. フレームワーク
マルチプレイにおけるEngineの構成とReplication Graphの位置付けをざっくり示すと以下のようになります。
Replication GraphのPluginが提供している各オブジェクトの役割について以下に説明します。
4.1. ReplicationGraph
UObject
UReplicationDriver // NetDriverと連動する実装を持たないクラス
UReplicationGraph // ReplicationGraphの基底クラス
UBasicReplicationGraph // 基本的な実装を持つクラス
UShooterReplicationGraph // ShooterGameのカスタムクラス
Replication Graphのメイン実装部です。GraphNodeの構築管理、ReplicationやRPCの実行などを処理します。
(※ReplicationGraph.hの内容を和訳したものです) Replication Graph 高度なReplication Graphの概要 ・例えばノードの1つに"Spatialization Node(空間ノード)"があります。距離ベースの関連性を使用する全てのActorは、原則的にこのノードに移動します。そして常に関連性を持つノードもあります。ノードはグローバル/接続毎/共有(例:チームで常に関連するノード)することができます。 ・(Replication GrapahがEngineの従来の動作に対して及ぼす)主な影響は、AActor::IsNetRelevantFor()やAActor::GetNetPriority()などの仮想関数がReplication Graphで使用されないことです。その他、いくつかのPropertyについても使用されないか、使用方法が異なります。 ・ゲームコードからReplicationのこの部分に関与する方法として、基本的に以下の3つの方法があります。 Graphから返された後、ActorListは距離と周期についてさらに絞り込まれ、マージされて、優先順位が付けられます。最終的な結果は、Actor Channelを作成/更新するためのロジックを作成するためにソートされたActorのリストです。 プロジェクトで実装が必要な関数 ・UReplicationGraph::InitGlobalActorClassSettings ・UReplicationGraph::InitGlobalGraphNodes ・UReplicationGraph::RouteAddNetworkActorToNodes ・UReplicationGraph::InitConnectionGraphNodesUReplicationGraphの概要
・Replication Driverの実装です。これはUReplicationGraphをサブクラス化することでカスタマイズできます。デフォルトの実装(UReplicationGraph)は完全には機能せず、オーバーライドして利用することを意図しています。最小限の機能セットで"そのまま使える"最小限の実装についてはBasicReplicationGraph.hをご確認下さい。より高度な実装についてはShooterGame/UShooterReplicationGraphをご確認下さい。
・Graphはネットワーク接続ごとに複製リストを生成するノード群です。基本的に複製するActorの永続的なリスト(Persistent List)を保持してNetwork Connectionに送ります。これにより出来るだけ多くの処理を共有することができ、Actor数×接続数に対するシステムのスケーラビリティが大幅に向上します。
- Graph自身での定義:新しいUReplicationNodesを追加するか、ActorがGraphに配置される方法を変更する
- FGlobalActorReplicationInfo:RepGraphが所有する"全体に対してGlobalなActor毎の連想データ"
- FConnectionReplicationActorInfo:RepGraphが所有する「接続毎に保存されるActor毎の連想データ"
UReplicationGraphのSubClass(カスタムReplication Graph)においては以下の関数を実装する必要があります。
UReplicationGraph::GlobalActorReplicationInfoMapを初期化します。
CreateNewNodeを介して新しいUGraphNodesをインスタンス化します。
UReplicationGraph::AddGlobalGraphNodeは全ての接続に対してGlobalな場合に使用します。
・UReplicationGraph::RouteRemoveNetworkActorToNodes
指定のノードに対してActorの登録/破棄を実行します。もしくはノード自身からActorを収集します。
接続毎のノードを初期化します。もしくはAddConnectionGraphNodeを介して共有ノードに関連付けます。
UReplicationGraph InitForNetDriver InitNode InitGlobalGraphNodes InitConnectionGraphNodes AddGlobalGraphNode AddConnectionGraphNode RemoveConnectionGraphNode FindOrAddConnectionManager AddClientConnection CreateClientConnectionManagerInternal RemoveClientConnection SetWorld InitializeForWorld AddNetworkActor RouteAddNetworkActorToNodes RemoveNetworkActor RouteRemoveNetworkActorToNodes ForceNetUpdate FlushNetDormancy NotifyActorTearOff NotifyActorFullyDormantForConnection NotifyActorDormancyChange ReadyForNextReplication ServerReplicateActors ReplicateSingleActor HandleStarvedActorList UpdateActorChannelCloseFrameNum ProcessRemoteFunction IsConnectionReadyUReplicationGraphのAPI
コンストラクタです。グローバルデータの生成(FReplicationGraphGlobalData)、グローバル情報Mapデータ(GlobalActorReplicationInfoMap)生成します。
ReplicationDriverを初期化します。GlobalActorClassとGlobalGraphNodeの初期化、ClientConnetion(NetConnection)を追加します。NetDriverの初期化のタイミング(UNetDriver::InitBase)で呼び出されます。
指定のノードを初期化します。UReplicationGraphNodeを初期化して準備リストにノードを登録します。CreateNewNodeで新しいノードを作成した際に呼び出されます。
GlobalGraphNodeを初期化します(基本的にはオーバーライドして必要な処理を書く必要があります)。ReplicationDriver(UReplicationGraph::InitForNetDriver)のタイミングで呼ばれます。
ConnectionManagerの初期化処理、ActorがTearOffした際にハンドル対象を登録しておく必要があります。ConnectionManagerの生成時に呼ばれます。
GlobalGraphNodeを追加します。
ConnectionManagerにConnectionGraphNodeを追加します。
ConnectionManagerからConnectionGraphNodeを削除します。
指定のConnectionManagerを検索(無ければ追加登録)します。
ConnectionList(Connections)に登録します。
新しいConnectionManagerの生成と初期化します。
指定のNetConnectionをConnectionListから削除します。
ReplicationGraphのグローバルデータのWorldを登録します。
ReplicationGraph上の全てのNodeをリセットし、World上に存在するActorからNetworkActorを再取得します。
ActiveNetworkActorsリストに追加してGlobalInfoMapの情報を更新します。
全てのNodeにNetworkActorが追加されたことを通知します。
ActiveNetworkActorsリストから削除してGlobalInfoMapの情報を更新します。
全てのNodeにNetworkActorが破棄されたことを通知します。
Replication情報更新を指定のNetworkActorに通知します。
休止情報更新を指定のNetworkActorに通知します。
指定のNetworkActorがTearOffされたことをTearOffNodeへ通知します。
指定のNetworkActorが完全休止したことを通知します。
休止情報が変化したことを通知します。
次のReplicationの実行可能か結果を返却します。
ServerでのReplicationを処理します。NetworkActorの収集(優先付け、距離/周期のスケーリング、ゲームコードでのスケーリング、ソート)、接続毎のReplicate(PacketBudgetのトラッキング、ActorChannel監視、破棄情報の更新)などを処理します。UNetDriver::TickFlush、UNetDriver::ServerReplicateActorsから呼び出されます。
Actor単体のReplication処理を実行します。
欠損したActorリストを更新します。
ActorChannelの情報(Actorの欠損タイムアウト検出フレーム)を更新します。
RPCの呼び出し処理を実行します。
NetConnectionの送信準備が完了しているかの結果を返却します。
4.2. ReplicationConnectionDriver
UObject
UReplicationConnectionDriver // 接続毎のReplication拡張機能クラス
UNetReplicationGraphConnection // 特定の接続に対するActorReplicate管理クラス
特定の接続に対してActorのReplicationを管理するObjectです。ReplicationConnectionDriverが定義されている場合、ActorChannelが生成される際にReplication専用のConnectionを生成してReplicationを補完します。
UNetReplicationGraphConnection NotifyActorChannelAdded NotifyActorChannelRemoved NotifyActorChannelCleanedUp InitForGraph InitForConnection AddConnectionGraphNode RemoveConnectionGraphNode PrepareForReplication NotifyAddDestructionInfo NotifyRemoveDestructionInfo NotifyResetDestructionInfo NotifyClientVisibleLevelNamesAdd ReplicateDestructionInfosUNetReplicationGraphConnectionのAPI
コンストラクタですがここでは何もしません。
ReplicationActor情報に対象となるActorを追加します。
ActorChannelが破棄される際に呼び出されます。
ActorChannelがクリーンアップされる際に呼び出されます。内部的に保持しているReplicationActor情報をクリーンアップします。
ReplicationActorに対するReplicationGraph情報を初期設定します。
NetConnectionが持つReplicaitonGraphConnectionを設定し、ReplicationDebugActorを生成します。
ReplicationGraphNodeを追加します。
ReplicationGraphNodeを削除します。
Replicationを実行可能かどうかの結果を返します。
NetDriverでActor情報が破棄される場合に実行されます。PendingDestructInfoListに配置して後から破棄します。
PendingDestructInfoListに設定された情報を破棄します。
PendingDestructInfoListに設定された情報をリセットします。
ClientにLevelが追加された際に呼び出します。ActorのDormantOnConnectionを無効にしてレベルにストリーミング情報を通知します。
PendingDestructInfoList(破棄待ち情報)Replicateします。
4.3. ReplicationGraphNode
UObject
UReplicationGraphNode
UReplicationGraphNode_ActorListFrequencyBuckets // StreamingLevelに基づくActor管理用
UReplicationGraphNode_GridSpatialization2D // 空間分割時のCell管理用
UReplicationGraphNode_AlwaysRelevant // AlwaysReleventActor管理用
UReplicationGraphNode_ActorList // Actor管理用
UReplicationGraphNode_ConnectionDormanyNode // RepListから削除済みDormantActorの管理用
UReplicationGraphNode_DormancyNode // DormancyActor管理用
UReplicationGraphNode_GridCell // 空間分割時のActor管理用
UReplicationGraphNode_AlwaysRelevant_ForConnection // 接続毎のAlwaysReleventActor管理用
UReplicationGraphNode_TearOff_ForConnection // 接続毎のTearOffActor管理用
UShooterReplicationGraphNode_PlayerStateFrequencyLimiter // (ShooterGame) PlayerStateのRepFreq管理用
UShooterReplicationGraphNode_AlwaysRelevant_ForConnection // (ShooterGame) 接続毎のAlwaysReleventActor管理用
ReplicationのグラフノードでReplicationを行う条件をNode毎に設定することができます。
UReplicationGraphNode NotifyAddNetworkActor NotifyRemoveNetworkActor NotifyResetAllNetworkActors TearDown GatherActorListsForConnection PrepareForReplicationUReplicationGraphNodeのAPI
コンストラクタ、子Nodeに通知するための関数を設定します。
NetworkActorが生成された時、またはActorがReplicationStatusを変更した時に呼び出されます。
NetworkActorが破棄された時、またはActorが長い間Replicationを実行しない時に呼び出されます。
Worldが変更された時、またはすべてのサブクラスがここに複製されたActorに関する永続的なデータ/リストをDumpするときに呼び出されます (これが呼び出される前に新しい/次のWorldが設定されます)。
Nodeが破棄される際に実行する処理です。
各Nodeで処理すべきActorを収集します。
RequiresPrepareForReplicationCall=trueの場合、RootNode(UReplicationGraph::CreateNodeで作成されたNode)のみで、Replicationの前にフレーム毎に1度呼び出されます。
UReplicationGraphNode_ActorListFrequencyBuckets UReplicationGraphNode_GridSptilization2D UReplicationGraphNode_AlwaysRelevant UReplicationGraphNode_ActorList UReplicationGraphNode_ConnectionDormanyNode UReplicationGraphNode_DormancyNode UReplicationGraphNode_GridCell UReplicationGraphNode_AlwaysRelevant_ForConnection UReplicationGraphNode_TearOff_ForConnectionその他のGraphNode
ReplicateActorListsを含むノードです。NonStreamingLevelのActor用の複数のバケットが含まれて、交互のフレームで各バケットから引き出されます。広範囲の負荷のバランスをとる方法として利用可能です。
マップ上に存在するActorを空間管理するためのベースとなるノードです。空間管理にはワールド上をGridで分割して、2次元座標(X,Y)の情報を持つCellがそれぞれ配置されます。そこで生成されるCellは子ノードとしてUReplicationGraphNode_GridSpatialization2Dが割り当てられます。そしてCell毎に存在しているActorの情報をStatic/Dynamic/Dormancyとして管理します。
AlwaysRelevantActorを管理するためのノードです。
Actorの情報を持つ基本ノードです。
(接続されている)休止中のActorをReplicationListから削除するノードです。
MasterActorListの接続毎のコピーを保管します。完全に休止しているConnectionListから要素をSkipして削除します。
レベル上のActorを空間管理する際のCellノードです。空間分割された数だけこのノードが生成されてActorを管理します。
接続毎にAlwaysRelevantActorを管理します。4.21ではPlayerControllerとViewTarget(通常はpawn)を追加するだけです。
接続毎にTearOffActorを追加します。4.21ではPlayerControllerとViewTarget(通常はpawn)を追加するだけです。
4.4. ReplicationGraphDebugActor
AActor
AReplicationGraphDebugActor // RepGraph関連のデバッグをサポートするActor
Debug用のActorでRepGraphの様々なデバッグ機能を提供します。
5. ShooterGameのユースケース
ShooterGameにおけるReplication Graphの位置付けをざっくり示すと以下のようになります。
全ての機能はUShooterReplicationGraphに記載されていますのでご参考下さい。ノードの構成に関しては基本的に上記から変わりませんが、ノードに所属するActorは動的に変わります。
(※ShooterReplicationGraph.cppの内容を和訳したものです) 概要 ShooterGameの場合、ReplicationGraphによりActorの関連性が機能する方法が変わります。AActor::IsNetRelevantForはこのシステムでは使用されていません。代わりにUShooterReplicationGraphにはUReplicationGraphNodeが含まれています。これらのノードは、接続毎にReplicateするActorのリストを生成します。これらのリストの殆どはフレームを越えて持続します。これにより、殆どの収集作業(どのActorをReplicaitonの対象と見なすべきか)を共有/再利用することができます。ノードはグローバル(全ての接続で使用される)、接続固有(各接続が独自のノードを取得)、または共有(チームなど、同じチームで共有する全ての接続)のいずれかです。Actorは複数のノードに存在することができます。例えば、PawnがSpatilizationノードにあるだけでなく、AlwaysRelevantノードにある場合もあります。それは同じチームのメンバに2度返却されます。可能であれば最小化する必要がありますがこれは問題ありません。 "UShooterReplicationGraph"は意図的にゲームコードから使用されないようになっています。これは"ShooterReplicationGraph.h"を他のゲームコードに含める必要はありません。UShooterReplicationGraphはゲームコードに依存し、ゲームコードがブロードキャストするイベント(例:チームに登録/解除するプレイヤーのためのイベント)を登録します。これはUShooterReplicationGraphがActorのReplicationの全体像を把握するためです。一般的なPublic関数を公開するのではなく、ゲーム内のコードが呼び出すことができて全ての通知はUShooterReplicationGraph::InitGlobalActorClassSettingsに明示的に登録されます。 ShooterGameのノード ・UReplicationGraphNode_GridSpatialization2D ・UReplicationGraphNode_ActorList ・UShooterReplicationGraphNode_AlwaysRelevant_ForConnection ・UShooterReplicationGraphNode_PlayerStateFrequencyLimiter ・UReplicationGraphNode_TearOff_ForConnection 従属Actor(AShooterWeapon) 使い方 ・常に接続に関連するものにする デバッグ方法 ・Net.RepGraph.PrintGraph ・Net.RepGraph.PrintGraph class ・Net.RepGraph.PrintGraph nclass ・Net.RepGraph.PrintAll [Frames] [ConnectionIdx] ["Class"/"Nclass"] ・Net.RepGraph.PrintAllActorInfo [ActorMatchString] ・ShooterRepGraph.PrintRoutingShooterGame の ReplicationGraph
以下は現在使用されているノードにおける最上位に位置するノードです。
空間化ノードです。全ての距離基づく関連性を持つActorが登録されます。このノードはマップを2Dグリッドに分割します。グリッド内の各セルには更新/休止状態に基づいてActorのリストを保持する子ノードです。Actorは複数のセルに配置されます。接続はそれらが入っている単一セルから引き出されます。
常に関係のあるActorを含むActorListのノードです。これらのActorは常にあらゆる関係に関連しています。
接続毎に固有のAlwaysRelevantActorのノードです。このノードは永続リストを維持しませんがフレームごとに構築します。これらのActorは全てPlayerControllerから簡単にアクセスできます。永続リストでは、これらのActorが変更されたときに通知をブロードキャストする必要があります。これは可能ですが現在は不要です。
PlayerStateのReplicationを処理するためのカスタムノードです。これは小さなローリングセット(繰り返し実行するため)のPlayerState(2fに1回)をReplicateします。これはPlayerStateが再現するようにするためです。低い安定した周期で接続をシミュレートして共有シリアライズ機能を利用します。AutoProxyなPlayerStateはより高い周期でReplicateされます。
UShooterReplicationGraphNode_AlwaysRelevant_ForConnectionによる所有接続のみ)
TearOffするActorを処理するための接続毎の固有のノードです。これはReplication Graphの基本実装で作成および管理されます。
Replication Graphは、依存するActorのReplicationの概念を導入します。これは別のActorがReplicateする時にのみReplicateするActor(AShooterWeapon)です。つまり武器のActor自体は決してReplicationGraphに入りません。それは自分自身で収集することもなく、優先順位が付けられることもありません。PawnがReplicateしたときに複製する機会があるだけです。武器のActorのために特別な作業をする必要がないのでグラフをより小さくします。UShooterReplicationGraph::OnCharacterWeaponChangeを参照してください。これはActorが依存するActorリストに追加または削除される方法です。
・何か必要な場合は避けてください
必要な場合はクラスデフォルトでAActor::bAlwaysRelevant=trueを設定するだけで問題ありません。
UShooterReplicationGraphNode_AlwaysRelevant_ForConnection::GatherActorListsForConnectionを変更する必要があります。これはActorが他のノードの1つに入れられないようにするためです。これを行う最も安全な方法は、UShooterReplicationGraph::InitGlobalActorClassSettingsでEClassRepNodeMappingをNotRoutedに設定することです。
問題がシステム固有のものか、もしくは一般的なReplicaitonやGamePlayの問題であるかを確認するにはReplicaiton Graphを無効にすることをお勧めします。問題がReplication Graph関連であれば、利用可能なコンソールコマンドがあります。ReplicationGraph_Debugging.cppをご覧ください。ClientからServer上で実行するには"Cheat"コマンドを使用してください。
グラフをログに出力します(ノードと所属するActor)。
上記と同じですがクラスごとにグループ化されます。
上記と同じですがネイティブクラスでグループ化されます(Blueprintのノイズを隠します)。
グラフ全体、収集したActor、x個のフレームに対して与えられた接続に対してそれらがどのように優先されたかを表示します。
Actor/Classに関連付けられているクラス、グローバル、および接続毎のReplication情報を出力します。MatchStringが空の場合、全ての情報が出力されます。クライアントから直接呼び出します。
各クラスのEClassRepNodeMappingを出力します。特定のActorがReplicaiton Graphでどのように接続されるか(またはルーティングされないか)です。
ShooterRepGraph.DestructInfo.MaxDist (30000.f) ShooterRepGraph.DisplayClientLevelStreaming (0) ShooterRepGraph.CellSize (10000.f) ShooterRepGraph.SpatialBiasX (-150000.f) ShooterRepGraph.SpatialBiasY (-200000.f) ShooterRepGraph.DynamicActorFrequencyBuckets (3) ShooterRepGraph.DisableSpatialRebuilds (1)ShooterGame の ReplicationGraphDebug
FActorDestructionInfoとReplicateするConnectionとの間の最大距離を上書きします。実際の値はこの値の2乗の値が適用されます。
有効な場合、レベルに追加されたActorの情報をログに出力します。
UReplicationGraphNode_GridSpatialization2DのCellSizeを設定します。この値が空間分割におけるCellのXYの大きさとなります。
基本的に"Min X"はReplicate用の初期値です。 Actorがこの外に出現するとシステムは自動的にリセットされます。
基本的に"Min Y"はReplicate用の初期値です。Actorがこの外に出現するとシステムは自動的にリセットされます。
動的に空間的なActorを広めるBuket数を定義します。これは個々のActorが独自のNetUpdateFrequencyチェックを行う前に発生します。
この値が有効な場合、すべての空間の再構築(SpatilRebuildBlacklist)を無効にします。
6. Console Command
Replication Graphで提供されるConsole Commandについて以下に示します。
Net.RepGraph.DrawGraph
GraphNodeの構造をHUDに出力します。
Net.RepGraph.PrintGraph
GraphNodeの構造をログに出力します。
(※全てを実証していませんがおおよそこの通りです) Net.RepGraph.Pause (0) Net.RepGraph.Frequency (0.00f) Net.RepGraph.UseLegacyBudget (1) Net.RepGraph.FixedBudget (0) Net.RepGraph.SkipDistanceCull (0) Net.RepGraph.PrintCulledOnConnectionClasses (0) Net.RepGraph.PrioritizedLists.Print [ConnectionIdx] Net.RepGraph.TrackClassReplication (0) Net.RepGraph.PrintTrackClassReplication (0) Net.RepGraph.Verify (0) Net.RepGraph.TrickleDistCullOnDormanyNodes (1) Net.RepGraph.EnableRPCSendPolicy (1) Net.RepGraph.LogNetDormancyDetails (0) Net.RepGraph.LogActorRemove (0) Net.RepGraph.LogActorAdd (0) Net.RepGraph.Lists.DisplayDebug Net.RepGraph.PrintAllActorInfo [MatchString] Net.RepGraph.PrioritizedLists.Print [ConnectionIdx] Net.RepGraph.PrioritizedLists.Draw [ConnectionIdx] Net.RepGraph.PrintAll [Frames] [ConnectionIdx] ["Class"/"Num"] Net.PacketBudget.HUD Net.PacketBudget.HUD.Toggle Net.RepGraph.Lists.Details Net.RepGraph.StarvedList [ConnectionIdx] Net.RepGraph.Lists.Statsその他のコンソールコマンド
ReplicationGraphのActorReplicationを中断します。
ReplicationManagerが有効な場合、Replicationの周期を指定します。0の場合はレガシーなNetDriverの実装を使用します。
レガシー実装におけるバジェットを指定します。
固定されたバジェットを指定します(Bits/frame)。
有効な場合、ReplicationGraphにおけるNetworkDistanceCullingをスキップします。
有効な場合、カリングされたConnectionClassを出力します。
有効な場合、ClassのReplicationをトラッキングします。
有効な場合、ClassのReplicationトラッキング結果を出力します。
有効な場合、ActorがNodeに追加された際にActorの検証を実行します(処理速度が低速なためデフォルトはOFFとなっています)。
有効な場合、距離CullingされたDormancyノードに所属するActorはDormancyノードをリセットします。
有効な場合、RPC送信ポリシーを有効にします(例:特定の関数をキューに入れるのではなく即時送信します)。
有効な場合、Replication Graph/Nodeの処理におけるDormancy情報の詳細ログを出力します。
有効な場合、Replication Graph/NodeからActorが削除されたことをログ出力します。
有効な場合、Replication Graph/NodeにActorが追加されたことをログ出力します。
RepActorListのstatsをHUDに出力します。
MatchStringを含むパス名を持つActorに関するグローバルおよび接続固有の情報を出力します。クライアントから呼び出すことができます。
優先順位付けされたReplicationListを出力してログに出力します。
HUD上の優先順位付きReplicationListを描画します。
指定されたFramesに対して、指定されたConnectionIdxのレプリケーショングラフと優先順位付きリストを出力します。
Packet Budgetの詳細をHUDに出力します。
Packet Budgetの詳細をHUDに出力する際の停止/更新を切り替えます。
拡張されたRepActorListの詳細をログに出力します。
ActorのStarvedListをHUDに出力します。
RepActorListのstatsをログに出力します。
7. まとめ
ReplicationGraphは、Replicationを効率的に管理できて通信コストを削減するのに役立ち、Replicationの管理状況が把握しやすいという面でのメリットがあります。しかしながら、ゲームに併せて適切に設定・拡張しないと不都合が発生する可能性もあるという点や、ReplicateするActorが少ない場合はパフォーマンス改善の効果が大きくありません。よって、この機能を利用する際には、コンテンツに適合するかどうかを予め検討した上で、コンテンツとReplicationGraphで実現する内容を良く把握した上でご利用下さい。