きかいや。

機械といいつつだいたいプログラミングのはなし

MFT2014でHPASim(OculusRift対応版)を出した話

この記事はOculus Rift Advent Calendar 2014 の7日目の記事になります。

Maker Faire Tokyo 2014 | Maker Faire Tokyo 2014 | Make: Japan

に、「はかるひと」という出展内の一企画として、人力飛行機シミュレータ HPASimを出展してきました。(はかるひと、というのは慣性センサをロケットや人力飛行機や鳥にくっつけて、飛びもののセンサ計測を趣味や仕事でやっているひとたちの集まりです。)

今回はこのレポートというか、ここに至るまでの忘備録です。何を考えてこんなものを作っているか、という話になります。Oculusのカレンダーですが、人力飛行機の話や筐体側を作るうえでの話、体験会での注意点的なものが多くなっています。適宜飛ばして読んでいただければ。

 

1.HPASimって何?なんで作ったの?(人力飛行機の話)

人力飛行機シミュレータ(Human Powered Airplane Simulator)といいます。
人力飛行機はペダルをこぐ力でプロペラを回し、空を飛ぶというものです。傍から見ると漕ぐのが大変そうなのはわかるのですが、その操縦性が難しいことはあまり知られていないと思います。慣性が大きく応答が悪いため、飛行機の動きを予測して早めに舵を切らないといけないのです。たとえるなら、ハンドルを切ってから2秒後にやっと曲がり始める車みたいなモノです。(パイロットは筋肉だけ鍛えればいいというものではない)

 昔コレの設計と製作をしていたのですが、その操縦性の悪さにもかかわらず、操縦練習できるシミュレータがこれといって公開されていませんでした(滑空機のシミュレータはいくつかあったのですが、プロペラ機のモノがない。あっても研究室のものだったり、あそこが持っているらしいという話くらい)。パイロットはラジコン飛行機を飛ばしたり、グライダーに乗せてもらったり、市販のフライトシミュのパラメータをいじったりしてそれっぽい動きの飛行機をつくり練習をした後、最後は実機で操作を体得するという流れでした。人力飛行機は出来上がったら荷重試験や重心調整をしたのち、自家用飛行機の滑走路などを使ってテストフライトを行っています)。FlightGear,MSFS,RealFlightのような一般機のフライトシミュの特性を書き換えるのは割と面倒で、真面目に合わせようと思うと飛行機の運動特性を自前で計算してやることになり、この計算が面倒です。スタートボタンを押したらすぐ飛べて練習できる、そんなシミュレータがあればなぁ、という思いからDXライブラリでシミュレータを作りました。そしてOculusRiftを知り、コレを使えばとてもいい練習用のシミュレータになるだろう、と考えて作りました。

あと、アレって基本的にパイロットの専用機なので、作ってるほかの人は乗れないんですよ。せっかく作ったら自分も乗ってみたくなるじゃないですか、アレ。(本音)

f:id:machinemaker:20141207200652j:plain

( こんな筐体に乗ってペダルをこぐと、画面内の飛行機が飛びます)


流れとしては
DXライブラリ+MMDモデルで作成、twitterで公開 -> MFT2013で展示 -> OculusRift(DK1)購入 -> Unityで作り直す ->Oculus Rift(DK1)対応 -> Ocufes(秋葉原大好き祭り)展示 -> ペダル連動するよう筐体作成 -> 裏オキュフェス2で発表 -> OculusRift(DK2)購入->mbed祭り2014@夏の東銀座【一般参加枠】 - mbed祭り | Doorkeeperで飛び入り発表 -> ポジショントラッキング対応、筐体作り直し -> MFT2014で展示

と変遷をたどっています。

 

2.設計コンセプト
設計コンセプトは以下のようにしています。

  • 没入感を高め、また視界を忠実に再現するため、パイロットのアバターを表示する( ポジショントラッキング対応とアバターのIK対応
  • 操縦系/操縦方法を人力飛行機のものに合わせることで、実機への乗り換えをシームレスに行う。
  • デモンストレーションで持ち運び可能なように設計する。(解体・組立・輸送)
  • 特殊な工作具を使用しないでも作れる(というか使えない)

 

3.機器構成

MFTやOcufesでは、体験してもらってハイ次のひとー、という形になってしまったので、あまり技術面の話をじっくりできませんでしたので、ここに。(mbed祭りや裏Ocufesではその辺の話もしていたので、特色が出ますね。)

  • 筐体構成
    フレーム:棚を作るためのL字アングルで構成
    椅子:座椅子を分解してフレームを取り出し、金具でフレームに固定。園芸用のアルミの台を上において、下にクッションゴムを敷き詰めて荷重を床に逃がしています。(MFT2014はビッグサイトで行われ、防火法のため装飾の布類に防炎証明が必要でした。展示物は法律上別扱いとも聞いたのですが、筐体はできるだけ金属や塩ビなど燃えないもの、自己消化性をもつもので構成しました)

    操縦:
    ペダル入力…ペダルをこぐとプロペラが回ります。ペダルにはコレ

    Amazon.co.jp | ながら エクササイズ フィットネス 足 こぎ ペダル ローラー | スポーツ&アウトドア 通販

    を使っています。右ペダルにフォトインタラプタと回転盤、左ペダルに磁石とホールセンサがついています。回路の項で後述。
    尾翼・補助翼(ラダー・エレベータ・エルロン):飛行機の水平尾翼垂直尾翼主翼についている補助翼を操作することで機体のロール・ピッチ・ヨーを制御できます。ここはジョイパッドですが、操縦桿にしたいですね。

  • 回路
    マイコン:mbedマイコンのコレ


    mbed NXP LPC1768 + Starborad orange 【きばん本舗SHOP】

    を使用しています。今回はシリアル通信とセンサのOn/OFFしか見ていないので、ここまで高級なマイコンとボードを使うこともないのですが、扱いやすさや今後の拡張性からコレを使用しています。あと、実機も最近はフライバイワイヤの機体はサーボで尾翼やエルロンを動かし、エンコーダで足元の回転数を見ていたりするので、その基板をそのまま使えるというのが理想的です。車でもそうですが、シミュレータは操縦桿やペダルなどをその操縦系と同じものを使うのが理想だ、という考えが根底にあります。(あとArduinoやH8ではなくmbed推しなのは、AVRは遅い、H8はレジスタのセットアップが面倒という研究室時代にうえつけられた悪夢イメージと、開発環境のインストールが不要でmbedのクラウド開発環境にソースもコンパイラも置いてあるというのが非常に便利なためです。あとCではなくC++で書けるのと、レジスタ周りをみなくても簡単に使えるので良い。ほかの人が作ったクラスやコードのインポートがボタン一発で終わって、ボタンを押せば実行ファイルがダウンロードできて、USBでD&Dで書き込まれるの、楽すぎます。あと、mbedクラスタtwitterにいるので、割と人に聞きやすいです。mbed派増えないかなぁ、Oculusクラスタ。)

    センサ:

     

    f:id:machinemaker:20141207210051j:plain


    ホールセンサ…回転位置のリセット(キャリブレーション)用です。左のペダルに磁石(画像にある、ペダルのパイプについてる黒いやつ)がついており、磁石の通過を検知すると回転の絶対値をリセットします。これがあることで、お客さんはキャリブレーション用の動作なく、知らないうちにリアルの脚の回転とVRの脚の回転が一致します。(今見たら、ディスコンになってる…)

    f:id:machinemaker:20141207205333j:plain

    f:id:machinemaker:20141207211600j:plain


    フォトインタラプタ…画像の黒いやつです。光がさえぎられてのを検出し、回転角度に変換します。空間分解能は2°です。VRでは時間・空間的分解能が低いとアニメーションががくがくして、思いのほか体験の質が低下します。鋏とカッタで作れる中でできるだ歯(スリット)を増やそうとしてこのような直径300mmの大円盤になっています。また、分解能が高ければ人力飛行機的には脈動も見ることができるので、漕ぎ方自体の練習にもなるのではないかな、とも。
    (90パルス2逓倍で分解能2°、A層、Z層のみのロータリエンコーダとなっているので、逆回転させても正転しているように認識しますが、自転車を逆さに漕ぐこともあまりないこと、A層に対して1/4周期ずらしたB層用の回転盤をうまく固定できないし壊れたら直せないだろうということから、このようになっています。ホットメルトで固定してあったのですが、展示中数回この円盤は外れました。最後はガムテ固定でどうにかしました)
  • ソフト
    Untiy4.5.4+Oculus SDK 0.4.2で開発しました。PCがASUS


    ノートパソコン - U24A - ASUS
    で、グラフィックオンボードチップ(Intel4000HD)の、DK2には心もとないスペックです。そのためエフェクトの類を極力きり、DirectモードでFPS75を維持しています。Oculus Riftの体験の質を上げているのは何よりも、人の動きに対する画面の追従速度で、立体視や解像度などおまけに過ぎません。なので、最近のデスクトップPCなら問題なく動くはずです。
    Oculus Riftの体験の質を上げているのは何よりも、人の動きに対する画面の追従速度で、立体視や解像度などおまけに過ぎません。大事なことなので二回書きました。これだけ覚えておけばOKです。

4.これまで展示をしてきて感じたことなど

  • A.筐体と回路は頑丈に、きれいに作ろう
    mbed祭りに参加するまで、ブレッドボード上で回路を組んでいたのですが、mbed祭りでは輸送中に壊れました。また体験会中にDK2の配線が絡みまくりました。ペダルもフレームなしでおいていただけだったので、ガタンガタンと前後左右にズレて漕ぎづらそうでした。この時MFTへの参加が決まっていたころだったので、「このままだとあの規模の体験会だと確実に壊れるぞ」と感じて基板、筐体ともにちゃんと作りました。またフレームの角でけがをしないよう、各所養生やゴムで保護などをしています。
  • 無線と有線
    裏オキュフェスまでは、mbedとPCはbluetooth接続だったのですが、春のVR/AR祭りに出そうとした際、PCとの相性(デモ用PCがほかの人のだった)、会場の電波の込み具合(ワイヤレスLANだらけだったらしい)からか、接続できず封印されていたということがあったので、MFTでは有線にしています。電波が込み合う会場の場合、無線で通信しているものはこの辺リスクになります。
  • 運び込むことを考えよう
    デモ用に作っているため、自分で輸送できることが大切です。そのため車に運び込めるサイズに抑えること、分解組立が可能なようにしています。大きいですが、できるだけ軽く作ったので一人で持ち上げることもできます。ビッグサイトに運ぶ際は、コレをもって階段を上っていたので、周りの人に心配されたり奇異の目で見られたりしました…
    あと、平地移動用にキャスターが付け外しできるようにしています。
  • ゲーブルが引っかからないようにしよう

    f:id:machinemaker:20141207212341j:plain

    f:id:machinemaker:20141207212332j:plain
    Oculus Rift DK2はケーブルお化けです。ワイヤーが絡んだり、人がひっかけたりして大参事になります。あと今回のモノは人の脚で動かす非電動器具とはいえ回転モノな ので、巻き込みに気を付けなければなりません(本当は回転部を露出しないようにフルカバーしたかったところです。巻き込みそうな服装でないかは一応チェッ クしてました)。なので、ケーブル類はスパイラルケーブルでまとめ、フレームにケーブルタイやテープなどで固定しています。センサ系のワイヤーはコレで固定しています。USBハブを使ってPCと接続 するようにすると、ハブのケーブルだけを扱えばいいのでセットアップが楽です。

  • 展開性
    組みあがり状態で車に積めるので、現地ではUSBハブを二個PCとつなぎ、カメラの脚立を置くだけでセットアップ完了です。運び込める時間が決まっているので、展開・撤収が速いと楽です。
  • 説明書をタイトルで表示
    説明書をタイトル画面で表示していました。が、一人5分とかの体験だと、そもそも操作を複雑にしないことが肝心だろうなぁ…。説明だけで1分かかったりするので。展示会によっては「漕ぐだけ」のような形でもありじゃないかなと思っています。
  • 難易度調整
    本物のパラメータに比べ、思いっきり操縦をしやすくしています。1月のocufesでは5割程度のクリアだったのですが、7-8割くらいの人はクリアできるようでした。1月のocufesで展示するまえ、昔人力飛行機を一緒に作っていた人たち(パイロット、非パイロット)に使ってもらったところ、パイロットには「本物より操作しやすい」と言われたものの、それ以外の人たちはほとんどすぐに墜落しました。なので、体験会にもっていくたびに機体パラメータを甘めに書き換えていっています(具体的には、尾翼の位置を本物よりだいぶ後ろにあるように計算させている。また、上反角を実際よりかなり大きくしている)。やはり展示会によっては「漕ぐだけ」のような形でもありじゃないかなと思っています。難易度を選択できるようにしておくべきかな。
  • 制限時間など
    制限時間制、リトライN回まで、みたいにしてあらかじめ説明すると、買い移転率良く回せると思います。
  • キャリブレーション
    カメラの位置のリセット機能を必ずつけましょう。最新版でのやり方はこちらで紹介されています。SDK0.4.2でもCameraConrollerの中にRecenterPose()があるので、それを呼ぶとカメラの位置姿勢がリセットされます。

4.今後

まずは操縦桿が付けたいですね。それから、滑走路を走っているときの振動をフィードバックして離陸時にフッと振動が消える感じを出したり、ペダルの負荷をシミュレーションと連動させてやりたいです。ものが大きいので、展示機会が限られるのですが、そのうちまた何かに出したいと思います。
シミュレータソフトのアップロードは準備中なので、ちょっと待っていていただければ…SDKのアップデートが激しすぎてついていけない!