本発明の実施形態における自律飛行ロボット1は、図1の概観図に示すように、クアッドロータ型の小型無人ヘリコプタである。なお、本発明の適用範囲は、クアッドロータ型の小型無人ヘリコプタに限定されるものではなく、シングルロータ型の小型無人ヘリコプタについても同様に適用することができる。
自律飛行ロボット1は、図2のシステム構成図に示すように、外部の警備センタ100や管理装置102と通信し、移動空間内に存在する所定の移動物体を目標対象物Mとして追跡し、当該目標対象物Mに対して所定の機能を発揮するように構成されている。目標対象物Mとなる移動物体は、例えば、監視領域内に侵入した人物(賊等)や車両等である。本実施形態では、所定の機能として、目標対象物Mを撮像する機能を例に説明するが、特に限定されるものではなく、目標対象物Mに対して音を発したり、発光による警告を行ったりする等の機能であってもよい。
警備センタ100と管理装置102とはインターネット等の情報通信網110を介して情報伝達可能に接続される。また、自律飛行ロボット1と管理装置102は、無線通信等によって情報伝達可能に接続される。
警備センタ100は、管理装置102を介して自律飛行ロボット1と通信を行い、自律飛行ロボット1によって撮像された目標対象物Mの撮像画像を受信する。警備センタ100は、撮像画像に対して画像処理を行い、警備センタ100にて異常監視している管理者等(図示しない)に警告を発するような機能を備えていてもよい。また、管理装置102から目標対象物Mの位置(座標)に関する情報を受信し、当該目標対象物Mと自律飛行ロボット1によって撮像された撮像画像とを関連付けて管理するというような機能を備えてもよい。
管理装置102は、地面や壁面等に設置された固定型の目標対象物検出センサ104(104a,104b・・・)、風速計105(105a,105b・・・)を備え、目標対象物Mの位置を検知する。目標対象物検出センサ104は、例えば、レーザセンサとすることができる。レーザセンサは、一定の角度サンプル間隔の角度毎にレーザを二次元的にスキャンすることによって、地面(又は床面)から一定の高さの水平面における検知範囲内に存在する物体(障害物)との距離情報を極座標値として取得する。レーザセンサは、放射状にレーザ光である探査信号を走査し、物体に反射して戻ってきた探査信号を受信して、送信と受信の時間差から物体までの距離を算出し、レーザセンサの設置位置の座標及び探査信号を送信した方向と算出した距離から当該物体の位置の極座標値を求め、当該極座標値から3次元の直交座標値(Xt,Yt,Zt)を求める。管理装置102は、目標対象物検出センサ104によって求められた物体の位置を目標対象物Mの位置として自律飛行ロボット1へ送信する。自律飛行ロボット1は、目標対象物Mの位置を受信すると、その位置に基づいて自らの移動経路を算出し、当該移動経路に沿って移動する。なお、管理装置102は、レーザセンサの検知範囲が重複する領域に存在する目標対象物Mの同一性を検証することで複数のレーザセンサの検知範囲に渡る目標対象物Mの追跡を行う。すなわち、レーザセンサ104aの検知範囲に存在する目標対象物Mがレーザセンサ104bの検知範囲に移動したとしても、管理装置102は、当該目標対象物Mが同一の物体であると判定することができる。
また、管理装置102は、地面や壁面等に設置された固定型の風速計105(風測定手段)を複数備え、移動空間内の各位置における風速(風の強さ)を測定することができる。本実施形態では、風速計105は、図2に表すようにプロペラ等の回転子を利用し、プロペラの回転数により風速を換算する機械式の風速計105を利用している。しかし、これに限らず、超音波方式やレーザードップラー方式などを利用した電気式の風速計を用いてもよい。また、風速計105を自律飛行ロボット1自身が搭載してもよい。この場合、自らの移動速度などの移動制御に係る情報を考慮して風速計105の出力を補正し、実際の風速に近い値を求めることが好適である。さらに、自律飛行ロボット1が風速計105を備えずに、自律飛行ロボット1の無風時におけるモータ4の制御指令値とこの場合における移動距離・移動速度の値とを予め測定しておき、現時点のモータ4の制御指令値と実際の移動距離・移動速度の値とを求め、両者を比較することにより、現時点の風速を推測してもよい。管理装置102は、風速計105によって求められた風速を自律飛行ロボット1へ送信する。自律飛行ロボット1は、風速を受信(または計測)すると、後述するように記憶部8に風速情報82として記憶し、風速の大きさに基づいて移動経路を算出し、当該移動経路に沿って移動する。
以下、図1の概観図及び図3の機能ブロック図を参照して、自律飛行ロボット1の構成及び機能について説明する。
自律飛行ロボット1は、図1に示すように、4枚のロータ(プロペラ)2(2a〜2d)を一平面上に有する。各ロータ2は、バッテリ(二次電池:図示しない)により駆動されるモータ4(4a〜4d)を用いて回転させられる。一般的に、シングルロータ型のヘリコプタでは、メインロータによって発生する反トルクをテールロータが生み出すモーメントで相殺することによって方位角を保っている。一方、自律飛行ロボット1のようなクアッドロータ型のヘリコプタでは、前後・左右で異なる方向に回転するロータ2を用いることで反トルクの相殺を行っている。そして、各ロータ2の回転数(fa〜fd)を制御することにより、様々な機体の移動や姿勢の調節を行うことができる。例えば、機体をヨー方向に回転させたいときは、前後のロータ2a、2cと左右ロータ2d、2bの回転数に差を与えればよい。
撮像部3は、例えばレンズなどの光学系および所定画素(例えば640×480画素)のCCDやCMOSなどの2次元アレイ素子を有する二次元イメージセンサで構成され、移動空間の撮像画像を所定の時間間隔で取得するいわゆるカラーカメラである。本実施形態では、撮像部3は、その光軸が自律飛行ロボット1の正面方向を撮像するよう筐体部分に設置され、かつ、水平面(XY平面)から予め定めた俯角θにより斜め下方の空間を視野角φにおいて撮像するよう設置されている。取得した撮像画像は後述する制御部7に出力され、制御部7により記憶部8に記憶されたり、後述する通信部9を介して管理装置102に送信されたりする。
距離検出センサ5は、自律飛行ロボット1の周囲に存在する障害物と自律飛行ロボット1との間の距離を検出し、センサ検出範囲内に存在する障害物の相対的な位置を取得するセンサである。本実施形態では、距離検出センサ5としてマイクロ波センサを備える。マイクロ波センサは、空間にマイクロ波を放出し、その反射波を検知することによって、自律飛行ロボット1の周囲にある物体を探知し、その物体までの距離を求める。距離検出センサ5は、例えば、自律飛行ロボット1の前方に向けて設け、目標対象物Mまでの距離を測定するために用いることができる。また、距離検出センサ5は、例えば、自律飛行ロボット1の下部に下向きに設け、地面との距離(高度)を測定するために用いることもできる。また、距離検出センサ5は、例えば、撮像部3の光軸方向に向けて設け、撮像部3の撮像対象物である目標対象物Mまでの距離を測定するために用いることができる。
位置検出センサ6は、自律飛行ロボット1の現在位置を取得するためのセンサである。位置検出センサ6は、例えば、GNSS(Global Navigation Satellite System)等の航法衛星(人工衛星)から送信される電波(航法信号)を受信する。位置検出センサ6は、複数の航法衛星(人工衛星)から送信される航法信号を受信して制御部7へ入力する。なお、位置検出センサ6は、レーザスキャナ、ジャイロセンサ、電子コンパス、気圧センサ等の他のセンサを用いて既知の従来技術により自己位置を得るための情報を取得するものとしてもよい。
通信部9は管理装置102との間で、例えば無線LANや携帯電話回線等により無線通信するための通信モジュールである。本実施形態では、撮像部3によって取得した撮像画像を通信部9により管理装置102に送信し、当該撮像画像を管理装置102から警備センタ100に送信することにより、警備員等が遠隔から侵入者を監視することを可能にする。また、通信部9は、管理装置102から目標対象物Mの位置(座標:Xt,Yt,Zt)を受信することにより、後述するような移動経路の設定を可能にする。
記憶部8は、ROM(Read Only Memory)、RAM(Random Access Memory)、HDD(Hard Disk Drive)等の情報記憶装置である。記憶部8は、各種プログラムや各種データを記憶し、制御部7との間でこれらの情報を入出力する。各種データには、目標対象物位置81、風速情報82、ボクセル情報83、移動空間グラフ情報84、各種パラメータ85等の制御部7の各処理に用いられる情報、各センサ等の出力値及び撮像画像等が含まれる。
目標対象物位置81は、管理装置102から受信した目標対象物Mの位置情報(座標:Xt,Yt,Zt)である。本実施形態では、目標対象物位置81を目標対象物Mの足元位置、すなわち目標対象物Mが地面(床面)に接している位置とする。制御部7は、通信部9を介して目標対象物Mの位置を受信すると目標対象物位置81として記憶部8に記憶させる。なお、管理装置102は、目標対象物Mの位置(座標:Xt,Yt,Zt)の時間変化に基づいて目標対象物Mの姿勢(例えば、目標対象物Mの正面方向を示した情報)を推定し、目標対象物位置81として記憶してもよい。
風速情報82は、管理装置102から受信した風速の大きさを表す情報である。本実施形態では、移動空間に複数の風速計105を設置し、各風速計105の設置位置と各風速計105によって測定された風速値とを対応付けて記憶している。しかし、これに限らず、移動空間に一つの風速計105を設置し、当該風速計105によって測定された風速値を、当該移動空間における風速の大きさとみなしてもよい。また、風速計105を自律飛行ロボット1が搭載している場合は、搭載した風速計105によって測定された風速値と自己位置とを対応付けて記憶する。
ボクセル情報83は、移動空間をボクセル空間として複数のボクセルに分割して移動空間の障害物の構造等を表した情報であり、予め管理者等によって設定され記憶部8に記憶され、また、後述するように位置推定手段71及び経路探索手段73にて更新される情報である。本実施形態では、移動空間を所定の大きさ(例えば15cm×15cm×15cm)のボクセルに等分割し、各ボクセルの識別子であるボクセルIDと、移動空間におけるボクセルの位置(三次元座標)と、ボクセル属性と、ボクセルコスト値とを対応付けてボクセル情報83として記憶する。ボクセル属性には、飛行禁止エリアに相当するボクセルを「占有ボクセル」と定義して、自律飛行ロボット1が移動できない空間とする。なお飛行禁止エリアには、例えば建造物等の障害物に相当するエリア、飛行が許可された敷地外のエリア、飛行が許可された高度よりも高いエリアなどが挙げられる。そして、占有ボクセルの近くに存在する空間に位置するボクセルを「近接ボクセル」、それ以外の自由に飛行可能なエリアに位置するボクセルを「自由ボクセル」として定義する。
各ボクセルには、後述する経路探索手段73にて移動経路を生成する際に利用できるよう、占有度を示すボクセルコスト値が関連付けて登録される。ボクセルコスト値は、占有ボクセルにおいて最大値Cmaxをとり、占有ボクセルからの距離が大きくなるほど小さな値となるように設定される。例えば、あるボクセル(評価ボクセル)のボクセルコスト値は、ボクセルコスト値=Cmax × exp{−λ×R}…式(1)の計算式により算出することが好適である。ここでλは実験によって求めたパラメータとし、Rは評価ボクセルに最も近い占有ボクセルからの距離とする。そして、予め定めた閾値以上のボクセルコスト値を有するボクセルを「近接ボクセル」とする。また、ボクセルコスト値が当該閾値よりも小さいボクセルを「自由ボクセル」とし、自由ボクセルとみなされたボクセルのボクセルコスト値を0と設定する。
移動空間グラフ情報84は、ボクセル情報83に基づいて作成された3次元グラフ情報である。具体的には、ボクセル情報83に基づいて、各ボクセルの中心位置をノードとし、当該ノードに隣接するノード間を連結した線分をエッジとしたグラフ構造からなる情報である。図4は移動空間グラフ情報84のグラフ構造を説明する図であり、移動空間におけるボクセルの一部(27個)を切り欠いたものである。図4において符号Bで表す個々の立方体はボクセルを表すものである。また、これらのボクセルBの中心位置にある黒又はハッチングにて塗りつぶした球はノードであり、ノード間を連結する点線で表示する線分はエッジである。なお、移動空間グラフ情報84におけるエッジの重みとして、隣接するノード間の距離に基づいて求められる後述する距離コストCMが設定されているものとする。
また、記憶部8には、各種パラメータ85として離間距離等も記憶される。離間距離は、目標対象物Mに追従飛行するにあたって、自律飛行ロボット1と目標対象物Mとの水平面における維持すべき相対距離である。離間距離は、自律飛行ロボット1の管理者等によって予め設定される。自律飛行ロボット1を用いて所定の目標対象物Mを監視する場合、目標対象物Mに近づき、より詳細な撮像画像を取得できる必要がある。しかし、侵入者などの敵対する目標対象物Mから攻撃を受けないようにするためには一定距離以上離間する必要がある。そのため、本実施形態の自律飛行ロボット1は、目標対象物Mの詳細な撮像画像を取得でき、かつ、当該目標対象物Mから攻撃を受け難い距離に離間距離を予め、当該離間距離を保ちつつ追従飛行するように制御される。離間距離は、例えば3mとして設定される。
制御部7は、CPU等を備えたコンピュータで構成され、位置推定処理、速度推定処理、ボクセル情報更新処理、移動経路生成処理、移動制御処理(経路追従制御)を行う一連の処理として、位置推定手段71、速度推定手段72、経路探索手段73、移動制御手段74を含んでいる。
位置推定手段71は、位置検出センサ6の出力に基づいて、移動空間における自律飛行ロボット1の現在位置(自己位置)を推定する位置推定処理を行う。
具体的には、位置検出センサ6から得られた複数の航法衛星からの航法信号に基づいて既知の周知技術に基づいて推定した緯度・経度と、距離検出センサ5から得られた高度とから自己位置の座標(Xs,Ys,Zs)を計算する。さらに、電子コンパスやジャイロセンサなどの位置検出センサ6からの出力を受けて自己位置として姿勢YAWを求める。なお、自己位置の推定方法はこれに限定されるものではなく、他の方法を用いて自律飛行ロボット1の現在位置を推定してもよい。
位置推定手段71は、推定された自己位置(座標:Xs,Ys,Zs及び姿勢YAW)と管理装置102から受信した目標対象物Mの位置(座標:Xt,Yt,Zt)を経路探索手段73へ出力する。
なお、位置推定手段71は、目標対象物Mの位置に基づいてボクセル情報83を更新する処理を行う。具体的には、記憶部8のボクセル情報83に基づいたボクセル空間に目標対象物Mの位置を中心として予め定めた目標対象物Mの大きさと略同じ大きさの円柱モデル(例えば、監視対象の目標対象物Mを侵入者であるとしたとき、底面の半径0.3m、高さ1.7mの円柱モデル)を配置し、当該円柱モデルと干渉するボクセルを占有ボクセルとして設定することによりボクセル情報83を更新する。後述するように、自律飛行ロボット1は、占有ボクセルには移動しないように飛行制御されるが、上記のように目標対象物Mの位置に基づいてボクセル情報83を更新することにより、自律飛行ロボット1と目標対象物Mとの接触を回避することができる。
速度推定手段72は、後述する移動制御手段74における移動制御で利用するため、自律飛行ロボット1の現在の飛行速度(vx,vy,vz,vyaw)を推定する処理を行う。本実施形態では、位置推定手段71にて推定した自己位置(座標:Xs,Ys,Zs及び姿勢YAW)の時間変化から飛行速度を求める。この際、測定誤差等の影響を考慮して拡張カルマンフィルタを利用して飛行速度を推定することが好適である。この他にも、GNSSにおけるドップラー効果を利用した速度推定方法を用いてもよい。
経路探索手段73は、自律飛行ロボットの現在位置(自己位置)から所定の移動目標位置に至る移動経路を算出する処理を行う。特に、本実施形態における経路探索手段73は、移動経路を算出する際、風速情報82に基づいて風速が大きいほど占有ボクセル(飛行禁止エリア)からより遠くに離れた位置に移動経路を生成する。
まず、経路探索手段73は、記憶部8に記憶された風速情報82に基づいてボクセル情報83を更新するボクセル情報更新処理を行う。以下、ボクセル情報更新処理の詳細について説明する。ボクセル情報更新処理では、移動空間における風速情報82の風速値が大きいほど、近接ボクセルの範囲が大きく(広く)設定されるように、ボクセルコスト値を算出する。なお、本実施形態におけるボクセル情報更新処理では、自己位置に最も近い位置に設置された風速計105の風速値を利用することとして以下で説明する。自律飛行ロボット1自体が風速計105を搭載している他の実施形態においては、当該搭載している風速計105の風速値をボクセル情報更新処理にて利用することとし、搭載している風速計105が故障等によって利用できないときは、自己位置に近い位置に設置された風速計105の風速値を利用することとする。
本実施形態では、経路探索手段73は、風速情報82から風速値を読み出し、式(1)におけるλの値を、風速が大きいほど小さな値となるように更新し、更新した当該λの値を用いて、式(1)を用いて同様に各ボクセルのボクセルコスト値を算出するものとする。例えば、風速10mの時はλ=0.1、風速8mの時はλ=0.15、風速6mの時はλ=0.2などといったように、予め風速の大きさが大きくなるほどλの値が小さくなるよう風速に対応付けてλの値を記憶しておき、ボクセル情報更新処理の実行時における風速値に基づいて計算に用いるλの値を読み出して、式(1)によりボクセルコストを計算する。このようにして各ボクセルについて求めたボクセルコスト値によってボクセル情報83を更新する。そして、予め定めた閾値以上のボクセルコスト値を有するボクセルのボクセル属性を「近接ボクセル」、当該閾値未満のボクセルコスト値を有するボクセルのボクセル属性を「自由ボクセル」としてボクセル情報83を更新する。
図5は、ボクセル情報更新処理によって再設定されたボクセル情報83を説明する図であり、時刻tのときにボクセルで表示した移動空間の一部を真上から見下ろしたときの図について表している。図5において、符号B1で表わした黒色で塗られた領域は「占有ボクセル」を示し、例えば、建造物などを構成する物体が占有する空間である。また、符号B2で表わしたハンチングで塗られた領域は「近接ボクセル」であり、符号B3で表わした白色の領域(何も塗られていない領域)は「自由ボクセル」である。図5(a)は、風速が小さい(弱風)のときに設定されたボクセル情報83を表しており、図5(b)は、風速が大きい(強風)のときに設定されたボクセル情報83を表している。図5に表すように、移動空間における風速が大きくなるほど、占有ボクセルから離れた位置にあるボクセルが、(自由ボクセルではなく)近接ボクセルとして設定されることになる。
なお、ボクセル情報更新処理は、経路探索手段73によって移動経路を生成する際(後述する移動経路生成処理を実行する際)に、その都度実行してもよいし、所定期間毎に実行してもよいし、風速が所定範囲以上変化する度に実行してもよい。或いは、複数通りの風速値における全ボクセルのボクセルコスト値を式(1)によって予め算出した上で、風速値に対応付けて記憶しておき、ボクセル情報更新処理の実行時における風速値に対応する全ボクセルのボクセルコスト値を読み出して更新してもよい。
続いて、経路探索手段73は、位置推定手段71で推定された自己位置及び目標対象物位置81と、記憶部8に記憶された各種情報とを用いて自律飛行ロボット1の移動経路を算出する移動経路生成処理を行う。以下に、移動経路生成処理の詳細について説明する。
移動経路生成処理では、まず、目標対象物位置81から予め設定した離間距離(3m)だけ水平方向に離れた位置であって予め設定された高度(3m)の位置に移動目標位置を設定する処理を行う。この際、経路探索手段73は、ボクセル情報83を参照し、占有ボクセル又は近接ボクセルに含まれる位置には移動目標位置を設定しないようにする。なお、(目標対象物位置81の時間変化により求めた)目標対象物Mの移動方向を目標対象物Mの正面方向として定め、当該正面方向に近い位置に移動目標位置を設定することが好適である。
次に移動経路生成処理では、設定された移動目標位置Qと、記憶部8に記憶されたボクセル情報83及び移動空間グラフ情報84と、位置推定手段71にて推定された自己位置と、を用いて自律飛行ロボット1の移動経路を算出する。この際、空間情報82及び移動空間グラフ情報84を参照し、移動目標位置に対応するボクセルのノード(以下「スタートノード」という)から自己位置に対応するボクセルのノード(以下「ゴールノード」という)に至る総コスト値Cが最も小さくなる経路をA*経路探索法により探索する。
A*経路探索法では、ある評価ノードn(ノードIDがnのノード)における総コスト値C(n)=g(n)+h(n)…式(2)で表わす。
ここで、g(n)は、評価ノードnについてのA*経路探索法におけるgコスト値であり、本実施形態では、スタートノードから評価ノードnに至るまでの移動距離や障害物への接触危険性を考慮したコスト値として求める。すなわち、評価ノードnのgコスト値であるg(n)は、隣接ノードにおけるgコスト値であるg(n−1)と、当該隣接ノードから評価ノードに至る距離に基づいて設定された距離コストCM、評価ノードにおけるボクセルコストCv(n)との和とし、g(n)=g(n−1)+CM+Cv(n)により求める。また、h(n)は、評価ノードnについてのA*経路探索法におけるhコスト値であり、評価ノードnからゴールノードに至る距離の推定コスト値である。本実施形態では、評価ノードnからゴールノードに至る直線距離によりh(n)を求める。A*経路探索法では、スタートノードから順に隣接ノードの総コスト値C(n)を算出していくことを繰り返し、最終的にゴールノードに至る総コスト値C(n)が最も小さくなる経路を探索していく。
以下に、A*経路探索法による移動経路の生成について簡単に説明する。A*経路探索法では、まず、スタートノードに隣接する一又は複数のノード(隣接ノード)を評価ノードとして設定するところから開始する。この際、ボクセル情報83のボクセル属性を参照し、占有ボクセル又は近接ボクセルに相当する位置にある隣接ノードは評価ノードから除外し、占有ボクセル又は近接ボクセルに移動経路が生成されないようにする。そして、それぞれの評価ノードについて式(2)により総コスト値を求める。次に、評価ノードの中で最小の総コスト値となるノードを注目ノードと称したとき、当該注目ノードの(これまで評価ノードと設定されていない新たな)隣接ノードを新たに評価ノードとして追加し、新たに追加された評価ノードに対しても同様に総コスト値を求める。続いて、同様に全ての評価ノードの中で最小の総コスト値となる評価ノードを注目ノードに再設定する。このように、評価ノードの総コスト値に基づいた注目ノードの再設定と、当該再設定に伴う新たな評価ノードの追加及び総コスト値の計算を繰り返し、最終的にゴールノードが注目ノードとして設定されたとき、経路の探索は終了する。
このようにして、起点となるスタートノードから終点となるゴールノードに至る最良の移動経路が生成される。経路探索手段73で生成された移動経路のデータは、経由点となるノードの位置(x,y,z)の集合データであり、この情報は記憶部8に一時的に記憶される。図6は、風速に応じて生成された移動経路の違いについて説明する図であり、図6(a)は、風速が小さい(弱風)のときに設定された移動経路を表しており、図6(b)は、風速が大きい(強風)のときに設定された移動経路を表している。このように、経路探索手段73は、風速が大きいほど占有ボクセル(飛行禁止エリア)からより遠くに離れた位置に移動経路を生成する。
なお、経路の探索方法は、A*経路探索法に限定されるものでなく、ダイクストラ法等の他の経路探索方法を適用してもよい。
移動制御手段74は、経路探索手段73にて算出された移動経路と位置推定手段71にて推定された自己位置と速度推定手段72で推定された飛行速度とを用いて、自律飛行ロボット1が経路探索手段73で算出された移動経路に沿って飛行するように経路追従制御を行う。具体的には、移動経路、自己位置及び飛行速度を用いて各時刻での飛行制御値である制御指令値を求め、当該制御指令値に基づいてモータ4を制御し、ロータ2の回転数を制御する。
経路追従制御では、まず、各時刻での自律飛行ロボット1が目標とすべき直近の位置(以下、「ローカル目標」と呼ぶ)を算出する処理を行う。図7はローカル目標の算出を説明する図である。ローカル目標の算出にあたり、移動制御手段74は、経路探索手段73で生成された移動経路を記憶部8から読出し、自律飛行ロボット1が現在時刻で目指している経由点Wp1と前回通過済みである経由点Wp0との2点間を繋げた直線Wを求める。そして、移動制御手段74は、求めた直線Wと自律飛行ロボット1の自己位置を中心とした球Sとの交点Lp’、Lpを算出し、目指している経由点Wp1に近い交点Lpをローカル目標として求める。このように、各時刻においてローカル目標を目指して自律飛行ロボット1が移動するよう飛行制御することで、常にローカル目標も移動経路上を移動目標位置Poに向かって移動していき、自律飛行ロボット1は移動経路に沿って飛行していくことになる。
次に、経路追従制御では、算出したローカル目標に向かって飛行するようX、Y、Z、ヨー角の各方向毎に制御指令値ux,uy,uz,uψを算出する処理を行う。この際、現在の自己位置とローカル目標の位置との差異が小さくなるような制御指令値を求める。具体的には、XYZ軸方向の制御指令値u=(ux,uy,uz)は、位置推定手段71で求められた自己位置r=(Xs,Ys,Zs)と速度推定手段72で推定した速度v=(vx,vy,vz)とを利用し、PID制御により求める。XYZ軸方向の各制御指令値をu=(ux,uy,uz)、ローカル目標をr’=(x,y,z)としたとき、制御指令値は、u=Kp(r’−r)+Kd・v+Ki・eの式で算出される。ここで、Kp、Kd、KiはそれぞれPID制御のゲインのことであり、e=(ex,ey,ez)は誤差の積分値である。一方、ヨー角方向の制御指令値uψは、ψ'を目標角度、ψを位置推定手段71にて推定した自律飛行ロボット1の姿勢(角度)、vyawを速度推定手段72で推定した角速度とすると、uψ=Kp(ψ’−ψ)+Kd・vyawの式のようなPD制御により求める。なお、本実施形態では、目標角度ψ'を目標対象物Mの方向、すなわち、目標対象物Mの位置の方向を向く角度とした。
このように、制御部7は、上述した位置推定手段71、速度推定手段72、経路探索手段73、移動制御手段74における各処理を逐次繰り返す。これにより、本実施形態の自律飛行ロボット1は、目標対象物Mから離間距離だけ離れた位置に対して移動目標位置を逐次更新し、その都度移動経路についても逐次更新していくことによって、目標対象物Mを撮像しながら追従移動することができる。特に本実施形態における自律飛行ロボット1は、風速が大きいほど占有ボクセル(飛行禁止エリア)から大きく離れるように移動経路を生成することにより、風による障害物への衝突する危険性を少なくすることができる。
ところで、本発明は、上記実施形態に限定されるものではなく、特許請求の範囲に記載した技術的思想の範囲内で、更に種々の異なる実施形態で実施されてもよいものである。また、実施形態に記載した効果は、これに限定されるものではない。
上記実施形態におけるボクセル情報更新処理では、風速情報82に基づいて式(1)におけるλの値を変更して、各ボクセルのボクセルコストを算出した上で、閾値判定によりボクセル属性(近接ボクセル/自由ボクセル)を判定している。しかし、これに限定されるものではなく、風速が大きくなるほど占有ボクセル(飛行禁止エリア)からより遠くに離れた位置に移動経路が生成されるよう、他の方法を用いてボクセル情報83を更新してもよい。例えば、全てのボクセルについての無風時におけるボクセルコストを式(1)によって予め算出してボクセル情報83として記憶し、風速の大きさが大きくなるほど大きい値となる補正コスト値を別途算出して、予め記憶している無風時のボクセルコスト値に当該補正コスト値を加算することによりボクセルコストを算出し、ボクセル情報83を更新してもよい。そして、当該ボクセルコスト値を閾値判定することによりボクセル属性を判定してもよい。
また、ボクセル情報更新処理では、ボクセルコストを更新せずに(一定のまま)、ボクセル属性のみを更新してもよい。例えば、風速の大きさに応じて近接ボクセルと判定するための閾値を変更し、当該変更した閾値を用いて各ボクセルが近接ボクセルであるか否かを判定し、ボクセル情報83のボクセル属性を更新してもよい。すなわち、風速の大きさが大きいほど、近接ボクセルと判定するための閾値を小さくなるように設定することにより、あるボクセルのボクセルコスト値が風速に応じて変わらなくても、風速が大きくなるほど近接ボクセルとして設定され易くなる。他にも、風速が大きくなるほど大きな値となる離間距離を求め、あるボクセル(評価ボクセル)から当該離間距離の範囲内に占有ボクセルが存在していたときは、当該評価ボクセルのボクセル属性を近接ボクセルとして設定してもよい。この際、例えば、離間距離=α×風速値により求めてもよい(ここでαは実験により求めたパラメータとする)。
また、上記実施形態におけるボクセル情報更新処理では、風速の大きさからなる風速情報82に基づいてボクセル情報83を更新している。しかし、これに限定されるものではなく、風速だけでなく風向も測定可能な風速計105を用い、当該風速計105によって出力された風速・風向に基づいてボクセル情報83を更新してもよい。すなわち、風速計105にて測定された風向を参照して、風速が大きいほど風向の風下に位置する飛行禁止エリアからより遠くに離れた位置に移動経路を生成する。具体的には、生成される移動経路から見て風上側に位置する飛行禁止エリアからよりも、生成される移動経路から見て風下側に位置する飛行禁止エリアからの方が、より遠くに離れるような位置となるように移動経路を生成するものとする。例えば、あるボクセル(評価ボクセル)のボクセルコストを求めるのに際し、まず、評価ボクセルから占有ボクセルに向かう直線方向と風向とがなす角δが小さいほど、式(1)におけるλの値が小さくなるように設定する。例えば、式(1)におけるλ値を、λ=λ0−β×cosδ(0°≦δ<90°)…式(3)により求めることができる。ここで、λ0は無風時におけるλ値として予め設定された値であり、βは風速の大きさが大きくなるほど大きな値となる値であって風速に対応付けて予め設定された値である。なお、式(3)においてδ≧90°の場合はλ=λ0を用いるものとする。また、風向を考慮してボクセルコストを算出する場合、式(1)及び式(3)で対象とする占有ボクセルを、評価ボクセルに最も近い占有ボクセルではなく、評価ボクセルの所定範囲内の周囲に存在する占有ボクセルについて其々ボクセルコストを算出し、求めた各ボクセルコストの中で最も大きい値のボクセルコストを採用するのが好適である。図8は、式(1)及び式(3)により風速・風向に基づいてボクセル情報83を更新した例を表す図である。図8(a)は、移動空間に東風が発生していた時のボクセル情報83の例を表しており、図8(b)は、西風が発生していた時のボクセル情報83の例を表しており、図8(a)に表すように、東風が発生している場合、評価ボクセルから見て当該風向(東風)と同じ方向(東側)に存在する占有ボクセルの影響を強く受ける。したがって、占有ボクセルの西側に位置するボクセルの多くが近接ボクセルとして設定されることになる。一方、図8(b)に表すように、西風が発生している場合は、占有ボクセルの東側に位置するボクセルの多くが近接ボクセルとして設定されることになる。このように風速だけでなく風向も考慮してボクセルコストを算出することにより、経路探索手段73は、風速が大きいほど、風向と逆の方向(風上)にある占有ボクセルからよりも、風向と同じ方向(風下)にある占有ボクセルから大きく(より遠くに)離れるように移動経路を生成する。これにより、自律飛行ロボット1は、移動自由度を確保しつつ、より安全に飛行することが可能となる。なお式(3)におけるλ0は、風速に関係なく固定値としているが、当該λ0についても風速に応じて小さくなるように更新してもよい。
また、上記実施形態におけるボクセル情報更新処理では、ボクセル情報更新処理の実行時(現在)における風速の大きさに基づいて、式(1)の計算に用いるλの値を決定している。しかし、これに限定されるものではなく、現在から過去の所定期間(例えば、10分間)における最大瞬間風速に基づいてλの値を決定してもよい。すなわち、現在から過去の所定期間における最大瞬間風速値が大きいほど、式(1)の計算に用いるλの値が小さくなるように決定する。したがって、経路探索手段73は、現在から過去の所定期間における最大瞬間風速値が大きいほど、占有ボクセル(飛行禁止エリア)から大きく離れるような移動経路を生成するようになる。これにより、一時的に風が弱くなったタイミングで設定されたボクセルコスト(及びボクセル属性)に基づいて移動経路が生成され、再び風が強くなることによって障害物に衝突する危険性を低下させることができる。
また、上記各実施形態におけるボクセル情報更新処理では、風速(及び風向)に基づいてボクセル情報83を更新している。しかし、これに限定されるものではなく、現在から過去の所定期間内における最大瞬間風速と平均風速との比から突風率(突風率=最大瞬間風速÷平均風速)を更に求め、突風率も考慮してボクセル情報83を更新してもよい。すなわち、突風率が大きいほど式(1)の計算に用いるλの値が小さくなるように決定する。或いは、突風率が大きいほど各ボクセルのボクセルコストが大きくなるように補正したり、近接ボクセルを判定する閾値が小さくなるように補正した上で、ボクセル属性を更新してもよい。このようにしてボクセル情報83を更新することにより、経路探索手段73は、突風率が大きいほど、占有ボクセル(飛行禁止エリア)から大きく離れるような移動経路を生成するようになる。したがって、突風の影響を考慮して移動経路を生成することができ、突風により障害物に衝突する危険性を低下させることができる。
また、上記各実施形態における移動経路生成処理では、A*経路探索法によって移動経路を生成する際、ボクセル情報83のボクセル属性を参照することで近接ボクセルに移動経路が生成されないよう処理している。しかし、これに限定されるものではなく、ボクセル属性を参照せずにボクセルコストのみを用いて移動経路を生成してもよい。すなわち、この場合においても、風速に基づいてボクセルコストを更新することにより、風速が大きいほど占有ボクセル(飛行禁止エリア)から大きく離れるよう移動経路を生成されることに変わりない。
また、上記実施の形態では、管理装置102に接続された目標対象物検出センサ104を用いて目標対象物Mを検出している。しかしながら、これに限定されるものではなく、撮像部3で取得した撮像画像を画像解析することにより、目標対象物Mの位置を推定してもよい。例えば、撮像画像の各フレームを画像処理して目標対象物Mの画像領域を抽出する処理を行う。この際、既知の従来技術(特開2006−146551号公報を参照)であるオプティカルフロー法、ブースティング学習(例えば、Haar−like特徴を用いているAdaBoostベース識別器による顔検出手法)による識別器等を用いて目標対象物Mの画像領域(人物領域)を抽出する。次に、当該抽出された画像領域の位置に基づいて目標対象物Mと自律飛行ロボット1との距離を推定する。具体的には、抽出した目標対象物Mの画像領域の頭頂部の(撮像画像における)y座標位置と距離との対応表を予め飛行高度毎に作成しておき、現在の飛行高度及び目標対象物Mの頭頂部のy座標位置を当該対応表に照らし合わせて自律飛行ロボット1との距離を推定する。しかし、これに限らず、抽出した目標対象物Mの頭部の大きさから距離を算出してもよい。すなわち、頭部の大きさと距離との対応表を予め作成しておき、抽出された目標対象物Mの頭部の大きさを当該対応表に照らし合わせて自律飛行ロボット1との距離を推定してもよい。
また、自律飛行ロボット1に撮像部3としてカラーカメラの代わりに距離画像センサを搭載して、当該距離画像センサから取得した距離画像を用いて、既知の移動物体抽出技術により目標対象物Mを抽出して、抽出した目標対象物Mと自律飛行ロボット1との距離値と自己位置とから目標対象物Mの位置を推定してもよい。また、自律飛行ロボット1にレーザスキャナを搭載し、当該レーザスキャナの出力値と自己位置とを用いて目標対象物Mの位置を推定してもよい。
また、上記実施の形態では、制御部7において位置推定処理、速度推定処理、ボクセル情報更新処理、移動経路生成処理、移動制御処理(経路追従制御)の一連の処理を行っている。しかし、これに限らず、図示しない制御用のPCを用意し、当該PCにこれらの一連の処理を実施させてもよい。すなわち、自律飛行ロボット1は、PCによって行われた位置推定処理、速度推定処理、ボクセル情報更新処理、移動経路生成処理、移動制御処理によって得られた制御指令値を無線通信又は有線通信によりPCから受信し、当該制御指令値に基づいてモータ4の回転数を制御することにより、目的の位置に飛行するようにしてもよい。このように、外部PCを用いて上記の一連の処理を分担することにより、自律飛行ロボット1のCPU処理負荷を低減することができ、ひいてはバッテリの消耗も抑えることができる。