JP2021000672A - 調整支援装置 - Google Patents

調整支援装置 Download PDF

Info

Publication number
JP2021000672A
JP2021000672A JP2019114072A JP2019114072A JP2021000672A JP 2021000672 A JP2021000672 A JP 2021000672A JP 2019114072 A JP2019114072 A JP 2019114072A JP 2019114072 A JP2019114072 A JP 2019114072A JP 2021000672 A JP2021000672 A JP 2021000672A
Authority
JP
Japan
Prior art keywords
control
adjustment
data
force
force control
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2019114072A
Other languages
English (en)
Other versions
JP7239399B2 (ja
Inventor
幹人 ▲羽▼根
幹人 ▲羽▼根
Mikito Hane
佐藤 貴之
Takayuki Sato
貴之 佐藤
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fanuc Corp
Original Assignee
Fanuc Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Fanuc Corp filed Critical Fanuc Corp
Priority to JP2019114072A priority Critical patent/JP7239399B2/ja
Priority to US16/889,807 priority patent/US11285602B2/en
Priority to DE102020115658.8A priority patent/DE102020115658A1/de
Priority to CN202010568366.4A priority patent/CN112109080A/zh
Publication of JP2021000672A publication Critical patent/JP2021000672A/ja
Application granted granted Critical
Publication of JP7239399B2 publication Critical patent/JP7239399B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1628Programme controls characterised by the control loop
    • B25J9/163Programme controls characterised by the control loop learning, adaptive, model based, rule based expert control
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J13/00Controls for manipulators
    • B25J13/08Controls for manipulators by means of sensing devices, e.g. viewing or touching devices
    • B25J13/085Force or torque sensors
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1628Programme controls characterised by the control loop
    • B25J9/1633Programme controls characterised by the control loop compliant, force, torque control, e.g. combined with position control
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1656Programme controls characterised by programming, planning systems for manipulators
    • B25J9/1661Programme controls characterised by programming, planning systems for manipulators characterised by task planning, object-oriented languages
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/33Director till display
    • G05B2219/33056Reinforcement learning, agent acts, receives reward, emotion, action selective
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/40Robotics, robotics mapping to robotics vision
    • G05B2219/40032Peg and hole insertion, mating and joining, remote center compliance
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/40Robotics, robotics mapping to robotics vision
    • G05B2219/40033Assembly, microassembly

Abstract

【課題】力制御のパラメータ調整に失敗した場合に、過去に行われた力制御で用いられる制御パラメータに基づく調整支援を行う調整支援装置を提供すること。【解決手段】調整支援装置1は、産業用ロボットの力制御を行った時の動作における力状態データ及び位置データを状態変数とし、該状態の下で行われた力制御の結果を所定の基準で良否の判定をした判定データとして、機械学習することにより生成された学習モデルを記憶する学習モデル記憶部150と、学習モデルを解析して、産業用ロボット2の力制御に失敗した際に用いていた制御パラメータについて、該力制御の成功度を改善する該制御パラメータの調整方法を解析する解析部130と、解析部130による解析の結果に基づいて力制御に失敗した際に用いていた力制御の制御パラメータの調整方法を決定して出力する調整決定部38とを備える。【選択図】図2

Description

本発明は、調整支援装置に関し、特にロボットの力制御における制御パラメータの設定に係る調整支援装置に関する。
部品同士を精密な嵌め合う場合やギヤの位相合わせ、バリ取りや研磨などの作業を力センサ付きロボットで行う場合がある。このような作業は、ロボットに部品やツールを把持させて、所定の方向の力を所望の値に制御する(力制御)ことにより実現される。この様な力制御の方式として、インピーダンス制御やダンピング制御、ハイブリッド制御などが知られているが、いずれの方式でも適切な制御ゲインを人手で設定する必要がある。制御ゲインを自動調整する方法は公知である(例えば、特許文献1等)。
特開2007−237312号公報
上記したように、力制御における制御ゲインの設定方法については公知となっているが、その他のパラメータ、例えば適切な押付け力や進行速度、進行方向などは作業者による調整に頼っているが、この様なパラメータ調整に失敗した際に、どの制御パラメータを変更すれば問題が解決するのかを判断することが難しい。
そこで、力制御のパラメータ調整に失敗した場合に、過去に行われた力制御で用いられる制御パラメータに基づく調整支援を行う調整支援装置が望まれている。
本発明の一態様による調整支援装置は、機械学習により過去に行われた力制御における制御パラメータと、該力制御の結果に対する判定データとから、類似する判定における力制御時の制御パラメータの特徴を計算する学習モデルを構築し、該学習モデルを用いて制御パラメータの調整を支援することにより、上記課題を解決する。
そして、本発明の一態様では、マニピュレータに掛かる力とモーメントを検出する機能を備えた産業用ロボットの動作の調整を支援する調整支援装置であって、前記産業用ロボットの力制御を行った時の動作における力状態データ及び位置データを状態変数とし、該状態の下で行われた力制御の結果を所定の基準で良否の判定をした判定データとして、機械学習することにより生成された学習モデルを記憶する学習モデル記憶部と、前記学習モデルを解析して、前記産業用ロボットの力制御に失敗した際に用いていた制御パラメータについて、該力制御の成功度を改善する該制御パラメータの調整方法を解析する解析部と、前記解析部による解析の結果に基づいて前記力制御に失敗した際に用いていた力制御の制御パラメータの調整方法を決定して出力する調整決定部と、を備えた調整支援装置である。
本発明により一態様によれば、力制御に失敗した際に、慣れていない作業者であっても適切な力制御の制御パラメータ調整を行う事ができるようになる。
一実施形態による調整支援装置の概略的なハードウェア構成図である。 第1の実施形態による制御装置の概略的な機能ブロック図である。 産業用ロボットによる部品の嵌合作業の例を示す図である。 産業用ロボットによる部品の嵌合作業における動作のフェーズを分ける例を示す図である。 解析部の動作例について説明する図である。 解析部の他の動作例について説明する図である。 産業用ロボットによるギヤの組立作業の例を示す図である。 産業用ロボットによるワークのバリ取り・研磨作業の例を示す図である。 第2の実施形態による制御装置の概略的な機能ブロック図である。 一実施形態によるコンピュータの概略的なハードウェア構成図である。
以下、本発明の実施形態を図面と共に説明する。
図1は一実施形態による調整支援装置の要部を示す概略的なハードウェア構成図である。調整支援装置1は、例えばロボットを制御する制御装置(ロボットコントローラ)として実装することができる。また、調整支援装置1は、例えばロボットを制御する制御装置に併設されたパソコンや、該制御装置に有線/無線のネットワークを介して接続されたセルコンピュータ、エッジコンピュータ、フォグコンピュータ、クラウドサーバ等のコンピュータとして実装することができる。本実施形態では、調整支援装置1を、ロボットを制御する制御装置として実装した場合の例を示す。
本実施形態による調整支援装置1が備えるCPU11は、調整支援装置1を全体的に制御するプロセッサである。CPU11は、ROM12に格納されたシステム・プログラムをバス20を介して読み出し、該システム・プログラムに従って調整支援装置1全体を制御する。RAM13には一時的な計算データ、教示操作盤60や入力装置71を介して作業者が入力した各種データ等が一時的に格納される。
不揮発性メモリ14は、例えば図示しないバッテリでバックアップされたメモリやSSD(Solid State Drive)等で構成され、調整支援装置1の電源がオフされても記憶状態が保持される。不揮発性メモリ14には、インタフェース19を介して教示操作盤60から入力された教示データや、入力装置71から入力されたデータ、図示しないインタフェースを介して入力された産業用ロボット制御用のプログラム、産業用ロボットに取り付けられたセンサ3が検出したデータ(マニピュレータに掛かる力やモーメント等)、産業用ロボットの軸を駆動するサーボモータ50から検出されたデータ(サーボモータ50の電流値、位置、速度、加速度、トルク等)、図示しない外部記憶装置やネットワークを介して読み込まれたデータ等が記憶される。不揮発性メモリ14に記憶されたプログラムや各種データは、実行時/利用時にはRAM13に展開されても良い。また、ROM12には、ロボットの制御や教示位置の教示に掛かる処理などを実行するための各種のシステム・プログラム(後述する機械学習装置100とのやりとりを制御するためのシステム・プログラムを含む)があらかじめ書き込まれている。
表示装置70には、メモリ上に読み込まれた各データ、プログラム等が実行された結果として得られたデータ、後述する機械学習装置100から出力されたデータ等がインタフェース17を介して出力されて表示される。また、キーボードやポインティングデバイス等から構成される入力装置71は、作業者による操作に基づく指令,データ等をインタフェース18を介してCPU11に渡す。
教示操作盤60はディスプレイやハンドル、ハードウェアキー等を備えた手動データ入力装置であり、インタフェース19を介して調整支援装置1からの情報を受けて表示すると共に、ハンドルやハードウェアキー等から入力されたパルスや指令、各種データをCPU11に渡す。
産業用ロボットが備える関節等の軸を制御するための軸制御回路30はCPU11からの軸の移動指令量を受けて、軸の指令をサーボアンプ40に出力する。サーボアンプ40はこの指令を受けて、ロボットが備える軸を移動させるサーボモータ50を駆動する。軸のサーボモータ50は位置・速度検出器を内蔵し、この位置・速度検出器からの位置・速度フィードバック信号を軸制御回路30にフィードバックし、位置・速度のフィードバック制御を行う。なお、図1のハードウェア構成図では軸制御回路30、サーボアンプ40、サーボモータ50は1つずつしか示されていないが、実際には制御対象となるロボットに備えられた軸の数だけ用意される。例えば、6つの軸を備えたロボットの場合には、軸制御回路30、サーボアンプ40、サーボモータ50は、それぞれの軸に対して用意される。
インタフェース21は、調整支援装置1と機械学習装置100とを接続するためのインタフェースである。機械学習装置100は、機械学習装置100全体を統御するプロセッサ101と、システム・プログラム等を記憶したROM102、機械学習に係る各処理における一時的な記憶を行うためのRAM103、及び学習モデル等の記憶に用いられる不揮発性メモリ104を備える。機械学習装置100は、インタフェース21を介して調整支援装置1で取得可能な各情報(マニピュレータに掛かる力やモーメント、サーボモータ50の電流値、位置、速度、加速度、トルク等)を観測することができる。また、調整支援装置1は、機械学習装置100から出力される、力制御パラメータの調整対象と調整方向の指示を受けて、プログラムや教示データに基づくロボットの制御指令の調整等を行う。
図2は、第1実施形態による調整支援装置1と機械学習装置100の概略的な機能ブロック図である。図2に示した各機能ブロックは、図1に示した調整支援装置1が備えるCPU11、及び機械学習装置100のプロセッサ101が、それぞれのシステム・プログラムを実行し、調整支援装置1及び機械学習装置100の各部の動作を制御することにより実現される。
本実施形態の調整支援装置1は、制御部32、データ取得部34、前処理部36、調整決定部38を備え、調整支援装置1が備える機械学習装置100は、学習部110、解析部130を備えている。また、不揮発性メモリ14上には、産業用ロボット2,センサ3等から取得されたデータが記憶される取得データ記憶部54が設けられており、機械学習装置100の不揮発性メモリ104上には、学習部110による機械学習により構築される少なくとも1つの学習モデルを記憶する学習モデル記憶部150が設けられている。
制御部32は、作業者による図示しない操作盤の制御操作や、不揮発性メモリ14等に記憶された制御用プログラムに基づいて産業用ロボット2を制御する機能手段である。制御部32は、制御用プログラム52により産業用ロボット2が備える各軸(関節)の移動が指令されている場合に当該軸を駆動するモータに対して制御周期毎に軸角度の変化量としての指令データを出力する、等といったように、産業用ロボット2の各部を制御するために必要とされる一般的な制御のための機能を備える。また、制御部32は、産業用ロボット2が備える各モータのモータ状態量(モータの電流値、位置、速度、加速度、トルク等)を取得し、データ取得部34へと出力する。
データ取得部34は、産業用ロボット2、センサ3、及び入力装置71等から各種データを取得する機能手段である。データ取得部34は、例えば、産業用ロボット制御用のプログラムによる指令や、産業用ロボット2のマニピュレータに掛かる力やモーメント、産業用ロボット2の軸を駆動するサーボモータ50の電流値、位置、速度、加速度、トルク等を取得し、取得データ記憶部54に記憶する。データ取得部34は、センサ3から検出するデータや、サーボモータ50に掛かるデータを時系列データとして取得するようにしても良い。また、データ取得部34は、入力装置71から作業者が入力した力制御に係る制御パラメータや、力制御の結果に対する判定結果(判定データ)を取得するようにしても良い。データ取得部34は、図示しない外部記憶装置や有線/無線のネットワークを介して他のコンピュータからデータを取得するようにしても良い。
データ取得部34が産業用ロボット2、センサ3、及び入力装置71等から取得した取得データには、予め定められた所定の基準に従って取得データを分類する判定データが付与される。データ取得部34が取得する判定データの例として、図3に示されるような、シリンダーの挿入などでの目的に使われる、円柱を円筒穴に差し込む円柱嵌合の良否を判定する場合を例とすると、予め閾値tlim1<閾値tlim2<閾値tlim3を定めておき、目標深さまで嵌合するまでにかかった時間tがtlim1未満の場合に成功(高)、目標深さまで嵌合するまでに掛かった時間tがtlim1以上閾値tlim2未満の場合に成功(中)、目標深さまで嵌合するまでに掛かった時間tがtlim2以上tlim3未満の場合に成功(低)、時間tlim3までに目標深さまで嵌合しなかった場合に失敗とする事が考えられる。この様に、データ取得部34が取得するデータには、予め定められた基準に基づいて、取得データを成功や失敗等のように複数に分類した判定データが付与される他、更に成功や失敗等の各分類の中を複数の副分類に分類した判定データが付与されるようにしても良い。なお、この判定データは、予め与えられた所定の基準(上記した各閾値と判定式)に基づいて、データ取得部34が自動的に作成するようにしても良い。また、上記した例では、成功の分類を更に時間基準で副分類に分類した判定データを示しているが、例えば、成功の分類を丁寧さ重視の副分類(ロボット先端部に掛かる力の最大値に応じて分類)や速度重視の副分類(作業完了までに掛かった時間に応じて分類)で分類した判定データを付与しても良いし、失敗の副分類をこじり具合(ロボット先端部に掛かる力の最大値に応じて分類)や精度(ロボット先端部の位置の精度に応じて分類)で分類した判定データとしても良い。
更に、産業用ロボット2による力制御が行われた1つの動作を複数のフェーズへと分けた上で、それぞれのフェーズにおいて個別の基準を設けて分類した判定データを付与するようにしても良い。例えば、円柱を円筒穴に対して差し込む円柱嵌合においては、図4に例示されるように、嵌合動作の前半においては円柱部品の姿勢を重視し、嵌合動作の後半では嵌合方向(押し付け方向)の力加減を慎重に調整していく、等と言ったように、各フェーズにおいて重要視される力制御のパラメータが異なる場合がある。このような場合にも対応できるように、取得データに含まれる所定のデータに対して閾値を設けることで力制御のフェーズを分けた上で、それぞれのフェーズにおける動作を所定の基準に基づいて分類した判定データを付与するようにしても良い。例えば、円柱嵌合においては深さ方向の移動距離に対して複数の閾値を設けることで嵌合動作のフェーズを分けるようにすれば良いし、別の力制御を用いた動作においては、例えばロボット先端部の姿勢等に応じて動作のフェーズを分けるようにしても良い。なお、前記した基準や閾値は、例えば熟練した作業者等が適宜定めておくようにしても良い。
前処理部36は、データ取得部34が取得した機械学習用の取得データに基づいて、機械学習装置100による学習に用いられる学習データを作成する。前処理部36は、データ取得部34が取得したデータを機械学習装置100において扱われる統一的な形式へと変換(数値化、サンプリング等)した状態データを作成する。
前処理部36が作成する状態データSは、例えば産業用ロボット2のマニピュレータを力制御する際のマニピュレータに掛かる力に係る情報(目標押付け力や実際に掛かっている力等)を含む力状態データS1、マニピュレータの速度に係る情報(目標速度指令値や位置の推移を示すデータ等)を含む位置データS2を含んでいても良い。この様な場合、力状態データS1は、産業用ロボット2のマニピュレータに掛かる送り方向の力を少なくとも含み、また、送り方向以外の方向に掛かる力や、力のモーメントを含んでいても良い。力状態データS1は、産業用ロボット2に対する指令値や設定値から求めても良いし、産業用ロボット2のマニピュレータに設置されたセンサ3や、それぞれの軸を駆動するサーボモータ50に流れる電流等から総合的に求めるようにしても良い。位置データS2は、前記力状態データS1の力の状態において設定されるマニピュレータの位置の推移を示すデータ等を少なくとも含み、また、更に位置の推移から算出される速度、加速度、目標送り速度指令値、送り方向以外の方向の制御指令を含んでいても良い。
なお、前処理部36が学習データとして用いる判定データDは、取得データ記憶部54に記憶された判定データをそのまま用いるようにすれば良い。
調整決定部38は、設定した制御パラメータに基づく力制御に失敗した際に、機械学習装置100に対して取得データ記憶部54に記憶される取得データに基づく解析を指令して、その結果に基づいて制御パラメータの調整対象と調整方向を決定及び出力する機能手段である。調整決定部38は、例えば入力装置71を介して作業者から産業用ロボット2の力制御に失敗した旨が通知されると、機械学習装置100に対して、取得データ記憶部54に記憶された取得データを用いて学習部110が機械学習をすることで生成された学習モデルを解析し、該解析結果から失敗時に設定されていた制御パラメータのいずれを調整すれば力制御を成功させることができるのかを求める。調整決定部38は、求めた結果を例えば表示装置70に対して表示出力する。
学習部110は、前処理部36が作成したデータを用いた機械学習を行う。学習部110は、例えば教師あり学習等の公知の機械学習の手法により、作業者により調整された産業用ロボット2の動作状態に対する、該動作に対する良否の判定を学習した学習モデルを生成し、生成した学習モデルを学習モデル記憶部150に記憶する。学習部110が行う教師あり学習の手法としては、例えばLinear regression法、Multilayer perceptron法、Recurrent neural network法、Long Short−Term Memory法、convolutional neural network法等が挙げられる。
学習部110は、状態データSに対して判定データDをラベルデータとした学習データを用いて教師あり学習を行い、産業用ロボット2の動作の成功/失敗(即ち、作業者による調整動作の成功/失敗)の判別境界、成功の度合い乃至失敗の度合いの判別境界を学習モデルとして生成することができる。
なお、学習部110は、学習が完了して学習モデル記憶部150に必要な学習モデルが記憶されている状態においては必ずしも必要ではなく、例えばメーカが調整支援装置1を顧客に出荷する際には調整支援装置1から学習部110を取り除いても良い。
解析部130は、調整決定部38からの指令に応じて学習モデル記憶部150に記憶された学習モデルに基づいて、産業用ロボット2の力制御に失敗した際に用いていた制御パラメータの内で、いずれの制御パラメータを調整すれば力制御に成功するのかを解析する機能手段である。解析部130は、例えば制御パラメータの内で、制御ゲイン、力状態データS1に対応するマニピュレータの押付け力、位置データS2に対応するマニピュレータの進行速度、進行方向のいずれの制御パラメータをどの程度調整すれば、失敗した力制御を成功させることができるのかを解析する。
以下では、学習部110が生成する学習モデルと、解析部130による解析処理について、図3に示したシリンダーの嵌合操作を例として説明する。
学習部110は、取得データ記憶部54に記憶されている取得データに基づいて、例えば以下の数1式に示す回帰式をモデルとした学習モデルを生成する。なお、数1式において、pi(i=1,2,3,…)は産業用ロボット2のマニピュレータを力制御する際に設定される制御パラメータであり、Qは成功の度合いを表す重みとして定義される。
学習部110は、取得データ記憶部54に記憶される取得データの内で、所定の同じ指標に基づいた判定データを含む取得データに基づいて学習モデルを生成しても良く、例えば、学習部110は、力制御に成功した際に取得された取得データの内で、シリンダーの嵌合操作における丁寧さ重視の基準での判定データ(丁寧さが高,中,低等)を含む取得データを用いて学習モデルaを生成して学習モデル記憶部150に記憶したり、速度重視の基準での判定データ(速度が高,中,低等)を含む取得データを用いて学習モデルbを生成して学習モデル記憶部150に記憶したりしても良い。また、学習部110は、更に所定の指標における副分類毎に学習モデルを生成しても良く、例えば、学習部110は、シリンダーの嵌合操作における丁寧さ重視の基準での判定データを含む取得データについて、丁寧さが高の副分類に属する取得データに基づいた学習モデルa1、丁寧さが中の副分類に属する所得データに基づいた学習モデルa2、丁寧さが低の副分類に属する所得データに基づいた学習モデルa3をそれぞれ生成して学習モデル記憶部150に記憶するようにしても良い。
このような学習モデルが学習モデル記憶部150に記憶されている時に、調整決定部38から、マニピュレータの力制御に失敗した際の制御パラメータの値と、制御パラメータの調整の基準が指令されると、解析部130は、学習モデル記憶部150に記憶される学習モデルの中から、調整決定部38の指令に含まれる制御パラメータの調整の基準と同じ基準で生成されている学習モデルを選択し、選択した学習モデルを解析することで、産業用ロボット2の力制御に失敗した際に用いていた制御パラメータの内で、いずれの制御パラメータを調整すれば力制御に成功するのかを解析する。
解析処理の一例として、解析部130は、学習モデルとして選択した回帰式上で、成功の度合Qの変化傾向に基づいて、制御パラメータの調整対象を決定しても良い。この様な解析手法を取る場合、解析部130は、まず力制御に失敗した際に取得された制御パラメータの回帰式上での位置を特定する。次に、解析部130は、特定した回帰式上での位置において、それぞれの制御パラメータの傾きを求める。そして、解析部130は、求めたそれぞれの制御パラメータの傾きを比較し、最も傾きが大きい制御パラメータを調整対象の制御パラメータとして決定する。例えば、図5に例示されるように、解析部130は、パラメータpiついて他のパラメータpj(j≠i)を力制御が失敗した際に用いていた値に固定してQとpiの式を作成する。次に、解析部13は、力制御が失敗した際に用いていたpiの値の位置における式の傾きを求める。この様な処理を、それぞれの制御パラメータについて行い、学習モデルとして選択した回帰式において、力制御が失敗した際に用いていた値の位置において最も傾きが大きい制御パラメータを調整対象の制御パラメータとして選択すれば良い。そして、解析部130が選択した調整対象の制御パラメータを、Qが増加する調整方向へと所定の値だけ調整するように、調整決定部38に対して通知する。
解析処理の他の例として、解析部130は、学習モデルとして選択した回帰式の上で、所定の制御パラメータの変分量に対する成功の度合いQの変化傾向に基づいて、制御パラメータの調整対象を決定しても良い。この様な解析手法を取る場合、解析部130は、まず力制御に失敗した際に取得された制御パラメータの回帰式上での位置を特定する。次に、解析部130は、特定した位置の近傍において、それぞれの制御パラメータについて所定の変分量だけ変更した場合の成功の度合いQの変化を算出する。そして、解析部130は、算出した制御パラメータの変分量に対するQの変化の傾向を比較し、制御パラメータの変分量に対してQの変化が最も大きい(効率よくQの値を改善できる)制御パラメータを調整対象の制御パラメータとして決定する。例えば、図6に例示されるように、解析部130は、パラメータpiついて他のパラメータpj(j≠i)を力制御が失敗した際に用いていた値に固定してQとpiの式を作成する。次に、解析部130は、力制御が失敗した際に用いていたpiの値を中心として、所定の変分量Δd毎に変化させた時のQの値を求めることで、力制御が失敗した際のpiの値の近傍におけるQの変化傾向を解析する。この様な処理を、それぞれの制御パラメータについて行い、学習モデルとして選択した回帰式において、力制御が失敗した際に用いていたpiの値の位置において最も効率よくQを増加させることができる制御パラメータを調整対象の制御パラメータとして選択すれば良い。そして、解析部130が選択した調整対象の制御パラメータをQが増加する調整方向へと所定の値だけ調整するように、調整決定部38に対して通知する。この解析手法は学習モデルとしてニューラルネットワーク等を用いている場合にも用いることができる。
なお、解析部130による解析処理は、学習モデルの種類等に合わせて、公知の数理解析の手法や、幾何学的な手法等、力制御に失敗した制御パラメータの値の近辺における成功の度合いQの変化傾向を把握できるどのような手法を採用しても良い。
上記した構成を備えた調整支援装置1では、産業用ロボット2の力制御に失敗した際に、いずれの制御パラメータをどのように調整すれば力制御を成功させる事ができるのかを、過去に取得された取得データに基づいて生成された学習モデルを解析して作業者に通知してくれる。そのため、経験に乏しい作業者であっても効率よく産業用ロボット2の力制御の制御パラメータを調整することが可能となる。
本実施形態の調整支援装置1は、図3に例示した嵌合動作以外にも、例えば図7に例示されるように、産業用ロボット2に取り付けられたマニピュレータでギヤを把持して、他のギヤに対して歯車の位相を合わせながらギヤを組み立てる動作や、図8に例示されるように、産業用ロボット2にマニピュレータのエンドエフェクタ部(ハンド部や先端部等)に代わりに取り付けられた研磨工具でワークのバリ取りや研磨を行う動作等にも適用することができる。
本実施形態の一変形例として、解析部130は、調整対象の制御パラメータとして、複数の制御パラメータを優先順位を付けて調整決定部38に通知するようにしても良い。この様にする場合、例えば、力制御が失敗した際に用いていた制御パラメータのpiの値の位置において、傾きが大きい順に複数の制御パラメータを調整対象として調整決定部38に対して通知するようにしても良い。
本実施形態の他の変形例として、学習部110が学習に用いる状態データSとして、産業用ロボット2及びセンサ3から取得された力状態データ及び位置状態データに加えて、力制御における制御ゲイン、ロボットの先端に取り付けられたツールの質量、ワークとツールとの隙間距離、摩擦係数、温度、力センサ特性等の各種データを状態データSに追加して、機械学習を行うようにしても良い。
図9は、調整支援装置1’を備えた第2実施形態によるシステム170を示す。システム170は、セルコンピュータやフォグコンピュータ、ホストコンピュータ、クラウドサーバ等のコンピュータとして実装されたと調整支援装置1’と、制御部32(ロボットコントローラ)を備えた少なくとも1つの産業用ロボット2と、調整支援装置1’及び産業用ロボット2を互いに接続する有線/無線のネットワーク172とを備える。
本実施形態による調整支援装置1’は、図2で説明した機能手段の内で制御部32以外の機能手段を備えている点で、第1実施形態と異なる。上記構成を有するシステム170では、調整支援装置1’が、各々の産業用ロボット2から動作時に取得された取得データをネットワーク172を介して収集し、収集した取得データを用いた機械学習を行い、学習モデルを生成する。
そして、調整支援装置1’は、各々の産業用ロボット2を利用している作業者から力制御に失敗した際の制御パラメータの調整支援の依頼を受けて、調整対象の制御パラメータとその調整方法を解析し、解析結果を各々の産業用ロボット2に対して返信する。
本実施形態によるシステム170では、例えばエッジコンピュータとしての複数の産業用ロボット2に対して設置されたフォグコンピュータ上に調整支援装置1’を実装し、各々の産業用ロボット2における力制御の制御パラメータの調整支援を調整支援装置1’上で集中的に行うことができるようになり、産業用ロボット2毎に機械学習装置100を用意する必要がなくなるため、機械学習装置100の運用コストを削減することができる。
図10は、図9で示した調整支援装置1’の概略的なハードウェア構成図である。
調整支援装置1’が備えるCPU511は、調整支援装置1’を全体的に制御するプロセッサである。CPU511は、ROM512に格納されたシステム・プログラムをバス520を介して読み出し、該システム・プログラムに従って調整支援装置1’全体を制御する。RAM513には一時的な計算データ、入力装置531を介して作業者が入力した各種データ等が一時的に格納される。
不揮発性メモリ514は、例えば図示しないバッテリでバックアップされたメモリやSSD(Solid State Drive)等で構成され、調整支援装置1’の電源がオフされても記憶状態が保持される。不揮発性メモリ514には、調整支援装置1’の動作に係る設定情報が格納される設定領域や、入力装置531から入力されたデータ、各調整支援装置1から取得されるデータ、図示しない外部記憶装置やネットワークを介して読み込まれたデータ等が記憶される。不揮発性メモリ514に記憶されたプログラムや各種データは、実行時/利用時にはRAM513に展開されても良い。また、ROM512には、各種データを解析するための公知の解析プログラム等を含むシステム・プログラムが予め書き込まれている。
調整支援装置1’は、インタフェース516を介してネットワーク172と接続されている。ネットワーク172には、少なくとも1つの産業用ロボット2や他のコンピュータ等が接続され、調整支援装置1’との間で相互にデータのやり取りを行っている。
表示装置530には、メモリ上に読み込まれた各データ、プログラム等が実行された結果として得られたデータ等がインタフェース517を介して出力されて表示される。また、キーボードやポインティングデバイス等から構成される入力装置531は、作業者による操作に基づく指令,データ等をインタフェース518を介してCPU511に渡す。
なお、機械学習装置100については、図1で説明したものと同様のハードウェア構成を備える。
以上、本発明の実施の形態について説明したが、本発明は上述した実施の形態の例のみに限定されることなく、適宜の変更を加えることにより様々な態様で実施することができる。
例えば、上記した実施形態では調整支援装置1と機械学習装置100が異なるCPU(プロセッサ)を有する装置として説明しているが、機械学習装置100は調整支援装置1が備えるCPU11と、ROM12に記憶されるシステム・プログラムにより実現するようにしても良い。
1,1’ 調整支援装置
2 産業用ロボット
3 センサ
11 CPU
12 ROM
13 RAM
14 不揮発性メモリ
16,17,18,19 インタフェース
20 バス
21 インタフェース
30 軸制御回路
32 制御部
34 データ取得部
36 前処理部
38 調整決定部
40 サーボアンプ
50 サーボモータ
52 制御用プログラム
54 取得データ記憶部
60 教示操作盤
70 表示装置
71 入力装置
100 機械学習装置
101 プロセッサ
102 ROM
103 RAM
104 不揮発性メモリ
110 学習部
130 解析部
150 学習モデル記憶部
170 システム
172 ネットワーク
511 CPU
512 ROM
513 RAM
514 不揮発性メモリ
516,517,518,519 インタフェース
520 バス
521 インタフェース

Claims (2)

  1. マニピュレータに掛かる力とモーメントを検出する機能を備えた産業用ロボットの動作の調整を支援する調整支援装置であって、
    前記産業用ロボットの力制御を行った時の動作における力状態データ及び位置データを状態変数とし、該状態の下で行われた力制御の結果を所定の基準で良否の判定をした判定データとして、機械学習することにより生成された学習モデルを記憶する学習モデル記憶部と、
    前記学習モデルを解析して、前記産業用ロボットの力制御に失敗した際に用いていた制御パラメータについて、該力制御の成功度を改善する該制御パラメータの調整方法を解析する解析部と、
    前記解析部による解析の結果に基づいて前記力制御に失敗した際に用いていた力制御の制御パラメータの調整方法を決定して出力する調整決定部と、
    を備える調整支援装置。
  2. 前記解析部が解析する制御パラメータの調整方法は、少なくとも制御パラメータの調整対象と調整方向とを含む、
    請求項1に記載の調整支援装置。
JP2019114072A 2019-06-19 2019-06-19 調整支援装置 Active JP7239399B2 (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP2019114072A JP7239399B2 (ja) 2019-06-19 2019-06-19 調整支援装置
US16/889,807 US11285602B2 (en) 2019-06-19 2020-06-02 Adjustment support device
DE102020115658.8A DE102020115658A1 (de) 2019-06-19 2020-06-15 Anpassungsunterstützungsvorrichtung
CN202010568366.4A CN112109080A (zh) 2019-06-19 2020-06-19 调整辅助装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2019114072A JP7239399B2 (ja) 2019-06-19 2019-06-19 調整支援装置

Publications (2)

Publication Number Publication Date
JP2021000672A true JP2021000672A (ja) 2021-01-07
JP7239399B2 JP7239399B2 (ja) 2023-03-14

Family

ID=73654144

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2019114072A Active JP7239399B2 (ja) 2019-06-19 2019-06-19 調整支援装置

Country Status (4)

Country Link
US (1) US11285602B2 (ja)
JP (1) JP7239399B2 (ja)
CN (1) CN112109080A (ja)
DE (1) DE102020115658A1 (ja)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE102021109336B4 (de) 2021-04-14 2023-06-01 Robert Bosch Gesellschaft mit beschränkter Haftung Vorrichtung und Verfahren zum Trainieren eines Neuronalen Netzes zum Steuern eines Roboters für eine Einsetzaufgabe
DE102021109333B4 (de) 2021-04-14 2023-07-06 Robert Bosch Gesellschaft mit beschränkter Haftung Vorrichtung und Verfahren zum Trainieren eines Neuronalen Netzes zum Steuern eines Roboters für eine Einsetzaufgabe
DE102021109334B4 (de) 2021-04-14 2023-05-25 Robert Bosch Gesellschaft mit beschränkter Haftung Vorrichtung und Verfahren zum Trainieren eines Neuronalen Netzes zum Steuern eines Roboters für eine Einsetzaufgabe
DE102021109332B4 (de) 2021-04-14 2023-07-06 Robert Bosch Gesellschaft mit beschränkter Haftung Vorrichtung und Verfahren zum Steuern eines Roboters zum Einsetzen eines Objekts in eine Einsetzstelle

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017159429A (ja) * 2016-03-11 2017-09-14 セイコーエプソン株式会社 ロボット制御装置、情報処理装置、及びロボットシステム
JP2018126798A (ja) * 2017-02-06 2018-08-16 セイコーエプソン株式会社 制御装置、ロボットおよびロボットシステム
JP2020110900A (ja) * 2019-01-16 2020-07-27 ファナック株式会社 判定装置

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4202365B2 (ja) * 2006-03-07 2008-12-24 ファナック株式会社 力制御装置
US9008836B2 (en) * 2007-01-09 2015-04-14 Abb Inc. Method and system for robotic assembly parameter optimization
JP4271249B2 (ja) * 2007-06-14 2009-06-03 ファナック株式会社 嵌合装置
US9108316B2 (en) * 2008-12-10 2015-08-18 Abb Research Ltd. Method and system for in-production optimization of the parameters of a robot used for assembly
EP2749974A2 (en) * 2012-12-28 2014-07-02 Kabushiki Kaisha Yaskawa Denki Robot teaching system, robot teaching assistant device, and robot teaching method
US9486918B1 (en) * 2013-03-13 2016-11-08 Hrl Laboratories, Llc System and method for quick scripting of tasks for autonomous robotic manipulation
US9811074B1 (en) * 2016-06-21 2017-11-07 TruPhysics GmbH Optimization of robot control programs in physics-based simulated environment
JP2018126797A (ja) * 2017-02-06 2018-08-16 セイコーエプソン株式会社 制御装置、ロボットおよびロボットシステム
JP6785687B2 (ja) * 2017-03-03 2020-11-18 株式会社キーエンス ロボットシミュレーション装置、ロボットシミュレーション方法、ロボットシミュレーションプログラム及びコンピュータで読み取り可能な記録媒体並びに記録した機器
JP6707485B2 (ja) * 2017-03-22 2020-06-10 株式会社東芝 物体ハンドリング装置およびその較正方法
CN107696034A (zh) * 2017-09-30 2018-02-16 东北大学 一种针对工业机器人的错误自主恢复方法
JP6458912B1 (ja) * 2018-01-24 2019-01-30 三菱電機株式会社 位置制御装置及び位置制御方法
JP2018158439A (ja) * 2018-03-15 2018-10-11 株式会社東芝 物体ハンドリング装置、制御装置、および較正方法

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017159429A (ja) * 2016-03-11 2017-09-14 セイコーエプソン株式会社 ロボット制御装置、情報処理装置、及びロボットシステム
JP2018126798A (ja) * 2017-02-06 2018-08-16 セイコーエプソン株式会社 制御装置、ロボットおよびロボットシステム
JP2020110900A (ja) * 2019-01-16 2020-07-27 ファナック株式会社 判定装置

Also Published As

Publication number Publication date
US11285602B2 (en) 2022-03-29
DE102020115658A1 (de) 2020-12-24
CN112109080A (zh) 2020-12-22
JP7239399B2 (ja) 2023-03-14
US20200398423A1 (en) 2020-12-24

Similar Documents

Publication Publication Date Title
JP7000359B2 (ja) 判定装置
JP7239399B2 (ja) 調整支援装置
US10668619B2 (en) Controller and machine learning device
JP6959278B2 (ja) びびり振動判定装置、機械学習装置及びシステム
US9207668B2 (en) Method of and apparatus for automated path learning
CN108422420B (zh) 具有学习控制功能的机器人系统以及学习控制方法
US7912584B2 (en) Power consumption estimation apparatus
US10996650B2 (en) Numerical control system
JP6940542B2 (ja) 把持力調整装置及び把持力調整システム
CN108214485B (zh) 机器人控制装置、以及机器人控制方法
US20190299406A1 (en) Controller and machine learning device
JP6836577B2 (ja) 研磨工具摩耗量予測装置、機械学習装置及びシステム
US20200101603A1 (en) Controller and control system
US11161249B2 (en) Robot control apparatus and robot system
US11059142B2 (en) Controller, machine learning device, and system
US20190291270A1 (en) Controller, machine learning device, and system
DE102020115631A1 (de) Maschinenlernvorrichtung, Robotersystem und Maschinenlernverfahren zum Lernen eines Zustands eines Werkzeugs
US20190129381A1 (en) Life prediction apparatus
CN112512762A (zh) 异常判定装置和异常判定方法
JP2020082198A (ja) 工具取付異常検出装置
JP2019184512A (ja) 波形表示装置
JP6928031B2 (ja) 制御装置及び制御システム
US20230191513A1 (en) Tool diagnostic device
WO2022181595A1 (ja) 産業機械システム
JPWO2022176762A5 (ja) 制御装置、ロボットシステム、学習装置、軌跡モデル、制御方法、およびプログラム

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20220317

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20230131

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20230131

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20230302

R150 Certificate of patent or registration of utility model

Ref document number: 7239399

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150