Mercurial > hg > Papers > 2022 > riono-master
view Paper/chapter/2-RewriteCS.tex @ 21:866f4329e430
title fix and add Continuation section
author | riono <e165729@ie.u-ryukyu.ac.jp> |
---|---|
date | Mon, 31 Jan 2022 17:01:47 +0900 |
parents | d550ccb7f803 |
children | 06daf5e1e9de |
line wrap: on
line source
\chapter{ChristieのC\#への書き換え} \section{Unity} UnityはUnity Technologiesが開発、公開しているゲームエンジンである。 画像や3Dモデルの表示、物理演算、UIのイベント機能などゲーム制作に必要な機能が標準で備わっており、 個人でもゲーム開発が可能となっている。 さまざまなプラットフォームに対応可能であり、PC、iOS、Androidやその他コンシューマ機器も開発可能である。 また、非常に動作が軽いことも特徴であり、スペックが低いノートPCでも十分ゲーム開発が可能である。 プログラミング言語としてはC\#がサポートされている。 最新バージョンである2021.2.8ではC\# 9がサポートされており、 .NET Frameworkはバージョン4.6に対応している。 C\#向けの既存のAPIや外部ライブラリ、Unity用に開発されたAPIなども使用可能である。 拡張性が高く、開発に必要な機能を作成しUnityのメニューから実行することも可能である。 本研究では、開発環境を整えるためのハードルの低さ、公開されている通信ライブラリの豊富さなどを考慮しUnityを採用した。 Unity上でChristieを動作させるために、Javaで記述されているChristieをC\#に書き換えを行う。 \section{Christie Sharpの書き換えの基本方針} Javaで記述されたChristieと区別するため、C\#で記述するChristieをChrisite Sharpとする。 Chrisite Sharpではコードの保守性や、Christie設計時の意図などを守るため、Chrisiteと同じ挙動、同じ動作をする必要がある。 初めにC\#単体で動作するように、Christieの核となる部分の書き換えを行った。 ChristieはJava 9から開発されていたため、現在では非推奨なコードやバージョンアップが必要な箇所が存在する。 そこで書き換えを行う際に、C\#に対応しつつ処理動作の向上や最適化を行うために以下の改良を行った。 \begin{itemize} \item MessagePackの変更及びバージョンアップ \item ThreadPoolからTaskへの変更 \end{itemize} \section{attributeの実装} ChristieではDGを取得する際に、annotationを用いてTakeやPeekなどのコマンドを処理していた。 Christie Sharpはannotationではなく、代わりにattributeを利用してコマンドの処理を行っている。 \lstinputlisting[label=src:JavaTakeImple, caption=JavaにおけるTake annotationの実装]{src/java/Take.java} \lstinputlisting[label=src:CSTakeImple, caption=C\#におけるTake attributeの実装]{src/cs/Take.cs} ソースコード\ref{src:JavaTakeImple}はJavaにおけるTake annotationの実装である。 Javaでannotationを自作する際には、\@interfaceで宣言を行う。 1行目ではannotationの適用可能箇所を指定しておりフィールド変数に対して付与可能としている。 また、2行目はannotationの情報をどの段階まで保持するかを指定しており、Takeの場合JVMによって保存され、ランタイム環境で使用可能となっている。 ソースコード\ref{src:CSTakeImple}はC\#におけるTake attributeの実装である。 C\#でattributeを自作する際には、System.Attributeを継承する必要がある。 attributeの適用可能箇所については、1行目にてフィールド変数を指定している。 attributeの使用方法はannotationと同じく変数の宣言の前に、[ ]内に使用するattributeを宣言する(ソースコード\ref{src:CSTakeExample})。 \lstinputlisting[label=src:CSTakeExample, caption=Take attributeの例]{src/cs/TakeExample.cs} \section{TaskによるCodeGearの処理} ChrisiteではCGの実行にThreadPoolを利用していた。 しかしThreadPoolは管理や生成が煩雑であり、コストパフォーマンスの低下につながりやすい。 C\#にはThreadをより使いやすく高機能にしたTaskという機能がある。 TaskはC\#のThreadPoolを拡張しており、内部にThreadPoolと実行待ちQueueを持っている。 Task.RunメソッドやTask.Factory.StartNewメソッドで処理を実行でき、処理が渡されるとThreadPoolで処理されるため、Christieと同じ動作をすると考え、Christie SharpではTaskで書き換えを行った。 \lstinputlisting[label=src:JavaThreadPoolExecutor, caption=ChristieにおけるThreadPoolの実装の一部]{src/java/ThreadPoolExecutor.java} ソースコード\ref{src:JavaThreadPoolExecutor}はChristieにおけるCodeGearを処理するThreadPoolの実装の一部である。 Javaでは独自にThreadPoolを実装する際にはThreadPoolExecutorを継承する。 またThreadの優先度を変更する機能が実装されており、CodeGear実行時に処理の優先度を設定することが可能となっている。 \newpage \lstinputlisting[label=src:CSThreadPoolExecutor, caption=Christie SharpにおけるThreadPoolの実装]{src/cs/ThreadPoolExecutor.cs} ソースコード\ref{src:CSThreadPoolExecutor}はソースコード\ref{src:JavaThreadPoolExecutor}をC\#に書き換えを行ったものである。 CGの実行には14行目のExecuteを呼び出し、Taskで実行を行っている。 Threadの優先度による実行順変更については、実装の優先度が低かったため今回は実装を行っていない。 Taskのスケジューラーは自作可能であり、実行待ちQueueの処理順を変更することができるため実装可能である。 \section{Socket通信用のThreadをTaskに変更} Christieでは、Socket通信を行っている箇所もThreadを使用したmulti Threadで動作している。 こちらも可読性や保守性のためTaskへの書き換えを行った。 \lstinputlisting[label=src:JavaAcceptThread, caption=ChristieにおけるAcceptThreadの実装の一部]{src/java/AcceptThread.java} ソースコード\ref{src:JavaAcceptThread}はChristieにおけるSocket通信を行っているThreadの実行箇所である。 無限ループを行い、他nodeがSocketで接続される度にデータ送受信専用のThreadを作成する。 IncomingTCPConnectionではデータの受け取りを行っており、OutboundTCPConnectionではSocket通信が終了する際のコマンドの送信をそれぞれmulti Threadで行っている。 \lstinputlisting[label=src:CSAcceptThread, caption=Christie SharpにおけるAcceptThreadの実装の一部]{src/cs/AcceptThread.cs} ソースコード\ref{src:CSAcceptThread}はソースコード\ref{src:JavaAcceptThread}をC\#に書き換えを行ったものである。 Christieでは、Socket通信のためにmulti Threadを用意していた。 \section{MessagePackの変更} \section{送信データの修正}