Robot controller
A robot controller for an articulated robot, capable of controlling the articulated robot for the highly accurate high-speed movement of the work along a predetermined route. The robot controller a memory for previously storing functions for calculating position gains and speed gains for the joints of the articulated robot. A detecting operates to detect the present position and present speed of each of the joints during the operation of the articulated robot. A first calculating operation calculates a position gain and a speed gain for each joint on the basis of the present position and present speed of the joint detected by the detecting feature by using the functions stored in the memory. A second calculating operation the calculates instructions to be give to the actuators on the basis of position instructions, the present position and the present speed of the joints detected by the detecting feature, and the position gains and the speed gains calculated by the first calculating operation.
Latest Kabushiki Kaisha Kobe Seiko Sho Patents:
- CONCRETE REINFORCING COMPOSITE MATERIAL AND CONCRETE REINFORCING REBAR
- SEMI-HARD MAGNETIC STEEL COMPONENT
- WELDING CONTROL METHOD, WELDING CONTROL DEVICE, WELDING POWER SUPPLY, WELDING SYSTEM, PROGRAM, WELDING METHOD, AND ADDITIVE MANUFACTURING METHOD
- OPTICAL SYSTEM FOR SHAPE MEASURING DEVICE
- ADDITIVE MANUFACTURING PLAN CREATION METHOD
1. Field of the Invention
The present invention relates to a robot controller for controlling an articulated robot, such as a welding robot and, more particularly, to a robot controller for controlling an articulated robot, capable of controlling the movement of a work gripped by the gripping unit of the articulated robot along a desired locus at a high accuracy.
2. Description of the Prior Art
In an industrial robot having a plurality of degrees of freedom of motion, such as an articulated robot or a polar coordinates robot, the load on each joint shaft varies owing to the variation of the moment of inertia of components according to the mode of action of a plurality of actuators. Since the variation of the moment of inertia of the component affects the response characteristics of a servomechanism associated with each joint shaft, the moment of inertia of the component must be taken into consideration in controlling the industrial robot.
J.P. Pat. Provisional Pub. (Kokai) No. 61-163406 proposes a control system which calculates the variation of the moment of inertia on the basis of the performance of the actuator. FIGS. 4, 5, 6 and 7 illustrate this previously proposed control system.
Referring to FIG. 5, an articulated robot RB has six degrees of freedom of motion, and the component segments of the articulated robot RB are rotatable as indicated by .theta..sub.1 to .theta..sub.6 respectively on joints 1 to 6. These component segments are driven for rotation respectively on the joints 1 to 6 by servomotors M.sub.1 to M.sub.6, not shown in FIG. 5.
Referring to FIG. 6 diagrammatically showing a robot controller for controlling the articulated robot RB of FIG. 5, a CPU (central processing unit) 9 executes operations for providing instructions, analyzing data, calculating instructions and calculating data for position control servomechanisms in accordance with data given thereto by operating a keyboard 8, and gives outputs to servo amplifiers A.sub.1 to A.sub.6. The servo amplifiers A.sub.1 to A.sub.6 give control signals produced by amplifying the outputs of the CPU 9 to the servomotors M.sub.1 to M.sub.6. Photoencoders E.sub.1 to E.sub.6 are combined respectively with the servomotors M.sub.1 to M.sub.6 detect the angles of rotation of the servomotors M.sub.1 to M.sub.6, and then give detection signals representing the angles of rotation to the CPU 9.
Referring to FIG. 7 showing one of the six position control servomechanisms for the joints 1 to 6, a position control servo loop 60 includes a speed control minor servo loop 61. A deviation signal 63 is obtained by subtracting feedback position data 77 fed back through the position control loop 60 from angle instruction data 62 created on the basis of data stored in a memory, not shown, by teaching operations and instructions given by operating the keyboard 8. A block 64 amplifies the deviation signal 63 at a gain of K.sub.p to provide an output position signal 65. Feedback speed data 79 fed back through the speed control minor servo loop 61 is subtracted from the output position signal 65 to obtain a deviation signal 66. The servo amplifier 67 (one of the servo amplifiers A.sub.1 to A.sub.6) amplifies the deviation signal 66 at a gain of K.sub.a to give an amplified output signal 68 to the motor M (one of the servomotors M.sub.1 to M.sub.6). The motor M generates a torque 70 corresponding to a torque constant K.sub.t specified by a block 69. A block 71 integrates the torque 70 with respect to time and divides the integral by the moment of inertia to obtain a rotating speed 72. In FIG. 7, indicated at s is a Laplace operator and at J is a moment of inertia obtained by converting a moment of inertia with respect to the axis of the joint into a moment of inertia with respect to the axis of the shaft of the motor M. A block 73 integrates the rotating speed 72 with respect to time to obtain an angle of rotation 74 of the motor M.
The photoencoder E (one of the photoencoders E.sub.1 to E.sub.6) encodes the rotating speed 72 of the motor M at an encoder gain of K.sub.e to provide an encoder output 75. Although it was presumed in the description with reference to FIG. 6 that the photoencoders E.sub.1 to E.sub.6 are those for detecting the angle of rotation, it is presumed in the description with reference to FIG. 7 for convenience' sake that the photoencoders E.sub.1 to E.sub.6 are those for detecting the rotating speed 72.
A block 76 integrates the encoder output 75 with respect to time to obtain a feedback position data 77, which is fed back to a point before the block 64. A block 78 operates the feedback position data 77 by using a speed gain K.sub.v to provide a feedback speed data 79. In the foregoing processes, viscous resistances are neglected for simplicity.
The moment of inertia J is dependent on joint angles at the joints 2 to 6 and the mass of the work, not shown, held by the articulated robot RB. The influence of the variation of the joint angles at the joints 4, 5 and 6 on the variation of the moment of inertia J is comparatively small as compared with that of other factors. Therefore, in this example, the value of the speed gain K.sub.v is varied according to the joint angles at the joints 2 and 3 and the mass of the work. The range of each of the joint angles .theta..sub.2 and .theta..sub.3 is divided into a plurality of subranges, for example, sixteen subranges, an optimum speed gain K.sub.v0 when the mass of the work is zero, an optimum speed gain Kv.sub.max when the mass of the work corresponds to the maximum allowable weight capacity and the difference .DELTA.K.sub.v between the speed gain Kv.sub.max and the speed gain K.sub.vO are calculated beforehand for each subrange, and the calculated values are stored in a memory, such as a RAM.
Speed gain K.sub.v to be used by the servo loop during the operation of the articulated robot RB is calculated by:
K.sub.v =K.sub.v0 +.DELTA.K.sub.v .times.m/M.sub.max ( 1)
where m (kg) is the mass of the work, M.sub.max is the maximum allowable mass capacity, K.sub.v0 is optimum speed gain when m=0, and .DELTA.K.sub.v is the difference between the maximum speed gain when m=M.sub.max and K.sub.v0.
FIG. 4 shows steps of procedure for calculating the values of the speed gain K.sub.v for all the joints and for controlling the articulated robot RB by using the values of speed gain K.sub.v.
Referring to FIG. 4, the mass of the work is measured in step 51. In step 52, the values of speed gain K.sub.v0 and the difference .DELTA.K.sub.v for the joints 3, 4, 5 and 6 are read from the memory, the values of speed gain K.sub.v for the joints 3, 4, 5 and 6 are calculated by using the expression (1), and then the calculated values of speed gain K.sub.v are written in the gain table of the memory.
In step 53, the present subrange of the joint angle .theta..sub.3 is detected. This subrange may be detected by reading a desired angle of movement from the memory or by detecting the present joint angle by the photoencoder E.sub.3. In either manner, the present joint angle is determined during the operation of the articulated robot RB.
In step 54, the values of speed gain K.sub.v0 and difference .DELTA.K.sub.v for the joint 2 corresponding to the detected subrange of the joint angle .theta..sub.3 are read from the table of the memory, the value of speed gain K.sub.v for the joint 2 is calculated by using the expression (1), and then the calculated value is written in the gain table.
Similarly, in step 55, the subrange of the joint angle .theta..sub.2 is detected, the values of speed gain K.sub.v0 and difference .DELTA.K.sub.v for the joint 1 corresponding to the subranges of the joint angles .theta..sub.2 and .theta..sub.3 are read from the table of the memory, the value of speed gain K.sub.v for the joint 1 is calculated by using the expression (1), and then the calculated value of speed gain K.sub.v for the joint 1 is written in the gain table.
Thus, the values of speed gain K.sub.v for all the joints at a specified time are specified. Then, in step 57, the values of speed gain K.sub.v are given together with input data including instructions for robot motions, constants and feedback data to the CPU, the CPU calculates output instructions for the servomechanisms and the calculated output instructions are given to the driving mechanisms. In step 58, a determination is made to see if the instructions are final. These steps are repeated until final instructions are obtained.
The foregoing operation of the conventional robot controller is summarized as follows.
Sets of the amounts of actions (joint angles) of the actuators, namely, the servomotors M.sub.1 to M.sub.6, reference values (K.sub.v0) of speed gain for the position servomechanism and the variation (.DELTA.K.sub.v) of speed gain corresponding to the variation of the mass of the work are stored in the memory, the reference values of speed gain and the variations of speed gain corresponding to the amounts of actions of the actuators detected by the photoencoders E.sub.1 to E.sub.6 are read from the memory upon the detection of the amounts of actions of the actuators, values of speed gain (K.sub.v) corresponding to the moments of inertia (J) of the actuators are calculated on the basis of the data read from the memory, and then outputs for the servomechanisms are calculated on the basis of the calculated values of speed gain to control the servomechanisms for optimum response to the variation of the moments of inertia resulting from changes in the position of the functional components of the articulated robot and in the mass of the work.
However, it is difficult to control the locus of the work at a high accuracy by only controlling speed gain according to the variation of the moment of inertia resulting from variation in the position of the functional components of the articulated robot, because position gain is a significant factor affecting the response of the servomechanisms of the articulated robot.
Furthermore, the stepwise change (discontinuous change) of speed gain by reading the values of speed gain from the tables of the memory causes sudden changes in the values of instructions when the values of speed gain are read from positions near the boundaries of the tables, which adversely affects to the motion of the articulated robot deteriorating the accuracy of the locus of the work.
SUMMARY OF THE INVENTIONAccordingly, it is an object of the present invention to provide a robot controller eliminating the foregoing disadvantages of the conventional robot controller and capable of controlling an articulated robot for the highly accurate high-speed movement of the work without requiring a memory having a large capacity.
In one aspect of the present invention, a robot controller for controlling an articulated robot having a position control system for controlling the actuators of the articulated robot on the basis of position instructions and a speed control system comprises memory means for previously storing functions for calculating position gains and speed gains for joints of the articulated robot, detecting means for detecting the present position and present speed of each of the joints during the operation of the articulated robot; first calculating means for calculating a position gain and a speed gain for each joint shaft on the basis of the present position and present speed of the joint detected by the detecting means by using the functions stored in the memory means; and second calculating means for calculating instructions to be given to the actuators on the basis of the position instructions, the present positions and the present speeds detected by the detecting means, and the position gains and the speed gains calculated by the first calculating means.
The robot controller of the present invention uses the position gain in addition to the speed gain as a variable for the feedback position control by using a control loop including a speed control loop as a minor loop, and determines the speed gain and the position gain taking into account the moments of inertia of all the joints by representing the position gain and the speed gain as functions of the positions of the actuators. The gains are stored as functional coefficients in a memory means having a comparatively small capacity instead of storing the gains in tables. A first calculating operation calculates the position gain and the speed gain on the basis of the present position and the present speed detected by the a detecting operation during the operation of the articulated robot by using the functional coefficients. A second calculating operation calculates instruction outputs for the position control system and the speed control system on the basis of the data detected by the detecting operation and position instructions and gives the instruction outputs to the actuators for the accurate position control of the articulated robot.
Thus, the robot controller of the present invention has the following advantages.
(1) Continuous change of the position gain and speed gain of the control systems according to the position and speed of the articulated robot enables uniform control of the work over the entire range of motion of the articulated robot.
(2) The regulation of the position gain in addition to the speed gain enables the highly accurate control of the locus of the work in response to the variation of the position and operating speed of the joints.
(3) The storage of the gains as a function requires a memory having a comparatively small storage capacity, the highly accurate control of the movement of the work, which reduces the cost of the articulated robot and improves the performance of the articulated robot.
BRIEF DESCRIPTION OF THE DRAWINGSThe above and other objects, features and advantages of the present invention will become more apparent from the following description taken in conjunction with the accompanying drawings, in which:
FIG. 1 is a block diagram of a robot controller in a preferred embodiment according to the present invention;
FIG. 2 is a block diagram of a servomechanism included in the robot controller of FIG. 1;
FIG. 3 is a flow chart of control procedure to be carried out by the robot controller of FIG. 1;
FIG. 4 is a flow chart of control procedure to be carried out by a conventional robot controller;
FIG. 5 is a diagram of a conventional articulated robot.
FIG. 6 is a block diagram of assistance in explaining the constitution of a conventional robot; and
FIG. 7 is a block diagram of a servomechanism included in the conventional robot controller.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTA robot controller embodying the present invention will be described hereinafter as applied to an articulated robot having six degrees of freedom of motion as shown in FIG. 5.
Shown in FIG. 1 are a coordinates converting unit 10 for converting position data on a rectilinear coordinate system into position instructions for joint shafts, position and speed control units C.sub.1 to C.sub.6 (second calculating means) which receive position instructions .theta..sub.1 to .theta..sub.6, respectively, from the coordinates converting unit 10 and execute position and speed control operation, servo amplifiers A.sub.1 to A.sub.6, servomotors M.sub.1 to M.sub.6 (actuators) associated, respectively, with the joint shafts, position detectors (photoencoders) E.sub.1 to E.sub.6, memories N.sub.1 to N.sub.6 for storing functional coefficients, and gain calculating units P.sub.1 to P.sub.6 (first calculating means) for calculating speed gains G.sub.v and position gains G.sub.p on the basis of the position data representing the positions of the joints and coefficients stored in the memories N.sub.1 to N.sub.6.
Each of the position and speed control units C.sub.1 to C.sub.6 are the same in constitution and function. Referring to FIG. 2 showing one of the position and speed control units C.sub.1 to C.sub.6, upon the reception of the position instruction 11 (one of the position instructions .theta..sub.1 to .theta..sub.6), the position and speed control unit subtracts a position signal 12 representing the present position of the associated joint provided by the position detector 24 (one of the position detectors E.sub.1 to E.sub.6) associated with the servomotor 23 (one of the servomotors M.sub.1 to M.sub.6) from the position instruction 11 to obtain a position deviation 13. Then, a position gain multiplier 14 multiplies the position deviation 13 by a position gain G.sub.p to obtain a signal 15.
A differentiator calculates the variation of the position signal 12 with time to determine the present speed 17. The present speed 17 is subtracted from the signal 15 to obtain a composite position and speed feedback signal 18. A speed gain multiplier 19 multiplies the composite position and speed feedback signal 18 by a speed gain G.sub.v to provide a signal 20. The signal 20 is given to the servo amplifier 21 to control the servomotor 23.
The set value of the position gain G.sub.p can be changed by a signal 25 given from the gain calculating unit (one of the gain calculating units P.sub.1 to P.sub.6) to the position gain multiplier 14. Similarly, the set value of the speed gain G.sub.v can be changed by a signal 26 given from the gain calculating unit to the speed gain multiplier 19.
Referring to FIG. 3 showing a control program to be executed by a control circuit comprising the position and speed control unit C.sub.i (i is one of numerals 1 to 6), the memory N.sub.i and the gain calculating unit P.sub.i, the control circuit receives data representing the present position of the joint and a position instruction for the joint in step 31 and calculates a position deviation, namely, the difference between the position instruction and the present position, in step 32. In step 33 a position gain G.sub.pi is calculated by using:
G.sub.pi =f.sub.i (.theta..sub.i) (2)
where f.sub.i is a simple function, such as a quadratic function, and .theta..sub.i is a position instruction for the joint i.
The function f.sub.i of the expression (2) is stored in the memory N.sub.i, and the position gain G.sub.pi corresponding to the position instruction .theta..sub.i is calculated by substituting the position instruction .theta..sub.i for the joint received in step 31 into the expression (2).
In step 34, the position deviation is multiplied by the position gain G.sub.pi to obtain a speed instruction V.sub.i. In step 35, the present speed is subtracted from the speed instruction V.sub.i to obtain a speed deviation. In step 36, a speed gain G.sub.v is calculated by using:
G.sub.vi =h.sub.i (V.sub.i) (3)
where h.sub.i is a simple function, such as a linear function, V.sub.i is the speed instruction for the joint i.
In step 37, the speed deviation is multiplied by the speed gain G.sub.vi to provide an instruction for the servo amplifier A.sub.i.
Thus, these simple functions for calculating the position gain G.sub.pi and the speed gain G.sub.vi are stored in the memory N.sub.i and the position gain G.sub.pi and the speed gain G.sub.vi are changed continuously according to the position and speed of the joint to improve the response characteristics of the servomechanism for the entire region of movement of the joint.
The calculations in steps 31 to 37 of the control program can be achieved by a single or a plurality of CPUs. Sampling periods for sampling data are decreased in the order of the coordinates conversion, the position control and the speed control.
Thus, the robot controller varies the position gain G.sub.pi and the speed gain G.sub.vi among the control constants for each joint as functions of the condition of all the joints for the continuous, highly accurate position and speed control of the joints. Since the position gains G.sub.p and the speed gains G.sub.v are calculated by using simple expressions for every control cycle, no table for storing the position gains G.sub.p and the speed gains G.sub.v is necessary and hence the robot controller may be provided with a comparatively small number of memories having a comparatively small storage capacity.
Although the invention has been described in its preferred form with a certain degree of particularity, obviously many changes and variations are possible therein. It is therefore to be understood that the present invention may be practiced otherwise than as specifically described herein without departing from the scope and spirit thereof.
Claims
1. A robot controller for controlling an articulated robot, comprising a position control system with a speed control minor servo loop for controlling the actuators of the articulated robot on the basis of position instructions, the improvement comprising:
- memory means for previously storing functions for calculating position gains and speed gains for each joint of the articulated robot;
- detecting means for detecting the present position and present speed of each of the joints during the operation of the articulated robot;
- first calculating means for calculating a position gain and a speed gain for each joint on the basis of the present position and present speed of the joint detected by the detecting means by using the functions stored in the memory means; and
- second calculating means for calculating instructions to be given to the actuators on the basis of position instructions, the present positions and present speeds of the joints detected by the detecting means, and the position gains and the speed gains calculated by the first calculating means.
3882368 | May 1975 | Carleton |
4345194 | August 17, 1982 | Green |
4518909 | May 21, 1985 | Friedli et al. |
4535277 | August 13, 1985 | Kurakake |
4540925 | September 10, 1985 | Jones |
4542471 | September 17, 1985 | Inaba et al. |
4603284 | July 29, 1986 | Perzley |
4621332 | November 4, 1986 | Sugimoto et al. |
4629956 | December 16, 1986 | Nozawa et al. |
4707780 | November 17, 1987 | Gose et al. |
4740885 | April 26, 1988 | Gose et al. |
4816734 | March 28, 1989 | Kurakake et al. |
4851748 | July 25, 1989 | Daggett et al. |
4859920 | August 22, 1989 | Kurakake et al. |
Type: Grant
Filed: Sep 19, 1989
Date of Patent: Jan 15, 1991
Assignee: Kabushiki Kaisha Kobe Seiko Sho (Kobe)
Inventors: Akira Nakazumi (Tokorozawa), Nobuaki Imamura (Kobe)
Primary Examiner: Paul Ip
Law Firm: Oblon, Spivak, McClelland, Maier & Neustadt
Application Number: 7/409,316
International Classification: G05B 1942;