JP5513146B2 - Robot simulator - Google Patents

Robot simulator Download PDF

Info

Publication number
JP5513146B2
JP5513146B2 JP2010018581A JP2010018581A JP5513146B2 JP 5513146 B2 JP5513146 B2 JP 5513146B2 JP 2010018581 A JP2010018581 A JP 2010018581A JP 2010018581 A JP2010018581 A JP 2010018581A JP 5513146 B2 JP5513146 B2 JP 5513146B2
Authority
JP
Japan
Prior art keywords
robot
workpiece
work
error
change amount
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.)
Active
Application number
JP2010018581A
Other languages
Japanese (ja)
Other versions
JP2011156605A (en
Inventor
剛 植山
順 太田
家 程
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.)
Denso Wave Inc
University of Tokyo NUC
Original Assignee
Denso Wave Inc
University of Tokyo NUC
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 Denso Wave Inc, University of Tokyo NUC filed Critical Denso Wave Inc
Priority to JP2010018581A priority Critical patent/JP5513146B2/en
Publication of JP2011156605A publication Critical patent/JP2011156605A/en
Application granted granted Critical
Publication of JP5513146B2 publication Critical patent/JP5513146B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Numerical Control (AREA)
  • Manipulator (AREA)

Description

本発明は、ロボットシミュレータに関する。   The present invention relates to a robot simulator.

ライン作業などで部品の組み立てや検査などに用いられるロボットは、ラインを流れる作業対象となるワークとの位置関係を高い精度で適切に設定する必要がある。この位置関係が不適切であると、作業点すなわちロボットがワークに作用する点がロボットの動作不可能な領域になったり、動作中のロボットと周囲の機器との干渉を招く。そこで、ロボットの設置位置とワークの載置位置との関係は、種々の計算を用いたシミュレーションにより、最適な値を導き出している。しかし、シミュレーションを用いてロボットの設置位置とワークの載置位置との関係を導き出す場合、多くの演算を必要とし、位置関係の最適な値を導き出すためには長期間を必要とするという問題がある。   A robot used for assembling or inspecting parts in a line work or the like needs to appropriately set a positional relationship with a work that is a work target flowing through the line with high accuracy. If this positional relationship is inappropriate, the work point, that is, the point where the robot acts on the workpiece becomes an inoperable region of the robot, or interference between the operating robot and surrounding devices occurs. Therefore, the optimum value of the relationship between the installation position of the robot and the placement position of the workpiece is derived by simulation using various calculations. However, when the relationship between the robot installation position and the workpiece placement position is derived using simulation, many calculations are required, and it takes a long time to derive the optimum position relationship value. is there.

特許文献1に開示されているシミュレーション装置は、ロボットの複数の関節軸のそれぞれについて、関節軸ごとに動作範囲に相関する関数を設定している。そして、設定した関数に基づいて、各関節軸の動作余裕値、すなわち各関節軸に許容される動作範囲の余裕値を算出している。これにより、各関節軸のぎりぎりの動作を回避し、ロボットの作業点が動作不可能な領域にならないように考慮し、種々のワークに対応可能な位置を求めている。   The simulation apparatus disclosed in Patent Document 1 sets a function that correlates to an operation range for each joint axis for each of a plurality of joint axes of the robot. Based on the set function, the operation margin value of each joint axis, that is, the margin value of the motion range allowed for each joint axis is calculated. In this way, it is possible to avoid a marginal movement of each joint axis, and not to make the robot work point in an inoperable region, and obtain a position capable of handling various workpieces.

しかしながら、関数によって導き出される余裕度は、各関節軸の作動角度ごと、つまり姿勢ごとに変化する。これに対し、特許文献1の場合、各関節軸の作動の組み合わせによって決定されるロボットの最終的な姿勢は考慮されていない。すなわち、特許文献1の場合、各関節軸ごとの余裕度の設定にとどまり、ロボットの作業空間座標での最終的な姿勢は考慮されていない。また、特許文献1の場合、予め設定された作業範囲についてのみ、ロボットとワークとの最適な位置関係が算出される。そのため、特許文献1の場合、ロボットを用いて希望する作業が限定されている場合にのみ適用可能である。   However, the margin derived by the function changes for each operating angle of each joint axis, that is, for each posture. On the other hand, in the case of Patent Document 1, the final posture of the robot determined by the combination of operations of the joint axes is not considered. That is, in the case of Patent Literature 1, the margin is set only for each joint axis, and the final posture of the robot in work space coordinates is not taken into consideration. Further, in the case of Patent Document 1, an optimal positional relationship between the robot and the workpiece is calculated only for a preset work range. Therefore, in the case of Patent Document 1, it can be applied only when a desired operation using a robot is limited.

ところで、特許文献1のように、シミュレーションを用いてロボットとワークとの適切な位置関係を導き出したとしても、ロボットシステムが構築される工場などでは、導き出した位置関係とロボットの設置位置およびラインの設置位置との間に誤差が生じる。また、適切な位置関係を導き出した場合でも、ラインやテーブルに載置されるワークの搭載位置、ワークの大きさなどに僅かな変化が生じると、ロボットとワークとの位置関係にはシミュレーションでは考慮されない誤差が生じる。さらに、ワークの仕様を変更した場合でも、ロボットとワークとの位置関係には相違が生じる。このようにロボットとワークとの位置関係に僅かな誤差や相違が生じると、ロボットの設置時におけるシミュレーションの精度を如何に高めても、作業点がロボットの動作不可能な領域に侵入し、ロボットの動作不良を招くという問題がある。   By the way, even if the appropriate positional relationship between the robot and the workpiece is derived using simulation as in Patent Document 1, in the factory where the robot system is constructed, the derived positional relationship, the installation position of the robot, and the line An error occurs with the installation position. Even if an appropriate positional relationship is derived, if a slight change occurs in the mounting position or workpiece size of a workpiece placed on a line or table, the positional relationship between the robot and the workpiece is considered in the simulation. Error will occur. Furthermore, even when the workpiece specifications are changed, there is a difference in the positional relationship between the robot and the workpiece. In this way, if a slight error or difference occurs in the positional relationship between the robot and the workpiece, no matter how much the simulation accuracy at the time of installation of the robot is increased, the work point enters the area where the robot cannot operate, and the robot There is a problem of causing a malfunction.

特許第3797986号明細書Japanese Patent No. 3797986

そこで、本発明の目的は、ロボットとワークとの位置関係に変化が生じることを前提に、位置関係に変化が生じてもロボットの姿勢が動作可能な領域であるか否かを簡単な処理で判定するロボットシミュレータを提供することにある。   Accordingly, an object of the present invention is to perform simple processing to determine whether or not the robot posture is operable even if the positional relationship changes, on the premise that the positional relationship between the robot and the workpiece changes. It is to provide a robot simulator for judging.

請求項1または2記載の発明では、設置位置判定手段は、ワーク誤差入力手段から入力された誤差Δpに基づいて、式(1)から姿勢変化量Δqiを算出する。
Δqi=Jv(qi)-1Δr (1)
ここで、位置変化量Δrは、ワークに誤差Δpが生じたとき、エンドエフェクタに生じる位置の変化である。また、姿勢変化量Δqiは、誤差Δpにともなうマニピュレータの各軸の変化量である。さらに、qiqiは、誤差Δpが存在しないときのマニピュレータの各軸の値である。そして、Jv(qi)は、このqiにおけるヤコビアンをである。ここで、添字iは、作業点の番号を示す。エンドエフェクタがワークに作用する作業点は、通常、複数設定される。この作業点を任意にi=1、2、3・・・として番号を付している。したがって、i≧1となる。
設置位置判定手段は、上記の式(1)から算出した姿勢変化量Δqiから、式(2)を用いてロボットの設置位置を判定する。
qi+Δqimax≦qmax (2)
ここで、最大変化量Δqimaxは、マニピュレータの各軸の変化量が最大となる値として式(1)から求められる。また、qmaxは、関節の回転角度限界である。設置位置判定手段は、式(1)で算出した姿勢変化量Δqiを用いて、この式(2)にあてはめることにより、ワークとの間に誤差が生じたときでも、その設置位置においてロボットがワークに対して作業が可能であるか否かを判定する。
In the first or second aspect of the invention, the installation position determining means calculates the posture change amount Δqi from the equation (1) based on the error Δp input from the work error input means.
Δqi = Jv (qi) −1 Δr (1)
Here, the position change amount Δr is a change in position that occurs in the end effector when an error Δp occurs in the workpiece. The posture change amount Δqi is a change amount of each axis of the manipulator with the error Δp. Furthermore, qiqi is the value of each axis of the manipulator when there is no error Δp. Jv (qi) is the Jacobian in qi. Here, the subscript i indicates a work point number. Usually, a plurality of work points at which the end effector acts on the workpiece are set. These work points are arbitrarily numbered as i = 1, 2, 3,. Therefore, i ≧ 1.
The installation position determination means determines the installation position of the robot using the equation (2) from the posture change amount Δqi calculated from the equation (1).
qi + Δqimax ≦ qmax (2)
Here, the maximum change amount Δqimax is obtained from Expression (1) as a value that maximizes the change amount of each axis of the manipulator. Qmax is the rotation angle limit of the joint. The installation position determining means applies the posture change amount Δqi calculated by the equation (1) to the equation (2), so that even if an error occurs between the robot and the workpiece, It is determined whether or not work is possible.

上記のような式(1)は、線形近似されている。そのため、演算装置にとって処理が容易な線形式を利用してロボットが作業可能な範囲であるか否かが判定される。ところで、ロボットの変化量が小さいときは、ロボットの姿勢の大きな変化や、作業時間の大幅な変化を招くものではない。すなわち、ロボットの各軸について、+側で+側の範囲内または−側で−側の範囲内に僅かな移動が生じる場合、ロボットの姿勢の変化は僅かであり、作業時間の変化も小さい。そのため、ロボットとワークとの位置関係を検証するためには、誤差Δpが生じていないときを基準とすればよく、線形近似された式(1)により簡単な演算で至適解の候補が算出される。   The above equation (1) is linearly approximated. Therefore, it is determined whether or not the robot can work using a line format that is easy for the arithmetic device to process. By the way, when the change amount of the robot is small, it does not cause a large change in the posture of the robot or a significant change in the work time. That is, for each axis of the robot, when a slight movement occurs within the range on the + side on the + side or within the range on the − side on the − side, the change in the posture of the robot is slight and the change in the working time is also small. Therefore, in order to verify the positional relationship between the robot and the workpiece, it is only necessary to use the time when the error Δp does not occur, and the optimal solution candidate is calculated by a simple calculation using the linearly approximated expression (1). Is done.

一方、従来は、ロバスト解探索と称される解の探索手法により、最悪の条件設定の下で最良の解(ロボットの場合、最短の動作時間)を求めている。これをロボットに適用する場合、ワークの設置には自由度nの誤差が存在する。この自由度の数nは、最大で6(x,y,zの各軸方向の並進のずれ3と、各軸の回転のずれ3とで合計が6となる。)である。そのため、最良の解を探索するためには、作業点の数をiとすると、全自由度の方向へ対応する必要があることから、26×i×M×2通りの解の探索が必要となる。ここで、Mは、ロボットの軸数である。解の探索は、このロボットの各軸を中心としたプラス方向およびマイナス方向についても判定が必要なため、さらに2倍の演算が必要となる。仮に6軸型ロボットで30点の作業点における作業を実行する場合、従来の解の探索手法では、26×30×6×2=23040通りの解の探索が必要となり、解の探索に長時間を必要とする。 On the other hand, conventionally, the best solution (the shortest operation time in the case of a robot) is obtained under the worst condition setting by a solution search method called a robust solution search. When this is applied to a robot, there is an error of n degrees of freedom in workpiece setting. The number of degrees of freedom n is 6 at maximum (the total of 6 is the translational deviation 3 in each axial direction of x, y, z and the rotational deviation 3 of each axis). Therefore, in order to search for the best solution, if the number of work points is i, it is necessary to correspond to the direction of total degrees of freedom, and therefore 2 6 × i × M × 2 solutions must be searched. It becomes. Here, M is the number of axes of the robot. The search for the solution requires a determination in the plus direction and the minus direction centered on each axis of the robot, and thus requires a further double calculation. If a 6-axis robot performs a task at 30 work points, the conventional solution search method requires 2 6 × 30 × 6 × 2 = 223040 solution searches, which makes it difficult to search for solutions. Need time.

本願の請求項1または2の発明では、式(1)を用いることにより、ワークの各作業点において一通りのヤコビアンで演算できる。そのため、本願の発明により、上述のように6軸型のロボットで30点の作業点における作業を実行する場合、ロボットの6つの関節軸においてプラス方向およびマイナス方向のそれぞれについて解を探索すれば足り、その演算は6×2=12通りとなる。このように、本願の発明では、作業点が多い場合でも、演算が容易となり、解の探索に必要な演算数は低減される。その結果、ロボットとワークとの位置関係に誤差Δpが生じる場合でも、ロボットが動作可能となるロボットとワークとの最適な位置関係が簡単な処理で導き出される。したがって、ロボットとワークとの間に誤差Δpにともなう位置関係の変化が生じても、ロボットの姿勢が動作可能な領域であるか否かを簡単な処理で判定することができる。   In invention of Claim 1 or 2 of this application, it can calculate by one Jacobian in each work point of a workpiece | work by using Formula (1). Therefore, according to the invention of the present application, when the work at the 30 work points is executed by the 6-axis robot as described above, it is sufficient to search for the solutions in the plus direction and the minus direction on the six joint axes of the robot. The calculation is 6 × 2 = 12. As described above, in the invention of the present application, even when there are many work points, the calculation becomes easy, and the number of calculations necessary for searching for a solution is reduced. As a result, even when an error Δp occurs in the positional relationship between the robot and the workpiece, the optimal positional relationship between the robot and the workpiece that enables the robot to operate can be derived by simple processing. Therefore, even if the positional relationship changes with the error Δp between the robot and the workpiece, it can be determined by simple processing whether or not the robot is in an operable region.

一実施形態によるロボットシミュレータの構成を示すブロック図The block diagram which shows the structure of the robot simulator by one Embodiment. 一実施形態によるロボットシミュレータのシミュレーションの対象となるロボットシステムの一例を示す模式図Schematic diagram showing an example of a robot system to be simulated by a robot simulator according to an embodiment 一実施形態によるロボットシミュレータのシミュレーションの対象となるワークおよび作業点を示す模式図The schematic diagram which shows the workpiece | work and work point which are the object of the simulation of the robot simulator by one Embodiment 一実施形態によるロボットシミュレータのシミュレーションの対象となるワークおよび作業点の誤差を示す模式図The schematic diagram which shows the workpiece | work of the simulation of the robot simulator by one Embodiment, and the error of a work point 一実施形態によるロボットシミュレータのシミュレーションの流れを示す概略図Schematic showing the flow of simulation of the robot simulator according to one embodiment 一実施形態によるロボットシミュレータで用いる式(1)を行列式で示す説明図Explanatory drawing which shows Formula (1) used with the robot simulator by one Embodiment by a determinant 一実施形態によるロボットシミュレータで用いる式(2)を行列式で示す説明図Explanatory drawing which shows Formula (2) used with the robot simulator by one Embodiment by a determinant

以下、本発明の一実施形態によるロボットシミュレータを図面に基づいて説明する。
(ロボットシステム)
まず、ロボットシミュレータによるシミレーションの対象となるロボットシステムについて図2を用いて説明する。ロボットシステム10は、ロボット11およびワーク搭載部12を備えている。本実施形態のロボット11は、6軸型である。なお、本実施形態で説明する6軸型のロボット11は一例であり、ロボット11の軸の数すなわち関節の数は任意に設定することができる。また、本実施形態では、図2に示すように、設備の床面13をワーク搭載部12とし、この床面13の座標軸をそれぞれX軸およびY軸と定義し、この床面13に垂直な座標軸をZ軸と定義する。さらに、X軸を中心軸とした回転座標をRx、Y軸を中心とした回転座標をRy、Z軸を中心とした回転座標をRzと定義する。
Hereinafter, a robot simulator according to an embodiment of the present invention will be described with reference to the drawings.
(Robot system)
First, a robot system to be simulated by a robot simulator will be described with reference to FIG. The robot system 10 includes a robot 11 and a work mounting unit 12. The robot 11 of this embodiment is a 6-axis type. Note that the six-axis robot 11 described in the present embodiment is an example, and the number of axes of the robot 11, that is, the number of joints, can be arbitrarily set. Further, in the present embodiment, as shown in FIG. 2, the floor surface 13 of the facility is used as the work mounting portion 12, and the coordinate axes of the floor surface 13 are defined as the X axis and the Y axis, respectively, and are perpendicular to the floor surface 13. The coordinate axis is defined as the Z axis. Further, the rotation coordinate with the X axis as the central axis is defined as Rx, the rotation coordinate with the Y axis as the center is defined as Ry, and the rotation coordinate with the Z axis as the center is defined as Rz.

ロボットシステム10は、上述の通りロボット11およびワーク搭載部12を備えている。また、ロボットシステム10は、図示しないコントローラを備えている。ロボット11は、ロボットコントローラからの指示により駆動される。ロボット11は、アームおよび関節から構成されるマニピュレータ14、ならびにエンドエフェクタ15を有している。図2に示す本実施形態のロボット11は、第一関節21、第二関節22、第三関節23、第四関節24、第五関節25および第六関節26を有している。また、ロボット11は、第一アーム31、第二アーム32、第三アーム33、第四アーム34および第五アーム35を有している。   The robot system 10 includes the robot 11 and the work mounting unit 12 as described above. The robot system 10 includes a controller (not shown). The robot 11 is driven by an instruction from the robot controller. The robot 11 has a manipulator 14 composed of an arm and a joint, and an end effector 15. The robot 11 of this embodiment shown in FIG. 2 has a first joint 21, a second joint 22, a third joint 23, a fourth joint 24, a fifth joint 25, and a sixth joint 26. The robot 11 has a first arm 31, a second arm 32, a third arm 33, a fourth arm 34 and a fifth arm 35.

ロボット11は、設備の床面13に設置されている。床面13には、床面13から垂直上方すなわちZ軸と平行に立ち上がる土台部41が固定されている。第一関節21は、この土台部41と第一アーム31とを接続している。第一アーム31は、第一関節21において床面13に垂直な軸を中心に回転可能である。第二関節22は、第一アーム31と第二アーム32とを接続している。第一アーム31と第二アーム32とは、第二関節22を中心に回転する。これにより、第二アーム32は、Z軸に対する傾斜角度が変化する。第三関節23は、第二アーム32と第三アーム33とを接続している。第二アーム32と第三アーム33とは、第三関節23を中心に回転可能である。すなわち、第二アーム32と第三アーム33とは、第三関節23を支点として開閉する。   The robot 11 is installed on the floor 13 of the facility. Fixed to the floor surface 13 is a base portion 41 that rises vertically upward from the floor surface 13, that is, parallel to the Z axis. The first joint 21 connects the base portion 41 and the first arm 31. The first arm 31 is rotatable about an axis perpendicular to the floor surface 13 at the first joint 21. The second joint 22 connects the first arm 31 and the second arm 32. The first arm 31 and the second arm 32 rotate around the second joint 22. Thereby, the inclination angle of the second arm 32 with respect to the Z-axis changes. The third joint 23 connects the second arm 32 and the third arm 33. The second arm 32 and the third arm 33 are rotatable around the third joint 23. That is, the second arm 32 and the third arm 33 open and close using the third joint 23 as a fulcrum.

第四関節24は、第三アーム33と第四アーム34とを接続している。第三アーム33と第四アーム34とは、第四関節24を中心に相対的に回転する。第三アーム33と第四アーム34とは、同一の軸上に位置している。第四アーム34は、第四関節24においてこの軸を中心に第三アーム33に対し回転する。第五関節25は、第四アーム34と第五アーム35とを接続している。第五アーム35は、第五関節25を中心に回転する。すなわち、第五アーム35は、第四アーム34の軸に垂直な第五関節25の軸を中心に回転する。第六関節26は、第五アーム35とエンドエフェクタ15とを接続している。第五アーム35とエンドエフェクタ15とは、同一の軸上に位置している。エンドエフェクタ15は、第六関節26においてこの軸を中心に第五アーム35に対し回転する。すなわち、エンドエフェクタ15は、第五関節25の軸と垂直な軸を中心に回転する。   The fourth joint 24 connects the third arm 33 and the fourth arm 34. The third arm 33 and the fourth arm 34 rotate relatively around the fourth joint 24. The third arm 33 and the fourth arm 34 are located on the same axis. The fourth arm 34 rotates relative to the third arm 33 about this axis at the fourth joint 24. The fifth joint 25 connects the fourth arm 34 and the fifth arm 35. The fifth arm 35 rotates around the fifth joint 25. That is, the fifth arm 35 rotates about the axis of the fifth joint 25 perpendicular to the axis of the fourth arm 34. The sixth joint 26 connects the fifth arm 35 and the end effector 15. The fifth arm 35 and the end effector 15 are located on the same axis. The end effector 15 rotates relative to the fifth arm 35 around this axis at the sixth joint 26. That is, the end effector 15 rotates around an axis perpendicular to the axis of the fifth joint 25.

エンドエフェクタ15は、作業の対象となるワーク42に作用する。具体的には、ロボット11を用いてワーク42を加工する場合、エンドエフェクタ15はワーク42を把持するハンドやワーク42に加工を加えるツールなどであり、ロボット11を用いてワーク42を検査する場合、エンドエフェクタ15はワーク42を撮影するカメラなどである。このように、エンドエフェクタ15は、作業の対象となるワーク42に対し、接触または非接触により作用する。   The end effector 15 acts on the work 42 to be worked. Specifically, when the workpiece 42 is processed using the robot 11, the end effector 15 is a hand that grips the workpiece 42, a tool that applies processing to the workpiece 42, and the like, and when the workpiece 42 is inspected using the robot 11. The end effector 15 is a camera or the like that photographs the work 42. As described above, the end effector 15 acts on the work 42 to be worked by contact or non-contact.

ワーク搭載部12は、ロボット11による作業の対象となるワーク42が搭載される。本実施形態の場合、ワーク42は、床面13に搭載される。そのため、ワーク搭載部12は設備の床であり、この床の上端面すなわち床面13はワーク42が搭載される搭載面に一致する。なお、ワーク搭載部12は、例えば床面13から上方へ立ち上がったテーブル上やコンベヤなどの搬送手段上に形成してもよい。この場合、ワーク42が搭載されるテーブルやコンベヤがワーク搭載部12を構成する。   The workpiece mounting unit 12 is mounted with a workpiece 42 that is a work target of the robot 11. In the case of this embodiment, the work 42 is mounted on the floor surface 13. Therefore, the work mounting portion 12 is a floor of the facility, and the upper end surface of the floor, that is, the floor surface 13 coincides with the mounting surface on which the work 42 is mounted. In addition, you may form the workpiece | work mounting part 12 on conveyance means, such as on the table and conveyor which stood up from the floor surface 13, for example. In this case, a table or a conveyor on which the workpiece 42 is mounted constitutes the workpiece mounting unit 12.

(ロボットシミュレータ)
次に、図1に基づいてロボットシミュレータ50について説明する。ロボットシミュレータ50は、例えばパーソナルコンピュータなどの演算装置において、コンピュータソフトウェアであるシミレーションプログラムを実行することにより、ソフトウェア的に実現される。ロボットシミュレータ50を実現するパーソナルコンピュータは、入力部51、演算部52および出力部53を備えている。入力部51は、例えばマウス54およびキーボード55などの一般的な入力機器を有している。演算部52は、例えばCPU56、ROM57およびRAM58を有するコンピュータで構成されており、上述のシミュレーションプログラムを実行することにより、ロボットシミュレータ50の全体を制御する。出力部53は、例えば液晶ディスプレイなどの表示部61やプリンタ62などを備えており、入力部51から入力されたデータや演算部52でシミュレーションプログラムにしたがって算出されたシミュレーションデータなどを出力する。
(Robot simulator)
Next, the robot simulator 50 will be described with reference to FIG. The robot simulator 50 is realized in software by executing a simulation program, which is computer software, in an arithmetic device such as a personal computer. The personal computer that implements the robot simulator 50 includes an input unit 51, a calculation unit 52, and an output unit 53. The input unit 51 includes general input devices such as a mouse 54 and a keyboard 55, for example. The calculation unit 52 is configured by a computer having, for example, a CPU 56, a ROM 57, and a RAM 58, and controls the entire robot simulator 50 by executing the above-described simulation program. The output unit 53 includes a display unit 61 such as a liquid crystal display, a printer 62, and the like, and outputs data input from the input unit 51, simulation data calculated by the calculation unit 52 according to a simulation program, and the like.

以下、具体的にロボットシミュレータ50の構成について説明する。ロボットシミュレータ50は、パーソナルコンピュータなどの演算装置においてシミュレーションプログラムを実行することにより、演算部52において、作業順序設定部65、最短位置抽出部66および設置位置判定部67をソフトウェアによって仮想的に実現する。また、ロボットシミュレータ50の入力部51は、条件入力部68およびワーク誤差入力部69を構成する。   Hereinafter, the configuration of the robot simulator 50 will be specifically described. The robot simulator 50 virtually implements the work order setting unit 65, the shortest position extraction unit 66, and the installation position determination unit 67 in the calculation unit 52 by executing a simulation program in a calculation device such as a personal computer. . The input unit 51 of the robot simulator 50 constitutes a condition input unit 68 and a work error input unit 69.

条件入力部68は、ロボット11の初期位置、作業順序および作業点の座標などが入力される。ロボット11の初期位置とは、ロボットシミュレータ50によるシミュレーションの実行に際して、ワーク搭載部12に搭載されたワーク42に対するロボット11の初期位置である。すなわち、ロボット11の初期位置は、シミュレーションの開始時における、ロボット11とワーク42との初期的な位置関係である。ロボット11の初期位置となるロボット11の原点ΣR0は、ワーク42の中心を原点ΣWとしたとき、ΣW上の座標WR0とするワークの座標系として表わされる。
このロボット11の初期位置は、入力部51から任意の座標として入力することができる。作業順序とは、ロボットシステム10を用いて実行する複数の工程を時系列で設定したものである。ロボット11は、各作業点への移動と移動した作業点における作業とを繰り返す。作業順序は、この作業点への移動の順序および作業点における作業を設定したものである。作業点の座標とは、ロボット11のエンドエフェクタ15がワーク42に対して作用を及ぼす位置の座標である。例えばロボットシステム10を用いてワーク42の加工を行う場合、作業点とはその加工を行うためにエンドエフェクタ15とワーク42とが接する点である。また、例えばロボットシステム10を用いてワーク42の検査を行う場合、作業点とはその検査を行うためにエンドエフェクタ15が移動する位置である。作業点の座標とは、図3に示すようにワーク42の中心を原点ΣW0としたとき、これらの作業点71、72、73における各座標軸の座標W(71)W(72)W(73)である。
The condition input unit 68 receives the initial position of the robot 11, the work order, the coordinates of the work points, and the like. The initial position of the robot 11 is the initial position of the robot 11 with respect to the workpiece 42 mounted on the workpiece mounting unit 12 when the robot simulator 50 executes the simulation. That is, the initial position of the robot 11 is an initial positional relationship between the robot 11 and the workpiece 42 at the start of the simulation. Origin ΣR0 of the robot 11 as the initial position of the robot 11, when the center of the workpiece 42 as the origin .SIGMA.W, expressed as a coordinate system of the workpiece to coordinate W P R0 on .SIGMA.W.
The initial position of the robot 11 can be input from the input unit 51 as arbitrary coordinates. The work order is a set of a plurality of processes to be executed using the robot system 10 in time series. The robot 11 repeats the movement to each work point and the work at the moved work point. The work order is a set of the order of movement to the work point and the work at the work point. The coordinates of the work point are the coordinates of the position at which the end effector 15 of the robot 11 acts on the workpiece 42. For example, when the workpiece 42 is machined using the robot system 10, the work point is a point where the end effector 15 and the workpiece 42 are in contact with each other for the machining. For example, when the workpiece 42 is inspected using the robot system 10, the work point is a position where the end effector 15 moves to perform the inspection. As shown in FIG. 3, the coordinates of the work points are the coordinates W P (71) , W P (72) , W P (72) of the coordinate axes at the work points 71, 72, 73 when the center of the work 42 is the origin ΣW0. W P (73) .

作業順序設定部65は、作業所要時間が最小となる最短作業順序を求める。作業順序設定部65は、条件入力部68から入力されたロボット11とワーク42との位置関係に基づいて、条件入力部68から入力された作業順序に含まれる複数の工程の作業所要時間を算出する。作業所要時間は、ロボット11とワーク42との位置関係および作業点ごとの工程の順序が変更されると、これに基づいて変化する場合がある。そこで、作業順序設定部65は、ロボット11とワーク42との位置関係を設定した状態で必要に応じて工程の順序を入れ替えながら作業所要時間が最短となる最短作業順序を求める。   The work order setting unit 65 obtains the shortest work order that minimizes the work required time. The work order setting unit 65 calculates work required times for a plurality of processes included in the work order input from the condition input unit 68 based on the positional relationship between the robot 11 and the workpiece 42 input from the condition input unit 68. To do. When the positional relationship between the robot 11 and the workpiece 42 and the order of the processes for each work point are changed, the work required time may change based on this. Therefore, the work order setting unit 65 obtains the shortest work order that requires the shortest work time while changing the process order as necessary in a state where the positional relationship between the robot 11 and the work 42 is set.

最短位置抽出部66は、所要時間が最短となるロボット11とワーク42との位置関係を抽出する。最短位置抽出部66は、条件入力部68から入力されたワーク42に対するロボット11の初期位置における原点ΣR0を含む床面13すなわちX−Y平面上に任意の設置範囲Aを設定する。つまり、最短位置抽出部66は、まず床面13の任意の位置に、ロボット11の設置位置の候補となる範囲の設置範囲Aを設定する。この設置範囲Aには、ロボット11の初期位置における原点ΣR0が含まれている。そして、最短位置抽出部66は、この設定した任意の設置範囲A内において、ロボット11とワーク42との位置関係について至適解の候補となる複数の位置関係を抽出する。すなわち、最短位置抽出部66は、設置範囲A内において、ロボット11とワーク42とが好適な位置関係になると予想される複数の位置を抽出し、これを至適解の候補とする。ここで、最適解とせずに至適解の候補としているのは、ロボット11とワーク42との最適な位置関係が存在することが予想される場合でも、その最適解が設置範囲A内に含まれるとは限らない。ロボット11およびワーク42は、無限の空間に設置されるのではなく、工場など有限の設備に設置される。そのため、算出した解は、最適解とは限らない。したがって、本実施形態の場合、最短位置抽出部66は、設置範囲A内において条件を満たす位置関係を至適解とし、この至適解となることが予想される複数の位置関係を至適解の候補として抽出している。   The shortest position extraction unit 66 extracts the positional relationship between the robot 11 and the work 42 that requires the shortest time. The shortest position extraction unit 66 sets an arbitrary installation range A on the floor surface 13 including the origin ΣR0 at the initial position of the robot 11 with respect to the workpiece 42 input from the condition input unit 68, that is, the XY plane. That is, the shortest position extraction unit 66 first sets an installation range A that is a candidate for the installation position of the robot 11 at an arbitrary position on the floor surface 13. This installation range A includes the origin ΣR0 at the initial position of the robot 11. Then, the shortest position extraction unit 66 extracts a plurality of positional relationships that are candidates for the optimal solution for the positional relationship between the robot 11 and the workpiece 42 within the set arbitrary installation range A. That is, the shortest position extraction unit 66 extracts a plurality of positions that are expected to have a suitable positional relationship between the robot 11 and the workpiece 42 within the installation range A, and sets these as candidates for the optimum solution. Here, the optimal solution candidate is not the optimal solution, but the optimal solution is included in the installation range A even when the optimal positional relationship between the robot 11 and the workpiece 42 is expected to exist. Not always. The robot 11 and the workpiece 42 are not installed in an infinite space, but are installed in a finite facility such as a factory. Therefore, the calculated solution is not necessarily the optimal solution. Therefore, in the case of this embodiment, the shortest position extraction unit 66 sets the positional relationship that satisfies the condition in the installation range A as the optimal solution, and optimally determines the multiple positional relationships that are expected to be the optimal solution. Are extracted as candidates.

最短位置抽出部66は、抽出した至適解の候補となるロボット11とワーク42との位置関係ごとに最短作業順序でロボット11の複数の工程を仮想的に実行する。すなわち、最短位置抽出部66は、抽出した至適解の候補となるロボット11とワーク42との複数の位置関係について、それぞれ作業順序設定部65で求めた最短作業順序にしたがって複数の工程を仮想的に実行する。この場合、最短位置抽出部66は、複数の工程をシミュレーションプログラムにしたがって仮想的に実行する。そして、最短位置抽出部66は、至適解の候補のうち最も所要時間の短いロボット11とワーク42との位置関係を抽出する。すなわち、最短位置抽出部66は、至適解の候補となる複数の位置関係において、仮想的に複数の工程を実行する。そして、複数の位置関係の中から複数の工程の所要時間が最短となるロボット11とワーク42との位置関係を抽出する。これにより、ワーク42に対する位置関係が設置範囲A内において最も好適となるロボット11の設置位置が抽出される。この場合、好適となるロボット11の設置位置は、必ずしも一つに限らず、検討候補として複数抽出してもよい。   The shortest position extraction unit 66 virtually executes a plurality of processes of the robot 11 in the shortest work order for each positional relationship between the robot 11 and the workpiece 42 that are candidates for the extracted optimal solution. That is, the shortest position extraction unit 66 virtually performs a plurality of processes according to the shortest work order obtained by the work order setting unit 65 for each of the plurality of positional relationships between the robot 11 and the workpiece 42 that are candidates for the optimal solution extracted. Run it. In this case, the shortest position extraction unit 66 virtually executes a plurality of processes according to a simulation program. Then, the shortest position extraction unit 66 extracts the positional relationship between the robot 11 and the work 42 having the shortest required time among the candidates for the optimal solution. That is, the shortest position extraction unit 66 virtually executes a plurality of processes in a plurality of positional relationships that are candidates for the optimal solution. Then, the positional relationship between the robot 11 and the work 42 that requires the shortest time required for the plurality of steps is extracted from the plurality of positional relationships. Thereby, the installation position of the robot 11 in which the positional relationship with respect to the workpiece 42 is most suitable within the installation range A is extracted. In this case, the preferred installation position of the robot 11 is not necessarily limited to one, and a plurality of candidate positions may be extracted as examination candidates.

ワーク誤差入力部69は、ワーク搭載部12に搭載されるワーク42の位置として想定される誤差量、または個体差によって想定されるワーク42の誤差量が誤差Δpとして入力される。最短位置抽出部66において、複数の工程の所要時間が最短となるロボット11とワーク42との至適な位置関係が抽出されても、工場などの設備にロボットシステム10を設置する際に、ロボット11とワーク搭載部12との位置関係が変化したり、ワーク42のロットの変更やワーク42の寸法的な個体差などによってロボット11とワーク42との位置関係が僅かに変化することがある。このような場合、最短位置抽出部66におけるロボット11とワーク42との位置関係の抽出精度を向上させても、実際の設備では僅かな誤差によってロボット11の動作不良を招くことになる。そこで、ワーク誤差入力部69からは、予め想定されるワーク42の誤差量が誤差Δpとして入力される。この誤差Δpは、図4に示すようにワーク42に対し初期位置として設定されている初期作業点pに対し、ワーク搭載部12に搭載されるワーク42に想定される誤差量である。ここで初期作業点pは、ロボット11とワーク42との位置関係が最短位置抽出部66で抽出された至適な位置関係にあるとき、ワーク42の原点ΣW0からの座標として表わされる。つまり、初期作業点pは、空間の位置座標(px,py,pz)として示される。これに対し、誤差Δpが生じた場合の作業点p’は、P’=T(Δp)・Pとして表わされる。ここで、P’、Pは、それぞれ位置座標(px,py,pz,1)、(px’,py’,pz’,1)で示されるベクトルであり、T(Δp)は、Δp=(Δpx,Δpy,Δpz,Δprx,Δpry,Δprz)より求められる同時変換行列である。   The workpiece error input unit 69 receives an error amount assumed as a position of the workpiece 42 mounted on the workpiece mounting unit 12 or an error amount of the workpiece 42 estimated by individual differences as an error Δp. Even when the optimum position relationship between the robot 11 and the workpiece 42 in which the time required for a plurality of processes is the shortest is extracted by the shortest position extraction unit 66, the robot is not used when installing the robot system 10 in equipment such as a factory. The positional relationship between the robot 11 and the workpiece 42 may slightly change due to a change in the positional relationship between the robot 11 and the workpiece mounting unit 12, a change in the lot of the workpiece 42, or a dimensional individual difference between the workpieces 42. In such a case, even if the extraction accuracy of the positional relationship between the robot 11 and the workpiece 42 in the shortest position extraction unit 66 is improved, the actual equipment may cause a malfunction of the robot 11 due to a slight error. Therefore, a presumed error amount of the workpiece 42 is input from the workpiece error input unit 69 as the error Δp. The error Δp is an error amount assumed for the work 42 mounted on the work mounting unit 12 with respect to the initial work point p set as the initial position with respect to the work 42 as shown in FIG. Here, the initial work point p is expressed as coordinates from the origin ΣW0 of the workpiece 42 when the positional relationship between the robot 11 and the workpiece 42 is the optimum positional relationship extracted by the shortest position extraction unit 66. That is, the initial work point p is indicated as a spatial coordinate (px, py, pz). On the other hand, the working point p ′ when the error Δp occurs is expressed as P ′ = T (Δp) · P. Here, P ′ and P are vectors indicated by position coordinates (px, py, pz, 1) and (px ′, py ′, pz ′, 1), respectively, and T (Δp) is Δp = ( (Δpx, Δpy, Δpz, Δprx, Δtry, Δprz).

設置位置判定部67は、ワーク誤差入力部69から入力された誤差Δpに基づいて、ロボット11でワーク42に対する作業が可能か否かを判定する。具体的には、設置位置判定部67は、ワーク誤差入力部69から入力された誤差Δpに基づいて、この誤差Δpが生じたときのエンドエフェクタ15の位置の変化をベクトルである位置変化量Δrとして設定する。また、設置位置判定部67は、入力された誤差Δpにともなうマニピュレータ14における各軸の変化量を姿勢変化量Δqiとして設定する。位置変化量Δrは、入力された誤差Δpに基づいて算出してもよく、誤差Δpに対応するテーブルとして予め設定しておいてもよい。ここで、誤差Δpが存在しないときのマニピュレータ14の各軸の値をqiとする。このqiは、最短位置抽出部66で抽出した至適解に相当するロボット11とワーク42との位置関係におけるマニピュレータ14の各軸の値である。そして、設置位置判定部67は、このqiにおけるヤコビアンをJv(qi)として、以下の式(1)から姿勢変化量Δqを算出する。なお、ヤコビアンJv(qi)は、qiが抽出されるごとに逐次設定される構成としてもよく、想定されるqiについて予め設定してROM57やRAM58に記録しておく構成としてもよい。
Δqi=Jv(qi)-1Δr (1)
ここで、Jv(qi)は、誤差Δpが存在しないときのマニピュレータ14の各軸におけるヤコビアン、すなわちヤコビ行列である。
The installation position determination unit 67 determines whether or not the robot 11 can work on the workpiece 42 based on the error Δp input from the workpiece error input unit 69. Specifically, the installation position determination unit 67 is based on the error Δp input from the work error input unit 69, and the change in position of the end effector 15 when this error Δp occurs is a position change amount Δr that is a vector. Set as. Further, the installation position determination unit 67 sets the change amount of each axis in the manipulator 14 due to the input error Δp as the posture change amount Δqi. The position change amount Δr may be calculated based on the input error Δp, or may be set in advance as a table corresponding to the error Δp. Here, the value of each axis of the manipulator 14 when there is no error Δp is defined as qi. This qi is the value of each axis of the manipulator 14 in the positional relationship between the robot 11 and the workpiece 42 corresponding to the optimal solution extracted by the shortest position extraction unit 66. And the installation position determination part 67 calculates attitude | position change amount (DELTA) q from the following formula | equation (1) by making the Jacobian in this qi into Jv (qi). The Jacobian Jv (qi) may be configured to be sequentially set every time qi is extracted, or may be configured to be set in advance for the assumed qi and recorded in the ROM 57 or the RAM 58.
Δqi = Jv (qi) −1 Δr (1)
Here, Jv (qi) is a Jacobian in each axis of the manipulator 14 when there is no error Δp, that is, a Jacobian matrix.

この式(1)は、姿勢変化量Δqiに基づいて位置変化量Δrを算出する既知の式(1A)を逆変換することにより導き出される。
Δr=Jv(qi)Δqi (1A)
上記の式(1)は、姿勢変化量Δqiと位置変化量Δrとが線形の関係に近似されているため、姿勢変化量Δqiは位置変化量Δrに基づいて線形式によって算出される。そのため、式(1A)に比較して姿勢変化量Δqiの算出に必要な演算が簡略化され、複数の関節を有するマニピュレータ14の姿勢変化量Δqiの演算が容易になる。
This equation (1) is derived by inversely transforming the known equation (1A) for calculating the position change amount Δr based on the posture change amount Δqi.
Δr = Jv (qi) Δqi (1A)
In the above formula (1), since the posture change amount Δqi and the position change amount Δr are approximated to a linear relationship, the posture change amount Δqi is calculated in a linear format based on the position change amount Δr. Therefore, the calculation required for calculating the posture change amount Δqi is simplified as compared with the equation (1A), and the calculation of the posture change amount Δqi of the manipulator 14 having a plurality of joints is facilitated.

設置位置判定部67は、上記の式(1)に基づいて姿勢変化量Δqiが算出されると、式(2)に基づいてマニピュレータ14の各軸の値qiを判定する。すなわち、設置位置判定部67は、式(1)による姿勢変化量Δqiの算出の対象としたロボット11とワーク42との位置関係の至適解における各軸の値qiが、式(2)の関係を満たすか否かを判定する。
qi+Δqimax≦qmax (2)
ここで、最大変化量Δqimaxは、姿勢変化量Δqiが最大となるときのマニピュレータ14の各軸の変化量の最大値である。この最大変化量Δqimaxは、誤差Δpが最大となるときの姿勢変化量として式(1)で算出することにより、既知の値として得られる。また、qmaxは、ロボット11のマニピュレータ14を構成する複数の関節ごとの回転角度限界である。すなわち、設置位置判定部67は、式(1)で算出した誤差Δpが最大となるときの姿勢変化量Δqiである最大変化量Δqimaxから、式(1)における演算で用いたqiが、式(2)で示される関係において回転角度限界qmaxとの大小関係を満たすか否かを判定する。設置位置判定部67は、この判定した結果に基づいて、ロボット11でワーク42に対する作業が可能か否かについて判定する。つまり、設置位置判定部67は、式(1)で算出された姿勢変化量Δqiに含まれる要素が式(2)の大小関係を満たすとき、ワーク42の位置に変化が生じたときでも、ロボット11とワーク42との位置関係が至適であると判定する。設置位置判定部67は、以上の演算により、式(1)および式(2)に基づいて、ワーク42が初期位置から誤差Δpだけ移動したとしても、ロボット11がワーク42に対して作業可能であるか否かを判定する。この判定についての詳細は、以下のシミュレーションの流れにおいて詳細に説明する。
When the posture change amount Δqi is calculated based on the above equation (1), the installation position determining unit 67 determines the value qi of each axis of the manipulator 14 based on the equation (2). That is, the installation position determination unit 67 determines that the value qi of each axis in the optimal solution of the positional relationship between the robot 11 and the workpiece 42, which is the target of calculation of the posture change amount Δqi according to Expression (1), is expressed by Expression (2). Determine whether the relationship is satisfied.
qi + Δqimax ≦ qmax (2)
Here, the maximum change amount Δqimax is the maximum value of the change amount of each axis of the manipulator 14 when the posture change amount Δqi is maximized. The maximum change amount Δqimax is obtained as a known value by calculating the posture change amount when the error Δp is maximum using the equation (1). Further, qmax is a rotation angle limit for each of a plurality of joints constituting the manipulator 14 of the robot 11. That is, the installation position determination unit 67 calculates the qi used in the calculation in the equation (1) from the maximum change amount Δqimax, which is the posture change amount Δqi when the error Δp calculated in the equation (1) is maximum. It is determined whether or not the relationship represented by 2) satisfies the magnitude relationship with the rotation angle limit qmax. Based on the determination result, the installation position determination unit 67 determines whether or not the robot 11 can work on the workpiece 42. In other words, the installation position determination unit 67 can determine whether the position of the workpiece 42 has changed when the elements included in the posture change amount Δqi calculated by Expression (1) satisfy the magnitude relationship of Expression (2). 11 and the workpiece 42 are determined to be optimal. The installation position determination unit 67 can operate the robot 11 on the workpiece 42 by the above calculation even if the workpiece 42 moves by an error Δp from the initial position based on the equations (1) and (2). It is determined whether or not there is. Details of this determination will be described in detail in the following simulation flow.

(シミュレーションの流れ)
次に、上記の構成によるロボットシミュレータ50によるシミュレーションの流れについて図5に基づいて説明する。
図5に示すように、ロボットシミュレータ50は、大きくS101およびS102における入力処理、S103からS106までにおける最適化処理、およびS107における出力処理に大別される。以下、各処理について説明する。
(Simulation flow)
Next, the flow of simulation by the robot simulator 50 having the above configuration will be described with reference to FIG.
As shown in FIG. 5, the robot simulator 50 is roughly divided into an input process in S101 and S102, an optimization process in S103 to S106, and an output process in S107. Hereinafter, each process will be described.

ロボットシミュレータ50は、条件入力部68から初期状態の入力を受け付ける(S101)。S101では、初期状態としてロボット11の初期位置、作業順序および作業点の座標が入力部51から入力される。ロボット11の初期位置は、上述の通り、シミュレーションの実行に際して、ワーク搭載部12に搭載されたワーク42に対するロボット11の初期位置である。ロボット11の初期位置における原点ΣR0は、ワーク42の中心を原点ΣWとしたとき、各軸の座標としてΣR0=(XR0,YR0,ZR0)で表わされる。このロボット11の初期位置は、入力部51から任意の座標として入力される。
作業手順は、ロボットシステム10を用いて実行する複数の工程を時系列で設定したものである。すなわち、作業手順は、ロボット11の作業点における作業順序の初期的な情報である。なお、対象となるワーク42の外観を検査する外観検査などの場合、検査順序は拘束されない。そのため、検査の場合、すべての検査に必要な所要時間が最小となるように作業点における検査の順序が変更される。一方、対象となるワーク42の加工を行う場合、加工順序が拘束される。そのため、ワーク42の加工を行う場合、作業手順に含まれる各工程の順序は予め設定される。
The robot simulator 50 receives an initial state input from the condition input unit 68 (S101). In S <b> 101, the initial position, work order, and work point coordinates of the robot 11 are input from the input unit 51 as an initial state. As described above, the initial position of the robot 11 is the initial position of the robot 11 with respect to the work 42 mounted on the work mounting unit 12 when the simulation is executed. The origin ΣR0 at the initial position of the robot 11 is represented by ΣR0 = (XR0, YR0, ZR0) as the coordinates of each axis when the center of the workpiece 42 is the origin ΣW. The initial position of the robot 11 is input from the input unit 51 as arbitrary coordinates.
The work procedure is a set of a plurality of processes to be executed using the robot system 10 in time series. That is, the work procedure is initial information of the work order at the work point of the robot 11. In the case of an appearance inspection for inspecting the appearance of the target workpiece 42, the inspection order is not restricted. Therefore, in the case of inspection, the order of inspection at work points is changed so that the time required for all inspections is minimized. On the other hand, when processing the target workpiece 42, the processing order is constrained. Therefore, when processing the workpiece 42, the order of each process included in the work procedure is set in advance.

作業点は、ロボット11のエンドエフェクタ15がワーク42に対して作用を及ぼす位置の座標である。上述の通り、ロボットシステム10でワーク42の加工を行う場合、作業点はその加工を行うためにエンドエフェクタ15とワーク42とが接する点であり、ロボットシステム10でワーク42の検査を行う場合、作業点はエンドエフェクタ15が検査のために移動する点である。作業点は、各工程に応じて複数設定される。これら作業点P[i]の座標は、各軸における位置および回転角度から、P[i]=(Xi,Yi,Zi,Rxi,Ryi,Rzi)で表わされる。   The work point is a coordinate of a position where the end effector 15 of the robot 11 acts on the workpiece 42. As described above, when the workpiece 42 is processed by the robot system 10, the work point is a point where the end effector 15 and the workpiece 42 come into contact with each other, and when the workpiece 42 is inspected by the robot system 10, The work point is a point where the end effector 15 moves for inspection. A plurality of work points are set according to each process. The coordinates of these work points P [i] are represented by P [i] = (Xi, Yi, Zi, Rxi, Ryi, Rzi) from the position and rotation angle on each axis.

また、これら初期状態の入力に加えて、入力部51を構成するワーク誤差入力部69からは、ワーク42に想定される誤差量が誤差Δpとして入力される(S102)。上述のようにロボット11とワーク42との至適な位置関係を抽出したとしても、工場などへのロボットシステム10の設置の際、およびワーク42の形状の変化などによってロボット11とワーク42との位置関係が僅かに変化する。そのため、ワーク誤差入力部69から予め予想されるワーク42の誤差量を既知の誤差Δpとして入力し、この誤差Δpが許容されるか否かを後述するS105において判定する。そのため、S102において、S105における判定で用いる誤差Δpが入力される。なお、この誤差Δpの入力は、S102に限らず、S105における判定を実行する以前であれば、任意の時期に行ってもよい。   In addition to these initial state inputs, an error amount assumed for the workpiece 42 is input as an error Δp from the workpiece error input unit 69 constituting the input unit 51 (S102). Even if the optimum positional relationship between the robot 11 and the workpiece 42 is extracted as described above, the robot 11 and the workpiece 42 are not changed when the robot system 10 is installed in a factory or when the shape of the workpiece 42 changes. The positional relationship changes slightly. Therefore, an error amount of the workpiece 42 predicted in advance from the workpiece error input unit 69 is input as a known error Δp, and it is determined in S105 described later whether this error Δp is allowed. Therefore, in S102, the error Δp used in the determination in S105 is input. The input of the error Δp is not limited to S102, and may be performed at an arbitrary time as long as the determination in S105 is not performed.

以上のように、S101において入力部51から初期状態が入力、およびS102において誤差Δpが入力されると、ロボットシミュレータ50の作業順序設定部65は、作業所要時間が最小となる最短作業順序の評価を行う(S103)。具体的には、作業順序設定部65は、ワーク42に対してロボット11が条件入力部68から入力された初期位置における原点ΣR0にあるとき、任意の作業順序で作業所要時間を算出する。上述のように作業所要時間は、ロボット11とワーク42との位置関係や作業点ごとの工程の順序によって変化する。そのため、作業順序設定部65は、ワーク42に対しロボット11が初期位置における原点ΣR0にある状態で複数の工程の順序を入れ替えながら作業所要時間が最短となる最短作業順序を求め、工程の順序ごとに作業所要時間を評価する。   As described above, when the initial state is input from the input unit 51 in S101 and the error Δp is input in S102, the work order setting unit 65 of the robot simulator 50 evaluates the shortest work order that minimizes the work required time. (S103). Specifically, when the robot 11 is at the origin ΣR0 at the initial position input from the condition input unit 68 with respect to the work 42, the work order setting unit 65 calculates the work required time in an arbitrary work order. As described above, the work required time varies depending on the positional relationship between the robot 11 and the work 42 and the order of the processes for each work point. Therefore, the work order setting unit 65 obtains the shortest work order that requires the shortest work time while changing the order of a plurality of processes while the robot 11 is at the origin ΣR0 at the initial position with respect to the work 42, and for each process order. Evaluate the time required for work.

S103において最短作業順序の評価が終了すると、ロボットシミュレータ50の最短位置抽出部66は、所要時間が最短となるロボット11とワーク42との位置関係を抽出または変更する(S104)。最短位置抽出部66は、上述のように条件入力部68から入力されたワーク42に対するロボット11の初期位置における原点ΣR0を含む床面13であるX−Y平面上に任意の設置範囲Aを設定する。ロボット11の初期位置における原点ΣR0は、この設置範囲Aに含まれている。最短位置抽出部66は、この任意の設置範囲A内において、ロボット11とワーク42との位置関係について至適解の候補となる複数の位置関係を抽出する。すなわち、最短位置抽出部66は、設置範囲A内において、ロボット11とワーク42とが好適な位置関係になると予想される複数の位置を抽出し、これを至適解の候補とする。そして、最短位置抽出部66は、抽出した至適解の候補となるロボット11とワーク42の位置関係ごとに作業順序設定部65で評価した最短作業順序にしたがって複数の工程を仮想的に実行する。最短位置抽出部66は、至適解の候補となっている位置関係ごとに最短作業順序にしたがって複数の工程を仮想的に実行し、至適解の候補から所要時間が最短となるロボット11とワーク42との位置関係を抽出する。このように、最短位置抽出部66は、候補として抽出した至適解に基づいてロボット11とワーク42との位置関係を変化させながら、所要時間が最短となる至適解に相当するロボット11とワーク42との位置関係を抽出する。この複数の至適解の候補から、所要時間が最短となるロボット11とワーク42との位置関係に対応する至適解を抽出する処理は、例えばPSO法など既知の手法によって実行される。後述するS105の処理によってS104へリターンし、S104を再び実行する場合、最短位置抽出部66はロボット11とワーク42との位置関係を変更、すなわち至適解の候補をさらに変更し、上述の処理を繰り返す。   When the evaluation of the shortest work order is completed in S103, the shortest position extraction unit 66 of the robot simulator 50 extracts or changes the positional relationship between the robot 11 and the work 42 with the shortest required time (S104). The shortest position extraction unit 66 sets an arbitrary installation range A on the XY plane that is the floor surface 13 including the origin ΣR0 at the initial position of the robot 11 with respect to the workpiece 42 input from the condition input unit 68 as described above. To do. The origin ΣR0 at the initial position of the robot 11 is included in the installation range A. The shortest position extraction unit 66 extracts a plurality of positional relationships that are candidates for the optimal solution for the positional relationship between the robot 11 and the workpiece 42 within the arbitrary installation range A. That is, the shortest position extraction unit 66 extracts a plurality of positions that are expected to have a suitable positional relationship between the robot 11 and the workpiece 42 within the installation range A, and sets these as candidates for the optimum solution. Then, the shortest position extraction unit 66 virtually executes a plurality of processes according to the shortest work order evaluated by the work order setting unit 65 for each positional relationship between the robot 11 and the work 42 that are candidates for the extracted optimum solution. . The shortest position extraction unit 66 virtually executes a plurality of processes in accordance with the shortest work order for each positional relationship that is an optimal solution candidate, and the robot 11 that requires the shortest time from the optimal solution candidate. The positional relationship with the work 42 is extracted. As described above, the shortest position extraction unit 66 changes the positional relationship between the robot 11 and the workpiece 42 based on the optimal solution extracted as a candidate, and the robot 11 corresponding to the optimal solution with the shortest required time. The positional relationship with the work 42 is extracted. The process of extracting the optimum solution corresponding to the positional relationship between the robot 11 and the workpiece 42 having the shortest required time from the plurality of optimum solution candidates is executed by a known method such as the PSO method. When returning to S104 by the process of S105 described later and executing S104 again, the shortest position extraction unit 66 changes the positional relationship between the robot 11 and the workpiece 42, that is, further changes the candidate of the optimal solution, and the above-described process. repeat.

S104において、所要時間が最短となるロボット11とワーク42との位置関係が抽出されると、ロボットシミュレータ50の設置位置判定部67は、誤差Δpに基づいて、その誤差Δpを設定してもロボット11でワーク42に対して作業可能であるか、すなわち誤差Δpがロボット11の作業に許容できるものであるか否かを判定する(S105)。具体的には、設置位置判定部67は、上述の通り、S102においてワーク誤差入力部69から入力された誤差Δpに基づいて、この誤差Δpが生じたときのエンドエフェクタ15の位置の変化を位置変化量Δrとして設定する。この位置変化量Δrは、誤差Δpによって生じるワーク42の初期位置となる原点ΣWに対する各軸方向の位置および回転方向のずれであり、方向と大きさとからなるベクトルとして、Δr=(ΔXw,ΔYw,ΔZw,ΔRxw,ΔRyw,ΔRzw)で示される。添字wは、位置変化量Δrがワーク42の位置変化量であることを示す。また、設置位置判定部67は、入力された誤差Δpにともなうマニピュレータ14における各軸の値の変化を姿勢変化量Δqとして算出する。この姿勢変化量Δqiは、マニピュレータ14の各関節ごとの回転角度として、Δqi=(Δθ1,Δθ2,Δθ3,Δθ4,Δθ5,Δθ6)で表わされる。   In S104, when the positional relationship between the robot 11 and the work 42 with the shortest required time is extracted, the installation position determination unit 67 of the robot simulator 50 sets the error Δp based on the error Δp. 11, it is determined whether or not the work can be performed on the work 42, that is, whether or not the error Δp is acceptable for the work of the robot 11 (S <b> 105). Specifically, as described above, the installation position determination unit 67 determines the position change of the end effector 15 when the error Δp occurs based on the error Δp input from the work error input unit 69 in S102. Set as the amount of change Δr. This position change amount Δr is a deviation in the direction of each axis and the rotational direction with respect to the origin ΣW, which is the initial position of the work 42 caused by the error Δp, and is expressed as Δr = (ΔXw, ΔYw, ΔZw, ΔRxw, ΔRyw, ΔRzw). The subscript w indicates that the position change amount Δr is the position change amount of the work 42. Further, the installation position determination unit 67 calculates a change in the value of each axis in the manipulator 14 due to the input error Δp as the posture change amount Δq. This posture change amount Δqi is expressed as Δqi = (Δθ1, Δθ2, Δθ3, Δθ4, Δθ5, Δθ6) as a rotation angle for each joint of the manipulator 14.

より具体的には、設置位置判定部67は、以下の式(1)に基づいて、位置変化量Δrから姿勢変化量Δqiを算出する。以下の式(1)において、qiは、誤差Δpが存在しないときのマニピュレータ14の各軸の値である。このqiは、上述の通り最短位置抽出部66においてS104で抽出した至適解に相当するロボット11とワーク42との位置関係における各軸の値である。Jv(qi)は、このqiにおけるヤコビアンである。
Δq=Jv(qi)-1Δr (1)
この式(1)は、姿勢変化量Δqiと位置変化量Δrとが線形の関係に近似されているため、姿勢変化量Δqiは誤差Δpに相関する位置変化量Δrに基づいて線形的に算出される。そのため、式(1)を用いることにより、姿勢変化量Δqiの算出に必要な演算は簡略化され、複数の関節を有するマニピュレータ14の姿勢変化量Δqiはより容易な演算で算出される。式(1)を行列式で表わした場合、図6に示す式(1)’となる。この式(1)’では、誤差Δpに相関するワーク42の位置変化量Δrを、各軸方向の変化量および回転角度の要素として、Δr=(ΔX,ΔY,ΔZ,ΔRx,ΔRy,ΔRz)と表わしている。また、この位置変化量Δrを、qiのヤコビアンJv(qi)の逆行列であるJv(qi)-1で逆変換した結果として得られる姿勢変化量Δqは、ロボット11の各軸の回転角度として、Δqj=(Δθ1,Δθ2,Δθ3,Δθ4,Δθ5,Δθ6)で表わされる。ここで添字のj=1〜6は、ロボット11の第一関節21〜第六関節26にそれぞれ対応している。
More specifically, the installation position determination unit 67 calculates the posture change amount Δqi from the position change amount Δr based on the following equation (1). In the following formula (1), qi is the value of each axis of the manipulator 14 when there is no error Δp. This qi is the value of each axis in the positional relationship between the robot 11 and the workpiece 42 corresponding to the optimal solution extracted in S104 by the shortest position extraction unit 66 as described above. Jv (qi) is the Jacobian in qi.
Δq = Jv (qi) −1 Δr (1)
In this equation (1), since the posture change amount Δqi and the position change amount Δr are approximated to a linear relationship, the posture change amount Δqi is linearly calculated based on the position change amount Δr correlated with the error Δp. The Therefore, by using Expression (1), the calculation necessary for calculating the posture change amount Δqi is simplified, and the posture change amount Δqi of the manipulator 14 having a plurality of joints is calculated by an easier calculation. When Expression (1) is represented by a determinant, Expression (1) ′ shown in FIG. 6 is obtained. In this equation (1) ′, Δr = (ΔX, ΔY, ΔZ, ΔRx, ΔRy, ΔRz) where the positional change amount Δr of the work 42 correlated with the error Δp is used as an element of the change amount and the rotation angle in each axis direction. It expresses. Further, the posture change amount Δq obtained as a result of inversely transforming the position change amount Δr with Jv (qi) −1 which is an inverse matrix of the Jacobian Jv (qi) of qi is a rotation angle of each axis of the robot 11. , Δqj = (Δθ1, Δθ2, Δθ3, Δθ4, Δθ5, Δθ6). Here, the subscripts j = 1 to 6 correspond to the first joint 21 to the sixth joint 26 of the robot 11, respectively.

設置位置判定部67は、上記の式(1)に基づいて姿勢変化量Δqiが算出されると、式(2)に基づいてマニピュレータ14の各軸の値qiを判定する。すなわち、設置位置判定部67は、式(1)による姿勢変化量Δqiの算出の対象としたロボット11とワーク42との位置関係の至適解における各軸の値qiが式(2)の関係を満たすか否かを判定する。
qi+Δqimax≦qmax (2)
式(2)において、最大変化量Δqimaxは、ワーク42の誤差Δpが最大となるときのマニピュレータ14の各軸の変化量である。この最大変化量Δqimaxは、誤差Δpが最大となるときの姿勢変化量Δqiを式(1)で算出することにより、既知の値として得られる。また、qmaxは、ロボット11のマニピュレータ14を構成する複数の関節ごとの回転角度限界である。
When the posture change amount Δqi is calculated based on the above equation (1), the installation position determining unit 67 determines the value qi of each axis of the manipulator 14 based on the equation (2). That is, the installation position determination unit 67 determines that the value qi of each axis in the optimal solution of the positional relationship between the robot 11 and the workpiece 42 that is the target of calculating the posture change amount Δqi according to Equation (1) is the relationship of Equation (2). It is determined whether or not the above is satisfied.
qi + Δqimax ≦ qmax (2)
In Expression (2), the maximum change amount Δqimax is a change amount of each axis of the manipulator 14 when the error Δp of the workpiece 42 is maximized. This maximum change amount Δqimax is obtained as a known value by calculating the posture change amount Δqi when the error Δp is maximized by Equation (1). Further, qmax is a rotation angle limit for each of a plurality of joints constituting the manipulator 14 of the robot 11.

具体的に説明すると、式2は、図7の式(2)’に示すような行列式として表わされる。式(2)における最大変化量Δqmaxは、誤差Δpが最大となるときに式(1)に基づいて算出される既知の値である。姿勢変化量Δqiを構成する要素は、Δθj(jは、ロボット11の軸の番号であり、六軸型の本実施形態のロボット11の場合、j=1〜6となる。)で示される。また、式(2)におけるqmaxは、ロボット11のマニピュレータ14を構成する複数の関節ごとに許容される回転角度、すなわち回転角度限界である。この回転角度限界qmaxは、図7の式(2)’に示すように各関節ごとにθjmax(j=1〜6)としてそれぞれ予め設定されている。   More specifically, Equation 2 is expressed as a determinant as shown in Equation (2) ′ in FIG. The maximum change amount Δqmax in the equation (2) is a known value calculated based on the equation (1) when the error Δp is maximized. The element constituting the posture change amount Δqi is indicated by Δθj (j is the axis number of the robot 11 and j = 1 to 6 in the case of the robot 11 of the six-axis type in this embodiment). Further, qmax in Expression (2) is a rotation angle allowed for each of a plurality of joints constituting the manipulator 14 of the robot 11, that is, a rotation angle limit. The rotation angle limit qmax is set in advance as θjmax (j = 1 to 6) for each joint as shown in Expression (2) ′ in FIG.

設置位置判定部67は、S104で抽出して式(1)における計算の基礎とした至適解における初期的な各軸の値qiと式(1)を用いて算出した誤差Δpが最大となるときの姿勢変化量Δqimaxとの和が、回転角度限界qmax以下となるように、要素ごとに大小関係を判定する。つまり、設置位置判定部67は、式(1)の算出の基礎としたqiを構成する要素である第一関節21の回転角度θ1と、誤差Δpが最大となるとして式(1)で算出した姿勢変化量Δqimaxを構成する要素である第一関節21の角度変化量Δθ1maxとの和が、予め設定されている第一関節21の回転角度限界θ1max以下であるかを判定する。同様に、設置位置判定部67は、第二関節22についてθ2+Δθ2max≦θ2maxであるか、第三関節23についてθ3+Δθ3max≦θ3maxであるか、第四関節24についてθ4+Δθ4max≦θ4maxであるか、第五関節25についてθ5+Δθ5max≦θ5maxであるか、第六関節26についてθ6+Δθ6max≦θ6maxであるか否かをそれぞれ判定する。   The installation position determination unit 67 maximizes the error Δp calculated using the initial value qi of each axis and the equation (1) in the optimum solution extracted in S104 and used as the basis of the calculation in the equation (1). The magnitude relationship is determined for each element so that the sum of the change amount and the posture change amount Δqimax is less than or equal to the rotation angle limit qmax. That is, the installation position determination unit 67 calculates the rotation angle θ1 of the first joint 21 that is an element constituting qi based on the calculation of the equation (1) and the error Δp by the equation (1). It is determined whether the sum of the angle change amount Δθ1max of the first joint 21 which is an element constituting the posture change amount Δqimax is equal to or less than a preset rotation angle limit θ1max of the first joint 21. Similarly, the installation position determination unit 67 determines whether θ2 + Δθ2max ≦ θ2max for the second joint 22, θ3 + Δθ3max ≦ θ3max for the third joint 23, θ4 + Δθ4max ≦ θ4max for the fourth joint 24, or the fifth joint 25. It is determined whether or not θ5 + Δθ5max ≦ θ5max with respect to or whether or not θ6 + Δθ6max ≦ θ6max with respect to the sixth joint 26.

そして、設置位置判定部67は、上記の式(2)すなわち式(2)’を用いた判定の結果、要素となる複数の関節のすべてが式(2)すなわち式(2)’を満たす場合、式(1)における演算の基礎とした各軸の値qiが成立するとして、このqiに対応するロボット11とワーク42との位置関係が適切であると判定する。一方、設置位置判定部67は、要素となる複数の関節のうちいずれか一つが式(2)すなわち式(2)’の関係を満たさない場合、式(1)における演算の基礎とした各軸の値qiが成立しないとして、このqiに対応するロボット11とワーク42との位置関係が不適切であると判定する。上記のように、設置位置判定部67は、以上の演算により式(1)おおび式(2)に基づいて、ワーク42が初期位置から誤差Δpだけ移動、特に誤差Δpが際となるまで移動したとしても、ロボット11がワーク42に対して作業可能であるか否かをすべての作業点について判定する。   And as a result of the determination using the above formula (2), that is, the formula (2) ′, the installation position determining unit 67 satisfies the formula (2), that is, the formula (2) ′. Assuming that the value qi of each axis based on the calculation in Expression (1) is established, it is determined that the positional relationship between the robot 11 and the workpiece 42 corresponding to this qi is appropriate. On the other hand, when any one of a plurality of joints as elements does not satisfy the relationship of Expression (2), that is, Expression (2) ′, the installation position determination unit 67 determines each axis as the basis of the calculation in Expression (1). Is not established, it is determined that the positional relationship between the robot 11 and the workpiece 42 corresponding to this qi is inappropriate. As described above, the installation position determination unit 67 moves the workpiece 42 from the initial position by the error Δp, particularly until the error Δp becomes prominent, based on the equations (1) and (2) based on the above calculation. Even if it does, it will be determined about all the work points whether the robot 11 can work with respect to the workpiece | work 42. FIG.

設置位置判定部67は、式(1)および式(2)に基づく演算結果から、ロボット11がワーク42に対して作業可能である、すなわち誤差Δpが許容可能であると判定すると(S105:Yes)、計算時間制約を判定するために計算所要時間に到達したか否かを判断する(S106)。設置位置判定部67は、式(1)および式(2)によりロボット11がワーク42に対して作業可能であると判定したとき、計算時間が予め設定した計算所要時間内にあるか否かを判断する。ロボットシステム10では、複数の工程からなる作業の所要時間が最短となる具体的な時間を予め知ることはできない。そのため、設置位置判定部67では、各演算の無限の繰り返しを招くおそれがある。そこで、設置位置判定部67は、S106において予め設定した計算所要時間に到達したか否かを判断する。この計算所要時間は、確保したい精度に応じて任意に設定される。設置位置判定部67は、予め設定した計算所要時間に到達するまでS103からS106までの最適化処理を繰り返し、予め設定した計算所要時間を経過すると、S107へ移行する。すなわち、設置位置判定部67は、S103の最初の実行からの経過時間が計算所要時間に到達したか否かを判断し、計算所要時間に到達していないとき(S106:No)、S103へリターンし、作業順序の変更以降の最適化処理を繰り返す。一方、設置位置判定部67は、S103の最初の実行からの経過時間が計算所要時間に到達したと判断すると(S106:Yes)、S107の出力処理へ移行し、最適化によって得られた条件の範囲内における最適な作業順序、ロボット11とワーク42との位置関係を表示部61へ可視的に出力する。   If the installation position determination unit 67 determines that the robot 11 can work on the workpiece 42 from the calculation results based on the expressions (1) and (2), that is, the error Δp is allowable (S105: Yes). ), It is determined whether or not the calculation required time has been reached in order to determine the calculation time constraint (S106). When the installation position determination unit 67 determines that the robot 11 can work on the workpiece 42 according to the expressions (1) and (2), it determines whether or not the calculation time is within a predetermined calculation time. to decide. In the robot system 10, it is not possible to know in advance the specific time for which the time required for work consisting of a plurality of processes is the shortest. Therefore, the installation position determination unit 67 may cause infinite repetition of each calculation. Therefore, the installation position determination unit 67 determines whether or not the calculation required time set in advance in S106 has been reached. This calculation required time is arbitrarily set according to the accuracy to be secured. The installation position determination unit 67 repeats the optimization processing from S103 to S106 until the preset calculation time is reached, and when the preset calculation time has elapsed, the process proceeds to S107. That is, the installation position determination unit 67 determines whether or not the elapsed time from the first execution of S103 has reached the calculation required time. When the calculation required time has not been reached (S106: No), the process returns to S103. Then, the optimization process after changing the work order is repeated. On the other hand, if the installation position determination unit 67 determines that the elapsed time from the first execution of S103 has reached the calculation required time (S106: Yes), the process proceeds to the output process of S107, and the conditions obtained by the optimization are satisfied. The optimal work order within the range and the positional relationship between the robot 11 and the workpiece 42 are visually output to the display unit 61.

ところで、設置位置判定部67は、式(1)および式(2)に基づく算出結果から、ロボット11がワーク42に対して作業可能でない、すなわち誤差Δpが許容できないと判定すると(S105:No)、S104へリターンし、ロボット11とワーク42との位置関係を、複数の至適解の候補のうち他の候補に変更する。すなわち、S104では複数の至適解の候補から所要時間が最短となるロボット11とワーク42との位置関係が抽出され、この位置関係についてS105で誤差が許容されるか否かが判定される。ここで、所要時間が最短となるロボット11とワーク42との位置関係ではS105で誤差が許容できないと判定されると、先のS104で所要時間が最短と判断された位置関係の次に所要時間の短い至適解の候補を抽出し、S105の処理を繰り返す。そして、設置位置判定部67は、変更した至適解の候補に対応するロボット11とワーク42との位置関係に基づいて、S105における判定処理を実行する。   By the way, if the installation position determination unit 67 determines from the calculation results based on the formulas (1) and (2) that the robot 11 cannot work on the workpiece 42, that is, the error Δp is unacceptable (S105: No). Returning to S104, the positional relationship between the robot 11 and the workpiece 42 is changed to another candidate among a plurality of optimal solution candidates. That is, in S104, the positional relationship between the robot 11 and the work 42 having the shortest required time is extracted from a plurality of optimal solution candidates, and it is determined whether or not an error is allowed in S105 for this positional relationship. If it is determined in S105 that the error is unacceptable in the positional relationship between the robot 11 and the workpiece 42 in which the required time is the shortest, the required time next to the positional relationship in which the required time is determined to be the shortest in S104. Short optimal solution candidates are extracted, and the process of S105 is repeated. Then, the installation position determination unit 67 executes the determination process in S105 based on the positional relationship between the robot 11 and the workpiece 42 corresponding to the changed optimal solution candidate.

以上の手順により、ロボットシミュレータ50は、S104で設置範囲Aに抽出された至適解の候補について、ロボット11とワーク42と位置関係、および誤差Δpによるロボット11の作動の可否を計算所要時間に到達するまで繰り返し評価する。そして、計算所要時間に到達すると、ロボット11における作業順序および至適解に相当するロボット11とワーク42との位置関係を、シミュレーションの範囲内における最適値として表示部61に出力する。なお、至適解または至適解に近似するロボット11とワーク42との位置関係が複数ある場合、これら複数の位置関係を好ましい順に順位を付して表示部61に表示する構成としてもよい。   With the above procedure, the robot simulator 50 calculates the positional relationship between the robot 11 and the workpiece 42 and whether or not the robot 11 can be operated based on the error Δp for the optimal solution candidate extracted in the installation range A in S104. Evaluate repeatedly until it reaches. When the time required for the calculation is reached, the work order in the robot 11 and the positional relationship between the robot 11 and the work 42 corresponding to the optimal solution are output to the display unit 61 as optimum values within the simulation range. In addition, when there are a plurality of positional relationships between the robot 11 and the workpiece 42 that are optimal solutions or approximate to the optimal solutions, the plurality of positional relationships may be displayed on the display unit 61 in order of preference.

以上説明した一実施形態の場合、上記の式(1)は、線形近似されている。そのため、パーソナルコンピュータなどの演算部52にとって処理が容易な線形式を利用してロボット11が作業可能な範囲であるか否かが判定される。ところで、ワーク42に生じるとして設定している誤差Δpは、ロボット11の姿勢の大きな変化や、作業時間の大幅な増加を招くものではない。そのため、ロボット11とワーク42との位置関係を検証するためには、誤差Δpが生じていないときを基準とすればよく、線形近似された式(1)により簡単な演算で至適解の候補を算出することができる。一方、ロボット11の各軸の姿勢に大きな変化が生じる場合でも、上記の式(1)および式(2)を用いてそのまま計算することにより、作業が不可能な姿勢は式(2)によって不適切な解と判定される。そのため、ロボットとワークとの位置関係を検証するためには、誤差Δpが生じていないときを基準とすればよく、誤差Δpは無視してもよい。   In the case of the embodiment described above, the above equation (1) is linearly approximated. Therefore, it is determined whether or not the robot 11 is within a workable range using a linear format that is easy for the computing unit 52 such as a personal computer to process. Incidentally, the error Δp set to occur in the workpiece 42 does not cause a large change in the posture of the robot 11 or a significant increase in work time. Therefore, in order to verify the positional relationship between the robot 11 and the work 42, the time when no error Δp has occurred may be used as a reference, and a candidate for the optimum solution can be obtained by a simple calculation using the linearly approximated expression (1). Can be calculated. On the other hand, even if a large change occurs in the posture of each axis of the robot 11, by performing the calculation using the above formulas (1) and (2) as it is, the posture that cannot be worked is determined by the formula (2). It is determined as an appropriate solution. Therefore, in order to verify the positional relationship between the robot and the workpiece, the time when no error Δp occurs may be used as a reference, and the error Δp may be ignored.

また、一実施形態では、式(1)を用いることにより、ワーク42の各作業点において一通りのヤコビアンで演算できる。したがって、ロボット11とワーク42との位置関係に誤差Δpが生じる場合でも、ロボット11が動作可能となるロボット11とワーク42との最適な位置関係を簡単な処理で導き出すことができる。   Further, in one embodiment, by using the equation (1), calculation can be performed with one Jacobian at each work point of the work 42. Therefore, even when an error Δp occurs in the positional relationship between the robot 11 and the workpiece 42, the optimal positional relationship between the robot 11 and the workpiece 42 where the robot 11 can operate can be derived by simple processing.

以上説明した本発明は、上記実施形態に限定されるものではなく、その要旨を逸脱しない範囲で種々の実施形態に適用可能である。   The present invention described above is not limited to the above-described embodiment, and can be applied to various embodiments without departing from the gist thereof.

図面中、10はロボットシステム、11はロボット、12はワーク搭載部、14はマニピュレータ、15はエンドエフェクタ、21は第一関節、22は第二関節、23は第三関節、24は第四関節、25は第五関節、26は第六関節、31は第一アーム、32は第二アーム、33は第三アーム、34は第四アーム、35は第五アーム、42はワーク、50はロボットシミュレータ、51は入力部、52は演算部、53は出力部、65は作業順序設定部、66は最短位置抽出部、67は設置位置判定部、68は条件入力部、69はワーク誤差入力部を示す。   In the drawings, 10 is a robot system, 11 is a robot, 12 is a work mounting unit, 14 is a manipulator, 15 is an end effector, 21 is a first joint, 22 is a second joint, 23 is a third joint, and 24 is a fourth joint. , 25 is the fifth joint, 26 is the sixth joint, 31 is the first arm, 32 is the second arm, 33 is the third arm, 34 is the fourth arm, 35 is the fifth arm, 42 is the work, 50 is the robot Simulator, 51 is an input unit, 52 is a calculation unit, 53 is an output unit, 65 is a work order setting unit, 66 is a shortest position extraction unit, 67 is an installation position determination unit, 68 is a condition input unit, and 69 is a work error input unit. Indicates.

Claims (2)

ワークが搭載されるワーク搭載部と、複数のアームおよび関節から構成されるマニピュレータおよび前記マニピュレータの先端に設けられ前記ワークを取り扱うエンドエフェクタを有するロボットと、を備えるロボットシステムにおいて、前記ロボットの設置位置と前記ワークの設置位置との関係をシミュレーションするロボットシミュレータであって、
前記エンドエフェクタが前記ワークに作用する作業点のうち初期位置として予め設定されている初期作業点に対し、前記ワーク搭載部において想定される前記ワークの誤差量を誤差Δpとして入力するワーク誤差入力手段と、
ワーク誤差入力手段から入力された前記誤差Δpに基づいて、前記誤差Δpにともなう前記エンドエフェクタの位置の変化を位置変化量Δrとし、前記誤差Δpにともなう前記マニピュレータにおける各軸の変化量を姿勢変化量Δqiとし、前記誤差Δpが存在しないときの前記マニピュレータの各軸の値をqi(iは、作業点の番号であり、i≧1)とし、このqiにおけるヤコビアンをJv(qi)として、前記姿勢変化量Δqiを、
Δqi=Jv(qi)-1Δr (1)
により算出するとともに、
前記式(1)で算出される前記姿勢変化量Δqiが最大となるときの前記マニピュレータの各軸の変化量を最大変化量Δqimaxとし、前記関節の回転角度限界をqmaxとすると、
qi+Δqimax≦qmax (2)
を満たす前記マニピュレータの各軸の値qiを求めることにより、前記ロボットの設置位置の可否を判定する設置位置判定手段と、
を備えることを特徴とするロボットシミュレータ。
In a robot system comprising: a workpiece mounting portion on which a workpiece is mounted; a manipulator including a plurality of arms and joints; and a robot having an end effector that is provided at a tip of the manipulator and handles the workpiece. And a robot simulator for simulating the relationship between the workpiece installation position and the workpiece,
A workpiece error input means for inputting, as an error Δp, an error amount of the workpiece assumed in the workpiece mounting portion with respect to an initial working point set in advance as an initial position among the working points at which the end effector acts on the workpiece. When,
Based on the error Δp input from the workpiece error input means, a change in the position of the end effector with the error Δp is defined as a position change amount Δr, and a change in each axis in the manipulator with the error Δp is changed in posture. The amount Δqi, the value of each axis of the manipulator when the error Δp does not exist is qi (i is a work point number, i ≧ 1), and the Jacobian in qi is Jv (qi). Posture change amount Δqi is
Δqi = Jv (qi) −1 Δr (1)
As well as
When the change amount of each axis of the manipulator when the posture change amount Δqi calculated by the equation (1) is maximum is a maximum change amount Δqimax, and the rotation angle limit of the joint is qmax,
qi + Δqimax ≦ qmax (2)
An installation position determination means for determining whether the installation position of the robot is acceptable by obtaining a value qi of each axis of the manipulator satisfying
A robot simulator comprising:
ワークが搭載されるワーク搭載部と、複数のアームおよび関節から構成されるマニピュレータおよび前記マニピュレータの先端に設けられ前記ワークを取り扱うエンドエフェクタを有するロボットと、を備えるロボットシステムにおいて、前記ロボットの設置位置と前記ワークの設置位置との関係をシミュレーションするロボットシミュレータであって、
前記ワーク搭載部に搭載された前記ワークに対する前記ロボットの初期位置、前記ロボットによる複数の工程を含む作業順序、および前記ワークの中心を原点として前記エンドエフェクタが前記ワークに作用する作業点の座標をそれぞれ入力する条件入力手段と、
前記条件入力手段から入力された前記ワークに対する前記ロボットの設置位置について、前記条件入力手段から入力された前記複数の工程の作業所要時間を算出して前記作業所要時間が最小となる最短作業順序を求める作業順序設定手段と、
前記条件入力手段から入力された前記ワークに対する前記ロボットの初期位置を含む平面上において予め設定された設置範囲内において、至適解の候補となる前記ワークと前記ロボットとの複数の位置関係を抽出し、抽出した至適解の候補となる前記ワークと前記ロボットとの位置関係ごとに前記作業順序設定手段で求めた前記最短作業順序で前記ロボットによる複数の工程を実行し、前記至適解の候補のうち最も所要時間の短い前記ワークと前記ロボットとの位置関係を抽出する最短位置抽出手段と、
前記最短位置抽出手段で抽出された前記ワークと前記ロボットとの位置関係において、前記作業点のうち初期位置として予め設定されている初期作業点に対し、前記ワーク搭載部において想定される前記ワークの誤差量を誤差Δpとして入力するワーク誤差入力手段と、
ワーク誤差入力手段から入力された前記誤差Δpに基づいて、前記誤差Δpにともなう前記エンドエフェクタの位置の変化を位置変化量Δrとし、前記誤差Δpにともなう前記マニピュレータにおける各軸の変化量を姿勢変化量Δqiとし、前記誤差Δpが存在しないときの前記マニピュレータの各軸の値をqi(iは、作業点の番号であり、i≧1)とし、このqiにおけるヤコビアンをJv(qi)として、前記姿勢変化量Δqiを、
Δqi=Jv(qi)-1Δr (1)
により算出するとともに、
前記式(1)で算出される前記姿勢変化量Δqiが最大となるときの前記マニピュレータの各軸の変化量を最大変化量Δqimaxとし、前記関節の回転角度限界をqmaxとすると、
qi+Δqimax≦qmax (2)
を満たす前記マニピュレータのコンフィグレーションqiは、前記誤差Δpが生じたときに前記ロボットの設置位置において、前記ロボットで前記ワークに対する作業が可能な領域であると判定する設置位置判定手段と、
前記設置位置判定手段で判定した前記ロボットと前記ワークとの至適な位置関係を可視的に出力する出力手段と、
を備えることを特徴とするロボットシミュレータ。
In a robot system comprising: a workpiece mounting portion on which a workpiece is mounted; a manipulator including a plurality of arms and joints; and a robot having an end effector that is provided at a tip of the manipulator and handles the workpiece. And a robot simulator for simulating the relationship between the workpiece installation position and the workpiece,
An initial position of the robot with respect to the work mounted on the work mounting unit, a work order including a plurality of steps by the robot, and coordinates of a work point at which the end effector acts on the work with the center of the work as an origin. Condition input means to input each,
For the installation position of the robot with respect to the workpiece inputted from the condition input means, the work required time of the plurality of steps input from the condition input means is calculated, and the shortest work order that minimizes the work required time is calculated. Work order setting means to be obtained;
Extracting a plurality of positional relationships between the workpiece and the robot that are candidates for the optimal solution within an installation range set in advance on a plane including the initial position of the robot with respect to the workpiece input from the condition input means And executing a plurality of steps by the robot in the shortest work order obtained by the work order setting means for each positional relationship between the workpiece as a candidate for the extracted optimum solution and the robot, Shortest position extraction means for extracting a positional relationship between the workpiece and the robot having the shortest required time among candidates;
In the positional relationship between the work extracted by the shortest position extracting means and the robot, the initial position of the work that is set in advance as the initial position among the work points, A workpiece error input means for inputting an error amount as an error Δp;
Based on the error Δp input from the workpiece error input means, a change in the position of the end effector with the error Δp is defined as a position change amount Δr, and a change in each axis in the manipulator with the error Δp is changed in posture. The amount Δqi, the value of each axis of the manipulator when the error Δp does not exist is qi (i is a work point number, i ≧ 1), and the Jacobian in qi is Jv (qi). Posture change amount Δqi is
Δqi = Jv (qi) −1 Δr (1)
As well as
When the change amount of each axis of the manipulator when the posture change amount Δqi calculated by the equation (1) is maximum is a maximum change amount Δqimax, and the rotation angle limit of the joint is qmax,
qi + Δqimax ≦ qmax (2)
The configuration qi of the manipulator satisfying an installation position determining means for determining that the robot is capable of working on the workpiece at the installation position of the robot when the error Δp occurs;
An output means for visually outputting an optimal positional relationship between the robot and the workpiece determined by the installation position determination means;
A robot simulator comprising:
JP2010018581A 2010-01-29 2010-01-29 Robot simulator Active JP5513146B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2010018581A JP5513146B2 (en) 2010-01-29 2010-01-29 Robot simulator

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2010018581A JP5513146B2 (en) 2010-01-29 2010-01-29 Robot simulator

Publications (2)

Publication Number Publication Date
JP2011156605A JP2011156605A (en) 2011-08-18
JP5513146B2 true JP5513146B2 (en) 2014-06-04

Family

ID=44589042

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2010018581A Active JP5513146B2 (en) 2010-01-29 2010-01-29 Robot simulator

Country Status (1)

Country Link
JP (1) JP5513146B2 (en)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017018113A1 (en) * 2015-07-29 2017-02-02 株式会社オートネットワーク技術研究所 Object handling simulation device, object handling simulation system, method for simulating object handling, manufacturing method for object, and object handling simulation program
CN110536783B (en) * 2017-04-19 2022-06-14 株式会社安川电机 Programming support device, robot system, programming support method, and storage medium
JP6549654B2 (en) * 2017-08-03 2019-07-24 ファナック株式会社 Robot system simulation apparatus and simulation method
JP6806757B2 (en) * 2018-11-16 2021-01-06 ファナック株式会社 Operation program creation device

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0766289B2 (en) * 1986-06-20 1995-07-19 トキコ株式会社 Industrial robots
JPH0820894B2 (en) * 1987-07-01 1996-03-04 株式会社日立製作所 Industrial robot operation control method
JPH01267706A (en) * 1988-04-19 1989-10-25 Toyoda Mach Works Ltd Method for controlling robot
JPH0683974B2 (en) * 1988-07-07 1994-10-26 川崎重工業株式会社 How to determine the installation position of an industrial robot
JPH02257312A (en) * 1989-03-30 1990-10-18 Toyota Motor Corp Method for generating data for teaching robot
JP2750635B2 (en) * 1990-09-28 1998-05-13 新明和工業株式会社 Drive control method for cylindrical coordinate robot
JPH08328632A (en) * 1995-05-26 1996-12-13 Matsushita Electric Works Ltd Method for simulating robot operation
JP3572380B2 (en) * 1998-01-05 2004-09-29 日産自動車株式会社 Offline teaching method
JP3797986B2 (en) * 2003-07-03 2006-07-19 ファナック株式会社 Robot offline simulation equipment

Also Published As

Publication number Publication date
JP2011156605A (en) 2011-08-18

Similar Documents

Publication Publication Date Title
JP6497953B2 (en) Offline teaching apparatus, offline teaching method, and robot system
JP4271232B2 (en) Apparatus, method, program, and recording medium for executing offline programming of robot
Chen et al. Posture optimization in robotic machining based on comprehensive deformation index considering spindle weight and cutting force
JP4763614B2 (en) Method and system for optimizing task location for a robot that performs tasks
Wang et al. Calibration method of robot base frame using unit quaternion form
JP5872894B2 (en) Robot motion teaching support apparatus and method
JP5502348B2 (en) Simulation method
KR20110099386A (en) Error estimation method and device for multi-axis controlled machines
JP2009274148A (en) Simulation device
Deng et al. Elasto-geometrical error and gravity model calibration of an industrial robot using the same optimized configuration set
JP5513146B2 (en) Robot simulator
Pac et al. Interval analysis of kinematic errors in serial manipulators using product of exponentials formula
Bhatt et al. Optimizing part placement for improving accuracy of robot-based additive manufacturing
CN115401699B (en) Industrial robot precision reliability analysis method, device, equipment and storage medium
Schwartz et al. Designing Fingers in Simulation based on Imprints.
JP5513145B2 (en) Robot posture determination method
JP3639873B2 (en) Robot control method and robot control system
CN112084599B (en) Aerospace box part structure deformation-oriented compensation method
Mousavi Mohammadi et al. A real-time impedance-based singularity and joint-limits avoidance approach for manual guidance of industrial robots
JP2006289580A (en) Teaching point correcting method of program and teaching point correcting device of program
JP5803179B2 (en) Robot control method and robot control apparatus
JP2021186929A (en) Control method for multi-axis robot
Baizid et al. Industrial robotics platform for simulation design, planning and optimization based on off-line CAD programming
Ren et al. A heuristic iterative method for solving the inverse solution of kinematics of manipulators
Bath et al. A simulation driven development framework for parallel kinematics

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20130115

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130122

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130422

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20131209

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20131217

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: 20140304

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20140327

R150 Certificate of patent or registration of utility model

Ref document number: 5513146

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250