JP2021077149A - Information processing method, information processing equipment, and robot system - Google Patents
Information processing method, information processing equipment, and robot system Download PDFInfo
- Publication number
- JP2021077149A JP2021077149A JP2019203868A JP2019203868A JP2021077149A JP 2021077149 A JP2021077149 A JP 2021077149A JP 2019203868 A JP2019203868 A JP 2019203868A JP 2019203868 A JP2019203868 A JP 2019203868A JP 2021077149 A JP2021077149 A JP 2021077149A
- Authority
- JP
- Japan
- Prior art keywords
- information processing
- simulation
- object models
- contact
- robot
- 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
Links
- 230000010365 information processing Effects 0.000 title claims description 31
- 238000003672 processing method Methods 0.000 title claims description 15
- 238000004088 simulation Methods 0.000 claims abstract description 137
- 238000000034 method Methods 0.000 claims description 41
- 238000005096 rolling process Methods 0.000 claims description 7
- 238000004519 manufacturing process Methods 0.000 claims description 2
- 238000004364 calculation method Methods 0.000 abstract description 55
- 238000004458 analytical method Methods 0.000 abstract description 9
- 238000012545 processing Methods 0.000 abstract description 8
- 238000003860 storage Methods 0.000 description 15
- 230000001133 acceleration Effects 0.000 description 10
- 238000013459 approach Methods 0.000 description 2
- 238000012790 confirmation Methods 0.000 description 2
- 238000001514 detection method Methods 0.000 description 2
- 238000006073 displacement reaction Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000005484 gravity Effects 0.000 description 2
- 230000010354 integration Effects 0.000 description 2
- 230000015654 memory Effects 0.000 description 2
- 108010062618 Oncogene Proteins v-rel Proteins 0.000 description 1
- 201000001880 Sexual dysfunction Diseases 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Images
Landscapes
- Manipulator (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
Description
本発明は、複数の物体モデルが存在する仮想空間で、少なくとも1つの物体モデルを動作させるシミュレーションを行う情報処理方法、情報処理装置、およびロボットシステムに関する。 The present invention relates to an information processing method, an information processing device, and a robot system that perform a simulation of operating at least one object model in a virtual space in which a plurality of object models exist.
昨今様々な生産現場でロボットが用いられており、それらロボットの動作確認をオフラインで行う事ができるシミュレータの需要が高まっている。例えば、ロボットが他の治具に衝突していないかを確認するシミュレーションや、ロボット・治具・ワークなどの機構を構成する部品の挙動をコンピュータでシミュレートすることで組立プロセス設計を支援するダイナミクスシミュレーションが挙げられる。 Recently, robots are used in various production sites, and the demand for simulators that can check the operation of these robots offline is increasing. For example, dynamics that support assembly process design by simulating whether a robot collides with other jigs or by simulating the behavior of parts that make up a mechanism such as a robot, jig, or work with a computer. Simulation can be mentioned.
産業用ロボットで物体を組み立てる工程のダイナミクスシミュレーションを行う場合、物体モデル同士が接触した際に発生する接触力を正確に計算する必要がある。この接触力の計算方式は、計算量が少ないペナルティ法と、計算量が多いが理論的に正確性が保証されている解析法に大別する事ができる。 When performing a dynamics simulation of the process of assembling an object with an industrial robot, it is necessary to accurately calculate the contact force generated when the object models come into contact with each other. This contact force calculation method can be roughly divided into a penalty method with a small amount of calculation and an analysis method with a large amount of calculation but whose accuracy is theoretically guaranteed.
特許文献1は、物体モデル同士のオーバーラップ量から接触力を求めるペナルティ法に、弾性計算を導入した際の問題点を解決する手法を開示している。特許文献1の手法では、接触の開始時と終了時に発生する計算誤差を軽減するために、計算時間を細かく分割する。
非特許文献1は、解析法を用いて、接触力を正確に計算する手法を開示している。非特許文献1の手法は、物体同士の近接点において接触前と接触後の相対速度が理論的に正しくなるように連立方程式を立て、近接点の速度と接触力に関する条件式を用い、線形相補性問題として解くものである。
Non-Patent
コンピュータグラフィックスなどの分野では、接触力の計算にはペナルティ法が用いられる傾向がある。これに対して、産業用のロボットのシミュレーションなどにおいては、接触力の計算には精度が求められるため解析法が望ましい。 In fields such as computer graphics, the penalty method tends to be used to calculate contact force. On the other hand, in the simulation of industrial robots, the analysis method is desirable because the calculation of contact force requires accuracy.
解析法では、接触力を計算するために物体同士が十分近づいた際の近接点を用いるが、物体同士がオーバーラップすると、近接点を計算する事ができなくなる。そこで、オーバーラップ前に、物体同士が十分近づいたかどうかを物体同士の距離を接触閾値と比較して判定する必要がある。このとき、物体同士のオーバーラップ状態を防ぐ目的では、比較的大きな接触閾値を設定する。これにより、実際の接触点とかけ離れた点が力計算のための近接点として選ばれる傾向が生じ、シミュレーション精度が低下する可能性がある。 In the analysis method, the proximity points when the objects are sufficiently close to each other are used to calculate the contact force, but when the objects overlap each other, the proximity points cannot be calculated. Therefore, before the overlap, it is necessary to determine whether or not the objects are sufficiently close to each other by comparing the distance between the objects with the contact threshold value. At this time, a relatively large contact threshold value is set for the purpose of preventing the overlapping state of the objects. As a result, a point far from the actual contact point tends to be selected as a proximity point for force calculation, which may reduce the simulation accuracy.
本発明の課題は、上記の問題点に鑑み、オーバーラップが発生した後も、解析法の接触力演算に必要な近接点を求め、適切、かつ高精度なシミュレーション処理を継続することができるようにすることにある。 In view of the above problems, the object of the present invention is to obtain the proximity points required for the contact force calculation of the analysis method even after the overlap occurs, and to continue the appropriate and highly accurate simulation processing. To do.
上記課題を解決するため、本発明においては、複数の物体モデルが存在する仮想空間で、少なくとも1つの物体モデルを動作させるシミュレーションを行う情報処理方法において、制御装置が、第1のシミュレーションステップにおいて、複数の物体モデルのオーバーラップが発生しているか否かを判定し、前記複数の物体モデルのオーバーラップが発生している場合、シミュレーションの状態をオーバーラップが生じていない過去の第2のシミュレーションステップにロールバックさせる工程と、前記制御装置が、ロールバックさせた前記第2のシミュレーションステップにおいて、前記物体モデルの所定の閾値以内の距離で互いに近接する近接点を取得し、取得した前記近接点の接触前と接触後の相対速度を用いて、前記物体モデル同士が接触した場合に前記物体モデルの間に働く接触力を演算する工程と、を含む構成を採用した。 In order to solve the above problems, in the present invention, in an information processing method for performing a simulation in which at least one object model is operated in a virtual space where a plurality of object models exist, a control device is used in a first simulation step. It is determined whether or not the overlap of the plurality of object models has occurred, and if the overlap of the plurality of object models has occurred, the simulation state is the second simulation step in the past in which the overlap does not occur. In the step of rolling back to and the second simulation step of rolling back, the control device acquires proximity points that are close to each other within a predetermined threshold of the object model, and the acquired proximity points of the acquired proximity points. A configuration including a step of calculating the contact force acting between the object models when the object models come into contact with each other by using the relative velocities before and after the contact is adopted.
上記構成によれば、物体モデルのオーバーラップが発生した後も、解析法の接触力演算に必要な近接点を求め、適切、かつ高精度なシミュレーション処理を継続することができる。 According to the above configuration, even after the overlap of the object models occurs, the proximity points required for the contact force calculation of the analysis method can be obtained, and the appropriate and highly accurate simulation processing can be continued.
以下、添付図面を参照して本発明を実施するための形態につき説明する。なお、以下に示す構成はあくまでも一例であり、例えば細部の構成については本発明の趣旨を逸脱しない範囲において当業者が適宜変更することができる。また、本実施形態で取り上げる数値は参考数値の例示に過ぎない。 Hereinafter, embodiments for carrying out the present invention will be described with reference to the accompanying drawings. The configuration shown below is merely an example, and for example, a person skilled in the art can appropriately change the detailed configuration without departing from the spirit of the present invention. Moreover, the numerical values taken up in this embodiment are merely examples of reference numerical values.
<実施形態1>
本実施形態のシミュレーション処理(情報処理方法)を実行可能な情報処理装置の構成例を図1に示す。図1の装置は、例えば、ロボット装置を制御するロボット制御プログラムに記述された態様で、ロボット装置が操作する対象の物体に対応する物体モデルを仮想空間で動作させるシミュレーション装置である。
<
FIG. 1 shows a configuration example of an information processing apparatus capable of executing the simulation process (information processing method) of the present embodiment. The device of FIG. 1 is, for example, a simulation device for operating an object model corresponding to an object to be operated by the robot device in a virtual space in a mode described in a robot control program for controlling the robot device.
図1のシミュレーション装置1は、演算部としてのCPU20、記憶媒体としてのROM21、RAM22、HDD23、記録ディスクドライブ24、各種のインターフェース25,26,27,28を備えている。CPU20には、これらROM21、RAM22、HDD23、記録ディスクドライブ24、インターフェース25,26,27,28が、バス29を介して相互に通信可能に接続されている。
The
また、図7はこのシミュレーション装置1と、ロボット制御装置180、ロボット装置181から成るロボットシステムを含む構成の一例を示している。図7では、シミュレーション装置1は、図1のCPU20を中心としたブロック(ROM21、RAM22、HDD23など)を含む、例えばPC(パーソナルコンピュータ)のような形態の制御端末として図示してある。シミュレーション装置1には、キーボード11、マウス12、モニタ13が接続されている。
Further, FIG. 7 shows an example of a configuration including the
図7のモニタ13は、シミュレーション画面100を表示している。シミュレーション画面100は、ロボットモデルや、それにより操作される部品(物体モデル)を表示するCG画面を備える。このシミュレーション画面100は、さらに接触閾値などの設定操作を行うためのユーザーインターフェース40(図6)や、ロボット制御プログラムを設定するためのユーザーインターフェース1000(図8)などを備えている。
The
本実施形態のシミュレーション装置1は、接触を伴うロボット装置181の動作をオフラインで確認するような用途を想定している。例えば、図7において、シミュレーション装置1は、ロボット制御装置180がロボット装置181を駆動制御するためのロボット制御プログラムの検証などに利用できる。例えば、ハンド182、アーム、操作するワーク183、184などの各物体の接触を伴う動作をシミュレーションすることにより、ロボット装置181を駆動制御するロボット制御プログラムの妥当性を検証することができる。
The
ROM21には、CPU20を動作させるための各種のプログラムが格納されており、CPU20は、ROM21に格納されたプログラムに基づいて後述する部品の組立シミュレーションの演算処理を実行可能となっている。RAM22は、CPU20の処理結果を一時的に記憶するための記憶手段である。HDD23は、記憶装置であり、部品データ、ダイナミクス計算や接触力計算の計算式等の各種情報を予め記憶している。また、CPU20は、HDD23は、CPU20による演算結果等のデータを記憶させる。
Various programs for operating the
図1の制御系は、主制御手段としてのCPU20、記憶装置としてのROM21、およびRAM22を備えたPCハードウェアなどによって構成されている。ROM21には、本実施形態の組立シミュレーションを実現するためのCPU20の制御プログラムや定数情報などを格納しておくことができる。また、RAM22は、その制御手順を実行する時にCPU20のワークエリアなどとして使用される。
The control system of FIG. 1 is composed of a
本実施形態のシミュレーション処理を実現するためのCPU20の制御プログラムは、上記のHDD23やROM21の(例えばEEPROM領域)のような記憶部に格納しておくことができる。その場合、本実施形態の制御手順を実現するためのCPU20の制御プログラムは、ネットワークインターフェースなどを介して、上記の各記憶部に供給し、また新しい(別の)プログラムに更新することができる。また、あるいは、後述の制御手順を実現するためのCPU20の制御プログラムは、例えば記録ディスクドライブ24から上記の各記憶部に供給し、またその内容を更新することができる。記録ディスクドライブ24は、例えば、各種の磁気ディスクや光ディスク、フラッシュメモリなどの記憶手段と、そのためのドライブ装置などから成る。本実施形態の制御手順を実現するためのCPU20の制御プログラムを格納した状態における各種の記憶手段、記憶部、ないし記憶デバイスは、本発明の制御手順を格納したコンピュータ読み取り可能な記録媒体を構成することになる。
The control program of the
シミュレーション装置1は、インターフェース25を介して接続されたキーボード11及びインターフェース26を介して接続されたマウス12などから成る操作入力部を備える。この操作入力部ハードウェアを用いて構成されるユーザーインターフェースを介して、ユーザは各種の設定操作を行うことができる。さらに、シミュレーション装置1には、インターフェース27を介して接続されたモニタ13が備えられており、データ入力(編集)画面、部品等を仮想三次元空間に表示する表示画面などの各種画面が表示可能となっている。また、インターフェース28は、書き換え可能な不揮発性メモリや外付けHDD等の外部記憶装置14が接続可能に構成されている。
The
図2はシミュレーション全体の処理の流れを示している。以下で説明するシミュレーション処理は、複数の物体モデルが存在する仮想空間で、少なくとも1つの物体モデルを動作させるものである。これらシミュレーションモデルとしての物体モデルは、例えば、産業用のロボット装置、ないしそのロボット装置に対応するワークなどの物体、あるいはロボット装置が配置された実環境(仮想空間に相当)中に配置された障害物などの物体に相当する。なお、以下の仮想空間における物体モデルについては、簡略に「物体」と記載する場合がある。また、以下のシミュレーション処理の説明では、部品(ワーク)ロボット(装置)、障害物などの物体に相当する物体モデルも、「部品(ワーク)」、「ロボット(装置)」、「障害物」など、実環境における部材名称により言及する場合がある。 FIG. 2 shows the processing flow of the entire simulation. The simulation process described below operates at least one object model in a virtual space in which a plurality of object models exist. The object model as these simulation models is, for example, an industrial robot device, an object such as a work corresponding to the robot device, or an obstacle placed in a real environment (corresponding to a virtual space) in which the robot device is placed. Corresponds to an object such as an object. The object model in the following virtual space may be simply described as "object". In addition, in the following explanation of simulation processing, object models corresponding to objects such as parts (work) robots (devices) and obstacles are also referred to as "parts (work)", "robots (devices)", "obstacles", etc. , May be referred to by the member name in the actual environment.
本実施形態において、例えばロボット装置を動作させるロボット装置を制御するロボット制御プログラムに記述された態様で、前記ロボット装置が操作する対象の物体に対応する前記物体モデルを前記仮想空間で動作させる。このシミュレーション処理により、ロボット制御プログラムに記述されたロボット動作を検証することができる。そして、検証し、あるいはさらに必要な修正を行ったロボット制御プログラムを用いて、実際のロボット装置に物体モデルに相当するワークを操作させる組立動作を行い、例えば、物品の製造を実施することができる。 In the present embodiment, for example, in the embodiment described in the robot control program that controls the robot device that operates the robot device, the object model corresponding to the target object operated by the robot device is operated in the virtual space. By this simulation process, the robot operation described in the robot control program can be verified. Then, using a robot control program that has been verified or further modified as necessary, an assembly operation that causes an actual robot device to operate a work corresponding to an object model can be performed, and for example, an article can be manufactured. ..
本実施形態のシミュレーション処理は以下のように行われる。まず、ロボット装置のリンクやワークの位置情報、質量、慣性モーメント、重心位置、3Dモデルとして記述された物体モデル、その初期変位、初期速度、初期加速度、などの情報を読み込み、シミュレーションモデルの設定を行う(S1)。 The simulation process of this embodiment is performed as follows. First, read the information such as the link and work position information of the robot device, mass, moment of inertia, center of gravity position, the object model described as a 3D model, its initial displacement, initial velocity, initial acceleration, etc., and set the simulation model. Do (S1).
次に、シミュレーション時間、シミュレーション時間間隔、物体同士の反発係数、部品同士が接触したと判断するための所定の閾値、即ち接触閾値など、シミュレーション全体に係るシミュレーション条件について設定する(S2)。シミュレーションを行う準備ができたら、シミュレーション計算を開始する(S3)。 Next, simulation conditions related to the entire simulation, such as a simulation time, a simulation time interval, a coefficient of restitution between objects, and a predetermined threshold value for determining that parts are in contact with each other, that is, a contact threshold value, are set (S2). When the simulation is ready to be performed, the simulation calculation is started (S3).
本実施形態のシミュレーション計算では、1ステップずつ計算を行い、シミュレーションを進める。ここで、図3および図4を参照して本実施形態のシミュレーション計算について説明する。 In the simulation calculation of this embodiment, the calculation is performed step by step to proceed with the simulation. Here, the simulation calculation of the present embodiment will be described with reference to FIGS. 3 and 4.
図3は、接触計算を含むシミュレーション計算のフローチャートを表している。シミュレーション計算では、まず、後述の過去のシミュレーションステップへロールバックした後、用いるため、現在のシミュレーションステップ(第1のシミュレーションステップ)における位置と速度をバックアップする(S4)。下式においてqbackupで示す位置と加速度の変数領域は、例えばRAM22などに確保される。
FIG. 3 shows a flowchart of simulation calculation including contact calculation. In the simulation calculation, first, the position and speed in the current simulation step (first simulation step) are backed up for use after rolling back to the past simulation step described later (S4). The variable area of the position and acceleration indicated by q backup in the following equation is secured in, for example,
次に以降で説明するロールバックのために、シミュレーションの接触計算に用いる近接点数のゼロクリアを行う(S5)。なお、この接触計算の概略は、例えば以下の疑似プログラムコードに示すような判定処理である。 Next, for the rollback described later, the number of proximity points used in the contact calculation of the simulation is cleared to zero (S5). The outline of this contact calculation is, for example, a determination process as shown in the following pseudo program code.
次に下式のようなダイナミクス計算を行い、物体にかかる力から加速度を計算する(S6)。その場合、剛体の運動方程式は下式に示すように記述できる。 Next, the dynamics calculation as shown in the following equation is performed, and the acceleration is calculated from the force applied to the object (S6). In that case, the equation of motion of the rigid body can be described as shown in the following equation.
上式において、q、その微分、2階微分はそれぞれ剛体の変位、速度、加速度、τは剛体にかかる接触力である。また、H()は慣性項、C()はコリオリ・遠心項、G()は重力項である。上式の接触力τを用い、下式のように、剛体にかかる接触力から加速度を計算することができる。 In the above equation, q, its derivative, and the second derivative are the displacement, velocity, and acceleration of the rigid body, respectively, and τ is the contact force applied to the rigid body. Further, H () is an inertial term, C () is a Coriolis / centrifugal term, and G () is a gravity term. Using the contact force τ in the above equation, the acceleration can be calculated from the contact force applied to the rigid body as in the equation below.
次に、加速度から速度と位置を計算する積分計算を行う(S7)。剛体の初期状態は、一般的には下式のように与えられる。 Next, an integral calculation is performed to calculate the velocity and position from the acceleration (S7). The initial state of a rigid body is generally given by the following equation.
シミュレーション計算では、この初期状態(初期シミュレーションステップ)から離散ステップ(t)だけ進んだ次の状態(シミュレーションステップ)を、数値積分手法で連続的に計算する。例えばオイラー積分の場合、シミュレーション計算は下式のように計算することができる。 In the simulation calculation, the next state (simulation step) advanced by the discrete step (t) from this initial state (initial simulation step) is continuously calculated by the numerical integration method. For example, in the case of Euler integration, the simulation calculation can be calculated as follows.
そして、この歩進させた後のシミュレーションステップにおいて、接触計算を行い部品同士のオーバーラップがあるかどうかを確認する(S8)。ここでオーバーラップがなければ(S8のNO)、シミュレーションが完了したかを確認(S9)し、シミュレーションを続行する場合(S9のNO)は、制御をループさせ、次のシミュレーションステップの計算に移る。 Then, in the simulation step after this step, contact calculation is performed to confirm whether or not there is overlap between the parts (S8). If there is no overlap here (NO in S8), it is confirmed whether the simulation is completed (S9), and if the simulation is continued (NO in S9), the control is looped and the calculation of the next simulation step is started. ..
図4(a)〜(d)は、シミュレーション計算結果の一例を示している。図4(a)〜(d)において、物体31はシミュレーション対象の物体であり、物体331、332は障害物を示しており、ここでは、物体31と、物体331、332は互いに接近する速度を持っているものとする。シミュレーション計算を行うことにより、シミュレーション対象の物体31は、図4(a)〜(d)に32、327〜329で示すような位置に移動する。32、329の場合は、物体と障害物はオーバーラップしていない状態である。
4 (a) to 4 (d) show an example of the simulation calculation result. In FIGS. 4A to 4D, the
ところで、シミュレーション計算は離散ステップで行われるため、例えば、図4(a)〜(d)に示すように、位置を計算した際に物体同士、例えば物体331ないし332と物体327ないし328がオーバーラップする可能性がある。
By the way, since the simulation calculation is performed in discrete steps, for example, as shown in FIGS. 4A to 4D, when the positions are calculated, the objects, for example, the
解析法で接触力計算を行う場合は物体間の近接点の計算が必要であるが、オーバーラップが発生すると近接点が計算できないので接触力計算ができなくなる。図4(b)は、オーバーラップした場合のシミュレーション計算の結果を表している。ここでは、シミュレーション計算の結果、327で示すように、物体31が物体331(障害物)とオーバーラップしている。そして、オーバーラップが確認(S8のYES)された場合には、シミュレーション状態を過去のシミュレーションステップにロールバックする(S10)。このロールバック操作では、バックアップしたシミュレーションデータ(数式1に示した位置、加速度の変数領域)を用い、下式のようにシミュレーション状態(位置、加速度)を以前の状態(シミュレーションステップ)に戻す。
When calculating the contact force by the analysis method, it is necessary to calculate the proximity points between the objects, but if the overlap occurs, the proximity points cannot be calculated, so the contact force cannot be calculated. FIG. 4B shows the result of the simulation calculation when they overlap. Here, as a result of the simulation calculation, as shown by 327, the
図4(b)のように、離散ステップt+Δtで物体のオーバーラップが検出されると、上記のようにロールバックしたステップ(第2のシミュレーションステップ)で接触力が発生したものとして取り扱う。具体的には、物体が接触閾値内に存在するまで接触閾値の拡大(図3のS11)と、接触閾値内に物体が存在するか否かの判定(S12)を実施し、その後に近接点の取得計算(S13)を行う。接触閾値の拡大フローの最後には、閾値拡大によって近接点の数が増加したかどうかを判定し(S14)、近接点が増加した場合(S14のYES)には、近接点数を保存する(S15)。この近接点数の保存は、接触閾値拡大後の接触力計算に基づき、再度オーバーラップ判定が生じた場合に必要となるために行うものである。 As shown in FIG. 4B, when the overlap of the objects is detected in the discrete step t + Δt, it is treated as if the contact force was generated in the step rolled back as described above (second simulation step). Specifically, the contact threshold is expanded until the object is within the contact threshold (S11 in FIG. 3), and whether or not the object is within the contact threshold is determined (S12), and then the proximity point. Acquisition calculation (S13) is performed. At the end of the contact threshold expansion flow, it is determined whether or not the number of proximity points has increased due to the threshold expansion (S14), and if the number of proximity points has increased (YES in S14), the number of proximity points is saved (S15). ). This storage of the number of proximity points is performed because it is necessary when the overlap determination occurs again based on the contact force calculation after the contact threshold value is expanded.
なお、物体(例えばロボットで操作する部品やワーク)同士のオーバーラップや、接触閾値以内に物体同士が存在するかの判定方法については、公知の技術を利用できる。この種の干渉検出の手法は、例えば”Real−Time Collision Detection”,CRC Press,2004になどに記載されている。 It should be noted that known techniques can be used for overlapping objects (for example, parts and workpieces operated by a robot) and a method for determining whether objects exist within a contact threshold value. Techniques for this type of interference detection are described, for example, in "Real-Time Collection Detection", CRC Press, 2004 and the like.
例えば、部品の接触確認は、3Dモデルの3角形ポリゴン情報を用いて行う。2つの部品の3角形ポリゴンの要素それぞれについて交差が起きているかどうかを判定することにより、物体同士が接触しているかどうかを確認できる。3角形同士の交差の有無の判定手法は様々であるが、三角形の3頂点情報の関係性を用いた幾何学的演算により容易に計算することができる。同様に、接触閾値以内に物体同士が存在するか否かは、下記の疑似プログラムコードに示すような演算において、2つの部品の3角形ポリゴンのそれぞれについての距離Lと閾値Tを比較することで容易に判定できる。 For example, the contact confirmation of parts is performed using the triangular polygon information of the 3D model. By determining whether or not each of the elements of the triangular polygons of the two parts intersects, it is possible to confirm whether or not the objects are in contact with each other. There are various methods for determining the presence or absence of intersections between triangles, but it can be easily calculated by geometric calculation using the relationship of the information of the three vertices of a triangle. Similarly, whether or not the objects exist within the contact threshold value is determined by comparing the distance L and the threshold value T for each of the triangular polygons of the two parts in the calculation as shown in the pseudo program code below. It can be easily determined.
接触閾値内に物体が存在した場合には、接触力の計算を行う(S16)。この接触力に関しては、非特許文献1に記載の方法を利用して計算を行う。この非特許文献1の手法は、物体同士の近接点において接触前と接触後の相対速度が理論的に正しくなるように連立方程式を立て、近接点の速度と接触力に関する条件式を用い、線形相補性問題として解くものである。
If the object is within the contact threshold, the contact force is calculated (S16). This contact force is calculated by using the method described in
図5は、物体31と物体33に関して、接触閾値を拡大するデータ操作を示している。本実施形態において、接触閾値は、この値よりも物体同士が近接した場合に接触が発生したとするための基準である。図5において、最初は、接触閾値は351の状態であり、このとき閾値(351)以内の距離に物体31と物体33(障害物)が存在しない。本実施形態の処理では、この場合、接触閾値を352の状態に拡大する。このとき、物体31と障害物33は互いに接触閾値の相対距離に存在するため、接触が発生しているものとして取り扱えるようになる。この閾値拡大の操作について、ロールバック時の拡大量の設定は、予めシミュレーション条件設定(S2)で行うことが考えられる。
FIG. 5 shows a data manipulation that expands the contact threshold for the
図8は、ロボット制御プログラムを設定するためのユーザーインターフェース1000を示している。図8のユーザーインターフェース1000は、マウス12のクリックやドラッグ、あるいはキーボード11からのキーボードショートカット操作などによって操作することができる。ユーザーインターフェース1000のダイアログは、メニュー101を有し、このメニュー101は、例えばプルダウン(アップ)メニューなどの形態で実装され、シミュレーションに用いるロボット制御プログラムを指定できるように構成される。メニュー101のメニューアイテムには、HDD23などに現在格納されているロボット制御プログラムがリストされる。
FIG. 8 shows a
メニュー101でロボット制御プログラムを選択し、図8の開始ボタン1011を操作すると、仮想空間内で、ロボット制御プログラムで定義された動作を行うよう、仮想ロボットを動作させるシミュレーションを開始させることができる。仮想ロボット(当然ながら、これもシミュレーション対象の物体モデルの1つである)の動作は、図7のシミュレーション画面100中で、例えば3D表示などの形態でアニメーション表示させることができる。図8の停止ボタン1012は開始させたシミュレーションを停止(一時停止)させるために用いられる。
When the robot control program is selected from the
図8のユーザーインターフェース1000で選択されるロボット制御プログラムには、位置制御や力制御などのパラメータが記述されている。シミュレーションする仮想環境中では、もちろん、ロボット装置のアームやハンドなどの部位は、ロボット装置が操作するワークなどとともに、物体モデルとして取り扱う。シミュレーション環境で、ロボット制御プログラムに従い、これらの物体モデルを動作させることにより、例えば、ロボット制御プログラムの妥当性を検証することができる。
In the robot control program selected by the
シミュレーション計算における接触計算は計算コストが大きいため、図6のようなインターフェース40を用いてシミュレーションの精度と速度を調整できるようにしておくとよい。
Since the contact calculation in the simulation calculation has a high calculation cost, it is preferable to be able to adjust the accuracy and speed of the simulation by using the
図6のユーザーインターフェース40のダイアログにおいて、フィールド43は、最大ロールバック回数を指定するための、例えば数値入力フィールドである。ユーザは、フィールド43を介して図3のS10で行われるロールバックの回数の上限を指定することができる。最大ロールバック回数の値は、S10から始まるフローの無限ループの可能性を排除するために有効な設定項目である。
In the dialog of the
最大ロールバック回数がフィールド43を介して指定した上限値に達した場合には、図9に示すようなダイアログ1100をポップアップ表示し、シミュレーション継続の如何をユーザに尋ねる。図9のダイアログ1100は、最大ロールバック回数が指定した上限値に達したことを報知する、例えばテキスト、あるいはさらにアイコンなどのシンボル表示によるメッセージ1103を備える。また、図9のダイアログ1100は、ユーザがシミュレーションを継続させるための継続ボタン1101と、シミュレーションを停止させるための停止ボタン1102と、を有する。
When the maximum number of rollbacks reaches the upper limit value specified via the
図6のユーザーインターフェース40を構成するダイアログにおいて、フィールド44は、ユーザが接触閾値の拡大幅を指定するための、例えば数値入力フィールドである。この接触閾値の拡大幅は、図3のS11で用いられる接触閾値の拡大幅に相当する。ここで与える拡大幅が小さいほど接触計算の精度が上がるが、計算コストが大きくなる。なお、フィールド44では、0以下の拡大幅は設定できないものとする。
In the dialog constituting the
図6のダイアログ40において、フィールド45は、図3のS11〜S13で用いられる接触閾値の最大値をユーザが指定するための、例えば数値入力フィールドである。この接触閾値の最大値は、図3のS10から始まるフローの無限ループの可能性を排除するために有効である。
In the
図6のフィールド45から指定した接触閾値が上限(最大値)に達した場合には図10のようなダイアログ提示する。シミュレーション継続の如何をユーザに問うのが適当である。また、図10のダイアログ1100は、接触閾値が上限(最大値)に達したことを報知する、例えばテキスト、あるいはさらにアイコンなどのシンボル表示によるメッセージ1104を備える。また、図10のダイアログ1100は、ユーザがシミュレーションを継続させるための継続ボタン1101と、シミュレーションを停止させるための停止ボタン1102と、を有する。
When the contact threshold value specified from the
図4(c)は、図4(b)のシミュレーションをロールバックし、閾値拡大を行い、近接点を計算した場合のシミュレーション結果の一例を示している。図4中の341、342は、物体31、332同士の近接点を表している。近接点341と近接点342はペアになっており、この2点間の位置関係により反発力や摩擦力の方向が計算される。図4(c)例では、実線で示した物体31に対して、接触力を元にシミュレーション計算を行った結果、328で示すように、シミュレーション対象の物体31が障害物331とオーバーラップしている結果となっている。
FIG. 4C shows an example of the simulation result when the simulation of FIG. 4B is rolled back, the threshold value is expanded, and the proximity point is calculated. 341 and 342 in FIG. 4 represent close points between
図4(d)は、シミュレーションステップをロールバックし、物体31と、332の近接点341、342と、物体31と、331の近接点343、344を計算した状態である。この状態から、物体31の位置、速度、加速度などから接触力をシミュレーション計算することができる。
FIG. 4D shows a state in which the simulation step is rolled back and the proximity points 341 and 342 of the
これにより、接触力計算を無効にしてしまう物体31と障害物33のオーバーラップは解消される。そして、この場合は、シミュレーションをロールバックさせた位置、速度、加速度などから計算した物体31が物体331と物体332に対する接触力によって跳ね返るシミュレーションが実行できている(329)。
As a result, the overlap between the
以上に示したように、本実施形態のシミュレーション演算によれば、シミュレーション中に物体同士のオーバーラップが発生した場合でも、適切にシミュレーション演算を継続する事ができる。また、本実施形態のユーザーインターフェースによれば、シミュレーションをロールバックさせる場合には、接触閾値を拡大することができ、これにより、ロールバックした状態からのオーバーラップを解消できる可能性を増大させることができる。また、本実施形態ユーザーインターフェースによれば、接触閾値の拡大幅を小さな値に制限することもでき、シミュレーションを物体同士がより近接した接触状態に近い位置から続行させることができる。これにより、続行されるシミュレーションの接触力計算の精度を向上させることができる。また、ロールバックを行ってもオーバーラップが解消していなければ、オーバーラップを繰り返し、実行させることができる。その場合、本実施形態のユーザーインターフェースによれば、繰り返し実行回数を制限することができ、シミュレーション演算が無限ループ状態に入るような障害を回避することができる。 As described above, according to the simulation calculation of the present embodiment, the simulation calculation can be appropriately continued even when the objects overlap with each other during the simulation. Further, according to the user interface of the present embodiment, when the simulation is rolled back, the contact threshold value can be increased, thereby increasing the possibility of eliminating the overlap from the rolled back state. Can be done. Further, according to the user interface of the present embodiment, the expansion width of the contact threshold value can be limited to a small value, and the simulation can be continued from a position closer to the contact state where the objects are closer to each other. This can improve the accuracy of the contact force calculation of the continuing simulation. Further, if the overlap is not eliminated even after the rollback is performed, the overlap can be repeated and executed. In that case, according to the user interface of the present embodiment, the number of repeated executions can be limited, and it is possible to avoid an obstacle such that the simulation calculation enters an infinite loop state.
即ち、本実施形態によれば、複数の物体間の接触力を用いるシミュレーション処理において、物体同士のオーバーラップが発生しても解析法を用いたシミュレーションを継続することができる。また、オーバーラップが発生した際には状況に応じて最小な接触閾値が決定される。このため、従来技術におけるように、あらかじめ大きな接触閾値を設定する必要がなく、接触シミュレーションの精度が向上する。また、物体同士がオーバーラップした時のみ接触力計算を行うように計算を進めることができ、物体同士がオーバーラップしていない間の物体同士の接触閾値内判定を省略できるため、処理コストを大きく低減する事ができる。 That is, according to the present embodiment, in the simulation process using the contact force between a plurality of objects, the simulation using the analysis method can be continued even if the objects overlap each other. Further, when the overlap occurs, the minimum contact threshold value is determined according to the situation. Therefore, unlike the prior art, it is not necessary to set a large contact threshold value in advance, and the accuracy of contact simulation is improved. In addition, the calculation can proceed so that the contact force is calculated only when the objects overlap each other, and the determination within the contact threshold between the objects while the objects do not overlap can be omitted, so that the processing cost is increased. It can be reduced.
<実施形態2>
シミュレーション開始前に、上述の接触閾値の初期値を適宜設定しておき、物体モデル同士のオーバーラップが生じる前に、ロールバックを行うことなく接触力のシミュレーション演算が行われるよう制御手順を構成することもできる。
<
Before the start of the simulation, the initial value of the above-mentioned contact threshold value is appropriately set, and the control procedure is configured so that the simulation calculation of the contact force is performed without rolling back before the overlap between the object models occurs. You can also do it.
本実施形態の図11の制御手順は、図3の制御に、接触閾値の初期値を判定し、接触閾値以内に物体モデル同士が近接した場合にステップS13に分岐するためのステップS17を追加したものである。図11の他のステップは、上述の図3で説明したものと同じであるため、ここでは重複した説明は省略する。 In the control procedure of FIG. 11 of the present embodiment, step S17 for determining the initial value of the contact threshold value and branching to step S13 when the object models are close to each other within the contact threshold value is added to the control of FIG. It is a thing. Since the other steps in FIG. 11 are the same as those described in FIG. 3 above, duplicate description will be omitted here.
また、図12は、接触閾値の初期値を考慮した図6のユーザーインターフェースに、接触閾値の初期値を設定するための入力フィールド46を追加したユーザーインターフェースを示している。図12のユーザーインターフェースにおいて、入力フィールド46により設定された接触閾値の初期値は、図11のステップS17で用いられる接触閾値の初期値である。
Further, FIG. 12 shows a user interface in which an
以上のように、本実施形態は、シミュレーション制御に図11のようにステップS17の分岐を追加しておき、適宜接触閾値の初期値を設定できるよう構成されている。このような構成により、物体モデル同士のオーバーラップが生じる前に、ロールバックを行うことなく接触力のシミュレーション演算を行わせることができる。従って、本実施形態によれば、接触力シミュレーションをより高速化することができる。 As described above, the present embodiment is configured so that the branch of step S17 is added to the simulation control as shown in FIG. 11 and the initial value of the contact threshold value can be appropriately set. With such a configuration, it is possible to perform the simulation calculation of the contact force without performing rollback before the overlap between the object models occurs. Therefore, according to the present embodiment, the contact force simulation can be made faster.
なお、シミュレーション装置は、図3の制御手順と、図11の制御手順を双方とも用意しておき、適当な選択ユーザーインターフェース(不図示)を介していずれかの制御手順を選択できるように構成してもよい。あるいは、上記の選択ユーザーインターフェースは、図11のステップS17の分岐制御を挿入(有効化)するか否かを決定するラジオボタンなどにより構成してもよい。このような構成により、接触状態が少ないと予想されるようなシミュレーションでは図3の制御を用い、接触状態が多いと予想されるようなシミュレーションでは、図11の制御を用いるような選択が可能となる。 The simulation device is configured so that both the control procedure of FIG. 3 and the control procedure of FIG. 11 are prepared so that either control procedure can be selected via an appropriate selection user interface (not shown). You may. Alternatively, the selected user interface may be configured by a radio button or the like that determines whether or not to insert (enable) the branch control in step S17 of FIG. With such a configuration, it is possible to select to use the control of FIG. 3 in the simulation where the contact state is expected to be small, and to use the control of FIG. 11 in the simulation where the contact state is expected to be large. Become.
<実施形態3>
上記実施形態1では、シミュレーション中にオーバーラップが発生し、ロールバックを行う場合に、物体モデル同士のオーバーラップないし近接状態を判定するための接触閾値を拡大する、またその拡大幅を設定可能な構成を例示した。
<Embodiment 3>
In the first embodiment, when overlap occurs during simulation and rollback is performed, the contact threshold value for determining the overlap or proximity state between the object models can be expanded, and the expansion width can be set. The configuration is illustrated.
上記実施形態1の例は、接触閾値の拡大幅を手動設定するものであった。しかしながら、このような手動設定によると、ユーザが選択した接触閾値の拡大幅の設定と、シミュレーションする環境やモデルの構成との不整合によって、好ましくない制御状態が生じる可能性がある。例えば、接触閾値の拡大幅は、小さすぎると近接点検出までの閾値拡大の繰り返し回数が多くなり、大きすぎると意図しない近接点を検出してしまう。 In the example of the first embodiment, the expansion width of the contact threshold value is manually set. However, according to such a manual setting, an unfavorable control state may occur due to an inconsistency between the setting of the expansion width of the contact threshold selected by the user and the configuration of the environment or model to be simulated. For example, if the expansion width of the contact threshold value is too small, the number of times the threshold value expansion is repeated until the proximity point is detected increases, and if it is too large, an unintended proximity point is detected.
そこで、接触閾値の拡大幅の適正値を、物体モデルの状態に応じて自動設定する構成が考えられる。本実施形態では、接触閾値の拡大幅を、物体モデルの状態、例えば物体モデルの相対速度に基づき、計算、設定する例を示す。 Therefore, a configuration is conceivable in which the appropriate value of the expansion width of the contact threshold value is automatically set according to the state of the object model. In this embodiment, an example of calculating and setting the expansion width of the contact threshold value based on the state of the object model, for example, the relative velocity of the object model is shown.
図13は、シミュレーション中にオーバーラップする物体モデル36、39(例えば部品)を示している。ここで、物体モデル36は1ステップ後に位置37に移動するような速度38を有し、物体モデル39は1ステップ後に位置42に移動するような速度41を有する。実施形態1と同様の制御によると、物体モデル36、39が位置37、42を占めた時、オーバーラップが発生し、シミュレーションステップのロールバックが行われる。
FIG. 13 shows object
この場合、本実施形態では、例えば下式のような演算によって、接触閾値の拡大幅を計算する。まず、物体モデル36の速度38(v1)と物体モデル39の速度41(v2)を用いて、物体モデル36と物体モデル39の相対速度42‐1(vrel)を算出する。ここで、図14は、図13中の速度38(v1)、物体モデル39の速度41(v2)、物体モデル36と物体モデル39の相対速度42‐1(vrel)のベクトル表現で示している。
In this case, in the present embodiment, the expansion width of the contact threshold value is calculated by an operation such as the following equation. First, the relative velocity 42-1 (v rel ) of the
そして、下式のように相対速度にシミュレーションの1ステップの時間(Δt)を乗算することにより、それぞれの物体モデル(例えば部品)がシミュレーションの1ステップにおいて近づく距離(D)を算出できる。 Then, by multiplying the relative velocity by the time (Δt) of one step of the simulation as shown in the following equation, the distance (D) that each object model (for example, a part) approaches in one step of the simulation can be calculated.
以上のように、相対速度42‐1にシミュレーションの1ステップの時間を掛けた値を接触閾値の拡大幅とすることにより、たかだか1回の接触閾値拡大の試行で物体同士の近接点43‐1と近接点43‐2のペアを取得することができる(図15)。 As described above, by multiplying the relative velocity 42-1 by the time of one step of the simulation as the expansion width of the contact threshold value, the proximity point 43-1 between the objects can be obtained by at most one trial of the contact threshold expansion. And a pair of proximity points 43-2 can be obtained (Fig. 15).
以上のように、本実施形態によれば、シミュレーション処理に必要な物体モデルの接触閾値の拡大幅の適正値を、物体モデルの状態に応じて自動設定することができる。例えば、接触閾値の拡大幅は、物体モデルの状態、例えば物体モデルの相対速度に基づき、計算、設定することができる。従って、熟練を必要とする手動設定を行う必要がなく、自動的にシミュレーション処理に必要な物体モデルの接触閾値の拡大幅の適正値を、物体モデルの状態に応じて自動設定することができる。 As described above, according to the present embodiment, it is possible to automatically set an appropriate value of the expansion width of the contact threshold value of the object model required for the simulation process according to the state of the object model. For example, the expansion width of the contact threshold value can be calculated and set based on the state of the object model, for example, the relative velocity of the object model. Therefore, it is not necessary to perform manual setting that requires skill, and it is possible to automatically set an appropriate value of the expansion width of the contact threshold value of the object model required for the simulation process according to the state of the object model.
本発明は上述の実施例の1以上の機能を実現するプログラムをネットワーク又は記憶媒体を介してシステムまたは装置に供給し、そのシステムまたは装置のコンピュータにおける1つ以上のプロセッサーがプログラムを読出し実行する処理でも実現可能である。また、1以上の機能を実現する回路(例えば、ASIC)によっても実現可能である。 The present invention supplies a program that realizes one or more functions of the above-described embodiment to a system or device via a network or storage medium, and one or more processors in the computer of the system or device reads and executes the program. But it is feasible. It can also be realized by a circuit (for example, ASIC) that realizes one or more functions.
1…シミュレーション装置、13…モニタ、20…CPU、21…ROM、22…RAM、23…HDD、25〜28…インターフェース、1000…ユーザーインターフェース、1011…開始ボタン、1012…停止ボタン、31、32、331、332…物体(物体モデル)。 1 ... Simulation device, 13 ... Monitor, 20 ... CPU, 21 ... ROM, 22 ... RAM, 23 ... HDD, 25-28 ... Interface, 1000 ... User interface, 1011 ... Start button, 1012 ... Stop button, 31, 32, 331, 332 ... Object (object model).
Claims (16)
制御装置が、第1のシミュレーションステップにおいて、複数の物体モデルのオーバーラップが発生しているか否かを判定し、前記複数の物体モデルのオーバーラップが発生している場合、シミュレーションの状態をオーバーラップが生じていない過去の第2のシミュレーションステップにロールバックさせる工程と、
前記制御装置が、ロールバックさせた前記第2のシミュレーションステップにおいて、前記物体モデルの所定の閾値以内の距離で互いに近接する近接点を取得し、取得した前記近接点の接触前と接触後の相対速度を用いて、前記物体モデル同士が接触した場合に前記物体モデルの間に働く接触力を演算する工程と、を含む情報処理方法。 In an information processing method that simulates the operation of at least one object model in a virtual space where multiple object models exist.
In the first simulation step, the control device determines whether or not the overlap of the plurality of object models has occurred, and if the overlap of the plurality of object models has occurred, the simulation states are overlapped. The process of rolling back to the second simulation step in the past where
In the second simulation step rolled back, the control device acquires proximity points that are close to each other within a predetermined threshold of the object model, and the acquired proximity points are relative to each other before and after contact. An information processing method including a step of calculating a contact force acting between the object models when the object models come into contact with each other using a speed.
第1のシミュレーションステップにおいて、複数の物体モデルのオーバーラップが発生しているか否かを判定し、前記複数の物体モデルのオーバーラップが発生している場合、シミュレーションの状態をオーバーラップが生じていない過去の第2のシミュレーションステップにロールバックさせ、ロールバックさせた前記第2のシミュレーションステップにおいて、前記物体モデルの所定の閾値以内の距離で互いに近接する近接点を取得し、取得した前記近接点の接触前と接触後の相対速度を用いて、前記物体モデル同士が接触した場合に前記物体モデルの間に働く接触力を演算する制御装置を備えた情報処理装置。 In an information processing device that performs simulation to operate at least one object model in a virtual space where a plurality of object models exist.
In the first simulation step, it is determined whether or not the overlap of the plurality of object models has occurred, and if the overlap of the plurality of object models has occurred, the simulation states have not overlapped. In the second simulation step of rolling back to the second simulation step in the past and rolling back, the proximity points close to each other within a predetermined threshold of the object model are acquired, and the acquired proximity points of the acquired proximity points are acquired. An information processing device including a control device that calculates the contact force acting between the object models when the object models come into contact with each other by using the relative velocities before and after the contact.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2019203868A JP7374723B2 (en) | 2019-11-11 | 2019-11-11 | Information processing method, information processing device, and robot system |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2019203868A JP7374723B2 (en) | 2019-11-11 | 2019-11-11 | Information processing method, information processing device, and robot system |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2021077149A true JP2021077149A (en) | 2021-05-20 |
JP7374723B2 JP7374723B2 (en) | 2023-11-07 |
Family
ID=75898015
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019203868A Active JP7374723B2 (en) | 2019-11-11 | 2019-11-11 | Information processing method, information processing device, and robot system |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP7374723B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113298945A (en) * | 2021-06-08 | 2021-08-24 | 上海宝冶工程技术有限公司 | Calculation method of container packing scheme |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2004094750A (en) * | 2002-09-02 | 2004-03-25 | Ricoh Co Ltd | Three-dimensional configuration processor, interference model detecting method, program and storage medium |
JP2007114866A (en) * | 2005-10-18 | 2007-05-10 | Canon Inc | Contact decision system |
-
2019
- 2019-11-11 JP JP2019203868A patent/JP7374723B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2004094750A (en) * | 2002-09-02 | 2004-03-25 | Ricoh Co Ltd | Three-dimensional configuration processor, interference model detecting method, program and storage medium |
JP2007114866A (en) * | 2005-10-18 | 2007-05-10 | Canon Inc | Contact decision system |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113298945A (en) * | 2021-06-08 | 2021-08-24 | 上海宝冶工程技术有限公司 | Calculation method of container packing scheme |
Also Published As
Publication number | Publication date |
---|---|
JP7374723B2 (en) | 2023-11-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3593294B1 (en) | Training action selection neural networks using apprenticeship | |
US7194396B2 (en) | Simulation device | |
CN108145709B (en) | Method and apparatus for controlling robot | |
US11321895B2 (en) | Neural state machine digital character animation | |
US20200104685A1 (en) | Learning motor primitives and training a machine learning system using a linear-feedback-stabilized policy | |
US8924185B2 (en) | Designing a navigation scene | |
CN109605367B (en) | Robot programming method, device and equipment and storage medium | |
Gao et al. | Virtual assembly planning and assembly-oriented quantitative evaluation of product assemblability | |
Koestler et al. | Mobile robot simulation with realistic error models | |
JP6560227B2 (en) | Automatic operation of computer-aided design model | |
EP3884345A1 (en) | Method and system for predicting motion-outcome data of a robot moving between a given pair of robotic locations | |
JP2021077149A (en) | Information processing method, information processing equipment, and robot system | |
Kim et al. | Using VPS (Voxmap PointShell) as the basis for interaction in a virtual assembly environment | |
US6798416B2 (en) | Generating animation data using multiple interpolation procedures | |
CN108236782B (en) | External equipment positioning method and device, virtual reality equipment and system | |
US9129083B2 (en) | Automatic computation of reflected mass and reflected inertia | |
EP4052865A1 (en) | Information processing apparatus, robot system, information processing method, program, and recording medium | |
JP3076841B1 (en) | Teaching program creation method for real environment adaptive robot | |
US10032304B1 (en) | Automatic creation of temporary rigid relationships between moving parts in motion simulation | |
US10864434B2 (en) | Simulation of multiple connected bodies for real-time application | |
JP4446068B2 (en) | Numerical control device for machine tool and numerical control method for controlling machine tool | |
US20240058963A1 (en) | Multi-mode robot programming | |
US20240025035A1 (en) | Robotic simulations using multiple levels of fidelity | |
WO2023157235A1 (en) | Arithmetic device | |
Tagawa et al. | Manipulation of dynamically deformable object using impulse-based approach |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
RD02 | Notification of acceptance of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7422 Effective date: 20200206 |
|
RD04 | Notification of resignation of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7424 Effective date: 20200207 |
|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20221109 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20230912 |
|
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: 20230926 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20231025 |
|
R151 | Written notification of patent or utility model registration |
Ref document number: 7374723 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R151 |