IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ オムロン株式会社の特許一覧

特開2024-34216ロボットの動作経路を生成する装置、方法およびプログラム
<>
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図1
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図2
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図3
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図4
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図5
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図6
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図7
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図8
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図9
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図10
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図11
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図12
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図13
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図14
  • 特開-ロボットの動作経路を生成する装置、方法およびプログラム 図15
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024034216
(43)【公開日】2024-03-13
(54)【発明の名称】ロボットの動作経路を生成する装置、方法およびプログラム
(51)【国際特許分類】
   B25J 9/22 20060101AFI20240306BHJP
   G05B 19/4093 20060101ALI20240306BHJP
【FI】
B25J9/22 A
G05B19/4093 E
【審査請求】未請求
【請求項の数】10
【出願形態】OL
(21)【出願番号】P 2022138314
(22)【出願日】2022-08-31
(71)【出願人】
【識別番号】000002945
【氏名又は名称】オムロン株式会社
(74)【代理人】
【識別番号】110001195
【氏名又は名称】弁理士法人深見特許事務所
(72)【発明者】
【氏名】大城 篤志
【テーマコード(参考)】
3C269
3C707
【Fターム(参考)】
3C269AB33
3C269BB14
3C269QE10
3C269SA17
3C707BS12
3C707JU03
3C707KS11
3C707KS36
3C707KT03
3C707KT09
3C707LS15
3C707LV19
3C707MS06
3C707MS08
(57)【要約】
【課題】ロボットの動作前における経路設定のためのユーザの手間を削減するとともに、ロボットがどのような動作を行なうかを予測しやすい方法を提供する。
【解決手段】方法は、1以上の動作区間の指定を受け付けるステップと、1以上の動作区間のうちの対象動作区間について、ロボットの複数の経路候補を生成するステップと、複数の経路候補をユーザインターフェイスに表示するステップと、複数の経路候補の中から1つの経路候補の選択を受け付けるステップと、1つの経路候補を対象動作区間の動作経路として決定するステップと、を備える。
【選択図】図1
【特許請求の範囲】
【請求項1】
ロボットの動作前に前記ロボットの動作経路を生成する装置であって、
指定された1以上の動作区間のうちの対象動作区間について、前記ロボットの複数の経路候補を生成し、前記複数の経路候補の中から1つの経路候補の選択を受け付ける画面を示すデータを提供する生成部と、
前記1つの経路候補を前記対象動作区間の前記動作経路として決定する決定部とを備える、装置。
【請求項2】
前記生成部は、前記ロボットの配置される空間において物体が占有する領域を示す占有領域情報を用いて、前記物体と干渉しないように前記複数の経路候補を生成する、請求項1に記載の装置。
【請求項3】
前記生成部は、確率的手法を用いて前記複数の経路候補を生成する、請求項1または2に記載の装置。
【請求項4】
前記生成部は、前記複数の経路候補の各々を評価し、
前記画面は、前記複数の経路候補に対する評価結果を含む、請求項1に記載の装置。
【請求項5】
前記評価結果は、前記複数の経路候補の各々について、移動距離、移動時間および物体との干渉のリスクの度合いの少なくとも1つを表す、請求項4に記載の装置。
【請求項6】
前記1以上の動作区間は、第1~第N動作区間を含み、Nは2以上の整数であり、
前記装置は、さらに、
前記第1~第N動作区間の各々が第1グループおよび第2グループのいずれに属するかを設定する設定部を備え、
前記設定部は、前記第1~第N動作区間のうち前記第1グループに属する各動作区間を前記対象動作区間として設定し、
前記決定部は、
前記第1~第N動作区間のうち前記第2グループに属する各動作区間について、指定された教示データに基づいて前記ロボットの前記動作経路を決定し、
前記第1~第N動作区間について決定した前記動作経路を順に繋ぐことにより得られる経路を前記第1動作区間の開始点から前記第N動作区間の終了点までの全体経路として決定する、請求項1に記載の装置。
【請求項7】
前記全体経路に沿って前記ロボットを動作させる制御部をさらに備え、
前記設定部は、前記第1~第N動作区間の各々が第3グループおよび第4グループのいずれに属するかをさらに設定し、
前記制御部は、
前記ロボットの周囲の物体との干渉を回避するための干渉回避動作を行なうように前記ロボットを制御可能であり、
前記第1~第N動作区間のうち前記第3グループに属する各動作区間に対応する前記動作経路に沿って前記ロボットを動作させている場合、前記干渉回避動作を有効にし、
前記第1~第N動作区間のうち前記第4グループに属する各動作区間に対応する前記動作経路に沿って前記ロボットを動作させている場合、前記干渉回避動作を無効にする、請求項6に記載の装置。
【請求項8】
前記干渉回避動作は、動的物体から遠ざかる動作を含み、
前記制御部は、
動作中の前記ロボットと前記ロボットの周囲の静的物体との干渉のリスクを評価し、
前記リスクが予め定められた基準を超えたことに応じて、前記ロボットを停止させる、請求項7に記載の装置。
【請求項9】
ロボットの動作前に前記ロボットの動作経路を生成する方法であって、
1以上の動作区間の指定を受け付けるステップと、
前記1以上の動作区間のうちの対象動作区間について、前記ロボットの複数の経路候補を生成するステップと、
前記複数の経路候補をユーザインターフェイスに表示するステップと、
前記複数の経路候補の中から1つの経路候補の選択を受け付けるステップと、
前記1つの経路候補を前記対象動作区間の前記動作経路として決定するステップとを備える、方法。
【請求項10】
ロボットの動作前に前記ロボットの動作経路を生成する方法をコンピュータに実行させるプログラムであって、
前記方法は、
1以上の動作区間の指定を受け付けるステップと、
前記1以上の動作区間のうちの対象動作区間について、前記ロボットの複数の経路候補を生成するステップと、
前記複数の経路候補の中から1つの経路候補の選択を受け付ける画面を示すデータを提供するステップと、
前記1つの経路候補を前記対象動作区間の前記動作経路として決定するステップとを含む、プログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本開示は、ロボットの動作経路を生成する装置、方法およびプログラムに関する。
【背景技術】
【0002】
近年、FA(Factory Automation)分野などにおいて、人と協調して動作するロボットの開発が進められている。通常、ロボットを動作させる前に、ロボットの動作経路が予め設定される。「Mohammad Safeea、他2名、"On-line collision avoidance for collaborative robot manipulators by adjusting off-line generated paths: An industrial use case"、Robotics and Autonomous Systems、Elsevier、2019、119、pp.278-288」(非特許文献1)は、ユーザが経路上の全点を教示することにより、ロボットの動作経路を設定することを開示している。
【先行技術文献】
【非特許文献】
【0003】
【非特許文献1】Mohammad Safeea、他2名、"On-line collision avoidance for collaborative robot manipulators by adjusting off-line generated paths: An industrial use case"、Robotics and Autonomous Systems、Elsevier、2019、119、pp.278-288
【非特許文献2】Justinas Miseikis、他3名、「Multi 3D camera mapping for predictive and reflexive robot manipulator trajectory estimation」、2016 IEEE Symposium Series on Computational Intelligence (SSCI)
【発明の概要】
【発明が解決しようとする課題】
【0004】
ロボットの経路の全点を予め教示するにはユーザの手間がかかる。一方、ロボットの動作中において、周囲の物体との干渉を回避するように自動的に経路を生成する技術が知られている(「Justinas Miseikis、他3名、「Multi 3D camera mapping for predictive and reflexive robot manipulator trajectory estimation」、2016 IEEE Symposium Series on Computational Intelligence (SSCI)」(非特許文献2)参照)。そこで、ロボットの動作前にロボットの経路の全点を予め教示することなく、ロボットの動作中において自動的に経路を生成することが考えられる。しかしながら、この場合、ロボットの周囲にいる人にとって、ロボットがどのような動作を行なうかを予測しにくい。
【0005】
本開示は、上記の問題に鑑みてなされたものであり、その目的は、ロボットの動作前における経路設定のためのユーザの手間を削減するとともに、ロボットがどのような動作を行なうかを予測しやすい装置、方法およびプログラムを提供することである。
【課題を解決するための手段】
【0006】
本開示の一例によれば、ロボットの動作前にロボットの動作経路を生成する装置は、生成部と決定部とを備える。生成部は、指定された1以上の動作区間のうちの対象動作区間について、ロボットの複数の経路候補を生成し、複数の経路候補の中から1つの経路候補の選択を受け付ける画面を示すデータを提供する。決定部は、当該1つの経路候補を対象動作区間の動作経路として決定する。
【0007】
この開示によれば、ユーザは、上記の画面において、対象動作区間について自動的に生成された複数の経路候補の中の1つを選択することにより、対象動作区間の動作経路を設定できる。すなわち、ユーザは、対象動作区間における全点を教示する必要がない。そのため、ロボットの動作前における経路設定のためのユーザの手間が削減される。さらに、ユーザは、複数の経路候補のうちの1つを動作経路として選択するため、ロボットの動作前においてロボットの動作を予測しやすくなる。
【0008】
上述の開示において、生成部は、ロボットの配置される空間において物体が占有する領域を示す占有領域情報を用いて、物体と干渉しないように複数の経路候補を生成する。この開示によれば、物体と干渉しないように経路候補が生成される。
【0009】
上述の開示において、生成部は、例えば、確率的手法を用いて複数の経路候補を生成すればよい。
【0010】
上述の開示において、生成部は、複数の経路候補の各々を評価する。上記の画面は、複数の経路候補に対する評価結果を含む。評価結果は、例えば、複数の経路候補の各々について、移動距離、移動時間および物体との干渉のリスクの度合いの少なくとも1つを表す。
【0011】
この開示によれば、ユーザは、評価結果を参考にすることにより、複数の経路候補の中の1つを選択しやすくなる。
【0012】
上述の開示において、1以上の動作区間は、第1~第N動作区間を含む。Nは2以上の整数である。装置は、さらに、第1~第N動作区間の各々が第1グループおよび第2グループのいずれに属するかを設定する設定部を備える。設定部は、第1~第N動作区間のうち第1グループに属する各動作区間を対象動作区間として設定する。決定部は、第1~第N動作区間のうち第2グループに属する各動作区間について、指定された教示データに基づいてロボットの動作経路を決定する。決定部は、第1~第N動作区間について決定した動作経路を順に繋ぐことにより得られる経路を第1動作区間の開始点から第N動作区間の終了点までの全体経路として決定する。この開示によれば、ユーザは、動作区間毎に動作経路を設定することができる。
【0013】
上述の開示において、装置は、全体経路に沿ってロボットを動作させる制御部をさらに備える。設定部は、第1~第N動作区間の各々が第3グループおよび第4グループのいずれに属するかをさらに設定する。制御部は、ロボットの周囲の物体との干渉を回避するための干渉回避動作を行なうようにロボットを制御可能である。制御部は、第1~第N動作区間のうち第3グループに属する各動作区間に対応する動作経路に沿ってロボットを動作させている場合、干渉回避動作を有効にする。制御部は、第1~第N動作区間のうち第4グループに属する各動作区間に対応する動作経路に沿ってロボットを動作させている場合、干渉回避動作を無効にする。
【0014】
この開示によれば、ユーザは、例えば、精密な動作(例えば、挿入や押しつけなど)が必要である動作区間を第4グループに設定できる。これにより、ロボットが精密な動作を行なっている間、意図せず干渉回避動作が実行されることを防止できる。
【0015】
上述の開示において、干渉回避動作は、動的物体から遠ざかる動作を含む。制御部は、動作中のロボットとロボットの周囲の静的物体との干渉のリスクを評価する。制御部は、当該リスクが予め定められた基準を超えたことに応じて、ロボットを停止させる。
【0016】
この開示によれば、動的物体から遠ざかる動作によってロボットと静的物体との距離が短くなったとしても、静的物体とロボットとの干渉が回避される。
【0017】
本開示の一例によれば、ロボットの動作前にロボットの動作経路を生成する方法は、第1~第5のステップを備える。第1のステップは、1以上の動作区間の指定を受け付けるステップである。第2のステップは、1以上の動作区間のうちの対象動作区間について、ロボットの複数の経路候補を生成するステップである。第3のステップは、複数の経路候補をユーザインターフェイスに表示するステップである。第4のステップは、複数の経路候補の中から1つの経路候補の選択を受け付けるステップである。第5のステップは、1つの経路候補を対象動作区間の動作経路として決定するステップである。
【0018】
本開示の一例によれば、プログラムは、ロボットの動作前に前記ロボットの動作経路を生成する方法をコンピュータに実行させる。当該方法は、1以上の動作区間の指定を受け付けるステップと、1以上の動作区間のうちの対象動作区間について、ロボットの複数の経路候補を生成するステップと、複数の経路候補の中から1つの経路候補の選択を受け付ける画面を示すデータを提供するステップと、1つの経路候補を前記対象動作区間の動作経路として決定するステップとを含む。
【0019】
これらの開示によっても、ロボットの動作前における経路設定のためのユーザの手間を削減するとともに、ロボットがどのような動作を行なうかを予測しやすい。
【発明の効果】
【0020】
本開示によれば、ロボットの動作前における経路設定のためのユーザの手間を削減するとともに、ロボットがどのような動作を行なうかを予測しやすい。
【図面の簡単な説明】
【0021】
図1】実施の形態に係るシステムにおける、ロボットの動作経路を生成する方法の概要を示す図である。
図2】実施の形態に係るシステムの具体例を示す図である。
図3】制御装置および端末のハードウェア構成を示す模式図である。
図4】演算処理回路の機能構成の一例を示す図である。
図5】オクトマップの一例を示す図である。
図6】RRTアルゴリズムを用いて生成された複数の経路候補の一例を示す図である。
図7】動作区間を設定するための設定画面の一例を示す図である。
図8】複数の経路候補の中から1つの経路候補の選択を促す選択画面の一例を示す図である。
図9】オフライン期間における制御装置の処理の流れを示すフローチャートである。
図10図9に示すステップS3のサブルーチンの処理の流れを示すフローチャートである。
図11】オンライン期間における制御装置の処理の流れを示すフローチャートである。
図12】広い範囲を初期動作区間として指定したときの設定画面の一例を示す図である。
図13】初期動作区間を複数の動作区間に分割するときの設定画面の一例を示す図である。
図14】膨張処理を説明する図である。
図15】変形例6の選択画面を示す図である。
【発明を実施するための形態】
【0022】
本発明の実施の形態について、図面を参照しながら詳細に説明する。なお、図中の同一または相当部分については、同一符号を付してその説明は繰返さない。以下で説明される各変形例は、適宜選択的に組み合わされてもよい。
【0023】
§1 適用例
図1は、実施の形態に係るシステムにおける、ロボットの動作経路を生成する方法の概要を示す図である。図1に示されるように、システム1は、ユーザインターフェイス504と、ロボット200と、を備える。システム1は、例えば、工場等の生産現場に設けられる。特に、システム1は、人とロボット200とが協調して作業を行なう生産現場に好適である。
【0024】
ロボット200は、例えば、多関節ロボット、ドローン、自律走行ロボットなどの自律型ロボットを含む。
【0025】
図1に示されるように、システム1において実行される方法は、以下のステップ(1)~(5)を含む。ステップ(1)~(5)は、ロボット200の動作前(以下、「オフライン期間」と称する。)において、実行される。
【0026】
ステップ(1)は、ロボット200の1以上の動作区間の指定を受け付けるステップである。当該指定は、ユーザインターフェイス504を介して受け付けられる。ユーザは、各動作区間の開始点Psおよび終了点Peを指定すればよい。
【0027】
ステップ(2)は、1以上の動作区間のうちの対象動作区間について、ロボット200の複数の経路候補を生成するステップである。複数の経路候補は、公知の技術を用いて、対象動作区間の開始点Psと終了点Peとを繋ぐように生成される。
【0028】
ステップ(3)は、複数の経路候補をユーザインターフェイス504に表示するステップである。図1に示す例では、経路候補40a~40cがユーザインターフェイス504に表示されている。
【0029】
ステップ(4)は、複数の経路候補の中から1つの経路候補の選択を受け付けるステップである。当該選択は、ユーザインターフェイス504を介して受け付けられる。
【0030】
ステップ(5)は、選択された1つの経路候補を対象動作区間の動作経路として決定するステップである。図1に示す例では、経路候補40aが動作経路として決定されている。
【0031】
本実施の形態によれば、ユーザは、対象動作区間について自動的に生成された複数の経路候補の中の1つを選択することにより、対象動作区間におけるロボット200の動作経路を設定できる。すなわち、ユーザは、対象動作区間における全点を教示する必要がない。そのため、ロボットの動作前における経路設定のためのユーザの手間が削減される。
【0032】
また、ユーザは、複数の経路候補のうちの1つを動作経路として選択するため、ロボットの動作前においてロボットの動作を予測しやすくなる。
【0033】
§2 具体例
<システムの具体例>
以下、ロボット200として多関節ロボットを有するシステムについて説明する。ただし、上述したように、ロボット200は、多関節ロボットに限定されず、他のタイプのロボットであってもよい。
【0034】
図2は、実施の形態に係るシステムの具体例を示す図である。図2に示すシステム1は、制御装置100と、ロボット200と、複数のセンシングデバイス300と、端末500と、を備える。
【0035】
制御装置100は、ロボット200の動作経路を生成する機能と、ロボット200の動作を制御する機能とを有する。制御装置100は、複数のセンシングデバイス300と通信可能に接続される。制御装置100は、例えばGigE Vision(登録商標)またはUSB(Universal Serial Bus)を用いて、複数のセンシングデバイス300と通信する。
【0036】
センシングデバイス300は、ロボット200が存在する空間に配置され、当該空間における物体の位置を検知するデバイスである。物体には、ロボット200、ロボット200の周囲に存在する静的物体(例えば、机、壁など)、およびロボット200の周囲において移動可能な動的物体(例えば、人)が含まれる。センシングデバイス300は、例えばRGB-Dカメラまたはレーザレンジファインダであり、視野の点群データを生成する。空間において死角がないように、例えば4つ以上のセンシングデバイス300が互いに異なる位置に配置されることが好ましい。
【0037】
ロボット200は、マニピュレータ202と、マニピュレータコントローラ204と、を含む。
【0038】
マニピュレータ202は、6つの関節20_1~20_6を有するアーム220を有する。アーム220の先端部には、エンドエフェクタ230が取り付けられる。アーム220の先端部の中心は、ツールセンターポイント(TCP)と称される。
【0039】
マニピュレータコントローラ204は、ロボット200を動作させる期間(以下、「オンライン期間」と称する。)において、制御装置100からの指令に従って、マニピュレータ202の動作を制御する。
【0040】
端末500は、例えばデスクトップ型コンピュータ、ノート型コンピュータ、スマートフォン、タブレットなどによって構成され、制御装置100と通信可能である。端末500は、制御装置100から提供された情報を受信し、当該情報を表示する。さらに、端末500は、ユーザからの指示を受け付け、当該指示を制御装置100に送信する。
【0041】
<制御装置のハードウェア構成>
図3は、制御装置および端末のハードウェア構成を示す模式図である。制御装置100は、典型的には、汎用的なコンピュータアーキテクチャに従う構造を有する。
【0042】
図3に示されるように、制御装置100は、演算処理回路120と、フィールドネットワークコントローラ130と、を含む。
【0043】
演算処理回路120は、ロボット200の動作経路の生成およびロボット200の動作制御に必要な演算を実行する。一例として、演算処理回路120は、プロセッサ121と、メインメモリ122と、ストレージ123と、インターフェイス回路124とを含む。
【0044】
プロセッサ121は、例えばCPU(Central Processing Unit)、MPU(Micro Processing Unit)などで構成され、ロボット200の動作経路の生成およびロボット200の動作制御のための演算を実行する。メインメモリ122は、例えば、DRAM(Dynamic Random Access Memory)やSRAM(Static Random Access Memory)などの揮発性記憶装置などで構成される。ストレージ123は、例えば、SSD(Solid State Drive)やHDD(Hard Disk Drive)などの不揮発性記憶装置などで構成される。インターフェイス回路124は、ロボット200との間でデータをやり取りする。
【0045】
ストレージ123には、ロボット200の動作経路の生成およびロボット200の動作制御に関するシステムプログラム140が格納される。システムプログラム140は、ロボット200の動作経路の生成に係る演算を実行する命令、ロボット200の動作制御に係る演算を実行する命令、および、ロボット200との間のインターフェイスに係る命令を含む。さらに、システムプログラム140は、ウェブページを提供するサービスプログラムを含む。
【0046】
ストレージ123には、さらに、形状データ141と経路データ142と静的物体データ143とが格納される。形状データ141は、ロボット200の形状を示し、ロボットモデルが表示される画面の生成のために使用される。経路データ142は、生成された動作経路を示すデータであり、プロセッサ121がシステムプログラム140を実行することにより生成される。経路データ142は、動作経路上の複数の点の通過順序と、当該複数の点におけるマニピュレータ202が取るべき位置および姿勢と、を示す。静的物体データ143は、ロボット200の周囲に存在する静的物体の位置を示すデータであり、プロセッサ121がシステムプログラム140を実行することにより生成される。
【0047】
フィールドネットワークコントローラ130は、フィールドネットワークを介して、主として、センシングデバイス300との間でデータをやり取りする。
【0048】
端末500は、典型的には、汎用的なコンピュータアーキテクチャに従う構造を有する。図3に示されるように、端末500は、プロセッサ501と、メインメモリ502と、ストレージ503と、ユーザインターフェイス504と、を含む。
【0049】
プロセッサ501は、例えばCPU、MPUなどで構成され、各種の情報処理を実行する。メインメモリ502は、例えば、DRAMやSRAMなどの揮発性記憶装置などで構成される。ストレージ503は、例えば、SSDやHDDなどの不揮発性記憶装置などで構成される。ストレージ503には、ウェブサーバから提供されたウェブページを表示するためのブラウザ530が格納される。
【0050】
ユーザインターフェイス504は、例えば、液晶ディスプレイ、有機EL(Electro Luminescence)ディスプレイなどのディスプレイと、キーボード、マウス、タッチパッドなどの入力装置と、を含む。
【0051】
<演算処理回路の機能構成>
図4は、演算処理回路の機能構成の一例を示す図である。図4に示されるように、演算処理回路120は、オクトマップ取得部10と、キャリブレーション部11と、動作区間設定部12と、生成部13と、決定部14と、制御部15と、を備える。オクトマップ取得部10、キャリブレーション部11、動作区間設定部12、生成部13、決定部14、および制御部15は、図3に示すプロセッサ121がシステムプログラム140を実行することにより実現される。
【0052】
キャリブレーション部11、動作区間設定部12、生成部13、および決定部14は、ロボット200を動作させないオフライン期間において、以下に記す処理を実行する。制御部15は、ロボット200を動作させるオンライン期間において、以下に記す処理を実行する。オクトマップ取得部10は、オンライン期間およびオフライン期間の両方において、以下に記す処理を実行する。
【0053】
なお、オフライン期間およびオンライン期間は、交互に繰り返される。例えば、オフライン期間において一旦動作経路が決定され、次のオンライン期間において当該動作経路に従ってロボット200を動作させる。その後、何らかの理由で動作経路の見直しが必要になると、再度オフライン期間において動作経路が決定され、次のオンライン期間において当該動作経路に従ってロボット200を動作させる。
【0054】
(オクトマップ取得部)
オクトマップ取得部10は、オフライン期間およびオンライン期間において、一定周期毎にオクトマップを取得する。オクトマップは、ロボット200の配置される空間において物体が占有する領域を示す占有領域情報である。
【0055】
具体的には、オクトマップ取得部10は、複数のセンシングデバイス300から点群データを取得する。各センシングデバイス300から取得する点群データは、当該センシングデバイス300の座標系(以下、「カメラ座標系」と称する。)で表される。そのため、オクトマップ取得部10は、各センシングデバイス300から取得した点群データを、カメラ座標系からロボット200の座標系(以下、「ロボット座標系」と称する。)に変換する。カメラ座標系からロボット座標系に変換するための変換行列は、センシングデバイス300毎に予め実施されるキャリブレーションによって作成される。取得した全ての点群データを使用すると、コンピューティング負荷が大きくなる。そのため、オクトマップ取得部10は、点群データからオクトマップを生成する。
【0056】
図5は、オクトマップの一例を示す図である。図5に示されるように、オクトマップ50は、空間を区分けすることにより得られる、3次元立方体形状の複数のボクセル51の各々における物体の占有率を示す。物体には、ロボット200とロボット200の周囲の静的物体および動的物体とが含まれ得る。オクトマップ取得部10は、点群データにボクセル51を導入し、ボクセル51毎の占有率を計算する。占有率は、例えば0.00~100の値で示される。点群データからオクトマップ50を生成する手法として、公知の技術(例えば非特許文献2に記載の技術)を用いることができる。このようにして、オクトマップ取得部10は、各周期のオクトマップ50を取得する。
【0057】
(キャリブレーション部)
キャリブレーション部11は、オフライン期間の一部であるキャリブレーション期間において得られたオクトマップ50に基づいて、以下の条件a~cを満たすボクセル群を、ロボット200の周囲に存在する静的物体が占めるボクセル群として特定する。
条件a:占有率が予め定められた閾値以上である。
条件b:キャリブレーション期間において、占有率の時間変化が基準値よりも小さい。
条件c:条件a,bを満たすボクセルが予め定められた個数以上連結している。
キャリブレーション期間は、ロボット200の周囲に動的物体が存在しない期間として予め設定される。
【0058】
キャリブレーション部11は、特定したボクセル群の位置を示すデータを静的物体データ143として生成し、生成した静的物体データ143をストレージ123に格納する。
【0059】
(動作区間設定部)
動作区間設定部12は、オフライン期間において、端末500からの指示に応じて、1以上の動作区間を設定する。具体的には、動作区間設定部12は、1以上の動作区間を設定するための設定画面を示す画面データを端末500に送信する。当該設定画面は、ウェブページとして提供される。すなわち、当該画面データは、HTML(HyperText Markup Language)データであり、端末500が有するブラウザ530によって処理される。これにより、設定画面が端末500のユーザインターフェイス504に表示される。設定画面は、1以上の動作区間の指定を受け付ける。動作区間設定部12は、設定画面が受け付けた指定に従って、1以上の動作区間を設定する。
【0060】
各動作区間は、開始点、終了点、および、ツールセンターポイントが取りうる位置の範囲(以下、「動作可能範囲」と称する。)によって定義される。開始点および終了点は、ロボット200のツールセンターポイントの位置を定義付けるXYZ座標およびツールセンターポイントの姿勢を定義付けるオイラー角(Rx,Ry,Rz)によって表される。オイラー角は、予め定められた基準姿勢に対する、XYZ軸の各軸を中心とする回転角度を示す。
【0061】
なお、複数の動作区間(第1~第N動作区間(Nは2以上の整数))が設定される場合、第k動作区間(kは1~N-1の整数)の終了点は、第k+1動作区間の開始点と同一である。
【0062】
動作区間設定部12は、1以上の動作区間の各々が「Selectable」グループおよび「By Teaching」グループのいずれに属するかの指定の入力を促す画面(ウェブページ)を示す画面データを端末500に送信する。当該画面データは、HTMLデータであり、端末500が有するブラウザ530によって処理される。これにより、端末500は、当該画面を表示し、1以上の動作区間の各々について上記の指定を受け付ける。後述するように、「Selectable」グループに属する各動作区間について複数の経路候補が自動的に生成され、「By Teaching」グループに属する各動作区間におけるロボットの動作を定義付ける教示データの入力が促される。そのため、ユーザは、動作経路の設定のための手間を考慮して、1以上の動作区間の各々の属するグループを指定すればよい。
【0063】
さらに、動作区間設定部12は、1以上の動作区間の各々が「Active」グループおよび「Inactive」グループのいずれに属するかの指定の入力を促す画面(ウェブページ)を示す画面データを端末500に送信する。当該画面データは、HTMLデータであり、端末500が有するブラウザ530によって処理される。これにより、端末500は、当該画面を表示し、1以上の動作区間の各々について上記の指定を受け付ける。後述するように、「Active」グループに属する動作区間では、ロボット200と物体との干渉を回避するための干渉回避動作が有効に設定され、「Inactive」グループに属する動作区間では、ロボット200と物体との干渉を回避するための干渉回避動作が無効に設定される。例えば、ユーザは、制限時間内に完了すべき動作をロボット200に実行させる必要がある動作区間を「Inactive」グループに設定すればよい。これにより、干渉回避動作が実行されることによって動作時間が制限時間を超えるという不具合の発生を防止できる。
【0064】
動作区間設定部12は、画面への入力に応じて、各動作区間が属するグループを設定する。
【0065】
(生成部)
生成部13は、「Selectable」グループに属する各動作区間について、ロボット200の複数の経路候補を生成する。生成部13は、最新のオクトマップ50を用いて、ロボット200が物体と干渉しないように複数の経路候補を生成する。例えば、生成部13は、確率的手法を用いて複数の経路候補を生成する。確率的手法として、RRT(Rapidly-Exploring Random Tree)アルゴリズム、確率的ロードマップ(Probabilistic Road Map:PRM)法などが挙げられる。
【0066】
図6は、RRTアルゴリズムを用いて生成された複数の経路候補の一例を示す図である。RRTアルゴリズムでは、開始点Psおよび終了点Peが与えられたとき、経路計画の演算を行う空間内にランダムに点を配置し、作業条件を満たす点同士を結ぶことにより、経路が生成される。作業条件は、予め定められており、少なくとも、ロボット200が取りうる位置姿勢であるという条件、オクトマップ50において占有率が閾値未満であるという条件、動作可能範囲に含まれるという条件を含む。図6に示す例では、物体占有領域5は、オクトマップ50において占有率が閾値以上のボクセル群の領域である。すなわち、物体占有領域5は、物体が存在している領域である。図6に示されるように、物体占有領域5を避けるように、開始点Psと終了点Peとを繋ぐ複数の経路候補40a~40cが生成される。
【0067】
生成部13は、複数の経路候補の各々を評価してもよい。評価結果は、例えば、経路候補に沿ってロボット200を移動させるときのツールセンターポイントの移動距離および移動時間の少なくとも1つを示す。
【0068】
なお、確率的手法によって、開始点Psと終了点Peとを繋ぐ多数の経路が生成されることが考えられる。当該多数の経路が上記の複数の経路候補として表示されると、ユーザは、選択に迷う。そこで、生成部13は、確率的手法によって開始点Psと終了点Peとを繋ぐ多数の経路を生成した場合、当該多数の経路のうち、移動距離または移動時間が短い上位所定数(例えば3~5個)の経路を経路候補として決定することが好ましい。
【0069】
生成部13は、生成された複数の経路候補を示し、かつ、複数の経路候補の中から1つの経路候補の選択を促す選択画面(ウェブページ)を示す画面データを端末500に送信する。当該画面データは、HTMLデータであり、端末500が有するブラウザ530によって処理される。これにより、端末500は、選択画面をユーザインターフェイス504に表示し、複数の経路候補の中から1つの経路候補の選択を受け付ける。
【0070】
なお、生成部13は、複数の経路候補の各々を評価した場合、選択画面に評価結果を含ませる。これにより、ユーザは、移動距離または移動時間を考慮して、複数の経路候補の中から1つの経路候補を選択できる。
【0071】
生成部13は、「By Teaching」グループに属する各動作区間について、当該動作区間におけるロボットの動作を定義付ける教示データの入力を促す画面(ウェブページ)を示す画面データを端末500に送信する。当該画面データは、HTMLデータであり、端末500が有するブラウザ530によって処理される。これにより、端末500は、当該画面を表示する。そして、端末500は、教示データの入力を受け付ける。教示データは、経路上の全ての点における、ツールセンターポイントの位置姿勢を示す。生成部13は、端末500によって受け付けられた教示データに基づいて、対応する動作区間における1つの経路候補を生成する。
【0072】
(決定部)
決定部14は、端末500のユーザインターフェイス504への操作に応じて、「Selectable」グループに属する各動作区間について、選択画面において選択された1つの経路候補を、当該動作区間の動作経路として決定する。
【0073】
決定部14は、端末500のユーザインターフェイス504への操作に応じて、「By Teaching」グループに属する各動作区間について、教示データに基づいて生成された1つの経路候補を、対応する動作区間におけるロボット200の動作経路として決定する。
【0074】
複数の動作区間(第1~第N動作区間)が生成される場合、決定部14は、第1~第N動作区間について決定した動作経路を順に繋ぐことにより得られる経路を第1動作区間の開始点から第N動作区間の終了点までの全体経路として決定する。
【0075】
決定部14は、生成した動作経路を示す経路データ142を生成し、生成した経路データ142をストレージ123に格納する。
【0076】
(制御部)
制御部15は、オンライン期間において、オクトマップ50に基づいてロボット200の動作を決定し、決定した動作に応じた指令をロボット200に出力する。
【0077】
制御部15は、一定周期毎のオクトマップ50に基づいて、ロボット200の周囲に存在する物体の位置を特定する。具体的には、制御部15は、占有率が予め定められた閾値以上であるボクセル51の位置を物体の位置として特定する。制御部15は、特定した位置のうち、静的物体データ143によって示される位置と異なる位置の物体を動的物体として特定する。
【0078】
制御部15は、非特許文献1に記載の技術を用いて、動的物体から遠ざかろうとする排斥ポテンシャルと、経路データ142によって示される動作経路に沿って移動しようとする親和ポテンシャルとを用いて、ロボット200を制御する。
【0079】
制御部15は、マニピュレータ202における周囲の動的物体(例えば人)に最も近い点の排斥速度ベクトルvcp,repを計算する。排斥速度ベクトルvcp,repの単位ベクトルsは、以下の式(1)で表される。
【0080】
【数1】
【0081】
式(1)において、r1は、マニピュレータ202における周囲の動的物体に最も近い点の位置ベクトルである。r2は、動的物体におけるマニピュレータ202に最も近い点の位置ベクトルである。そのため、単位ベクトルsの方向は、動的物体からマニピュレータ202に向かう。
【0082】
排斥速度ベクトルvcp,repの大きさ|vcp,rep|は、マニピュレータ202と動的物体との最短距離dminから計算される速度vrep1と、マニピュレータ202と動的物体との相対速度に応じて計算される速度vrep2と、の和(vrep1+vrep2)に1次遅れ系の伝達関数γ(=1-exp(-t/τ))を乗じることにより計算される。
【0083】
速度vrep1は、以下の式(2)に従って計算される。式(2)において、k1は定数である。dcrは、マニピュレータ202の周囲に設定される進入禁止ゾーンの幅であり、予め定められる。d0は、オフセット距離であり、以下の式(3)に従って定められる。式(3)において、d1は、定数であり、人が危険と感じる距離に応じて予め定められる。cvは定数である。vrelは、マニピュレータ202と動的物体との相対速度である。マニピュレータ202と動的物体との距離が増大している場合、vrelが正となり、マニピュレータ202と物体との距離が減少している場合、vrelが負となる。
【0084】
【数2】
【0085】
速度vrep2は、以下の式(4)に従って計算される。式(4)において、k2は定数である。cは、マニピュレータ202と動的物体との最短距離dminに応じて変化する係数である。例えば、cは、最短距離dminが予め定められた閾値L1未満である場合に1であり、最短距離dminが予め定められた閾値L2(>L1)を超える場合に0であり、最短距離dminが閾値L1~L2の範囲内である場合に最短距離dminが大きくなるに従って1から0に変化するように予め定められる。
【0086】
【数3】
【0087】
このようにして計算された排斥速度ベクトルvcp,repは、動的物体から遠ざかる方向に向かい、その大きさは、マニピュレータ202と動的物体との距離が小さい程大きくなる。そのため、排斥速度ベクトルvcp,repは、動的物体から遠ざかろうとする排斥ポテンシャルを表している。
【0088】
さらに、制御部15は、エンドエフェクタ230の親和速度ベクトルve,attを計算する。親和速度ベクトルve,attは、以下の式(5)で表される。
e,att=β(ψp+ψi) ・・(5)
式(5)において、ψpは比例項であり、ψiは積分項である。
【0089】
比例項ψpは、以下の式(6)で表される。
ψp=-Kpe ・・(6)
式(6)において、Kpは比例係数である。eは、エンドエフェクタ230の点(例えばツールセンターポイント)を始点とし、動作経路上の次に通過すべき点を終点とする位置偏差ベクトルである。
【0090】
積分項ψiは、以下の式(7)に従って、位置偏差ベクトルeを積分することにより更新される。Kiは積分係数である。すなわち、最短距離dminと進入禁止ゾーンの幅dcrとの差がオフセット距離d0よりも大きい期間については、位置偏差ベクトルeの積分値と-Kiとの積だけ積分項ψiが更新され、それ以外の期間では、積分項ψiは更新されない。なお、初期の積分項ψiは0である。
【0091】
【数4】
【0092】
βは、マニピュレータ202と動的物体との最短距離dmin、マニピュレータ202の周囲に設定される進入禁止ゾーンの幅dcrおよびオフセット距離d0を以下の式(8)に代入することにより計算される。
【0093】
【数5】
【0094】
制御部15は、上記のようにして計算した排斥速度ベクトルvcp,repと以下の式(9)とを用いて、マニピュレータ202の関節20_1~20_6の速度ベクトルqrepを計算する。さらに、制御部15は、上記のようにして計算した親和速度ベクトルve,attと以下の式(10)とを用いて、マニピュレータ202の関節20_1~20_6の速度ベクトルqattを計算する。
【0095】
【数6】
【0096】
式(9)において、Jcpは、マニピュレータ202における周囲の動的物体に最も近い点のヤコビアン行列である。式(10)において、Jeは、エンドエフェクタ230の点(例えばツールセンターポイント)におけるヤコビアン行列である。λは、ダンピング定数であり、Iは、単位行列である。
【0097】
制御部15は、以下の式(11)に従って、速度ベクトルqrepと速度ベクトルqattとの合成ベクトルqを計算する。そして、制御部15は、合成ベクトルqに従って、マニピュレータ202の各関節の位置および回転角度に関する指令を生成し、生成した指令をマニピュレータコントローラ204に出力する。その結果、マニピュレータ202と動的物体との干渉が回避される。
【0098】
【数7】
【0099】
合成ベクトルqに従って生成された指令が出力されることにより、マニピュレータ202と動的物体との距離が大きく保たれている場合、速度ベクトルqrepの成分が相対的に小さくなり、速度ベクトルqattの成分が相対的に大きくなる。これにより、マニピュレータ202は、動作経路に沿って移動する。以下、動作経路に沿ったマニピュレータ202の移動動作を「平準動作」と称する。
【0100】
マニピュレータ202に動的物体が近づくと、速度ベクトルqrepの成分が相対的に大きくなり、速度ベクトルqattの成分が相対的に小さくなる。これにより、マニピュレータ202は、動作経路から外れ、動的物体から遠ざかるように移動する。その結果、マニピュレータ202と動的物体との干渉が回避される。以下、動的物体から遠ざかるマニピュレータ202の移動動作を「干渉回避動作」と称する。
【0101】
その後、動的物体がマニピュレータ202から離れると、速度ベクトルqrepの成分が相対的に小さくなり、速度ベクトルqattの成分が相対的に大きくなる。これにより、マニピュレータ202は、動作経路に向かって移動した後、動作経路に沿って移動する。以下、動作経路に向かうマニピュレータ202の移動動作を「帰還動作」と称する。
【0102】
ただし、制御部15は、ロボット200の現在の動作区間が後述する「Inactive」グループに属する場合、速度ベクトルqrepを0に設定し、マニピュレータ202が平準動作のみを行なうように制御する。言い換えると、制御部15は、ロボット200の現在の動作区間が後述する「Inactive」グループに属する場合、マニピュレータ202の干渉回避動作を無効にする。一方、制御部15は、ロボット200の現在の動作区間が後述する「Active」グループに属する場合、速度ベクトルqrepを0に設定せず、マニピュレータ202の干渉回避動作を有効にする。
【0103】
また、上記の干渉回避動作が繰り返されると、マニピュレータ202が周囲の静的物体と干渉する可能性がある。そこで、静的物体との干渉を回避するため、制御部15は、上記の処理と並行して、以下の処理を行なう。
【0104】
制御部15は、一定周期毎に、静的物体データ143によって示される位置に存在する静的物体とマニピュレータ202との最短距離を計算する。制御部15は、静的物体とマニピュレータ202との最短距離が予め定められた閾値Th1以下であり、かつ、速度ベクトルqrepの大きさ|qrep|が予め定められた閾値Th2を超えることに応じて、関節20_1~20_6の全ての停止させるための指令を生成し、生成した指令をマニピュレータコントローラ204に出力する。これにより、マニピュレータ202は停止する。以下、マニピュレータ202が停止する動作を「停止動作」と称する。
【0105】
<ユーザインターフェイスの画面例>
図7は、動作区間を設定するための設定画面の一例を示す図である。図7には、第3動作区間SEC3を設定するときの設定画面60が示される。設定画面60は、ウェブページとしてプロセッサ121によって生成され、端末500のユーザインターフェイス504に表示される。図7に示されるように、設定画面60は、表示エリア61と、入力欄62,63と、ボタン64,65と、を含む。
【0106】
表示エリア61には、ロボット200が配置される実空間に対応する仮想空間が表示される。表示エリア61には、形状データ141に基づいて生成されるロボットモデル70が表示される。
【0107】
ボタン64は、新たな動作区間を追加するときに使用される。ボタン64が押下されたことに応じて、プロセッサ121は、表示エリア61に、新たな動作区間(図7に示す例では、第3動作区間SEC3)を定義する立方体モデル72を含まれるように、設定画面60を更新する。立方体モデル72は、新たな動作区間においてツールセンターポイントが取りうる位置の範囲(動作可能範囲)を表す。設定画面60は、立方体モデル72の位置およびサイズの変更指示を受け付けることができる。ただし、1つ前の動作区間(図7に示す例では、第2動作区間SEC2)が設定されている場合、当該1つ前の動作区間の終了点が表面に位置するという制約を満たすように、立方体モデル72の位置およびサイズの変更指示を受け付ける。プロセッサ121は、当該変更指示に応じて設定画面60を更新し、表示エリア61に表示されている立方体モデル72の位置およびサイズを変更する。
【0108】
ボタン65は、動作区間の設定を終了するときに使用される。ボタン65が押下されたことに応じて、プロセッサ121は、動作区間の設定処理を終了する。
【0109】
プロセッサ121は、表示エリア61において、静的物体データ143によって示される位置に仮想物体モデル73を配置する。仮想物体モデル73は、静的物体のモデルである。これにより、ユーザは、立方体モデル72で表される動作区間とロボット200の周囲に存在する静的物体との位置関係を把握できる。
【0110】
なお、プロセッサ121は、立方体モデル72と重なり合う仮想物体モデル73のみを表示エリア61に配置させてもよい。
【0111】
設定画面60は、立方体モデル72の表面において、新たな動作区間の開始点72sおよび終了点72eの指定を受け付ける。ただし、1つ前の動作区間(図7に示す例では、第2動作区間SEC2)が設定されている場合、当該1つ前の動作区間の終了点が新たな動作区間の開始点72sとして決定されるため、設定画面60は、終了点72eのみ受け付ける。
【0112】
開始点72sおよび終了点72eは、ロボット200のツールセンターポイントの位置を定義付けるXYZ座標およびツールセンターポイントの位置を定義付けるオイラー角(Rx,Ry,Rz)によって表される。オイラー角は、予め定められた基準姿勢に対する、XYZ軸の各軸を中心とする回転角度を示す。
【0113】
プロセッサ121は、設定画面60が立方体モデル72の表面上の点の指定を受け付けると、ツールセンターポイントが指定された点にロボットモデル70が位置するように設定画面60を更新する。さらに、プロセッサ121は、設定画面60がロボットモデル70の姿勢の変更指示を受け付けると、ロボットモデル70が当該変更指示に応じた姿勢となるように設定画面60を更新する。ユーザは、新たな動作区間の終了点72eに対応する点を指定するとともに、終了点72eの姿勢と一致するようにロボットモデル70の姿勢の変更指示を入力すればよい。プロセッサ121は、設定画面60への入力に従って、新たな動作区間の終了点72eを設定する。
【0114】
なお、1つ前の動作区間が設定されていない場合、プロセッサ121は、終了点72eの設定方法と同様の設定方法に従って、新たな動作区間の開始点72sを設定すればよい。
【0115】
入力欄62は、動作区間が「Active」グループおよび「Inactive」グループのいずれに属するかの指定を入力するために使用される。プロセッサ121は、入力欄62への入力に従って、動作区間が「Active」グループおよび「Inactive」グループのいずれに属するかを決定する。
【0116】
入力欄63は、動作区間が「Selectable」グループおよび「By Teaching」グループのいずれに属するかの指定を入力するために使用される。プロセッサ121は、入力欄63への入力に従って、動作区間が「Selectable」グループおよび「By Teaching」グループのいずれに属するかを決定する。
【0117】
動作区間が「By Teaching」グループに属する旨の指定が入力されると、プロセッサ121は、当該動作区間におけるマニピュレータ202の動作を定義付ける教示データの入力を促す画面(図示しない)を示す画面データを端末500に送信する。これにより、端末500は、当該画面をユーザインターフェイス504に表示し、教示データの入力を受け付ける。プロセッサ121は、受け付けられた教示データに基づいて、対応する動作区間の動作経路を決定する。
【0118】
動作区間が「Selectable」グループに属する旨の指定が入力されると、プロセッサ121は、当該動作区間の開始点72sと終了点72eとを繋ぎ、かつ、立方体モデル72内を通過する複数の経路候補を生成する。そして、プロセッサ121は、複数の経路候補を示し、かつ、複数の経路候補の中から1つの経路候補の選択を促す選択画面を示す画面データを端末500に送信するこれにより、端末500は、選択画面をユーザインターフェイス504に表示する。
【0119】
図8は、複数の経路候補の中から1つの経路候補の選択を促す選択画面の一例を示す図である。図8に示す選択画面60Aは、図7に示す設定画面60と同様に表示エリア61を含む。選択画面60Aは、さらに、ラジオボタン66と、表示欄67と、ボタン68と、を含む。図8に示されるように、表示エリア61には、経路候補40a~40cが表示される。
【0120】
プロセッサ121は、経路候補40a~40cのいずれかがクリックされたことに応じて、ロボットモデル70がクリックされた経路候補に沿って移動するように選択画面60Aを生成する。これにより、ユーザは、各経路候補に沿ったロボット200の動作を把握しやすくなる。
【0121】
表示欄67には、経路候補40a~40cの評価結果が表示される。上述したように、評価結果は、例えば、経路候補に沿ってロボット200を移動させるときのツールセンターポイントの移動距離および移動時間の少なくとも1つを示す。
【0122】
ラジオボタン66は、経路候補40a~40cの中から1つの経路候補を選択するために使用される。プロセッサ121は、表示エリア61において、ラジオボタン66によって選択された経路候補(図8では経路候補40a)が実線で表され、残りの経路候補(図8では経路候補40b,40c)が破線で表されるように、選択画面60Aを更新する。
【0123】
ボタン68は、経路候補の選択を確定するために使用される。プロセッサ121は、ボタン68が押下されたときにラジオボタン66によって選択されている経路候補を、対象の動作区間の動作経路として決定する。
【0124】
なお、表示エリア61において、各動作区間の動作経路の表示形式は、「Active」グループおよび「Inactive」グループのうち当該動作区間が属するグループに応じて異なることが好ましい。例えば、「Active」グループに属する動作区間の動作経路が緑色で表示され、「Inactive」グループに属する動作区間の動作経路が赤色で表示される。
【0125】
<制御装置の処理の流れ>
(オフライン期間)
図9は、オフライン期間における制御装置の処理の流れを示すフローチャートである。
【0126】
まず、プロセッサ121は、動作区間の指定を受け付けた否かを判断する(ステップS1)。例えば、プロセッサ121は、端末500に提供している設定画面60(図7参照)のボタン64が押下された場合に動作区間の指定を受け付けたと判断する。動作区間の指定を受け付けていない場合(ステップS1でNO)、処理はステップS1に戻る。
【0127】
動作区間の指定を受け付けた場合(ステップS1でYES)、プロセッサ121は、設定画面60への入力に応じて、動作区間が属するグループを決定する(ステップS2)。次に、プロセッサ121は、設定画面60への入力に応じて、動作区間の動作経路を決定する(ステップS3)。
【0128】
次に、プロセッサ121は、次の動作区間の指定を受け付けたか否かを判断する(ステップS4)。例えば、プロセッサ121は、図7に示す設定画面60のボタン64が押下された場合に次の動作区間の指定を受け付けたと判断する。次の動作区間の指定を受け付けた場合(ステップS4でYES)、処理はステップS2に戻る。
【0129】
次の動作区間の指定を受け付けていない場合(ステップS4でNO)、プロセッサ121は、終了指示を受け付けたか否かを判断する(ステップS5)。例えば、プロセッサ121は、図7に示す設定画面60のボタン65が押下された場合に終了指示を受け付けたと判断する。
【0130】
終了指示を受け付けていない場合(ステップS5でNO)、処理はステップS4に戻る。終了指示を受け付けた場合(ステップS5でYES)、処理は終了する。
【0131】
図10は、図9に示すステップS3のサブルーチンの処理の流れを示すフローチャートである。
【0132】
プロセッサ121は、設定された1以上の動作区間のうちの1つの動作区間を選択する(ステップS11)。
【0133】
次に、プロセッサ121は、設定画面60への入力に基づいて、選択された動作区間が「Selectable」グループおよび「By Teaching」グループのいずれに属するかを判別する(ステップS12)。
【0134】
ステップS12において動作区間が「Selectable」グループに属すると判別された場合、プロセッサ121は、選択された動作区間について複数の経路候補を生成する(ステップS13)。さらに、プロセッサ121は、生成した複数の経路候補の各々を評価する(ステップS14)。
【0135】
次に、プロセッサ121は、複数の経路候補と評価結果とを含む選択画面を提供する(ステップS15)。提供された選択画面は、例えば端末500のユーザインターフェイス504に表示される。プロセッサ121は、選択画面を介して、複数の経路候補の中から1つの経路候補の選択を受け付ける(ステップS16)。
【0136】
次に、プロセッサ121は、指定された1つの経路候補を、対象の動作区間の動作経路として決定する(ステップS17)。
【0137】
ステップS12において動作区間が「By Teaching」グループに属すると判別された場合、プロセッサ121は、マニピュレータ202の動作を定義付ける教示データの入力を促す画面を提供し、教示データを受け付ける(ステップS18)。
【0138】
次に、プロセッサ121は、教示データに基づいて、選択された動作区間の動作経路を決定する(ステップS19)。
【0139】
ステップS17またはステップS19の後、プロセッサ121は、残りの動作区間が存在するか否かを判定する(ステップS20)。
【0140】
残りの動作区間が存在する場合(ステップS20でYES)、処理はステップS11に戻る。残りの動作区間が存在しない場合(ステップS20でNO)、処理は図9に示すステップS4に移る。
【0141】
(オンライン期間)
図11は、オンライン期間におけるロボットの制御処理の流れを示すフローチャートである。まず、プロセッサ121は、動作経路上の次に通過すべき点を決定する(ステップS31)。
【0142】
次に、プロセッサ121は、静的物体とマニピュレータ202との最短距離が閾値Th1以下であるか否かを判断する(ステップS32)。
【0143】
静的物体とマニピュレータ202との最短距離が閾値Th1を超える場合(ステップS32でNO)、プロセッサ121は、現在の動作区間が「Inactive」グループに属するか否かを判断する(ステップS33)。現在の動作区間が「Active」グループに属する場合(ステップS33でNO)、処理はステップS35に移る。現在の動作区間が「Inactive」グループに属する場合(ステップS33でYES)、プロセッサ121は、速度ベクトルqrepを0に設定する(ステップS34)。その後、処理はステップS35に移る。
【0144】
ステップS35において、プロセッサ121は、上記の合成ベクトルqを計算する。次に、プロセッサ121は、合成ベクトルqに応じた指令を生成し、生成した指令をロボット200に出力する(ステップS36)。
【0145】
静的物体とマニピュレータ202との最短距離が閾値Th1以下である場合(ステップS32でYES)、プロセッサ121は、動的物体との干渉リスクが基準より大きいか否かを判断する(ステップS37)。例えば、プロセッサ121は、qrepの大きさ|qrep|が予め定められた閾値Th2を超える場合に、動的物体との干渉リスクが基準より大きいと判断する。動的物体との干渉リスクが基準以下であることは、動作経路に沿って移動しようとする親和ポテンシャルが動的物体から遠ざかろうとする排斥ポテンシャルよりも大きいことを意味する。そのため、合成ベクトルqに応じた指令に従った動作は、帰還動作または平準動作となる。そこで、動的物体との干渉リスクが基準以下である場合(ステップS37でNO)、処理はステップS33に移る。
【0146】
動的物体との干渉リスクが基準より大きい場合(ステップS37でYES)、プロセッサ121は、停止動作を行なうための指令を生成し、生成した指令をロボット200に出力する(ステップS38)。
【0147】
ステップS36またはステップS38の後、プロセッサ121は、ロボット200が最後の動作区間の終了点に到着したか否かを判断する(ステップS39)。最後の動作区間の終了点に到達していない場合(ステップS39でNOの場合)、処理はステップS31に戻る。最後の動作区間の終了点に到達した場合(ステップS39でYESの場合)、処理は終了する。
【0148】
<変形例>
(変形例1)
プロセッサ121は、各動作区間について決定された動作経路の調整を受け付けてもよい。例えば、プロセッサ121は、各動作区間の動作経路を表示し、動作経路上の任意の点の移動操作を受け付けるための画面(ウェブページ)を示す画面データを端末500に送信してもよい。プロセッサ121は、当該画面に対する移動操作に応じて、動作経路を変更すればよい。
【0149】
(変形例2)
プロセッサ121は、1つの動作区間を2以上の動作区間に分割する指示を受け付けてもよい。例えば、プロセッサ121は、分割面の指定を受け付けるための画面(ウェブページ)を示す画面データを端末500に送信する。プロセッサ121は、当該画面において指定された分割面で動作区間を分割する。
【0150】
ロボット200の動作経路の設定に慣れていないユーザにとって、出発点から目的点までの広い範囲について複数の動作区間を適切に指定することが困難である。このようなユーザは、出発点から目的点までの広い範囲を初期動作区間として指定するとともに、当該初期動作区間を「Selectable」グループに属するように指定する。
【0151】
図12は、広い範囲を初期動作区間として指定したときの設定画面の一例を示す図である。図12に示す選択画面60Bの表示エリア61には、初期動作区間SEC1に対応する立方体モデル72の表面に指定された開始点72sおよび終了点72eを繋ぐ経路候補40d~40fが表示される。ユーザは、ラジオボタン66を操作することにより、経路候補40d~40fの中から1つを選択する。これにより、初期動作区間SEC1について動作経路が決定される。
【0152】
ユーザは、決定された動作経路を確認しながら、初期動作区間SEC1を複数の動作区間に分割すればよい。例えば、ユーザは、動作経路において進行方向が変化する箇所を通るように分割面を指定すればよい。これにより、動作の内容が変化するタイミングで動作区間を異ならせることができる。
【0153】
図13は、初期動作区間を複数の動作区間に分割するときの設定画面の一例を示す図である。図13に示す設定画面60Cの表示エリア61では、初期動作区間SEC1を3つに分割するための分割面77(1),77(2)が指定されている。プロセッサ121は、指定された分割面77(1),77(2)に従って、初期動作区間SEC1を動作区間SEC1(1),SEC1(2),SEC1(3)に分割する。動作区間SEC1(1)~SEC1(3)の動作可能範囲は、立方体モデル72(1)~72(3)によってそれぞれ表される。さらに、プロセッサ121は、指定された分割面77(1),77(2)に従って、初期動作区間SEC1に対して決定された動作経路を動作経路42(1)~42(3)に分割する。動作経路42(1)~42(3)は、動作区間SEC1(1)~SEC1(3)にそれぞれ属する。
【0154】
変形例2には変形例1が組合わされてもよい。例えば、設定画面60Cは、調整対象区間を選択するための入力欄69を含む。ユーザは、調整対象となる動作区間を入力欄69に入力する。図13に示す例では、動作区間SEC1(1)が調整対象として選択されている。設定画面60Cは、調整対象として選択された動作区間の動作経路(図13では、動作区間SEC1(1)の動作経路42(1))上の点の移動操作を受け付ける。例えば、ユーザは、動作経路42(1)上の任意の点をドラッグして移動すればよい。プロセッサ121は、当該移動操作に応じて、動作経路を変更する。これにより、ロボット200の動作経路の設定に慣れていないユーザであっても、簡易な操作で動作経路を設定することができる。
【0155】
設定画面60Cは、ボタン78を含む。ボタン78が押下されたことにより、プロセッサ121は、調整後の動作経路に従って経路データ142を生成し、生成した経路データ142をストレージ123に格納する。
【0156】
なお、設定画面60Cは、分割により得られた2以上の動作区間の各々について、「Active」グループおよび「Inactive」グループのいずれに属するかの指定を受け付けてもよい。プロセッサ121は、当該指定に従って、分割により得られた2以上の動作区間の各々が「Active」グループおよび「Inactive」グループのいずれに属するかを決定する。
【0157】
(変形例3)
生成部13として動作するプロセッサ121は、「Selectable」グループに属する各動作区間について生成した複数の経路候補の各々について、物体との干渉のリスクの度合いを評価してもよい。
【0158】
物体との干渉のリスクの度合いを評価するために、オンライン期間において、ロボット200のツールセンターポイントの位置毎の、ロボット200とロボット200の周囲に存在する物体との干渉のリスクを示すリスクマップMap(ptcp,Irisk)が取得される。
【0159】
リスクマップMap(ptcp,Irisk)は、ロボット200を含む空間に配列された複数のボクセルptcpの各々について、当該ボクセルptcpにロボット200のツールセンターポイントが位置するときのリスク値Iriskを示す。リスクマップMap(ptcp,Irisk)のボクセルptcpのサイズは、オクトマップ50のボクセル51のサイズと同じであってもよいし、異なっていてもよい。各ボクセルptcpは、xyz座標によって特定される。
【0160】
リスクマップ取得部として動作するプロセッサ121は、ロボット200の周囲に人が存在しないタイミング(例えばロボット200の動作開始前のタイミング)のオクトマップ50に基づいて、初期のリスクマップMap(ptcp,Irisk)を生成する。ロボット200の周囲に人が存在しないため、オクトマップ50において、静的物体が占有する領域のボクセル51のみ高い占有率を示す。プロセッサ121は、静的物体が占有する領域に位置するボクセルptcpのリスク値Iriskが0.97を示し、残りのボクセルptcpのリスク値Iriskが0を示すように、初期のリスクマップMap(ptcp,Irisk)を生成する。
【0161】
プロセッサ121は、ロボット200の動作中において、所定期間(例えば、数時間、1日、数日、1週間、数週間、1ヶ月、数ヶ月など)毎にリスクマップMap(ptcp,Irisk)を更新する。
【0162】
プロセッサ121は、所定期間において計算された速度ベクトルqrepに基づいて、以下のようにしてリスクマップMap(ptcp,Irisk)を更新する。
【0163】
まず、プロセッサ121は、所定期間において、速度ベクトルqrepが計算されるたびに、以下の式(12)に従ってリスク尤度qrisk_likelihoodを計算する。
【0164】
【数8】
【0165】
式(12)において、jは、関節20_1~20_6を特定するための変数であり、1~6の整数である。qj repは、速度ベクトルqrepのうち関節20_jの角速度成分である。qj maxは、関節20_jが取りうる最大角速度である。上述したように、速度ベクトルqrepは、動的物体から遠ざかろうとする排斥ポテンシャルに応じて求められた排斥速度ベクトルvcp,repと、マニピュレータ202における周囲の動的物体に最も近い点のヤコビアン行列Jcpとを用いて計算される。そのため、リスク尤度qrisk_likelihoodが大きいほど、動的物体との干渉のリスクが大きい。
【0166】
プロセッサ121は、複数のボクセルptcpの各々について、当該ボクセルptcpにツールセンターポイントが位置するときのリスク尤度qrisk_likelihoodの所定期間の積算値を示すリスク尤度マップMap(ptcp,qrisk_likelihood)を生成する。
【0167】
次に、プロセッサ121は、以下の式(13)に従ってリスク尤度マップMap(ptcp,qrisk_likelihood)を正規化することにより、正規化後マップMap(ptcp,Ratiorisk)を生成する。式(13)において、qrisk_likelihood_kは、k番目のボクセルptcp_kのリスク尤度qrisk_likelihoodである。Nは、ボクセルptcpの総数である。
【0168】
【数9】
【0169】
ロボット200の動作中において、ツールセンターポイントは、全てのボクセルptcpを通過するわけではない。そのため、正規化後マップMap(ptcp,Ratiorisk)において、あるボクセルptcpのRatioriskが0.8であるのに対し、隣のボクセルptcpのRatioriskが0であり得る。これは、あるボクセルptcpにツールセンターポイントが位置したときの速度ベクトルqrepが大きな値であったにもかかわらず、隣のボクセルptcpをツールセンターポイントが一度も通過しなかったためである。仮に隣のボクセルptcpにツールセンターポイントが位置した場合、速度ベクトルqrepは、比較的大きな値をとることが予想される。そこで、プロセッサ121は、正規化後マップMap(ptcp,Ratiorisk)に対して膨張処理を施し、膨張処理後マップMap(ptcp,infRatiorisk)を生成する。
【0170】
図14は、膨張処理を説明する図である。図14に示されるように、1ボクセルのサイズを標準偏差とする正規分布に従いリスクが広がっていると仮定して、各ボクセルptcpのRatioriskの影響分を周辺のボクセルptcpのRatioriskに加算する膨張処理が実施される。
【0171】
プロセッサ121は、所定期間毎に、以下の式(14)に従って、膨張処理後マップMap(ptcp,infRatiorisk)を用いてリスクマップMap(ptcp,Irisk)を更新する。
【0172】
【数10】
【0173】
式(14)において、logOdsは対数オッズ関数であり、以下の式(15),(16)に従って計算される。inv_logOdsは、対数オッズの逆変換関数であり、以下の式(17)に従って計算される。
【0174】
【数11】
【0175】
生成部13として動作するプロセッサ121は、オンライン期間において取得されたリスクマップMap(ptcp,Irisk)を用いて、物体との干渉のリスクの度合いを評価する。例えば、当該度合いは、対応する経路候補が通過するボクセルptcpのリスク値Iriskの総和によって表される。
【0176】
プロセッサ121は、複数の経路候補の各々の評価結果として、物体との干渉のリスクの度合いを含むように選択画面を生成すればよい。これにより、ユーザは、物体との干渉のリスクを考慮して、複数の経路候補の中から1つの経路候補を選択できる。
【0177】
(変形例4)
上記の説明では、制御部15は、静的物体とマニピュレータ202との最短距離が閾値Th1以下であり、かつ、速度ベクトルqrepの大きさ|qrep|が閾値Th2を超えることに応じて、関節20_1~20_6の全ての停止させるための指令を生成する。しかしながら、制御部15は、静的物体とマニピュレータ202との最短距離が閾値Th1以下であり、かつ、変形例3において説明したリスク尤度qrisk_likelihoodが予め定められた閾値Th3を超えることに応じて、関節20_1~20_6の全ての停止させるための指令を生成してもよい。
【0178】
(変形例5)
制御部15として動作するプロセッサ121は、オンライン期間において、ロボット200の現状の動作が平準動作、干渉回避動作、帰還動作および停止動作のいずれであるのかを示す動作状況情報を生成し、生成した情報を出力してもよい。生成された情報は、端末500に出力されてもよいし、図示しないインジケーターに出力されてもよい。これにより、ユーザは、当該情報を確認することにより、ロボット200の現状の動作状況を把握できる。
【0179】
例えば、プロセッサ121は、動的物体との干渉のリスクを表すパラメータ(以下、「リスクパラメータ」と称する。)と、マニピュレータ202と静的物体との最短距離とを用いて、動作状況情報を生成すればよい。リスクパラメータとして、例えば、変形例3において説明したリスク尤度qrisk_likelihoodが用いられる。あるいは、リスクパラメータとして、速度ベクトルqrepの大きさ|qrep|が用いられてもよい。
【0180】
例えば、プロセッサ121は、リスクパラメータが予め定められた閾値Th4以下であり、かつ、ロボット200が動作経路上に存在することに応じて、ロボット200の現状の動作が平準動作であることを示す動作状況情報を生成する。
【0181】
プロセッサ121は、リスクパラメータが閾値Th4を超え、かつ、静的物体とマニピュレータ202との最短距離が閾値Th1を超えることに応じて、ロボット200の現状の動作が干渉回避動作であることを示す動作状況情報を生成する。
【0182】
プロセッサ121は、リスクパラメータが閾値Th4を超え、かつ、静的物体とマニピュレータ202との最短距離が閾値Th1以下であることに応じて、ロボット200の現状の動作が停止動作であることを示す動作状況情報を生成する。
【0183】
プロセッサ121は、リスクパラメータが閾値Th4以下であり、かつ、ロボット200が動作経路上に存在しないことに応じて、ロボット200の現状の動作が帰還動作であることを示す動作状況情報を生成する。
【0184】
なお、リスクパラメータとして速度ベクトルqrepの大きさ|qrep|が用いられる場合、閾値Th4は、停止動作を行なうか否かを判断するために使用される上記の閾値Th2と同じである。リスクパラメータとしてリスク尤度qrisk_likelihoodが用いられる場合、閾値Th4は、変形例4において説明した閾値Th3と同じである。
【0185】
(変形例6)
生成部13は、複数の経路候補と変形例3において説明したリスクマップMap(ptcp,Irisk)とが重ねて表示されるように選択画面を生成してもよい。これにより、ユーザは、複数の経路候補のうち物体との干渉のリスクの低い経路候補を選択しやすくなる。
【0186】
図15は、変形例6の選択画面を示す図である。図15に示されるように、選択画面60Dは、図8に示す選択画面60Aと比較して、経路候補40a~40cにリスクマップMap(ptcp,Irisk)が重ねて表示される点で相違する。リスクマップMap(ptcp,Irisk)は、リスク値Iriskに応じた濃度の空間分布を示す形式で表示される。これにより、ユーザは、経路候補40a~40cの各々に沿ってロボット200を動作させたときの、物体との干渉のリスクの大小を把握でき、当該リスクを考慮して1つの経路候補を選択できる。
【0187】
§3 付記
以上のように、本実施の形態は以下のような開示を含む。
【0188】
(構成1)
ロボット(200)の動作前に前記ロボット(200)の動作経路を生成する装置(100)であって、
指定された1以上の動作区間のうちの対象動作区間について、前記ロボット(200)の複数の経路候補(40a~40f)を生成し、前記複数の経路候補(40a~40f)の中から1つの経路候補の選択を受け付ける画面(60A,60B,60D)を示すデータを提供する生成部(13,121)と、
前記1つの経路候補を前記対象動作区間の前記動作経路として決定する決定部(14,121)とを備える、装置(100)。
【0189】
(構成2)
前記生成部(13,121)は、前記ロボット(200)の配置される空間において物体が占有する領域を示す占有領域情報(50)を用いて、前記物体と干渉しないように前記複数の経路候補(40a~40f)を生成する、構成1に記載の装置(100)。
【0190】
(構成3)
前記生成部(13,121)は、確率的手法を用いて前記複数の経路候補を生成する、構成1または2に記載の装置(100)。
【0191】
(構成4)
前記生成部(13,121)は、前記複数の経路候補(40a~40f)の各々を評価し、
前記画面(60A,60B,60D)は、前記複数の経路候補(40a~40f)に対する評価結果を含む、構成1から3のいずれかに記載の装置(100)。
【0192】
(構成5)
前記評価結果は、前記複数の経路候補(40a~40f)の各々について、移動距離、移動時間および物体との干渉のリスクの度合いの少なくとも1つを表す、構成4に記載の装置(100)。
【0193】
(構成6)
前記1以上の動作区間は、第1~第N動作区間を含み、Nは2以上の整数であり、
前記装置は、さらに、
前記第1~第N動作区間の各々が第1グループおよび第2グループのいずれに属するかを設定する設定部(12,121)を備え、
前記設定部(12,121)は、前記第1~第N動作区間のうち前記第1グループに属する各動作区間を前記対象動作区間として設定し、
前記決定部は、
前記第1~第N動作区間のうち前記第2グループに属する各動作区間について、指定された教示データに基づいて前記ロボット(200)の前記動作経路を決定し、
前記第1~第N動作区間について決定した前記動作経路を順に繋ぐことにより得られる経路を前記第1動作区間の開始点から前記第N動作区間の終了点までの全体経路として決定する、構成1から5のいずれかに記載の装置(100)。
【0194】
(構成7)
前記全体経路に沿って前記ロボット(200)を動作させる制御部(15,121)をさらに備え、
前記設定部(12,121)は、前記第1~第N動作区間の各々が第3グループおよび第4グループのいずれに属するかをさらに設定し、
前記制御部(15,121)は、
前記ロボット(200)の周囲の物体との干渉を回避するための干渉回避動作を行なうように前記ロボット(200)を制御可能であり、
前記第1~第N動作区間のうち前記第3グループに属する各動作区間に対応する前記動作経路に沿って前記ロボット(200)を動作させている場合、前記干渉回避動作を有効にし、
前記第1~第N動作区間のうち前記第4グループに属する各動作区間に対応する前記動作経路に沿って前記ロボット(200)を動作させている場合、前記干渉回避動作を無効にする、構成6に記載の装置(100)。
【0195】
(構成8)
前記干渉回避動作は、動的物体から遠ざかる動作を含み、
前記制御部(15,121)は、
動作中の前記ロボット(200)と前記ロボット(200)の周囲の静的物体との干渉のリスクを評価し、
前記リスクが予め定められた第2基準を超えたことに応じて、前記ロボット(200)を停止させる、構成7に記載の装置(100)。
【0196】
(構成9)
ロボット(200)の動作前に前記ロボット(200)の動作経路を生成する方法であって、
1以上の動作区間の指定を受け付けるステップと、
前記1以上の動作区間のうちの対象動作区間について、前記ロボット(200)の複数の経路候補(40a~40f)を生成するステップと、
前記複数の経路候補(40a~40f)をユーザインターフェイス(504)に表示するステップと、
前記複数の経路候補(40a~40f)の中から1つの経路候補の選択を受け付けるステップと、
前記1つの経路候補を前記対象動作区間の前記動作経路として決定するステップとを備える、方法。
【0197】
(構成10)
ロボット(200)の動作前に前記ロボット(200)の動作経路を生成する方法をコンピュータに実行させるプログラムであって、
前記方法は、
1以上の動作区間の指定を受け付けるステップと、
前記1以上の動作区間のうちの対象動作区間について、前記ロボット(200)の複数の経路候補(40a~40f)を生成するステップと、
前記複数の経路候補(40a~40f)の中から1つの経路候補の選択を受け付ける画面(60A,60B,60D)を示すデータを提供するステップと、
前記1つの経路候補を前記対象動作区間の前記動作経路として決定するステップとを含む、プログラム。
【0198】
本発明の実施の形態について説明したが、今回開示された実施の形態はすべての点で例示であって制限的なものではないと考えられるべきである。本発明の範囲は特許請求の範囲によって示され、特許請求の範囲と均等の意味および範囲内でのすべての変更が含まれることが意図される。
【符号の説明】
【0199】
1 システム、5 物体占有領域、10 オクトマップ取得部、11 キャリブレーション部、12 動作区間設定部、13 生成部、14 決定部、15 制御部、20_1~20_6 関節、40a~40f 経路候補、42(1)~42(3) 動作経路、50 オクトマップ、51 ボクセル、60,60C 設定画面、60A,60B 選択画面、61 表示エリア、62,63,69 入力欄、64,65,68,78 ボタン、66 ラジオボタン、67 表示欄、70 ロボットモデル、72 立方体モデル、72e,Pe 終了点、72s,Ps 開始点、73 仮想物体モデル、77(1),77(2) 分割面、100 制御装置、120 演算処理回路、121,501 プロセッサ、122,502 メインメモリ、123,503 ストレージ、124 インターフェイス回路、130 フィールドネットワークコントローラ、140 システムプログラム、141 形状データ、142 経路データ、143 静的物体データ、200 ロボット、202 マニピュレータ、204 マニピュレータコントローラ、220 アーム、230 エンドエフェクタ、300 センシングデバイス、500 端末、504 ユーザインターフェイス、530 ブラウザ。
図1
図2
図3
図4
図5
図6
図7
図8
図9
図10
図11
図12
図13
図14
図15