WO2015137140A1 - ロボットアームの制御装置、ロボットアームの制御方法及びプログラム - Google Patents

ロボットアームの制御装置、ロボットアームの制御方法及びプログラム Download PDF

Info

Publication number
WO2015137140A1
WO2015137140A1 PCT/JP2015/055665 JP2015055665W WO2015137140A1 WO 2015137140 A1 WO2015137140 A1 WO 2015137140A1 JP 2015055665 W JP2015055665 W JP 2015055665W WO 2015137140 A1 WO2015137140 A1 WO 2015137140A1
Authority
WO
WIPO (PCT)
Prior art keywords
unit
control
joint
arm
robot arm
Prior art date
Application number
PCT/JP2015/055665
Other languages
English (en)
French (fr)
Inventor
康宏 松田
栄良 笠井
康久 神川
容平 黒田
亘 小久保
利充 坪井
哲治 福島
宮本 敦史
Original Assignee
ソニー株式会社
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 ソニー株式会社 filed Critical ソニー株式会社
Publication of WO2015137140A1 publication Critical patent/WO2015137140A1/ja

Links

Images

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1628Programme controls characterised by the control loop
    • B25J9/1633Programme controls characterised by the control loop compliant, force, torque control, e.g. combined with position control
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B34/00Computer-aided surgery; Manipulators or robots specially adapted for use in surgery
    • A61B34/30Surgical robots
    • AHUMAN NECESSITIES
    • A61MEDICAL OR VETERINARY SCIENCE; HYGIENE
    • A61BDIAGNOSIS; SURGERY; IDENTIFICATION
    • A61B90/00Instruments, implements or accessories specially adapted for surgery or diagnosis and not covered by any of the groups A61B1/00 - A61B50/00, e.g. for luxation treatment or for protecting wound edges
    • A61B90/36Image-producing devices or illumination devices not otherwise provided for
    • A61B90/361Image-producing devices, e.g. surgical cameras
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/36Nc in input of data, input key till input tape
    • G05B2219/36429Power assisted positioning
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/45Nc applications
    • G05B2219/45121Operating microscope, mounted on manipulator arm

Definitions

  • the present disclosure relates to a control device of a robot arm, a control method of a robot arm, and a program.
  • robot devices are widely used to perform tasks more accurately and more quickly.
  • the robot devices there are multi-link structures in which a plurality of links are connected to one another by joints, and by controlling rotational drive in the plurality of joints, the drive of the entire robot device is controlled.
  • position control and force control are known as a control method of a robot apparatus and each joint part.
  • position control for example, a command value such as an angle is given to an actuator of the joint unit, and drive of the joint unit is controlled to follow the command value.
  • force control a target value of force to be applied to the work target is given as the entire robot apparatus, and drive of the joint (for example, torque generated by the joint) is controlled to realize the force indicated by the target value. Be done.
  • position control is sometimes referred to as "hard control” because it is difficult to respond flexibly to external forces, and tasks (exercises while performing physical interaction (eg, human-physical interaction) with various external worlds. Purpose) not suitable for robotic devices that perform
  • force control is a control method that is particularly suitable for a robot apparatus that performs physical interaction, because it can realize "soft control" in force order while the system configuration is complicated, and a control method with better usability. It can be said.
  • Patent Document 1 discloses a robot apparatus including a moving mechanism including two opposing wheels and an arm having a plurality of joints, the wheel and the joints There is disclosed a robot apparatus that performs coordinated control on the whole as a whole (performs whole-body coordinated control).
  • a balance type arm support arm
  • various medical units tip units
  • a unit having various imaging functions such as a microscope
  • a practitioner user
  • the balance type arm needs to have a counter balance weight (also referred to as a counter weight or a balancer) to balance the force when moving the arm portion, the device tends to be large. is there.
  • balance type arm Met only a part of the drive of the arm, for example, only the drive of two axes for moving the tip unit on a plane (two-dimensional) is electrically driven, and the arm and the tip are moved. Movement of the unit requires manual positioning by the practitioner and surrounding medical staff. Therefore, in a general balance type arm, it is possible to secure stability at the time of imaging (for example, accuracy in positioning of the tip unit, vibration control, etc.) or various conditions in which the imaging site is fixed to a predetermined site of a patient's body. It was difficult to secure the degree of freedom of shooting such as shooting from the direction.
  • a medical robot arm apparatus whose drive is controlled by position control has also been proposed as an apparatus replacing the balance type arm.
  • the drive control of the robot arm device is higher because the user can more intuitively control the position and posture of the arm unit and the tip unit. Operability was required. In a robot arm device whose drive is controlled by position control, it has been difficult to meet such a user's request.
  • a speed acquisition unit that connects a plurality of links and acquires an operation speed of a joint unit that drives a multi-link structure configured of a plurality of the links; and the joint unit based on the operation speed
  • a parameter control unit that controls control parameters related to the operation of the control unit.
  • means for acquiring a motion speed of a plurality of joints for connecting a plurality of links and driving a multi-link structure composed of a plurality of the links, the joint based on the motion speed A program for causing a computer to function is provided as means for controlling control parameters related to the operation of the unit.
  • control in control of a robot arm device, control that can further improve operability and safety can be realized.
  • FIG. 1 is a schematic view showing an appearance of a robot arm apparatus according to an embodiment of the present disclosure. It is a sectional view showing typically signs that an actuator of a joint part concerning an embodiment of this indication was cut by a section which passes along a rotating shaft. It is the schematic which shows typically a mode that the torque sensor shown in FIG. 3 was seen from the axial direction of the drive shaft.
  • FIG. 7 is a schematic view showing another configuration example of a torque sensor applied to the actuator shown in FIG. 3; It is an explanatory view for explaining ideal joint control concerning one embodiment of this indication.
  • FIG. 6 is a schematic view showing an example of a map used when the inertia moment control unit 262 calculates the inertia moment I. It is a schematic diagram which shows the map used when the arm part 120 stops. It is a flow figure showing the processing procedure of the robot arm control method concerning one embodiment of this indication. It is a flowchart which shows the process which controls viscosity according to the operation speed. It is a characteristic view showing the cogging torque (dotted line) of a motor, and the torque (solid line) at the time of canceling cogging torque.
  • FIG. 1 is an explanatory diagram for describing an application example when the robot arm device according to an embodiment of the present disclosure is used for medical use.
  • FIG. 1 schematically shows the state of treatment using the robot arm apparatus according to the present embodiment.
  • a doctor who is a practitioner (user) 520 uses a surgical instrument 521 such as a scalpel, forceps, forceps, for example, to be treated on a treatment table 530 (patient)
  • a treatment table 530 patient
  • the term "treatment” is a generic term for various medical treatments such as surgery and examination, which the doctor who is the user 520 performs on the patient who is the treatment target 540.
  • the operation is illustrated as an example of the operation, but the operation using the robot arm device 510 is not limited to the operation, and various other operations such as an endoscope may be used. It may be an examination etc.
  • a robot arm apparatus 510 is provided beside the treatment table 530.
  • the robot arm device 510 includes a base portion 511 which is a base and an arm portion 512 extending from the base portion 511.
  • the arm unit 512 includes a plurality of joints 513 a, 513 b, and 513 c, a plurality of links 514 a and 514 b connected by the joints 513 a and 513 b, and an imaging unit 515 provided at the tip of the arm 512.
  • the arm 512 has three joints 513 a to 513 c and two links 514 a and 514 b, but in practice the positions of the arm 512 and the imaging unit 515 and
  • the number and shape of the joints 513a to 513c and the links 514a and 514b, the direction of the drive shaft of the joints 513a to 513c, and the like may be appropriately set so as to realize the desired degree of freedom in consideration of the degree of freedom of the posture. .
  • the joint units 513a to 513c have a function of rotatably connecting the links 514a and 514b to each other, and the drive of the arm unit 512 is controlled by driving the rotation of the joint units 513a to 513c.
  • the position of each component of the robot arm device 510 means the position (coordinates) in a space defined for drive control
  • the posture of each component is a drive. It means the orientation (angle) with respect to any axis in the space defined for control.
  • driving (or drive control) of the arm unit 512 means driving (or drive control) of the joints 513a to 513c and driving (or drive control) of the joints 513a to 513c. It means that the position and posture of each component of the arm unit 512 are changed (change is controlled).
  • an imaging unit 515 is provided at the tip of an arm 512 as an example of the tip unit.
  • the imaging unit 515 is a unit that acquires an image to be captured (captured image), and is, for example, a camera that can capture a moving image or a still image.
  • the posture and position of the arm unit 512 and the imaging unit 515 by the robot arm device 510 so that the imaging unit 515 provided at the tip of the arm unit 512 photographs the appearance of the treatment site of the operation target 540. Is controlled.
  • the tip unit provided at the tip of the arm unit 512 is not limited to the imaging unit 515, and may be various medical instruments.
  • the robot arm apparatus 510 is a medical robot arm apparatus provided with a medical instrument.
  • a stereo camera having two imaging units may be provided at the tip of the arm unit 512, and imaging may be performed so as to display an imaging target as a three-dimensional image (3D image).
  • a robot arm device 510 provided with an imaging unit 515 for photographing a treatment site and a camera unit such as the stereo camera as a tip unit is also referred to as a robot arm device for a video microscope.
  • a display device 550 such as a monitor or a display is installed.
  • the photographed image of the treatment site photographed by the imaging unit 515 is displayed on the display screen of the display device 550.
  • the user 520 performs various treatments while viewing the photographed image of the treatment site displayed on the display screen of the display device 550.
  • the robot arm device 510 is required to have the following performance, for example.
  • the robot arm device 510 is required to secure a work space in surgery. While the user 520 is performing various treatments on the treatment target 540, if the arm unit 512 or the imaging unit 515 obstructs the view of the practitioner or the movement of the hand performing the treatment, the efficiency of the surgery Leading to a decrease in
  • a plurality of other doctors who perform various support tasks such as handing the tool to the user 520 and confirming various vital signs of the patient 540 Since a nurse or the like is generally present around the user 520 and the patient 540, and there are other devices and the like for performing the support work, the surgical environment is complicated. Therefore, it is desirable that the robot arm device 510 be smaller.
  • the robot arm device 510 is required to have high operability when moving the imaging unit 515.
  • the user 520 has a request to observe the same operation site from various positions and angles while performing treatment on the operation site.
  • the angle at which the treatment site is observed it is necessary to change the angle of the imaging unit 515 with respect to the treatment site, but at this time the imaging direction of the imaging unit 515 remains fixed at the treatment site (that is, the same site). It is more desirable that only the shooting angle changes.
  • the imaging unit 515 moves in the plane of the cone with the treatment site at the top, pivoting operation with the axis of the cone as the pivot axis (
  • the robot arm device 510 is required to have a more flexible operability such as the pivoting motion).
  • the pivoting operation is also referred to as a point lock operation.
  • the imaging unit 515 in order to change the position and angle of the imaging unit 515, it is conceivable to move the imaging unit 515 to a desired position and angle, for example, by the user 520 manually moving the arm unit 512. Therefore, it is desirable that the movement of the imaging unit 515, the above-mentioned pivoting movement, and the like have operability that can be easily performed with one hand, for example.
  • the imaging center of the captured image captured by the imaging unit 515 is changed from the site being treated to another site (for example, the site to be subjected to the next treatment)
  • another site for example, the site to be subjected to the next treatment
  • various methods of driving the arm unit 512 such as a method of controlling the
  • the robot arm device 510 is required to have high operability that meets the intuition and desires of the user 520, for example, to realize easy pivoting movement and manual movement described above.
  • the robot arm device 510 is required to have stability in drive control of the arm unit 512.
  • the stability to the drive control of the arm unit 512 may be the stability of the position and posture of the tip unit when the arm unit 512 is driven.
  • the stability to the drive control of the arm unit 512 includes smooth movement of the tip unit when the arm unit 512 is driven and suppression of vibration (vibration suppression). For example, if the tip unit is the imaging unit 515 as in the example shown in FIG. 1, the captured image displayed on the display screen of the display device 550 will not be stable if the position or posture of the imaging unit 515 is not stable. May cause the user to feel uncomfortable.
  • a stereo camera having two imaging units (camera units) is provided as a tip unit, and a three-dimensional image generated based on an image captured by the stereo camera
  • a method of use may be envisaged in which the 3D image is displayed on the display 550.
  • the 3D image is displayed, if the position or posture of the stereo camera is unstable, so-called 3D sickness of the user may be induced.
  • the observation range captured by the imaging unit 515 may be expanded to about ⁇ 15 mm depending on the site to be operated and the content of the operation.
  • the imaging unit 515 when the imaging unit 515 enlarges and captures an image in a narrow range, a slight vibration of the imaging unit 515 appears as a large shaking or blurring of a captured image. Therefore, high positioning accuracy of about 1 mm is required for driving control of the arm unit 512 and the imaging unit 515. As described above, in the drive control of the arm unit 512, high-accuracy response and high positioning accuracy are required.
  • the inventors examined a general existing balance type arm and a robot arm device by position control from the viewpoint of the above three performances.
  • a counterbalance weight both counterweight and balancer
  • a counterbalance weight is usually used to balance the force when moving the arm part. Since it is provided inside the base portion etc., it is difficult to miniaturize the size of the device of the balance type arm, and it can not be said that the performance is satisfied.
  • the inventors obtained the knowledge that there is a demand for the three performances as described above with respect to the robot arm device. However, it is considered that it is difficult to satisfy these performances with a general existing balance type arm or a robot arm device with position control.
  • the present inventors considered the robot arm apparatus, the robot arm control system, the robot arm control method, and the program according to the present disclosure as a result of examining the configuration that satisfies the three performances described above. In the following, preferred embodiments of the configuration conceived by the present inventors will be described in detail.
  • [2-1. Appearance of Robot Arm Device] shows an appearance of the robot arm device according to the present embodiment, and a schematic configuration of the robot arm device will be described.
  • [2-2. About generalized inverse dynamics] and [2-3. About Ideal Joint Control] An overview of generalized inverse dynamics and ideal joint control used for control of a robot arm apparatus according to the present embodiment will be described.
  • [2-4. Configuration of Robot Arm Control System] The configuration of a system for controlling the robot arm apparatus according to the present embodiment will be described using a functional block diagram.
  • [2-5. Specific Example of Motion Purpose] will be described a specific example of whole-body cooperative control using generalized inverse dynamics in the robot arm apparatus according to the present embodiment.
  • the distal end unit of the arm unit of the robot arm device is an imaging unit, and as shown in FIG.
  • the present embodiment is not limited to such an example.
  • the robot arm control system according to the present embodiment is applicable even when a robot arm device having another tip unit is used for another application.
  • FIG. 2 is a schematic view showing an appearance of a robot arm apparatus according to an embodiment of the present disclosure.
  • a robot arm apparatus 400 includes a base unit 410 and an arm unit 420.
  • the base portion 410 is a base of the robot arm device 400, and the arm portion 420 is extended from the base portion 410.
  • a control unit that integrally controls the robot arm apparatus 400 may be provided in the base unit 410, and the driving of the arm unit 420 may be controlled by the control unit.
  • the control unit is composed of, for example, various signal processing circuits such as a central processing unit (CPU) and a digital signal processor (DSP).
  • the arm unit 420 includes a plurality of joints 421a to 421f, a plurality of links 422a to 422c mutually connected by the joints 421a to 421f, and an imaging unit 423 provided at the tip of the arm 420.
  • the links 422a to 422c are rod-like members, one end of the link 422a is connected to the base portion 410 via the joint portion 421a, the other end of the link 422a is connected to one end of the link 422b via the joint portion 421b, The other end of the link 422b is connected to one end of the link 422c via the joints 421c and 421d. Furthermore, the imaging unit 423 is connected to the tip of the arm 420, that is, the other end of the link 422c via the joints 421e and 421f.
  • the ends of the plurality of links 422a to 422c are connected to each other by the joint portions 421a to 421f with the base portion 410 as a fulcrum, whereby an arm shape extended from the base portion 410 is configured.
  • the imaging unit 423 is a unit that acquires an image of an imaging target, and is, for example, a camera that captures a moving image or a still image. By controlling the driving of the arm unit 420, the position and posture of the imaging unit 423 are controlled. In the present embodiment, the imaging unit 423 captures, for example, a partial region of the patient's body, which is a treatment site.
  • the tip unit provided at the tip of the arm unit 420 is not limited to the imaging unit 423, and various medical instruments may be connected to the tip of the arm unit 420 as a tip unit.
  • the robot arm apparatus 400 according to the present embodiment can be said to be a medical robot arm apparatus provided with a medical instrument.
  • the robot arm device 400 will be described by defining coordinate axes as shown in FIG. Also, according to the coordinate axes, the vertical direction, the longitudinal direction, and the horizontal direction are defined. That is, the vertical direction with respect to the base portion 410 installed on the floor surface is defined as the z-axis direction and the vertical direction. In addition, a direction perpendicular to the z axis and a direction in which the arm unit 420 is extended from the base unit 410 (that is, a direction in which the imaging unit 423 is positioned with respect to the base unit 410) It defines as the front and back direction. Furthermore, directions orthogonal to the y-axis and z-axis are defined as x-axis direction and left-right direction.
  • the joints 421a to 421f pivotally connect the links 422a to 422c to each other.
  • the joint portions 421a to 421f have an actuator, and have a rotation mechanism that is rotationally driven about a predetermined rotation axis by driving the actuator.
  • By controlling the rotational drive in each of the joint portions 421a to 421f it is possible to control the drive of the arm portion 420, such as extending or contracting (folding) the arm portion 420, for example.
  • the joints 421a to 421f are described in the following [2-2. About generalized inverse dynamics] Whole body coordinated control described later and the following [2-3. The drive is controlled by the ideal joint control described later in “Regarding Ideal Joint Control”.
  • the drive control of the joints 421a to 421f specifically refers to the joints 421a to 421f. It means that the rotation angle and / or the generated torque (torques generated by the joints 421a to 421f) are controlled.
  • the robot arm apparatus 400 has six joint portions 421a to 421f, and six degrees of freedom are realized with respect to driving of the arm portion 420. Specifically, as shown in FIG. 2, with the joints 421a, 421d, and 421f, the long axis direction of each of the connected links 422a to 422c and the imaging direction of the connected imaging unit 473 are taken as the rotational axis direction.
  • the joint portions 421b, 421c, and 421e are connected in the yz plane (a plane defined by the y-axis and the z-axis) with respect to the connection angle of each of the connected links 422a to 422c and the imaging unit 473.
  • the x axis direction which is the direction to be changed, is set as the rotation axis direction.
  • the joints 421a, 421d, and 421f have a function of performing so-called yawing
  • the joints 421b, 421c, and 421e have a function of performing so-called pitching.
  • the robot arm apparatus 400 achieves six degrees of freedom with respect to the drive of the arm unit 420. Therefore, the imaging unit within the movable range of the arm unit 420 You can move the 423 freely.
  • a hemisphere is illustrated as an example of the movable range of the imaging unit 423. Assuming that the central point of the hemisphere is the imaging center of the treatment site imaged by the imaging unit 423, the imaging unit 423 is moved on the spherical surface of the hemisphere with the imaging center of the imaging unit 423 fixed at the central point of the hemisphere. By doing this, the treatment site can be photographed from various angles.
  • FIG. 3 is a cross-sectional view schematically showing a state in which the actuators of the joint portions 421a to 421f according to an embodiment of the present disclosure are cut at a cross section passing through the rotation axis.
  • the joint portions 421a to 421f may have other configurations.
  • the joint units 421 a to 421 f may be, for example, a control unit for controlling driving of the actuator, or a support member for connecting and supporting the links 422 a to 422 c and the imaging unit 423. It has various configurations necessary for driving the arm unit 420.
  • driving of the joint of the arm may mean driving of an actuator in the joint.
  • the joints 421a to 421f have the following [2-3.
  • the drive is controlled by the ideal joint control described later in “Regarding Ideal Joint Control”. Therefore, the actuators of the joint portions 421a to 421f shown in FIG. 3 are configured to be able to drive corresponding to the ideal joint control. Specifically, the actuators of the joint portions 421a to 421f are configured to be able to adjust the rotation angle of the joint portions 421a to 421f and the torque associated with the rotational drive.
  • the actuators of the joint portions 421a to 421f are configured to be able to arbitrarily adjust the viscous drag coefficient with respect to rotational movement, and for example, are easy to rotate with respect to externally applied force (that is, the arm portion 420 is manually operated A state in which movement is easy) and a state in which rotation is difficult (that is, it is difficult to manually move the arm portion 420) can be realized.
  • the actuator 430 of the joints 421a to 421f includes a motor 424, a motor driver 425, a reduction gear 426, an encoder 427, a torque sensor 428, and a drive shaft 429.
  • the encoder 427, the motor 424, the reduction gear 426 and the torque sensor 428 are connected in series to the drive shaft 429 in this order.
  • Motor 424 is the prime mover in actuator 430 and rotates drive shaft 429 about its axis.
  • the motor 424 is an electric motor such as a brushless DC motor.
  • the rotational driving of the motor 424 is controlled by being supplied with an electric current.
  • the motor driver 425 is a driver circuit (driver IC (Integrated Circuit)) that rotationally drives the motor 424 by supplying a current to the motor 424, and adjusts the amount of current supplied to the motor 424 to rotate the motor 424. You can control the number. In addition, the motor driver 425 can adjust the viscous drag coefficient with respect to the rotational movement of the actuator 430 as described above by adjusting the amount of current supplied to the motor 424.
  • driver IC Integrated Circuit
  • the reduction gear 426 is connected to the drive shaft 429 and generates a rotational drive force (i.e., torque) having a predetermined value by decelerating the rotational speed of the drive shaft 429 generated by the motor 424 at a predetermined reduction ratio.
  • a rotational drive force i.e., torque
  • the reduction gear 426 may be a harmonic drive (registered trademark).
  • the torque generated by the reduction gear 426 is output via a torque sensor 428 connected to the output shaft of the reduction gear 426 (not shown, for example, connecting members such as the links 422 a to 422 c and the imaging unit 423) Transmitted to
  • the encoder 427 is connected to the drive shaft 429 and detects the number of rotations of the drive shaft 429. Based on the relationship between the rotational speed of the drive shaft 429 detected by the encoder and the reduction ratio of the reduction gear 426, information such as the rotational angle, rotational angular velocity and rotational angular acceleration of the joints 421a to 421f can be obtained.
  • the torque sensor 428 is connected to the output shaft of the reduction gear 426 and detects the torque generated by the reduction gear 426, that is, the torque output by the actuator 430.
  • the torque output by the actuator 430 is also simply referred to as generated torque.
  • the number of rotations of the motor 424 can be adjusted by adjusting the amount of current supplied to the motor 424.
  • the reduction gear ratio of the reduction gear 426 may be appropriately set according to the application of the robot arm device 400. Therefore, the generated torque can be controlled by appropriately adjusting the number of rotations of the motor 424 in accordance with the reduction gear ratio of the reduction gear 426.
  • information such as the rotation angle, rotation angular velocity, and rotation angular acceleration of the joint portions 421a to 421f can be obtained. Thus, it is possible to detect the generated torque at the joint portions 421a to 421f.
  • the torque sensor 428 can detect not only the torque generated by the actuator 430 but also an external torque applied from the outside. Therefore, by adjusting the amount of current supplied to the motor 424 by the motor driver 425 based on the external torque detected by the torque sensor 428, it is possible to adjust the viscous drag coefficient for the rotational movement as described above, for example It is possible to realize a state in which it is easy to rotate or a state in which it is difficult to rotate with respect to a force applied from the outside.
  • FIG. 4A is a schematic view schematically showing the torque sensor 428 shown in FIG. 3 as viewed from the axial direction of the drive shaft 429. As shown in FIG.
  • the torque sensor 428 includes an outer ring 431, an inner ring 432, beams 433a to 433d, and strain detection elements 434a to 434d.
  • the outer ring part 431 and the inner ring part 432 are arrange
  • the inner ring portion 432 is connected to the input side, ie, the output shaft from the reduction gear 426, and the outer ring portion 431 is connected to the output side, ie, an output member (not shown) at the subsequent stage.
  • the four beam portions 433a to 433d are disposed between the outer ring portion 431 and the inner ring portion 432 arranged concentrically, and connect the outer ring portion 431 and the inner ring portion 432 to each other. As shown in FIG. 4A, the beam portions 433a to 433d are interposed between the outer ring portion 431 and the inner ring portion 432 such that adjacent beam portions 433a to 433d form an angle of 90 degrees with each other.
  • Strain detection elements 434a to 434d are provided on two of the beam portions 433a to 433d facing each other, that is, provided at an angle of 180 degrees.
  • the generated torque and the external torque of the actuator 430 can be detected based on the amount of deformation of the beam portions 433a to 433d detected by the strain detection elements 434a to 434d.
  • strain detection elements 434a and 434b are provided to the beam portion 433a, and strain detection elements 434c and 434d are provided to the beam portion 433c.
  • the strain detection elements 434a and 434b are provided to sandwich the beam portion 433a, and the strain detection elements 434c and 434d are provided to sandwich the beam portion 433c.
  • the strain detection elements 434a to 434d are strain gauges, and are attached to the surfaces of the beam portions 433a and 433c to detect the amount of geometric deformation of the beam portions 433a and 433c based on a change in electrical resistance. As shown in FIG.
  • the detection elements 434a to 434d constitute a so-called Wheatstone bridge. Therefore, since distortion can be detected using a so-called four-gauge method, it is possible to reduce the influence of interference of the other axes other than the axis for detecting distortion, eccentricity of the drive shaft 429, temperature drift and the like.
  • the beam portions 433a to 433d play a role of a strain generating body for detecting distortion.
  • the types of strain detection elements 434a to 434d according to the present embodiment are not limited to strain gauges, and other elements may be used.
  • the strain detection elements 434a to 434d may be elements that detect the amount of deformation of the beam portions 433a to 433d based on a change in magnetic characteristics.
  • the configuration shown below may be applied.
  • the support moment is released by thinning the portions of the beam portions 433a to 433d connected to the outer ring portion 431 compared to other portions, so that the linearity of the detected deformation is improved and the radial load is improved.
  • a double-support bearing may be provided at the other end of the actuator 430 shown in FIG.
  • the configuration of the torque sensor 428 has been described above with reference to FIG. 4A. As described above, the configuration of the torque sensor 428 shown in FIG. 4A enables highly accurate detection in detecting the generated torque and the external torque of the actuator 430.
  • the configuration of the torque sensor 428 is not limited to the configuration shown in FIG. 4A, and may be another configuration.
  • the torque sensor applied to the actuator 430 an example of another configuration other than the torque sensor 428 will be described with reference to FIG. 4B.
  • FIG. 4B is a schematic view showing another configuration example of the torque sensor applied to the actuator 430 shown in FIG.
  • a torque sensor 428a according to the present modification includes an outer ring portion 441, an inner ring portion 442, beam portions 443a to 443d, and strain detection elements 444a to 444d.
  • 4B schematically shows the torque sensor 428a as viewed from the axial direction of the drive shaft 429, as in FIG. 4A.
  • the functions and configurations of the outer ring portion 441, the inner ring portion 442, the beam portions 443a to 443d, and the strain detection elements 444a to 444d are the same as the outer ring portion 431 and the inner ring portion 432 of the torque sensor 428 described with reference to FIG.
  • the functions and configurations of the beam portions 433a to 433d and the strain detection elements 434a to 434d are substantially the same.
  • the torque sensor 428a according to the present modification differs in the configuration of the connection portion between the beam portions 443a to 443d and the outer ring portion 441. Therefore, with regard to the torque sensor 428a shown in FIG. 4B, the configuration of the connection portion between the beam portions 443a to 443d and the outer ring portion 441, which is the difference from the torque sensor 428 shown in FIG. The explanation is omitted.
  • connection portion between the beam portion 443b and the outer ring portion 441 is enlarged and shown together with the overall view of the torque sensor 428a.
  • FIG. 4B only the connection portion between the beam portion 443b and the outer ring portion 441, which is one of the four connection portions between the beam portions 443a to 443d and the outer ring portion 441, is shown enlarged.
  • the other three connection portions between the beam portions 443a, 443c and 443d and the outer ring portion 441 have the same configuration.
  • the outer ring portion 441 is provided with an engagement recess, and the tip end of the beam portion 443b is engaged with the engagement recess As a result, both are connected. Further, gaps G1 and G2 are provided between the beam portion 443b and the outer ring portion 441.
  • the gap G1 represents the gap between the two in the direction in which the beam portion 443b extends toward the outer ring portion 441, and the gap G2 represents the gap in the direction orthogonal to the direction.
  • the beam portions 443a to 443d and the outer ring portion 441 are separately disposed with predetermined gaps G1 and G2. That is, in the torque sensor 428a, the outer ring portion 441 and the inner ring portion 442 are separated. Therefore, since the inner ring portion 442 is not restrained with respect to the outer ring portion 441 and has freedom of movement, distortion components due to the vibration can be obtained by combining the inner ring portion 442 and the outer ring portion 441 even if vibration occurs when driving the actuator 430, for example. Can be absorbed by the gaps G1, G2 between them. Therefore, by applying the torque sensor 428a as a torque sensor of the actuator 430, more accurate detection of the generated torque and the external torque is realized.
  • the configuration of the actuator 430 corresponding to the ideal joint control as shown in FIGS. 3, 4A and 4B is, for example, Japanese Patent Application Publication Nos. 2009-269102 and 2011, which are prior patent applications by the applicant of the present application. No. 209099 can be referred to.
  • the schematic configuration of the robot arm apparatus 400 according to the present embodiment has been described above with reference to FIGS. 2, 3, 4 ⁇ / b> A and 4 ⁇ / b> B.
  • drive of the arm unit 420 in the robot arm apparatus 400 according to the present embodiment that is, whole body cooperative control and ideal joint control for controlling the drive of the joint units 421a to 421f will be described.
  • various operation spaces are formed in a multi-link structure (for example, the arm unit 420 shown in FIG. 2 in the present embodiment) configured by connecting a plurality of links by a plurality of joints.
  • the basic operation in the whole body coordinated control of a multilink structure which converts the motion purpose regarding various dimensions in) into torques to be generated in a plurality of relevant joints while considering various constraint conditions.
  • the operation space is an important concept in force control of a robot device.
  • the operation space is a space for describing the relationship between the force acting on the multilink structure and the acceleration of the multilink structure.
  • the operation space is, for example, a joint space, a Cartesian space, a momentum space or the like, which is a space to which the multilink structure belongs.
  • the exercise purpose represents a target value in drive control of the multilink structure, and is, for example, a target value such as position, velocity, acceleration, force, impedance, etc. of the multilink structure to be achieved by drive control.
  • the constraint conditions are constraints on the position, velocity, acceleration, force, and the like of the multilink structure, which are determined by the shape and structure of the multilink structure, the environment around the multilink structure, and settings by the user.
  • the constraint conditions include information on generated force, priority, presence / absence of non-drive joint, vertical reaction force, friction weight, support polygon and the like.
  • the computing algorithm is the first stage virtual force determination process (virtual force calculation process); It consists of a real power conversion process (real power calculation process) which is the second stage.
  • the virtual force which is a virtual force acting on the operation space, necessary for achieving each exercise purpose is taken into consideration while considering the priority of the exercise purpose and the maximum value of the imaginary force. decide.
  • the virtual force obtained above is used as the actual force such as joint force and external force, taking into consideration constraints on non-drive joints, vertical reaction forces, friction weights, support polygons, etc.
  • a vector constituted by certain physical quantities at each joint of the multilink structure is called a generalized variable q (also referred to as a joint value q or a joint space q).
  • the operation space x is defined by the following equation (1) using the time derivative value of the generalized variable q and the Jacobian J.
  • q is the rotation angle of the joint portions 421a to 421f of the arm portion 420.
  • equation (2) The equation of motion with respect to the operation space x is described by the following equation (2).
  • f represents a force acting on the operation space x.
  • ⁇ 1 is an operation space inertia inverse matrix
  • c is a operation space bias acceleration, which are expressed by the following equations (3) and (4), respectively.
  • H is a joint space inertia matrix
  • is a joint force corresponding to the joint value q (for example, generated torque at joints 421a to 421f)
  • b is a term representing gravity, Coriolis force, and centrifugal force.
  • the LCP can be solved using, for example, the Iterative method, Pivot method, a method applying robust acceleration control, or the like.
  • the operation space inertia inverse matrix ⁇ ⁇ 1 and the bias acceleration c have large calculation costs when calculated according to the equations (3) and (4), which are definition equations. Therefore, calculation processing of the operation space inertia inverse matrix ⁇ -1 is applied by applying quasi-dynamics calculation (FWD) to obtain generalized acceleration (joint acceleration) from generalized force (joint force ⁇ ) of multi-link structure
  • FWD quasi-dynamics calculation
  • the multi-link structure such as the joint space q, the joint force ⁇ , the gravity g, etc.
  • the movement purpose relating to the position and velocity of the operation space x can be expressed as a target value of the operation space acceleration, and is specifically expressed by the following equation (7) (position of the operation space x
  • the target value of the velocity is expressed by superposing the first derivative of x and x with a superscript bar).
  • the concept of the decomposition operation space it is also possible to set the exercise purpose regarding the operation space (momentum, Cartesian relative coordinates, interlocking joint, etc.) represented by the linear sum of other operation spaces.
  • the operation space momentum, Cartesian relative coordinates, interlocking joint, etc.
  • the LCP can be solved in order of priority and from low priority, and the virtual force obtained by the LCP in the previous stage can be applied as a known external force of the LCP in the next stage.
  • the suffix a represents a set of drive joints (drive joint set), and the suffix u represents a set of non-drive joints (non-drive joint). That is, the upper part of the equation (8) represents the balance of the force of the space (non-driven joint space) by the non-driven joint, and the lower part represents the balance of the force of the space (drive joint space) by the driven joint.
  • J vu and J va are respectively a non-driven joint component of Jacobian and a driven joint component related to the operation space on which the virtual force f v acts.
  • J eu and J ea are non-driven joint components and driving joint components of the Jacobian relating to the operation space in which the external force fe acts.
  • ⁇ f v represents a component of the virtual force f v that can not be realized by real force.
  • Equation (8) The upper part of the equation (8) is undefined.
  • fe and ⁇ f v can be obtained by solving a quadratic programming problem (QP) as shown in the following equation (9).
  • is the difference between the upper and lower sides of the equation (8) and represents the equation error of the equation (8).
  • is a connection vector of fe and ⁇ f v and represents a variable vector.
  • Q 1 and Q 2 are positive definite symmetric matrices that represent weights at minimization.
  • the inequality constraint of the equation (9) is used to express a constraint condition regarding an external force such as a vertical reaction force, a friction cone, a maximum value of an external force, a support polygon, and the like.
  • the inequality constraint relating to a rectangular support polygon is expressed as the following equation (10).
  • z represents the normal direction of the contact surface
  • x and y represent orthogonal two-tangent directions perpendicular to z.
  • (F x, F y, F z) and (M x, M y, M z) is the external force and external force moment acting on the contact point.
  • ⁇ t and ⁇ r are friction coefficients related to translation and rotation, respectively.
  • (D x , d y ) represents the size of the support polygon.
  • I a is the moment of inertia (inertia) at the joints
  • ⁇ a is the generated torque of the joints 421 a to 421 f
  • ⁇ e is the external torque acting on the joints 421 a to 421 f from the outside
  • ⁇ a is each joint It is a viscous drag coefficient at 421a to 421f.
  • the above equation (12) can also be said to be a theoretical model that represents the motion of the actuator 430 at the joints 421a to 421f.
  • an error may occur between the motions of the joint portions 421a to 421f and the theoretical model as shown in the above equation (12).
  • the modeling errors can be roughly classified into those due to mass properties such as weight, center of gravity, inertia tensor of multi-link structure, and causes due to friction, inertia, etc. inside joints 421 a to 421 f. .
  • the modeling error caused by the former mass property can be relatively easily reduced at the time of constructing a theoretical model by improving the accuracy of CAD (Computer Aided Design) data and applying the identification method.
  • modeling errors caused by friction, inertia, etc. in the latter joint portions 421a to 421f are caused by phenomena such as friction in the reduction gear 426 of the joint portions 421a to 421f, which are difficult to model.
  • a modeling error that can not be ignored during model construction may remain.
  • an error occurs between the value of inertia I a and viscosity resistance coefficient [nu a in the equation (12), and these values in the actual joints 421a ⁇ 421f.
  • the motions of the joint portions 421a to 421f may not respond according to the theoretical model shown in the above equation (12). Therefore, even when the real force ⁇ a , which is a joint force calculated by the generalized inverse dynamics, is applied, there may be a case where the exercise purpose which is the control target is not achieved.
  • the responses of the joint portions 421a to 421f are corrected to perform an ideal response according to the theoretical model shown in the above equation (12). Think about it.
  • ideal joint control is performed to control the drive of the joint unit so that the joint units 421a to 421f of the robot arm apparatus 400 perform an ideal response as shown in the above equation (12). It is called.
  • an actuator whose drive is controlled by the ideal joint control is also referred to as a virtualized actuator (VA) because an ideal response is performed.
  • VA virtualized actuator
  • FIG. 5 is an explanatory diagram for describing ideal joint control according to an embodiment of the present disclosure. Note that FIG. 5 schematically illustrates, in block form, a conceptual computing unit that performs various operations relating to ideal joint control.
  • the actuator 610 schematically represents a mechanism of the actuator 430 shown in FIG. 3, and includes a motor (Motor) 611, a reduction gear (Reduction Gear) 612, an encoder (Encoder) 613, and a torque sensor (Torque).
  • the Sensor) 614 corresponds to the motor 424, the reduction gear 426, the encoder 427, and the torque sensor 428 (or the torque sensor 428a shown in FIG. 4B) shown in FIG. 3, respectively.
  • the response of the actuator 610 according to the theoretical model represented by the equation (12) means that the rotational angular acceleration of the left side is achieved when the right side of the equation (12) is given. It is nothing but Further, as shown in the above equation (12), the theoretical model includes the external torque term ⁇ e acting on the actuator 610. In this embodiment, the external torque ⁇ e is measured by the torque sensor 614 in order to perform ideal joint control. Further, in order to calculate the estimated disturbance value tau d is an estimate of the torque due to the disturbance on the basis of the rotation angle q of the actuator 610 as measured by the encoder 613 applies a disturbance observer 620.
  • a block 631 represents a computing unit that performs computations according to the ideal joint model of the joints 421a to 421f shown in the equation (12).
  • a block 631 receives the generated torque ⁇ a , the external torque ⁇ e , and the rotational angular velocity (first derivative of the rotational angle q) as input, and outputs a rotational angular acceleration target value (rotational target value q ref shown on the left side of the equation (12) Second-order derivative) can be output.
  • the generated torque ⁇ a calculated by the method described in Generalized Inverse Dynamics and the external torque ⁇ e measured by the torque sensor 614 are input to a block 631.
  • the rotational angular velocity (first-order derivative of the rotational angle q) is calculated by inputting the rotational angle q measured by the encoder 613 to a block 632 representing an arithmetic unit that performs differential operation.
  • the rotation angle acceleration target value by the block 631 is calculated.
  • the calculated rotational angular acceleration target value is input to block 633.
  • Block 633 represents a computing unit that calculates the torque generated in the actuator 610 based on the rotational angular acceleration of the actuator 610.
  • the block 633 can obtain the torque target value ⁇ ref by multiplying the rotational angular acceleration target value by the nominal inertia (nominal inertia) J n of the actuator 610.
  • the desired motion purpose should be achieved by causing the actuator 610 to generate the torque target value ⁇ ref , but as described above, the actual response is affected by disturbances and the like.
  • the disturbance estimated value ⁇ d is calculated by the disturbance observer 620, and the torque target value ⁇ ref is corrected using the disturbance estimated value ⁇ d .
  • the disturbance observer 620 The configuration of the disturbance observer 620 will be described. As shown in FIG. 5, the disturbance observer 620, and the torque command value tau, based on the rotational angular velocities calculated from the rotation angle q measured by the encoder 613, and calculates the estimated disturbance value tau d.
  • the torque command value ⁇ is a torque value to be finally generated in the actuator 610 after the influence of the disturbance is corrected. For example, if the disturbance estimated value tau d is not calculated, the torque command value tau is the torque target value tau ref.
  • the disturbance observer 620 is composed of a block 634 and a block 635.
  • a block 634 represents a computing unit that calculates the torque generated in the actuator 610 based on the rotational angular velocity of the actuator 610.
  • the rotational angular velocity calculated by the block 632 is input to the block 634 from the rotational angle q measured by the encoder 613.
  • a block 634 performs a calculation represented by the transfer function J n s, that is, obtains a rotational angular acceleration by differentiating the rotational angular velocity, and further multiplies the calculated rotational angular acceleration by the nominal inertia J n.
  • the estimated value (torque estimated value) of the torque actually acting on the actuator 610 can be calculated.
  • the disturbance estimated value tau d is the value of the torque due to the disturbance is estimated.
  • the estimated disturbance value tau d is the torque command value tau before circumference of the control may be a difference between the estimated torque value in the present control.
  • the torque estimated value calculated by block 634 is based on the actual measured value, and the torque command value ⁇ calculated by block 633 is based on the ideal theoretical model of the joints 421a to 421f shown in block 631. Therefore, by taking the difference between the two, it is possible to estimate the influence of the disturbance which is not considered in the above theoretical model.
  • the disturbance observer 620 is provided with a low pass filter (LPF: Low Pass Filter) shown in block 635 in order to prevent the system from diverging.
  • LPF Low Pass Filter
  • the block 635 outputs only the low frequency component to the input value by performing the operation represented by the transfer function g / (s + g) to stabilize the system.
  • the difference between the estimated torque value calculated by block 634 and the torque command value ⁇ ref is input to block 635, and the low frequency component thereof is calculated as the estimated disturbance value ⁇ d .
  • a torque command value which is a torque value to be finally generated in the actuator 610 by performing feedforward control in which the disturbance estimated value ⁇ d calculated by the disturbance observer 620 is added to the torque target value ⁇ ref. ⁇ is calculated. Then, the actuator 610 is driven based on the torque command value ⁇ . Specifically, torque command value ⁇ is converted into a corresponding current value (current command value), and application of the current command value to motor 611 drives actuator 610.
  • the drive control of the joint portions 421 a to 421 f By taking the configuration described above with reference to FIG. 5, in the drive control of the joint portions 421 a to 421 f according to the present embodiment, even if there is a disturbance component such as friction, the response of the actuator 610 Can be made to follow the target value. Further, the drive control of the joint portion 421a ⁇ 421f, it is possible to perform an ideal response that theoretical models according to the assumed inertia I a and viscosity resistance coefficient [nu a.
  • the generalized inverse dynamics used in the present embodiment has been described above, and the ideal joint control according to the present embodiment has been described with reference to FIG.
  • the drive parameters of the joints 421a to 421f for example, the joints 421a to 421f
  • Whole-body coordinated control is performed in which the generated torque value is calculated in consideration of the constraint condition.
  • correction is performed in consideration of the influence of disturbance on the generated torque value calculated by whole body cooperative control using the above-mentioned generalized inverse dynamics.
  • FIG. 6 is a functional block diagram showing one configuration example of a robot arm control system according to an embodiment of the present disclosure.
  • the robot arm control system shown in FIG. 6 it has mainly shown in figure about the structure in connection with control of the drive of the arm part of a robot arm apparatus.
  • a robot arm control system 1 includes a robot arm device 10, a control device 20, and a display device 30.
  • the above-mentioned [2-2. Whole body coordinated control described in Generalized Inverse Dynamics and above] [2-3.
  • Various calculations in the ideal joint control described in [1. About ideal joint control] are performed, and the drive of the arm unit of the robot arm apparatus 10 is controlled based on the calculation result.
  • an imaging unit 140 described later is provided in an arm unit of the robot arm device 10, and an image captured by the imaging unit 140 is displayed on the display screen of the display device 30.
  • the configurations of the robot arm device 10, the control device 20, and the display device 30 will be described in detail.
  • the robot arm device 10 has an arm portion which is a multi-link structure composed of a plurality of joint portions and a plurality of links, and is provided at the tip of the arm portion by driving the arm portion within a movable range. Control the position and attitude of the tip unit.
  • the robot arm device 10 corresponds to the robot arm device 400 shown in FIG.
  • the robot arm apparatus 10 includes an arm control unit 110 and an arm unit 120.
  • the arm unit 120 also includes a joint unit 130 and an imaging unit 140.
  • the arm control unit 110 controls the robot arm apparatus 10 in an integrated manner and controls the drive of the arm unit 120.
  • the arm control unit 110 corresponds to the control unit (not shown in FIG. 2) described with reference to FIG.
  • the arm control unit 110 has a drive control unit 111, and the drive of the joint unit 130 is controlled by the control of the drive control unit 111, whereby the drive of the arm unit 120 is controlled.
  • the drive control unit 111 controls the number of rotations of the motor by controlling the amount of current supplied to the motor in the actuator of the joint unit 130, and the rotation angle and generation in the joint unit 130 Control the torque.
  • the drive control of the arm unit 120 by the drive control unit 111 is performed based on the calculation result in the control device 20. Therefore, the amount of current supplied to the motor in the actuator of the joint unit 130 controlled by the drive control unit 111 is the amount of current determined based on the calculation result in the control device 20.
  • the arm unit 120 is a multi-link structure composed of a plurality of joints and a plurality of links, and the drive thereof is controlled by the control of the arm control unit 110.
  • the arm unit 120 corresponds to the arm unit 420 shown in FIG.
  • the arm unit 120 has a joint unit 130 and an imaging unit 140.
  • the structure of one joint part 130 is shown in figure as a representative of these joint parts.
  • the joint unit 130 pivotally connects the links with each other in the arm unit 120, and drives the arm unit 120 by the control of its rotational drive under the control of the arm control unit 110.
  • the joint 130 corresponds to the joints 421a to 421f shown in FIG.
  • the joint unit 130 also has an actuator, and the configuration of the actuator is the same as that shown in FIGS. 3, 4A and 4B, for example.
  • the joint unit 130 includes a joint drive unit 131 and a joint state detection unit 132.
  • the joint drive unit 131 is a drive mechanism in an actuator of the joint unit 130, and the joint drive unit 131 drives the joint unit 130 to rotate.
  • the drive of the joint drive unit 131 is controlled by the drive control unit 111.
  • the joint drive unit 131 has a configuration corresponding to the motor 424 and the motor driver 425 shown in FIG. 3.
  • Driving of the joint drive unit 131 means that the motor driver 425 is a current according to the command from the drive control unit 111. It corresponds to driving the motor 424 by an amount.
  • the joint state detection unit 132 detects the state of the joint unit 130.
  • the state of the joint unit 130 may mean the state of movement of the joint unit 130.
  • the state of the joint unit 130 includes information such as the rotational angle, rotational angular velocity, rotational angular acceleration, and generated torque of the joint unit 130.
  • the joint state detection unit 132 has a rotation angle detection unit 133 that detects the rotation angle of the joint unit 130 and a torque detection unit 134 that detects the generated torque and the external torque of the joint unit 130.
  • the rotation angle detection unit 133 and the torque detection unit 134 correspond to the encoder 427 of the actuator 430 shown in FIG. 3 and the torque sensors 428 and 428a shown in FIGS. 4A and 4B, respectively.
  • the joint state detection unit 132 transmits the detected state of the joint unit 130 to the control device 20.
  • the imaging unit 140 is an example of a tip unit provided at the tip of the arm unit 120, and acquires an image of an imaging target.
  • the imaging unit 140 corresponds to the imaging unit 423 shown in FIG.
  • the imaging unit 140 is a camera or the like that can capture a shooting target in the form of a moving image or a still image.
  • the imaging unit 140 has a plurality of light receiving elements arranged in two dimensions, and can obtain an image signal representing an image to be photographed by photoelectric conversion in the light receiving elements.
  • the imaging unit 140 transmits the acquired image signal to the display device 30.
  • the imaging unit 42 is actually provided at the tip of the arm section 120 in the robot arm apparatus 10 as in the case where the imaging unit 423 is provided at the tip of the arm section 420.
  • a link is schematically illustrated between the joint unit 130 and the imaging unit 140 in which the imaging unit 140 is provided at the tip of the final link via the plurality of joint units 130 and the plurality of links. It is expressed by.
  • various medical instruments can be connected to the tip of the arm unit 120 as a tip unit.
  • the medical instrument include various treatment instruments such as a scalpel and forceps, and units of various inspection apparatuses such as a probe of an ultrasonic examination apparatus, and various units used in the treatment.
  • the imaging unit 140 shown in FIG. 6 and a unit having an imaging function such as an endoscope or a microscope may be included in the medical instrument.
  • the robot arm apparatus 10 according to the present embodiment is a medical robot arm apparatus provided with a medical instrument.
  • the robot arm control system 1 according to the present embodiment is a medical robot arm control system.
  • a robot arm apparatus for a video microscope provided with a unit having an imaging function as a tip unit.
  • a stereo camera having two imaging units may be provided at the tip of the arm unit 120, and imaging may be performed so as to display an imaging target as a 3D image.
  • the control device 20 includes an input unit 210, a storage unit 220, and a control unit 230.
  • the control unit 230 integrally controls the control device 20 and performs various calculations for controlling the drive of the arm unit 120 in the robot arm apparatus 10. Specifically, in order to control driving of the arm unit 120 of the robot arm apparatus 10, the control unit 230 performs various calculations in whole body cooperative control and ideal joint control.
  • the function and configuration of the control unit 230 will be described in detail, the whole body coordinated control and the ideal joint control will be described in the above [2-2. About generalized inverse dynamics] and the above [2-3. Since the ideal joint control has already been described, the detailed description is omitted here.
  • the control unit 230 includes a whole body coordination control unit 240 and an ideal joint control unit 250.
  • the whole body coordination control unit 240 performs various operations related to whole body coordination control using generalized inverse dynamics.
  • the whole-body coordination control unit 240 acquires the state (arm state) of the arm unit 120 based on the state of the joint unit 130 detected by the joint state detection unit 132.
  • the whole-body coordination control unit 240 generalizes the control value for whole-body coordination control of the arm unit 120 in the operation space based on the arm state and the exercise purpose and restraint condition of the arm unit 120. Calculated using The operation space is, for example, a space for describing the relationship between the force acting on the arm unit 120 and the acceleration generated in the arm unit 120.
  • the whole body coordination control unit 240 includes an arm state acquisition unit 241, a calculation condition setting unit 242, a virtual force calculation unit 243, and an actual force calculation unit 244.
  • the arm state acquisition unit 241 acquires the state (arm state) of the arm unit 120 based on the state of the joint unit 130 detected by the joint state detection unit 132.
  • the arm state may mean the state of movement of the arm unit 120.
  • the arm state includes information such as the position, velocity, acceleration, and force of the arm unit 120.
  • the joint state detection unit 132 acquires, as the state of the joint unit 130, information such as the rotation angle, the rotation angular velocity, the rotation angular acceleration, and the generated torque in each joint unit 130.
  • the storage unit 220 stores various types of information processed by the control device 20. In the present embodiment, the storage unit 220 stores various types of information (arm information on the arm unit 120).
  • the arm state acquisition unit 241 can acquire the arm information from the storage unit 220. Therefore, based on the state of the joint unit 130 and the arm information, the arm state acquisition unit 241 determines the positions (coordinates) of the plurality of joint units 130, the plurality of links, and the imaging unit 140 in space (that is, Information such as the shape, the position and orientation of the imaging unit 140, and the forces acting on each joint unit 130, link, and imaging unit 140 can be acquired as an arm state.
  • the arm state acquisition unit 241 transmits the acquired arm information to the calculation condition setting unit 242.
  • the calculation condition setting unit 242 sets calculation conditions in calculation related to whole-body cooperative control using generalized inverse dynamics.
  • the calculation condition may be an exercise purpose and a constraint condition.
  • the exercise purpose may be various types of information regarding the movement of the arm unit 120.
  • the exercise purpose is the position and orientation (coordinates) of the imaging unit 140, target values such as velocity, acceleration, and force, or the positions (coordinates of the plurality of joint units 130 of the arm unit 120 and the plurality of links And may be target values such as speed, acceleration, and force.
  • the constraint condition may be various types of information that restricts (restrains) the motion of the arm unit 120.
  • the constraint condition may be coordinates of a region in which each component of the arm portion can not move, a velocity that can not move, a value of acceleration, a value of a force that can not be generated, or the like.
  • the restriction ranges of various physical quantities under the constraint conditions may be set because it is impossible to structurally realize the arm unit 120, or may be set appropriately by the user.
  • the calculation condition setting unit 242 may be a physical model of the structure of the arm unit 120 (for example, the number and length of links constituting the arm unit 120, connection status via the joint unit 130 of the link, movement of the joint unit 130).
  • the motion condition and the constraint condition may be set by generating a control model in which the range etc. is modeled and the desired motion condition and the constraint condition are reflected in the physical model.
  • the arm unit 120 it is possible to cause the arm unit 120 to perform a desired operation by appropriately setting the exercise purpose and the restraint condition. For example, by setting a target value of the position of the imaging unit 140 as an exercise purpose, it goes without saying that the imaging unit 140 is moved to the target position, but the arm unit 120 does not intrude into a predetermined area in space. It is also possible to drive the arm unit 120 by providing a movement constraint according to the constraint condition, such as.
  • the purpose of exercise is that the imaging unit 140 moves in the plane of a cone with the treatment site at the top with the imaging direction of the imaging unit 140 fixed to the treatment site. It may be a pivoting operation which is a pivoting operation with the axis as a pivoting axis. Further, in the pivoting operation, the turning operation may be performed in a state in which the distance between the imaging unit 140 and the point corresponding to the apex of the cone is kept constant. By performing such pivoting, the observation site can be observed from an equal distance and at different angles, so that the convenience of the user who performs the surgery can be improved.
  • the exercise purpose may be to control the generated torque in each joint unit 130.
  • the movement purpose controls the state of the joint unit 130 so as to cancel the gravity acting on the arm unit 120, and further supports the movement of the arm unit 120 in the direction of the externally applied force.
  • It may be a power assist operation that controls the state of the joint unit 130. More specifically, in the power assist operation, the drive of each joint unit 130 is controlled so that each joint unit 130 generates a generation torque that cancels the external torque due to gravity in each joint unit 130 of the arm unit 120. Thus, the position and posture of the arm unit 120 are held in a predetermined state.
  • each joint unit 130 is controlled to generate generated torque in each joint unit 130 in the same direction as the applied external torque.
  • Ru By performing such a power assist operation, when the user manually moves the arm unit 120, the user can move the arm unit 120 with a smaller force, so as to move the arm unit 120 under weightlessness It can give the user a sense of presence. Moreover, it is also possible to combine the pivoting operation described above and the power assist operation.
  • the term “exercise purpose” may mean the movement (exercise) of the arm unit 120 realized in the whole-body coordinated control, or the instantaneous exercise purpose in the movement (ie, the exercise purpose). It may mean the target value in
  • the imaging unit 140 itself performs the pivoting movement for exercise purpose, but while the pivoting operation is performed, the imaging unit 140 in the conical surface in the pivoting operation is The values such as the position and the speed are set as an instantaneous exercise purpose (a target value for the exercise purpose).
  • performing the power assist operation to support the movement of the arm unit 120 in the direction of the externally applied force is the exercise purpose itself, but the power assist operation is performed.
  • the value of the generated torque in the same direction as the external torque applied to each joint 130 is set as an instantaneous exercise purpose (a target value for the exercise purpose).
  • the exercise purpose in the present embodiment is continuously achieved with an instantaneous exercise purpose (for example, a target value of position, velocity, force, etc. of each component of the arm unit 120 at a certain time) and an instantaneous exercise purpose.
  • an instantaneous exercise purpose for example, a target value of position, velocity, force, etc. of each component of the arm unit 120 at a certain time
  • an instantaneous exercise purpose is set each time, and the desired exercise purpose is finally achieved by repeatedly performing the calculation.
  • the viscous drag coefficient in the rotational movement of each joint unit 130 may be appropriately set.
  • the joint unit 130 according to the present embodiment is configured such that the viscous drag coefficient in the rotational movement of the actuator 430 can be appropriately adjusted. Therefore, by setting the viscous drag coefficient in the rotational movement of each joint unit 130 when setting the purpose of exercise, it is possible to realize, for example, a state in which rotation is easy or a state in which rotation is difficult with respect to externally applied force.
  • the viscous drag coefficient at the joint unit 130 is set small, so that the force required for the user to move the arm unit 120 may be smaller, and the weightlessness given to the user is Promoted more.
  • the viscous drag coefficient in the rotational movement of each joint unit 130 may be appropriately set according to the content of the purpose of the movement.
  • the storage unit 220 may store parameters regarding calculation conditions such as exercise purpose and restraint conditions used in calculations regarding whole-body coordinated control.
  • the calculation condition setting unit 242 can set the restriction condition stored in the storage unit 220 as a restriction condition used for the calculation of the whole-body coordinated control.
  • the calculation condition setting unit 242 can set the exercise purpose by a plurality of methods.
  • the calculation condition setting unit 242 may set the exercise purpose based on the arm state transmitted from the arm state acquisition unit 241.
  • the arm state includes information on the position of the arm unit 120 and information on the force acting on the arm unit 120. Therefore, for example, when the user is trying to move the arm unit 120 manually, the arm state acquisition unit 241 also acquires information on how the user is moving the arm unit 120 as an arm state. Ru. Therefore, based on the acquired arm state, the calculation condition setting unit 242 can set the position, the speed, the force, and the like at which the user moved the arm unit 120 as an instantaneous exercise purpose. By thus setting the exercise purpose, the drive of the arm unit 120 is controlled to follow and support the movement of the arm unit 120 by the user.
  • the calculation condition setting unit 242 may set an exercise purpose based on an instruction input by the user from the input unit 210.
  • the input unit 210 is an input interface for the user to input information, commands and the like related to drive control of the robot arm apparatus 10 to the control device 20.
  • the input unit 210 from the user The exercise purpose may be set based on the operation input.
  • the input unit 210 has, for example, operation means operated by the user, such as a lever and a pedal, and the positions, speeds, and the like of the respective constituent members of the arm unit 120 correspond to the operation of the lever and the pedal.
  • And may be set by the calculation condition setting unit 242 as an instantaneous exercise purpose.
  • the calculation condition setting unit 242 may set the exercise purpose stored in the storage unit 220 as the exercise purpose used for the calculation of the whole-body coordinated control. For example, if it is an exercise purpose that the imaging unit 140 is stopped at a predetermined point in space, the coordinates of the predetermined point can be set in advance as the exercise purpose. Also, for example, in the case of an exercise purpose where the imaging unit 140 moves on a predetermined trajectory in space, the coordinates of each point representing the predetermined trajectory can be set in advance as the exercise purpose. As described above, when the exercise purpose can be set in advance, the exercise purpose may be stored in the storage unit 220 in advance.
  • the movement purpose is limited to the position or velocity in the plane of the cone as the target value
  • the movement purpose is the force as the target value Limited to
  • the information on the range, the type, and the like of the target value that can be set as the instantaneous exercise purpose in these exercise purposes is It may be stored in the storage unit 220.
  • the calculation condition setting unit 242 can set various kinds of information regarding such exercise purpose as the exercise purpose.
  • the calculation condition setting unit 242 may be able to appropriately set by the user according to the application of the robot arm apparatus 10 or the like by which method the exercise purpose is set.
  • the calculation condition setting unit 242 may also set the exercise purpose and the restraint condition by appropriately combining the above-described methods.
  • the priority of the exercise purpose may be set in the constraint conditions stored in the storage unit 220, and when there are a plurality of different exercise goals, the calculation condition setting unit 242 determines the constraint The exercise purpose may be set according to the priority of the condition.
  • the calculation condition setting unit 242 transmits the arm state and the set exercise purpose and restraint condition to the virtual force calculation unit 243.
  • the virtual force calculation unit 243 calculates a virtual force in an operation related to whole-body cooperative control using generalized inverse dynamics.
  • the calculation process of the virtual force performed by the virtual force calculation unit 243 may be, for example, a series of processes described in the above (2-2-1 virtual force calculation process).
  • the virtual force calculation unit 243 transmits the calculated virtual force f v to the real force calculation unit 244.
  • the real force calculation unit 244 calculates real force in calculation relating to whole-body coordinated control using generalized inverse dynamics.
  • the calculation process of the real force performed by the real force calculation unit 244 may be, for example, the series of processes described in the above (2-2-2. Real force calculation process).
  • the real force calculation unit 244 transmits the calculated real force (generated torque) ⁇ a to the ideal joint control unit 250.
  • the torque generated tau a calculated by actual force calculation section 244 in the sense that the control value of the joint portion 130 in the systemic cooperative control, also referred to as the control value or the control torque value.
  • the ideal joint control unit 250 performs various operations related to ideal joint control using generalized inverse dynamics.
  • the ideal joint control unit 250 corrects the influence of the disturbance with respect to the generated torque ⁇ a calculated by the actual force calculation unit 244, thereby realizing a torque command that realizes an ideal response of the arm unit 120. Calculate the value ⁇ .
  • the calculation processing performed by the ideal joint control unit 250 is the same as that described in the above [2-3. It corresponds to a series of processing described in [About ideal joint control].
  • the ideal joint control unit 250 includes a disturbance estimation unit 251 and a command value calculation unit 252.
  • Disturbance estimation section 251 and the torque command value tau based on the rotational angular velocities calculated from the rotation angle q detected by the rotation angle detecting unit 133 calculates an estimated disturbance value tau d.
  • the torque command value ⁇ mentioned here is a command value that represents the generated torque at the arm unit 120 that is ultimately transmitted to the robot arm device 10.
  • the disturbance estimation unit 251 has a function corresponding to the disturbance observer 620 shown in FIG.
  • the command value calculation unit 252 uses the disturbance estimated value ⁇ d calculated by the disturbance estimation unit 251 to finally generate a torque command that is a command value representing a torque to be generated in the arm unit 120 and transmitted to the robot arm apparatus 10. Calculate the value ⁇ . Specifically, the command value calculation unit 252 adds the disturbance estimated value ⁇ d calculated by the disturbance estimation unit 251 to ⁇ ref calculated from the ideal model of the joint unit 130 shown in the equation (12). The torque command value ⁇ is calculated. For example, if the disturbance estimated value tau d is not calculated, the torque command value tau is the torque target value tau ref. As described above, the function of the command value calculation unit 252 corresponds to the function other than the disturbance observer 620 shown in FIG.
  • the information is repeatedly exchanged between the disturbance estimation unit 251 and the command value calculation unit 252, whereby the series of processes described with reference to FIG. To be done.
  • the ideal joint control unit 250 transmits the calculated torque command value ⁇ to the drive control unit 111 of the robot arm device 10.
  • the drive control unit 111 controls the number of rotations of the motor by controlling the supply of the current amount corresponding to the transmitted torque command value ⁇ to the motor in the actuator of the joint unit 130. Control the rotation angle and generated torque at
  • the drive control of the arm unit 120 in the robot arm apparatus 10 is continuously performed while the work using the arm unit 120 is performed. And the processing described above in the control device 20 is repeatedly performed. That is, the state of the joint unit 130 is detected by the joint state detection unit 132 of the robot arm device 10 and transmitted to the control device 20.
  • various calculations related to whole-body coordinated control and ideal joint control for controlling the drive of the arm unit 120 are performed based on the state of the joint unit 130 and the exercise purpose and restraint condition, and the calculation result
  • the torque command value ⁇ as is transmitted to the robot arm device 10.
  • the drive of the arm unit 120 is controlled based on the torque command value ⁇ , and the state of the joint unit 130 during or after driving is detected again by the joint state detection unit 132.
  • the input unit 210 is an input interface for the user to input information, commands, and the like related to drive control of the robot arm apparatus 10 to the control device 20.
  • the drive of the arm unit 120 of the robot arm apparatus 10 may be controlled based on the operation input from the input unit 210 by the user, and the position and orientation of the imaging unit 140 may be controlled.
  • the instruction condition setting unit 242 inputs instruction information related to an instruction for driving the arm input from the input unit 210 by the user to the operation condition setting unit 242, so that the operation condition setting unit 242 generates the instruction information.
  • the exercise purpose in whole body coordinated control may be set based on it. As described above, the whole body cooperative control is performed using the exercise purpose based on the instruction information input by the user, whereby the driving of the arm unit 120 according to the user's operation input is realized.
  • the input unit 210 includes operation means operated by the user, such as a mouse, a keyboard, a touch panel, a button, a switch, a lever, and a pedal.
  • operation means operated by the user such as a mouse, a keyboard, a touch panel, a button, a switch, a lever, and a pedal.
  • the user can control the driving of the arm unit 120 by operating the pedal with the foot. Therefore, even when the user performs treatment with both hands on the treatment site of the patient, the position and posture of the imaging unit 140 by the operation of the pedal with the foot, that is, the imaging position and imaging angle of the treatment site Can be adjusted.
  • the storage unit 220 stores various types of information processed by the control device 20.
  • the storage unit 220 can store various parameters used in the calculation regarding the whole body cooperative control and the ideal joint control performed by the control unit 230.
  • the storage unit 220 may store the exercise purpose and the constraint condition used in the calculation regarding the whole body coordination control by the whole body coordination controller 240.
  • the exercise purpose stored in the storage unit 220 may be, as described above, an exercise purpose that may be preset, such as, for example, the imaging unit 140 being stopped at a predetermined point in space.
  • the constraint conditions may be preset by the user and stored in the storage unit 220 according to the geometric configuration of the arm unit 120, the application of the robot arm apparatus 10, and the like.
  • the storage unit 220 may also store various types of information regarding the arm unit 120 used when the arm state acquisition unit 241 acquires the arm state. Furthermore, the storage unit 220 may store the calculation result in the calculation regarding the whole body cooperative control and the ideal joint control by the control unit 230, each numerical value calculated in the calculation process, and the like. As described above, the storage unit 220 may store all the parameters related to various processes performed by the control unit 230. The control unit 230 performs various processes while mutually exchanging information with the storage unit 220. be able to.
  • control device 20 The function and configuration of the control device 20 have been described above.
  • the control device 20 according to the present embodiment can be configured by, for example, various information processing devices (arithmetic processing devices) such as a PC (Personal Computer) and a server.
  • various information processing devices such as a PC (Personal Computer) and a server.
  • PC Personal Computer
  • display device 30 Next, the function and configuration of the display device 30 will be described.
  • the display device 30 visually notifies the user of the information by displaying various information on the display screen in various formats such as texts and images.
  • the display device 30 displays an image captured by the imaging unit 140 of the robot arm device 10 on the display screen.
  • the display device 30 performs an image signal processing unit (not shown) that performs various image processing on the image signal acquired by the imaging unit 140, and an image based on the processed image signal on the display screen. It has the function and configuration of a display control unit (not shown) that performs control to display.
  • the display device 30 may have various functions and configurations that the display device generally has, in addition to the functions and configurations described above.
  • the display device 30 corresponds to the display device 550 shown in FIG.
  • each component described above may be configured using a general-purpose member or circuit, or may be configured by hardware specialized for the function of each component. Further, all functions of each component may be performed by a CPU or the like. Therefore, it is possible to change the configuration to be used as appropriate according to the technical level at which the present embodiment is implemented.
  • the arm unit 120 which is the multi-link structure in the robot arm device 10 has at least six degrees of freedom or more, and a plurality of arm units 120 constituting the arm unit 120.
  • the drive control unit 111 controls the drive of each of the joint units 130.
  • a medical instrument is provided at the tip of the arm 120.
  • the drive control of the arm unit 120 with a higher degree of freedom is realized, and the medical robot arm device 10 with higher operability for the user is realized. .
  • the state of the joint unit 130 is detected by the joint state detection unit 132.
  • various calculations related to whole-body cooperative control using generalized inverse dynamics for controlling the drive of the arm unit 120 based on the state of the joint unit 130 and the exercise purpose and the constraint condition. Is performed to calculate a torque command value .tau.
  • the drive of the arm unit 120 is controlled based on the torque command value ⁇ .
  • the drive of the arm unit 120 is controlled by whole-body coordinated control using generalized inverse dynamics.
  • ideal joint control is applied together with whole-body cooperative control.
  • disturbance components such as friction and inertia inside the joint unit 130 are estimated, and feedforward control using the estimated disturbance components is performed. Therefore, even when there is a disturbance component such as friction, an ideal response can be realized for the drive of the joint unit 130. Therefore, in the drive control of the arm unit 120, highly accurate response and high positioning accuracy and stability with less influence of vibration and the like are realized.
  • each of the plurality of joint units 130 constituting the arm unit 120 has a configuration adapted to the ideal joint control as shown in, for example, FIG.
  • the generated torque and the viscous drag coefficient can be controlled by the current value.
  • the drive of each joint unit 130 is controlled by the current value, and the drive of each joint unit 130 is controlled while grasping the entire state of the arm unit 120 by the whole body coordinated control, so that the counterbalance becomes unnecessary.
  • the miniaturization of the robot arm device 10 is realized.
  • the power assist operation controls the state of the joint unit 130 so as to cancel the gravity acting on the arm unit 120, and further supports the movement of the arm unit 120 in the direction of the externally applied force.
  • the externally applied external torque is detected by the torque detection unit 134 and is generated in the same direction as the detected additional external torque.
  • An instantaneous exercise objective of causing torque to be generated in each joint 130 is further set.
  • the power assist operation is realized by controlling the drive of each joint unit 130 in accordance with such an instantaneous exercise purpose.
  • the power assist operation allows the user to move the arm portion with a smaller force, so that a feeling as if the arm portion 120 is being moved under weightlessness can be obtained, and the operability of the arm portion 120 by the user is improved. improves.
  • the tip unit provided at the tip of the arm unit 120 moves on the surface of a cone with the predetermined point at the top, with the direction of the tip unit fixed at the predetermined point in space.
  • the pivoting operation is the pivoting axis of the cone.
  • the imaging unit 140 provided at the tip of the arm unit 120 has the imaging direction of the imaging unit 140 fixed at a predetermined point in space. In the state, it is a pivoting motion with the axis of the cone as a pivot axis, which moves on the surface of the cone with the predetermined point as the apex.
  • a treatment site is selected as a point that hits the apex of the cone in the pivoting motion.
  • the pivoting operation may be performed in a state in which the distance between the tip unit or the imaging unit 140 and the point on the apex of the cone is kept constant.
  • the pivoting operation is also referred to as a point locking operation.
  • control of the arm unit 120 according to the speed according to the present embodiment will be described.
  • a power assist type robot arm powered by a motor For example, when the operator applies an excessive force to the robot arm to operate the robot arm, it is conceivable that the robot arm generates an excessive speed to lower the safety.
  • the robot arm vibrates and the operability decreases.
  • operability and safety are improved by changing control parameters for controlling the arm unit 120 according to the speed at which the arm unit 120 is operated.
  • the actuator 430 of each of the joint portions 421a to 421f includes the motor 424, the motor driver 425, the reduction gear 426, the encoder 427, the torque sensor 428, and the drive shaft 429. Therefore, the arm unit 120 can detect an external force by the torque sensor 428 of each of the joint units 421a to 421f. The operator holds the tip or other portion of the arm 120 and applies an operation force to generate angular acceleration in each of the joints 421a to 421f and move it to an appropriate position.
  • the control device 30 calculates the angular velocity, angular acceleration, and joint torque value of each joint 421a-421f by operating each joint 421a-421f from the given operation force. Then, a target joint angular acceleration (a second order differential value of q, q is a rotation angle of the joint portions 421 a to 421 f of the arm portion 420) is calculated from the above-mentioned equation (12).
  • q is the joint angle
  • the first derivative of q is the joint angular velocity
  • the second derivative of q is the joint angular acceleration
  • ⁇ a is the torque that the joint should generate
  • ⁇ e is the joint
  • I represents the inertia moment (inertia) of the joint
  • a a represents the viscous drag coefficient of the joint.
  • the moment of inertia I and the viscous drag coefficient a a represent the dynamic characteristics of the joint.
  • the moment of inertia I is a value indicating how easy it is to move with respect to the acceleration.
  • Viscous resistance coefficient [nu a is a parameter for the speed
  • the term viscous resistance coefficient [nu a are the terms of the negative in Equation (12) (negative)
  • increasing the viscosity resistance coefficient [nu a joint 421a ⁇ 421f is It becomes harder to move.
  • the control device 30 sends a command value to each actuator 430 of the arm unit 120 to operate so as to realize the target joint angular acceleration (second derivative value of q) obtained from Expression (12), and the operation by the user ends. Repeat the control loop.
  • the joint portion is in a stationary state.
  • FIG. 7 is a schematic view showing a configuration in which a configuration for realizing control according to the operation speed is added to the configuration of FIG.
  • an operating force control unit (parameter control unit) 260 is added to the configuration of FIG. 6.
  • the operation force control unit 260 includes an inertia moment control unit 262 and a viscous drag coefficient control unit 264.
  • the arm state acquisition unit 241 acquires the state (arm state) of the arm unit 120 based on the state of the joint unit 130 detected by the joint state detection unit 132.
  • the arm state includes information such as the position, velocity, acceleration, and force of the arm unit 120. Therefore, the arm state acquisition unit 241 can acquire parameters related to the operation of the arm unit 120 by the user.
  • the moment of inertia control unit 262 uses the mathematical equation (1st-order derivative of the rotation angle q) or the hand speed of the arm (first-order derivative of the hand position) calculated from the rotation angle q measured by the encoder 613. Calculate the moment of inertia I of 12).
  • the viscous drag coefficient control unit 264 is based on the rotational angular velocity (first derivative of the rotational angle q) calculated from the rotational angle q measured by the encoder 613 or the hand velocity of the arm (first derivative of the hand position). Then, the viscous drag coefficient a a of equation (12) is calculated.
  • the actual force calculation unit 244 transmits the calculated actual force (generated torque) ⁇ a to the ideal joint control unit 250.
  • the rotational angular velocity (first-order derivative of the rotational angle q) is input by inputting the rotational angle q measured by the encoder 613 in block 632 Is calculated. Then, in addition to the generated torque ⁇ a and the external torque ⁇ e, the rotational angular velocity is input to the block 631 so that the rotational angular acceleration target value (second derivative of the rotational angle q) is calculated from the equation (12) by the block 631 Ru.
  • the command value calculation unit 252 can obtain the torque target value ⁇ ref by multiplying the calculated rotational angular acceleration target value by the nominal inertia J n of the actuator 610.
  • the command value calculation unit 252 feeds back the calculated rotational angular acceleration target value for calculation of the rotational angular velocity.
  • a torque command that is a torque value to be generated in actuator 610 by adding disturbance estimated value ⁇ d to torque target value ⁇ ref obtained from the rotational angular acceleration target value.
  • the value ⁇ is calculated.
  • the torque command value ⁇ is input to the block 636 in FIG. 5 and is fed back to the rotation angle q, and the rotation angle q is input to the block 632 to calculate the rotation angular velocity.
  • FIG. 8 is a schematic view showing an example of a map used when the viscous drag coefficient control unit 264 calculates the viscous drag coefficient v a .
  • the map is defined such that the viscous drag coefficient a a increases as the rotational angular velocity (first derivative of the rotational angle q) increases. Therefore, when the operator applies an excessive force to the arm portion 120 to operate, since the rotational angular velocity is high, the viscous drag coefficient a a is set sufficiently large.
  • the map may be defined such that the viscous drag coefficient a a decreases as the rotational angular velocity (first derivative of the rotational angle q) increases.
  • FIG. 9 is a schematic view showing an example of a map used when the inertia moment control unit 262 calculates the inertia moment I.
  • the movement start of the actuator is difficult to move if the moment of inertia is large, so as shown by the characteristics of the solid line in FIG. 9, in the region where the rotation angular velocity is smaller than a predetermined value, the value of inertia moment I increases with the increase of the rotation angular velocity Do.
  • the characteristics of such a map when the operator operates the arm unit 120, the rotational angular velocity is small immediately after the operation is started, so the value of the moment of inertia I is set to a small value.
  • the feeling of operation of the arm portion 120 immediately after the start of the operation is lightened, and the arm portion 120 can be smoothly moved immediately after the start of the operation. Therefore, according to the map of FIG. 9, it is possible to smooth the operation feeling of the movement of the arm unit 120, and it is possible to stably move the arm unit 120 after the movement of the arm unit 120.
  • the map may be defined such that the moment of inertia I decreases as the rotational angular velocity (first derivative of the rotational angle q) increases. Further, the map may be defined to increase or decrease the moment of inertia when the arm unit 120 starts or stops operation.
  • the moment of inertia I may be a constant value regardless of the rotational angular velocity.
  • FIG. 10 is a schematic view showing a map used when the arm unit 120 is stopped, and is a schematic view showing a relationship between the passage of time during the operation of the arm unit 120 and the viscous drag coefficient a a . is there.
  • control is performed so that the viscous drag coefficient aa increases immediately before time t0 when the arm unit 120 stops.
  • the viscous drag coefficient aa is increased to perform deceleration, and the vibration of the arm 120 due to the quick stop can be suppressed. it can.
  • the same control can be performed also at the time of stop generally other than the stop by a brake.
  • FIG. 11 is a flow chart showing a processing procedure of a robot arm control method according to an embodiment of the present disclosure.
  • the robot arm control method according to the present embodiment is realized by the configuration of the robot arm control system 1 shown in FIG. 6 as an example. Therefore, it can be said that the robot arm control method according to the present embodiment is a medical robot arm control method.
  • the functions of the components of the robot arm control system 1 shown in FIG. Since the configuration of the robot arm control system has already been described, the detailed description will be omitted.
  • the joint state detection unit 132 first detects the state of the joint unit 130 in step S801.
  • the state of the joint unit 130 is, for example, a rotation angle at the joint unit 130, a generated torque, and / or an external torque.
  • the arm state acquisition unit 241 acquires an arm state based on the state of the joint unit 130 detected in step S801.
  • the arm state refers to the state of motion of the arm unit 120, and may be, for example, the position, velocity, acceleration, or force acting on each component of the arm unit 120.
  • step S805 based on the arm state acquired in step S803, the operation condition setting unit 242 sets an exercise purpose and a constraint condition used in the calculation in the whole-body coordinated control.
  • the calculation condition setting unit 242 does not have to set the exercise purpose based on the arm state, and for example, sets the exercise purpose based on the instruction information on the drive of the arm unit 120 input by the user from the input unit 210
  • the exercise purpose stored in advance in the storage unit 220 may be used. Furthermore, the exercise purpose may be set by appropriately combining the above-described methods.
  • the calculation condition setting unit 242 may use a constraint condition stored in advance in the storage unit 220.
  • step S 807 based on the arm state, the exercise purpose, and the restraint condition, calculation for whole-body coordinated control using generalized inverse dynamics is performed, and the control value ⁇ a is calculated.
  • the process performed in step S 807 is a series of processes in virtual force calculating unit 243 and actual force calculating unit 244 shown in FIG. 6, that is, the above [2-2. It may be a series of processing explained about the generalized inverse dynamics.
  • step S809 the calculated disturbance estimated value tau d is, by using the estimated disturbance value tau d, calculation of ideal joint control is performed, the command value tau is calculated from the control value tau a.
  • the process performed in step S809 is a series of processes in the ideal joint control unit 250 shown in FIG. It may be a series of processing described in [for ideal joint control].
  • step S811 the drive control unit 111 controls the drive of the joint unit 130 based on the command value ⁇ .
  • FIG. 11 is a flowchart showing a process of controlling the viscosity in accordance with the operation speed.
  • the operability and safety of the arm unit 120 are improved by controlling the inertia moment I (inertia of the joint) and the viscous drag coefficient a a (viscous resistance of the joint) according to the operation speed.
  • step S10 the operation force is applied to the arm unit 120 by the operator.
  • step S12 the rotational angular velocity of the joint is calculated based on the arm state.
  • step S14 based on the rotational angular velocity calculated in step S12, an inertia moment I (inertia) and a viscous drag coefficient a a are calculated.
  • the moment of inertia I and the viscous drag coefficient a a are calculated by the moment of inertia control unit 262 and the viscous drag coefficient control unit 264.
  • the rotational angular acceleration target value is calculated by applying the moment of inertia I and the viscous drag coefficient aa calculated in step S14 based on the equation (12).
  • a command to the arm unit 120 is issued based on the rotational angular acceleration target value. Specifically, torque target value ⁇ ref is calculated from the rotational angular acceleration target value, torque command value ⁇ is calculated by correcting with estimated disturbance value ⁇ d , and a command to arm unit 120 is calculated by torque command value ⁇ . Do.
  • step S20 it is determined whether or not the operation by the operator has ended. If the operation has not ended, the process returns to step S12, and the subsequent processing is continued. On the other hand, if it is determined in step S20 that the operation has ended, the process ends.
  • an unnecessary component related to torque may be present.
  • cogging torque may be present as an unnecessary component in the motor 424.
  • the torque sensor 428 may cause torque unevenness as the drive shaft 429 rotates.
  • an unnecessary component may occur in the torque of the motor 424 due to the current ripple.
  • FIG. 11 is a characteristic diagram showing the cogging torque (dotted line) of the motor 424 and the torque (solid line) when the cogging torque is canceled. As shown in FIG. 11, it is possible to reliably suppress the torque fluctuation by canceling the cogging torque (broken line). Similarly, with respect to the other unnecessary components, the torque of the unnecessary component is acquired in advance, and the torque is generated so as to cancel the acquired torque of the unnecessary component. Thereby, it becomes possible to remove the torque of an unnecessary component and to perform smoother operation.
  • the command value calculation unit 252 can perform the removal of the unnecessary component torque.
  • the command value calculation unit 252 corrects the calculated torque command value ⁇ with a torque that cancels out the torque of the unnecessary component acquired in advance, and outputs a torque target value from which the torque of the unnecessary component is removed.
  • the torque of the unnecessary component acquired in advance (the characteristic indicated by the broken line in FIG. 11) can be held in the storage unit 220.
  • the disturbance estimation unit 251 can also calculate a torque that cancels out the torque of the unnecessary component.
  • the rotational angular velocity calculated by block 632 in FIG. 5 is input to block 634, and block 634 performs the operation represented by the transfer function J n s, that is, the rotation angular velocity is differentiated.
  • the difference between the estimated torque value and the torque command value ⁇ is obtained, whereby the estimated disturbance value ⁇ d, which is the value of the torque due to the disturbance, is estimated.
  • the estimated torque value calculated by block 634 is based on the actual measured value including unnecessary components, and the torque command value ⁇ calculated by block 633 is an ideal theoretical model of the joints 421a to 421f shown in block 631. Therefore, by taking the difference between the two, unnecessary components can be removed.
  • the arm control unit 110 controls the arm unit 120 based on the torque command value ⁇ obtained by removing the unnecessary component torque. Thereby, when the arm unit 120 operates, the torque of the unnecessary component is removed, and a smoother movement can be realized. As described above, the torque of unnecessary components such as the cogging torque can be acquired in advance and stored in the storage unit 220.
  • FIG. 15 is a functional block diagram showing an example of the hardware configuration of the robot arm apparatus 10 and the control apparatus 20 according to an embodiment of the present disclosure.
  • the robot arm device 10 and the control device 20 mainly include a CPU 901, a ROM 903 and a RAM 905. Further, the robot arm device 10 and the control device 20 further include a host bus 907, a bridge 909, an external bus 911, an interface 913, an input device 915, an output device 917, a storage device 919, and a drive 921. , A connection port 923, and a communication device 925.
  • the CPU 901 functions as an arithmetic processing unit and a control unit, and according to various programs recorded in the ROM 903, the RAM 905, the storage unit 919 or the removable recording medium 927, the entire operation in the robot arm unit 10 and the control unit 20 or a part thereof. Control.
  • the ROM 903 stores programs used by the CPU 901, calculation parameters, and the like.
  • the RAM 905 primarily stores programs used by the CPU 901, parameters that appropriately change in the execution of the programs, and the like. These are mutually connected by a host bus 907 constituted by an internal bus such as a CPU bus.
  • the CPU 901 corresponds to, for example, the arm control unit 110 and the control unit 230 illustrated in FIG. 6 in the present embodiment.
  • the host bus 907 is connected to an external bus 911 such as a peripheral component interconnect / interface (PCI) bus via the bridge 909. Further, to the external bus 911, an input device 915, an output device 917, a storage device 919, a drive 921, a connection port 923, and a communication device 925 are connected via an interface 913.
  • PCI peripheral component interconnect / interface
  • the input device 915 is an operation unit operated by the user, such as a mouse, a keyboard, a touch panel, a button, a switch, a lever, and a pedal. Further, the input device 915 may be, for example, a remote control means (so-called remote control) using infrared rays or other radio waves, or a mobile phone or PDA corresponding to the operation of the robot arm device 10 and the control device 20
  • the external connection device 929 may be used.
  • the input device 915 includes, for example, an input control circuit that generates an input signal based on the information input by the user using the above-described operation means, and outputs the generated input signal to the CPU 901.
  • the user of the robot arm device 10 and the control device 20 can input various data to the robot arm device 10 and the control device 20 and instruct processing operations by operating the input device 915.
  • the input device 915 corresponds to, for example, the input unit 210 shown in FIG. 6 in the present embodiment.
  • the exercise purpose in the drive of the arm unit 120 may be set by the operation input by the user via the input device 915, and the whole body cooperative control may be performed according to the exercise purpose.
  • the output device 917 is configured of a device capable of visually or aurally notifying the user of the acquired information.
  • Such devices include display devices such as CRT display devices, liquid crystal display devices, plasma display devices, EL display devices and lamps, audio output devices such as speakers and headphones, and printer devices.
  • the output device 917 outputs, for example, results obtained by various processes performed by the robot arm device 10 and the control device 20.
  • the display device displays the results obtained by the various processes performed by the robot arm device 10 and the control device 20 in text or image.
  • the audio output device converts an audio signal composed of reproduced audio data, acoustic data and the like into an analog signal and outputs it.
  • various pieces of information regarding drive control of the arm unit 120 may be output from the output device 917 in any form.
  • a locus of movement of each component of the arm unit 120 in drive control of the arm unit 120 may be displayed on the display screen of the output device 917 in the form of a graph.
  • the display device 30 illustrated in FIG. 6 may be a device including the function and configuration of the output device 917 as a display device, and the configuration of a control unit for controlling the drive of the display device.
  • the storage device 919 is a device for data storage configured as an example of a storage unit of the robot arm device 10 and the control device 20.
  • the storage device 919 is configured of, for example, a magnetic storage unit device such as a hard disk drive (HDD), a semiconductor storage device, an optical storage device, a magneto-optical storage device, or the like.
  • the storage device 919 stores programs executed by the CPU 901, various data, and the like.
  • the storage device 919 corresponds to, for example, the storage unit 220 illustrated in FIG. 6 in the present embodiment.
  • the storage device 919 can store the calculation conditions (exercise purpose and restraint condition) in calculation related to whole-body coordinated control using generalized inverse dynamics, and the robot arm device 10 and the control device 20 may use these computing conditions stored in the storage device 919 to perform computations regarding whole-body coordinated control.
  • the drive 921 is a reader / writer for a recording medium, and is built in or externally attached to the robot arm device 10 and the control device 20.
  • the drive 921 reads out information recorded in a removable recording medium 927 such as a mounted magnetic disk, an optical disk, a magneto-optical disk, or a semiconductor memory, and outputs the information to the RAM 905.
  • the drive 921 can also write a record on a removable recording medium 927 such as a mounted magnetic disk, an optical disk, a magneto-optical disk, or a semiconductor memory.
  • the removable recording medium 927 is, for example, a DVD medium, an HD-DVD medium, a Blu-ray (registered trademark) medium, or the like.
  • the removable recording medium 927 may be Compact Flash (registered trademark) (CF: Compact Flash), a flash memory, an SD memory card (Secure Digital memory card), or the like.
  • the removable recording medium 927 may be, for example, an IC card (Integrated Circuit card) equipped with a non-contact IC chip, an electronic device, or the like.
  • various information regarding drive control of the arm unit 120 may be read from the various removable recording media 927 by the drive 921 or may be written to the various removable recording media 927.
  • the connection port 923 is a port for directly connecting the device to the robot arm device 10 and the control device 20.
  • Examples of the connection port 923 include a Universal Serial Bus (USB) port, an IEEE 1394 port, and a Small Computer System Interface (SCSI) port.
  • USB Universal Serial Bus
  • SCSI Small Computer System Interface
  • the connection port 923 there are an RS-232C port, an optical audio terminal, a high-definition multimedia interface (HDMI (registered trademark)) port, and the like.
  • HDMI registered trademark
  • various types of information related to the drive control of the arm unit 120 may be read from various external connection devices 929 via the connection port 923 or may be written to various external connection devices 929.
  • the communication device 925 is, for example, a communication interface configured of a communication device or the like for connecting to a communication network (network) 931.
  • the communication device 925 is, for example, a communication card for a wired or wireless LAN (Local Area Network), Bluetooth (registered trademark) or WUSB (Wireless USB).
  • the communication device 925 may be a router for optical communication, a router for Asymmetric Digital Subscriber Line (ADSL), a modem for various communications, or the like.
  • the communication device 925 can transmit and receive signals and the like according to a predetermined protocol such as TCP / IP, for example, with the Internet or another communication device.
  • the communication network 931 connected to the communication device 925 is configured by a network or the like connected by wire or wireless, and may be, for example, the Internet, home LAN, infrared communication, radio wave communication, satellite communication, etc. .
  • various information related to drive control of the arm unit 120 may be mutually transmitted and received by the communication device 925 via the communication network 931 with other external devices.
  • a computer program for realizing the functions of the robot arm apparatus 10, the control apparatus 20, and the display apparatus 30 according to the present embodiment as described above can be prepared and implemented on a personal computer or the like.
  • a computer readable recording medium in which such a computer program is stored can be provided.
  • the recording medium is, for example, a magnetic disk, an optical disk, a magneto-optical disk, a flash memory or the like.
  • the above computer program may be distributed via, for example, a network without using a recording medium.
  • the arm unit 120 which is the multi-link structure in the robot arm device 10 has at least six degrees of freedom or more, and a plurality of arm units 120 constituting the arm unit 120.
  • the drive control unit 111 controls the drive of each of the joint units 130.
  • a medical instrument is provided at the tip of the arm 120.
  • the drive control of the arm unit 120 with a higher degree of freedom is realized, and the medical robot arm device 10 with higher operability for the user is realized. .
  • the state of the joint unit 130 is detected by the joint state detection unit 132.
  • various calculations related to whole-body cooperative control using generalized inverse dynamics for controlling the drive of the arm unit 120 based on the state of the joint unit 130 and the exercise purpose and the constraint condition. Is performed to calculate a torque command value .tau.
  • the drive of the arm unit 120 is controlled based on the torque command value ⁇ .
  • the drive of the arm unit 120 is controlled by whole-body coordinated control using generalized inverse dynamics.
  • ideal joint control is applied together with whole-body cooperative control.
  • disturbance components such as friction and inertia inside the joint unit 130 are estimated, and feedforward control using the estimated disturbance components is performed. Therefore, even when there is a disturbance component such as friction, an ideal response can be realized for the drive of the joint unit 130. Therefore, in the drive control of the arm unit 120, highly accurate response and high positioning accuracy and stability with less influence of vibration and the like are realized.
  • each of the plurality of joint units 130 constituting the arm unit 120 has a configuration adapted to the ideal joint control as shown in, for example, FIG.
  • the generated torque and the viscous drag coefficient can be controlled by the current value.
  • the drive of each joint unit 130 is controlled by the current value, and the drive of each joint unit 130 is controlled while grasping the entire state of the arm unit 120 by the whole body coordinated control, so that the counterbalance becomes unnecessary.
  • the miniaturization of the robot arm device 10 is realized.
  • the above ⁇ 1. All the performances required for the robot arm device described in the discussion on the medical robot arm device can be satisfied. Therefore, in various treatments using the robot arm apparatus according to the present embodiment, the treatment can be performed more efficiently, and it is realized that the fatigue and burden of the user and the patient can be further reduced.
  • the arm unit 120 of the robot arm apparatus 10 is driven by force control, and even if the arm unit 120 interferes (contacts) the practitioner or staff during the operation, the arm unit 120 The arm unit 120 is safely stopped without generating an excessive force. Then, when released from the interference, the arm unit 120 moves to a desired position according to the set exercise purpose, and the treatment is continued.
  • force control for drive control of the robot arm apparatus 10 higher safety is ensured against interference between the arm unit 120 and surrounding objects during driving. .
  • the torque sensors 1800a, 1800b,..., 1800f of each joint can detect the user's operation, which part of the arm 120 of the robot arm apparatus 10 is operated. Even in this case, the arm unit 120 can be moved. As a result, it is possible to move the arm unit 120 even if the user does not directly hold the arm unit 120 by hand but presses the arm unit or the like.
  • the operability and safety of the robot arm device 10 can be improved by performing adaptive control according to the operation speed of the operation by the user. Specifically, by controlling the moment of inertia I of the joint and the viscous drag coefficient a a according to the operating speed, it becomes possible to realize smooth operability of the operation of the arm section 120, and the operating speed is excessive. Operability and safety can be improved. Further, since the vibration can be suppressed at the time of braking, the operability and safety of the robot arm device 10 can be improved.
  • the distal end unit of the arm unit of the robot arm apparatus is the imaging unit, and as shown in FIG. It is not limited to the example.
  • the robot arm control system 1 according to the present embodiment is applicable even when a robot arm device having another tip unit is used for another application.
  • the tip unit may be an endoscope or a laparoscope, or may be another inspection device such as an ultrasonic examination device or a gastroscope.
  • the robot arm operates the laparoscope to insert the laparoscope into the patient's body, and the laparoscope is operated to observe the image of the treatment site on the monitor while the patient's body is observed Use a forceps or an electric knife inserted in the procedure.
  • the operation can be performed by one user, More efficient treatment is possible.
  • the operation of the forceps and the electric scalpel for treatment by one's own hand and the operation of the laparoscope for observation by the robot arm device It can be easily performed by one practitioner.
  • the robot arm apparatus which concerns on this embodiment may be used for uses other than a medical treatment.
  • the robot arm apparatus according to the present embodiment high accuracy response and high stability are realized by the ideal joint control, so that it is possible to cope with, for example, processing or assembly of industrial parts that require high accuracy. is there.
  • the joint of the robot arm apparatus has the rotation mechanism, and the drive of the arm is controlled by controlling the rotational drive of the rotation mechanism.
  • the link constituting the arm unit may have a mechanism that expands and contracts in the extension direction of the link, and the length of the link may be variable.
  • the drive of the arm unit is controlled to achieve a desired exercise purpose by whole-body coordinated control in which the extension and contraction of the link are taken into consideration in addition to the rotation at the joint.
  • the said embodiment demonstrated the case where the freedom degree of the arm part in a robot arm apparatus is 6 or more degrees of freedom, this embodiment is not limited to this example.
  • the present embodiment is not limited to such an example.
  • various exercise purposes may be set according to the application of the robot arm device. Therefore, the arm may have a degree of freedom lower than 6 degrees of freedom, as long as the set exercise purpose can be achieved, and some of the joints constituting the arm are generally Joint having a typical joint mechanism may be used.
  • the configuration of the arm unit may be configured to be able to achieve an exercise purpose, and may be appropriately configured according to the application of the robot arm device.
  • a speed acquisition unit which acquires operation speeds of a plurality of joints which connect a plurality of links and drive a multi-link structure composed of a plurality of the links;
  • a parameter control unit that controls a control parameter related to the operation of the joint based on the operation speed;
  • Control device for a robot arm comprising: (2) The robot arm device according to (1), wherein the control parameter is a parameter related to viscosity resistance of an operation of the joint unit. (3) The robot arm device according to (2), wherein the parameter control unit increases or decreases the viscous resistance according to the operation speed. (4) The robot arm device according to (2), wherein the parameter control unit increases the viscous resistance when the joint unit starts or stops operation.
  • the robot arm device (5) The robot arm device according to (1), wherein the control parameter is an inertia moment of the joint unit. (6) The robot arm device according to (5), wherein the parameter control unit increases or decreases the moment of inertia according to the operation speed. (7) The robot arm device according to (6), wherein the parameter control unit controls the moment of inertia to a constant value when the operation speed exceeds a predetermined value. (8) The robot arm device according to (5), wherein the parameter control unit controls the moment of inertia when the joint unit starts or stops operation. (9) The control device of a robot arm according to any one of (1) to (8), further including a command value calculation unit that calculates a torque command value for driving the joint unit based on the control parameter.
  • the robot arm device (10) The robot arm device according to (9), wherein the command value calculation unit removes a component related to torque when the joint unit operates.
  • the component related to the torque may be at least one of cogging torque of a motor for driving the joint, torque unevenness of a torque sensor provided at the joint, current ripple, or reaction force of a magnet brake at the joint.
  • the robot arm device (10), including.
  • the robot arm device according to any one of (1) to (12), which is a device used for medical treatment.
  • (14) obtaining a motion speed of a joint unit connecting a plurality of links and driving a multi-link structure composed of the plurality of links; Controlling a control parameter related to the movement of the joint based on the movement speed;
  • a control method of a robot arm comprising: (15) Means for connecting a plurality of links and acquiring operation speeds of a plurality of joints for driving a multilink structure composed of a plurality of the links, Means for controlling control parameters related to the motion of the joint based on the motion speed; A program to make a computer function.

Abstract

 本開示に係るボットアームの制御装置は、複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体の駆動に対して少なくとも6自由度以上の自由度を実現する複数の関節部の動作速度を算出する速度算出部と、前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御するパラメータ制御部と、を備える。この構成により、ロボットアーム装置の制御において、操作性及び安全性の更なる向上を可能とする制御を実現することができる。

Description

ロボットアームの制御装置、ロボットアームの制御方法及びプログラム
 本開示は、ロボットアームの制御装置、ロボットアームの制御方法及びプログラムに関する。
 近年、工業分野においては、より正確により素早く作業を行うために、ロボット装置が広く用いられている。ロボット装置のなかには、複数のリンクが関節部によって互いに連結された多リンク構造体であり、複数の当該関節部における回転駆動が制御されることにより、ロボット装置全体としての駆動が制御されるものが存在する。
 ここで、ロボット装置及び各関節部の制御方法としては、位置制御と力制御が知られている。位置制御では、関節部のアクチュエータに、例えば角度等の指令値が与えられ、当該指令値に追随するように関節部の駆動が制御される。一方、力制御では、ロボット装置全体として作業対象に加えるべき力の目標値が与えられ、当該目標値が示す力を実現するように関節部の駆動(例えば関節部によって発生されるトルク)が制御される。
 一般的に、制御上の簡便さやシステムの構成のしやすさから、位置制御によって駆動されるロボット装置が大半である。しかしながら、位置制御は、外力に柔軟に応じることが困難であるため、俗に「硬い制御」と呼ばれることがあり、多様な外界との物理インタラクション(例えば、対人物理インタラクション)を行いながらタスク(運動目的)を遂行するロボット装置には適していない。一方、力制御は、システム構成は複雑化する半面、力オーダーでの「柔らかい制御」が実現できるため、特に対人物理インタラクションを行うロボット装置に適した制御方法であり、よりユーザビリティに優れた制御方法と言える。
 例えば、力制御が適用されたロボット装置として、特許文献1には、対向する2輪の車輪からなる移動機構と複数の関節部を有する腕部を備えたロボット装置において、当該車輪及び当該関節部の駆動を全体として協調させて制御する(全身協調制御を行う)ロボット装置が開示されている。
特開2010-188471号公報
 近年、医療分野においては、各種の施術(例えば、手術や検査)を行う際に、アーム部の先端に様々な医療用のユニット(先端ユニット)が設けられたバランス型アーム(支持アームとも呼称する。)を用いる試みが行われている。例えば、バランス型アームのアーム部の先端に顕微鏡等の様々な撮像機能を有するユニットを先端ユニットとして設け、施術者(ユーザ)が当該先端ユニットによって撮影された患部の画像を観察しながら各種の施術を行う方法が提案されている。しかしながら、バランス型アームは、アーム部を移動させた際の力の均衡を取るためのカウンターバランス用ウェイト(カウンターウェイト又はバランサーとも呼称する。)を備える必要があるため、装置が大型化する傾向がある。施術時の作業空間の確保の観点からは、施術に用いられる装置にはより一層の小型化が求められており、一般的に提案されているバランス型アームではこのような要請に応えることが困難であった。また、バランス型アームにおいては、アーム部の駆動の一部のみ、例えば先端ユニットを平面上(2次元上)で移動させるための2軸の駆動のみが電動駆動となっており、アーム部及び先端ユニットの移動には施術者自身や周囲の医療スタッフによる手動での位置決めが必要となる。従って、一般的なバランス型アームでは、撮影時の安定性(例えば先端ユニットの位置決めの精度や制振等)の確保や、例えば撮影部位を患者の体の所定の部位に固定した状態で様々な方向から撮影する等の撮影の自由度の確保が困難であった。
 このような状況を鑑みて、バランス型アームに代わる装置として、位置制御によって駆動が制御される医療用のロボットアーム装置も提案されている。しかしながら、施術の更なる効率化及びユーザの負担軽減のために、ロボットアーム装置の駆動制御には、ユーザによってアーム部及び先端ユニットの位置や姿勢をより直感的に制御することができる、より高い操作性が求められていた。位置制御によって駆動が制御されるロボットアーム装置では、このようなユーザの要望に応えることが困難であった。
 そこで、ロボットアーム装置の制御において、操作性及び安全性の更なる向上を可能とする制御の実現が望まれていた。
 本開示によれば、複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる関節部の動作速度を取得する速度取得部と、前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御するパラメータ制御部と、を備える、ロボットアームの制御装置が提供される。
 また、本開示によれば、複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる関節部の動作速度を取得することと、前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御することと、を備える、ロボットアームの制御方法が提供される。
 また、本開示によれば、複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる複数の関節部の動作速度を取得する手段、前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御する手段、としてコンピュータを機能させるためのプログラムが提供される。
 本開示によれば、ロボットアーム装置の制御において、操作性及び安全性の更なる向上を可能とする制御を実現することができる。
本開示の一実施形態に係るロボットアーム装置が医療用に用いられる場合の一適用例について説明するための説明図である。 本開示の一実施形態に係るロボットアーム装置の外観を示す概略図である。 本開示の一実施形態に係る関節部のアクチュエータを、回転軸を通る断面で切断した様子を模式的に示す断面図である。 図3に示すトルクセンサを、駆動軸の軸方向から見た様子を模式的に示す概略図である。 図3に示すアクチュエータに適用されるトルクセンサの他の構成例を示す概略図である。 本開示の一実施形態に係る理想関節制御について説明するための説明図である。 本開示の一実施形態に係るロボットアーム制御システムの一構成例を示す機能ブロック図である。 図6の構成に対して、操作速度に応じた制御を実現するための構成を付加した構成を示す模式図である。 粘性抵抗係数制御部264が粘性抵抗係数νを算出する際に用いるマップの一例を示す模式図である。 慣性モーメント制御部262が慣性モーメントIを算出する際に用いるマップの一例を示す模式図である。 アーム部120が停止する際に用いられるマップを示す模式図である。 本開示の一実施形態に係るロボットアーム制御方法の処理手順を示すフロー図である。 操作速度に応じて粘性を制御する処理を示すフローチャートである。 モータのコギングトルク(破線)と、コギングトルクを打ち消した場合のトルク(実線)を示す特性図である。
 以下に添付図面を参照しながら、本開示の好適な実施の形態について詳細に説明する。なお、本明細書及び図面において、実質的に同一の機能構成を有する構成要素については、同一の符号を付することにより重複説明を省略する。
 なお、説明は以下の順序で行うものとする。
 1.医療用ロボットアーム装置についての検討
 2.本開示の一実施形態
  2-1.ロボットアーム装置の外観
  2-2.一般化逆動力学について
   2-2-1.仮想力算出処理
   2-2-1.実在力算出処理
  2-3.理想関節制御について
  2-4.ロボットアーム制御システムの構成
  2-5.運動目的の具体例
 3.操作速度に応じた制御
 4.ロボットアーム制御方法の処理手順
 5.モータ、センサー等に関する不要成分の除去
 6.ハードウェア構成
 7.まとめ
 <1.医療用ロボットアーム装置についての検討>
 まず、本開示をより明確なものとするために、本発明者らが本開示に想到するに至った背景について説明する。また、モーターを動力源とするパワーアシスト型アームでは、安全かつ滑らかな操作感を実現することには困難が伴う。例えば、操作者が過大な力を加えてアームを動作させる場合、アーム部の動きに過大な速度が発生し、安全性が低下する問題がある。また、操作者が急にアームの動作を止める場合、アームに振動が起こり、操作性が低下する問題がある。更には、アームの全長が長い程、もしくは動作速度が速い程、これらの安全性、操作性の問題が顕著になる。このような事情に鑑み、本実施形態では、ロボットアーム装置の制御において、操作性及び安全性の更なる向上を可能とする制御を実現する。
 図1を参照して、本開示の一実施形態に係るロボットアーム装置が医療用に用いられる場合の一適用例について説明する。図1は、本開示の一実施形態に係るロボットアーム装置が医療用に用いられる場合の一適用例について説明するための説明図である。
 図1は、本実施形態に係るロボットアーム装置を用いた施術の様子を模式的に表している。具体的には、図1を参照すると、施術者(ユーザ)520である医師が、例えばメス、鑷子、鉗子等の手術用の器具521を使用して、施術台530上の施術対象(患者)540に対して手術を行っている様子が図示されている。なお、以下の説明においては、施術とは、手術や検査等、ユーザ520である医師が施術対象540である患者に対して行う各種の医療的な処置の総称であるとする。また、図1に示す例では、施術の一例として手術の様子を図示しているが、ロボットアーム装置510が用いられる施術は手術に限定されず、他の各種の施術、例えば内視鏡を用いた検査等であってもよい。
 施術台530の脇には本実施形態に係るロボットアーム装置510が設けられる。ロボットアーム装置510は、基台であるベース部511と、ベース部511から延伸するアーム部512を備える。アーム部512は、複数の関節部513a、513b、513cと、関節部513a、513bによって連結される複数のリンク514a、514bと、アーム部512の先端に設けられる撮像ユニット515を有する。図1に示す例では、簡単のため、アーム部512は3つの関節部513a~513c及び2つのリンク514a、514bを有しているが、実際には、アーム部512及び撮像ユニット515の位置及び姿勢の自由度を考慮して、所望の自由度を実現するように関節部513a~513c及びリンク514a、514bの数や形状、関節部513a~513cの駆動軸の方向等が適宜設定されてよい。
 関節部513a~513cは、リンク514a、514bを互いに回動可能に連結する機能を有し、関節部513a~513cの回転が駆動されることにより、アーム部512の駆動が制御される。ここで、以下の説明においては、ロボットアーム装置510の各構成部材の位置とは、駆動制御のために規定している空間における位置(座標)を意味し、各構成部材の姿勢とは、駆動制御のために規定している空間における任意の軸に対する向き(角度)を意味する。また、以下の説明では、アーム部512の駆動(又は駆動制御)とは、関節部513a~513cの駆動(又は駆動制御)、及び、関節部513a~513cの駆動(又は駆動制御)を行うことによりアーム部512の各構成部材の位置及び姿勢が変化される(変化が制御される)ことをいう。
 アーム部512の先端には先端ユニットとして各種の医療用器具が接続される。図1に示す例では、先端ユニットの一例としてアーム部512の先端に撮像ユニット515が設けられている。撮像ユニット515は、撮影対象の画像(撮影画像)を取得するユニットであり、例えば動画や静止画を撮影できるカメラ等である。図1に示すように、アーム部512の先端に設けられた撮像ユニット515が施術対象540の施術部位の様子を撮影するように、ロボットアーム装置510によってアーム部512及び撮像ユニット515の姿勢や位置が制御される。なお、アーム部512の先端に設けられる先端ユニットは撮像ユニット515に限定されず、各種の医療用器具であってよい。当該医療用器具としては、例えば、内視鏡や顕微鏡、上述した撮像ユニット515等の撮像機能を有するユニットや、各種の施術器具、検査装置等、施術に際して用いられる各種のユニットが挙げられる。このように、本実施形態に係るロボットアーム装置510は、医療用器具を備えた医療用ロボットアーム装置であると言える。また、アーム部512の先端に、2つの撮像ユニット(カメラユニット)を有するステレオカメラが設けられ、撮像対象を3次元画像(3D画像)として表示するように撮影が行われてもよい。なお、先端ユニットとして、施術部位を撮影するための撮像ユニット515や当該ステレオカメラ等のカメラユニットが設けられるロボットアーム装置510のことをビデオ顕微鏡用ロボットアーム装置とも呼称する。
 また、ユーザ520と対向する位置には、モニタやディスプレイ等の表示装置550が設置される。撮像ユニット515によって撮影された施術部位の撮影画像は、表示装置550の表示画面に表示される。ユーザ520は、表示装置550の表示画面に表示される施術部位の撮影画像を見ながら各種の処置を行う。
 このように、本実施形態においては、医療分野において、ロボットアーム装置510によって施術部位の撮影を行いながら手術を行うことが提案される。ここで、手術を含む各種の施術においては、より施術を効率的に行うことにより、ユーザ520及び患者540の疲労や負担を軽減することが求められる。このような要求を満たすために、ロボットアーム装置510には、例えば以下のような性能が求められると考えられる。
 まず、1点目として、ロボットアーム装置510には、手術における作業空間を確保することが求められる。ユーザ520が施術対象540に対して各種の処置を行っている最中に、アーム部512や撮像ユニット515が施術者の視界を妨げたり、処置を行う手の動きを妨げたりすると、手術の効率の低下につながる。また、図1では図示していないが、実際の手術現場では、ユーザ520に器具を渡したり、患者540の各種のバイタルサインを確認したりといった、様々なサポート作業を行う複数の他の医師や看護師等がユーザ520及び患者540の周囲にいることが一般的であり、また、当該サポート作業を行うための他の装置等が存在するため、手術環境は煩雑である。従って、ロボットアーム装置510は、より小型であることが望ましい。
 次いで、2点目として、ロボットアーム装置510には、撮像ユニット515を移動させる際の高い操作性が求められる。例えば、手術を行う部位や手術の内容によっては、ユーザ520には、施術部位に対して処置を行っている最中に、同じ施術部位を様々な位置、角度から観察したいという要求がある。施術部位を観察する角度を変えるには、撮像ユニット515の施術部位に対する角度を変更する必要があるが、その際、撮像ユニット515の撮影方向は施術部位に固定されたまま(すなわち、同一の部位を撮影したまま)、撮影する角度だけが変化することがより望ましい。従って、例えば、撮像ユニット515の撮影方向が施術部位に固定された状態で、撮像ユニット515が施術部位を頂点とした円錐の面内を移動する、当該円錐の軸を旋回軸とした旋回動作(ピボット動作)のような、より自由度の高い操作性がロボットアーム装置510に求められていた。なお、撮像ユニット515の撮影方向が所定の施術部位に固定されることから、ピボット動作はポイントロック動作とも呼ばれる。
 また、撮像ユニット515の位置及び角度を変化させるためには、例えばユーザ520が手動でアーム部512を動かすことによって、撮像ユニット515を所望の位置及び角度に動かす方法が考えられる。従って、撮像ユニット515の移動や上述したピボット動作等が、例えば片手でも容易に行える操作性があることが望ましい。
 また、手術時には、例えばユーザ520が両手で処置を行いながら、撮像ユニット515によって撮影される撮影画像の撮影中心を、処置を行っている部位から別の部位(例えば次の処置を行う部位)に移動させたいという要求も考えられる。従って、撮像ユニット515の位置及び姿勢を変化させる際に、上述したような手動によってアーム部512の駆動を制御する方法だけではなく、例えばペダル等の入力部からの操作入力によってアーム部512の駆動を制御する方法のような、多様なアーム部512の駆動方法が求められる。
 このように、2点目の性能として、ロボットアーム装置510には、例えば上述したピボット動作や手動による容易な移動を実現する、よりユーザ520の直感や要望に合った高い操作性が求められる。
 最後に、3点目として、ロボットアーム装置510には、アーム部512の駆動制御における安定性が求められる。アーム部512の駆動制御に対する安定性とは、アーム部512を駆動した際の先端ユニットの位置及び姿勢の安定性のことであってよい。また、アーム部512の駆動制御に対する安定性には、アーム部512を駆動した際の先端ユニットのスムーズな移動や振動の抑制(制振)も含まれる。例えば、図1に示す例のように先端ユニットが撮像ユニット515である場合に、もしも撮像ユニット515の位置や姿勢が安定しないと、表示装置550の表示画面に表示される撮影画像が安定せず、ユーザに不快感を与えかねない。特に、ロボットアーム装置510が手術に用いられる際には、先端ユニットとして2つの撮像ユニット(カメラユニット)を有するステレオカメラが設けられ、当該ステレオカメラによる撮影画像に基づいて生成される3次元画像(3D画像)が表示装置550に表示される使用方法が想定され得る。このように3D画像が表示される場合に、当該ステレオカメラの位置や姿勢が不安定であると、ユーザのいわゆる3D酔いを誘発する可能性がある。また、手術を行う部位や手術の内容によっては、撮像ユニット515によって撮影される観察範囲はφ15mm程度にまで拡大されることがある。このように撮像ユニット515が狭い範囲を拡大して撮影している場合には、撮像ユニット515の僅かな振動が撮像画像の大きな揺れやブレとなって表れる。従って、アーム部512及び撮像ユニット515の駆動制御には、許容範囲1mm程度の高い位置決め精度が要求される。このように、アーム部512の駆動制御においては、高精度の応答性と高い位置決め精度が求められる。
 本発明者らは、上記の3つの性能の観点から、一般的な既存のバランス型アームや位置制御によるロボットアーム装置について検討を行った。
 まず、1点目の手術の作業空間の確保に関しては、一般的なバランス型アームでは、通常、アーム部を移動させた際の力の均衡を取るためのカウンターバランス用ウェイト(カウンターウェイト又はバランサーとも呼称する。)がベース部の内部等に設けられるため、バランス型アームの装置の大きさを小型化することが難しく、当該性能を満たしているとは言い難い。
 また、2点目の高い操作性に関しては、一般的なバランス型アームでは、アーム部の駆動の一部のみ、例えば撮像ユニットを平面上(2次元上)で移動させるための2軸の駆動のみが電動駆動となっており、アーム部及び撮像ユニットの移動には手動による位置決めが必要となるため、高い操作性が実現できるとは言い難い。また、一般的な位置制御によるロボットアーム装置において、アーム部の駆動の制御、すなわち撮像ユニットの位置及び姿勢の制御に用いられる位置制御は、外力に柔軟に応じることが困難であるため、俗に「硬い制御」と呼ばれることがあり、要求されているようなユーザの直感に合った操作性を実現するには適していない。
 また、3点目のアーム部の駆動制御における安定性に関しては、一般的に、アーム部の関節部には、摩擦や慣性等のモデル化することが困難な因子が存在する。一般的なバランス型アームや位置制御によるロボットアーム装置においては、関節部の駆動制御においてこれらの因子が外乱となって表れてしまうことにより、理論上適切な制御値(例えば関節部のモータに印加する電流値)を与えた場合であっても所望の駆動(例えば関節部のモータにおける所望の角度の回転)が実現しないことがあり、要求されているようなアーム部の駆動制御における高い安定性を実現することは困難である。
 以上説明したように、本発明者らは、医療用に用いられるロボットアーム装置について検討した結果、ロボットアーム装置に関して、上述したような3点の性能に対する要求が存在するとの知見を得た。しかしながら、一般的な既存のバランス型アームや位置制御によるロボットアーム装置では、これらの性能を満たすことは困難であると考えられる。本発明者らは、上述した3点の性能を満たす構成について検討した結果、本開示に係るロボットアーム装置、ロボットアーム制御システム、ロボットアーム制御方法及びプログラムに想到した。以下では、本発明者らが想到した構成における好ましい実施形態について詳細に説明する。
 <2.本開示の一実施形態>
 以下では、本開示の一実施形態に係るロボットアーム制御システムについて説明する。本実施形態に係るロボットアーム制御システムにおいては、ロボットアーム装置に設けられる複数の関節部の駆動を、一般化逆動力学を用いた全身協調制御により制御する。更に、外乱の影響を補正することにより指令値に対する理想的な応答を実現する理想関節制御を当該関節部の駆動制御に適用する。
 以下の本実施形態の説明では、まず、[2-1.ロボットアーム装置の外観]で、本実施形態に係るロボットアーム装置の外観を示すとともに、ロボットアーム装置の概略構成について説明する。次いで、[2-2.一般化逆動力学について]及び[2-3.理想関節制御について]で、本実施形態に係るロボットアーム装置の制御に用いられる一般化逆動力学と理想関節制御の概要について説明する。次いで、[2-4.ロボットアーム制御システムの構成]で、本実施形態に係るロボットアーム装置を制御するためのシステムの構成について機能ブロック図を用いて説明する。最後に、[2-5.運動目的の具体例]で、本実施形態に係るロボットアーム装置における、一般化逆動力学を用いた全身協調制御の具体例について説明する。
 なお、以下の説明では、本開示の一実施形態として、ロボットアーム装置のアーム部の先端ユニットが撮像ユニットであり、図1に示すように手術時に当該撮像ユニットによって施術部位を撮影する場合について説明するが、本実施形態はかかる例に限定されない。本実施形態に係るロボットアーム制御システムは、他の先端ユニットを有するロボットアーム装置が他の用途に用いられる場合であっても適用可能である。
 [2-1.ロボットアーム装置の外観]
 まず、図2を参照して、本開示の一実施形態に係るロボットアーム装置の概略構成について説明する。図2は、本開示の一実施形態に係るロボットアーム装置の外観を示す概略図である。
 図2を参照すると、本実施形態に係るロボットアーム装置400は、ベース部410及びアーム部420を備える。ベース部410はロボットアーム装置400の基台であり、ベース部410からアーム部420が延伸される。また、図2には図示しないが、ベース部410内には、ロボットアーム装置400を統合的に制御する制御部が設けられてもよく、アーム部420の駆動が当該制御部によって制御されてもよい。当該制御部は、例えばCPU(Central Processing Unit)やDSP(Digital Signal Processor)等の各種の信号処理回路によって構成される。
 アーム部420は、複数の関節部421a~421fと、関節部421a~421fによって互いに連結される複数のリンク422a~422cと、アーム部420の先端に設けられる撮像ユニット423を有する。
 リンク422a~422cは棒状の部材であり、リンク422aの一端が関節部421aを介してベース部410と連結され、リンク422aの他端が関節部421bを介してリンク422bの一端と連結され、更に、リンク422bの他端が関節部421c、421dを介してリンク422cの一端と連結される。更に、撮像ユニット423が、アーム部420の先端、すなわち、リンク422cの他端に、関節部421e、421fを介して連結される。このように、ベース部410を支点として、複数のリンク422a~422cの端同士が、関節部421a~421fによって互いに連結されることにより、ベース部410から延伸されるアーム形状が構成される。
 撮像ユニット423は撮影対象の画像を取得するユニットであり、例えば動画、静止画を撮影するカメラ等である。アーム部420の駆動が制御されることにより、撮像ユニット423の位置及び姿勢が制御される。本実施形態においては、撮像ユニット423は、例えば施術部位である患者の体の一部領域を撮影する。ただし、アーム部420の先端に設けられる先端ユニットは撮像ユニット423に限定されず、アーム部420の先端には先端ユニットとして各種の医療用器具が接続されてよい。このように、本実施形態に係るロボットアーム装置400は、医療用器具を備えた医療用ロボットアーム装置であると言える。
 ここで、以下では、図2に示すように座標軸を定義してロボットアーム装置400の説明を行う。また、座標軸に合わせて、上下方向、前後方向、左右方向を定義する。すなわち、床面に設置されているベース部410に対する上下方向をz軸方向及び上下方向と定義する。また、z軸と互いに直交する方向であって、ベース部410からアーム部420が延伸されている方向(すなわち、ベース部410に対して撮像ユニット423が位置している方向)をy軸方向及び前後方向と定義する。更に、y軸及びz軸と互いに直交する方向をx軸方向及び左右方向と定義する。
 関節部421a~421fはリンク422a~422cを互いに回動可能に連結する。関節部421a~421fはアクチュエータを有し、当該アクチュエータの駆動により所定の回転軸に対して回転駆動される回転機構を有する。各関節部421a~421fにおける回転駆動をそれぞれ制御することにより、例えばアーム部420を伸ばしたり、縮めたり(折り畳んだり)といった、アーム部420の駆動を制御することができる。ここで、関節部421a~421fは、下記[2-2.一般化逆動力学について]で後述する全身協調制御及び下記[2-3.理想関節制御について]で後述する理想関節制御によってその駆動が制御される。また、上述したように、本実施形態に係る関節部421a~421fは回転機構を有するため、以下の説明において、関節部421a~421fの駆動制御とは、具体的には、関節部421a~421fの回転角度及び/又は発生トルク(関節部421a~421fが発生させるトルク)が制御されることを意味する。
 本実施形態に係るロボットアーム装置400は、6つの関節部421a~421fを有し、アーム部420の駆動に関して6自由度が実現されている。具体的には、図2に示すように、関節部421a、421d、421fは、接続されている各リンク422a~422cの長軸方向及び接続されている撮像ユニット473の撮影方向を回転軸方向とするように設けられており、関節部421b、421c、421eは、接続されている各リンク422a~422c及び撮像ユニット473の連結角度をy-z平面(y軸とz軸とで規定される平面)内において変更する方向であるx軸方向を回転軸方向とするように設けられている。このように、本実施形態においては、関節部421a、421d、421fは、いわゆるヨーイングを行う機能を有し、関節部421b、421c、421eは、いわゆるピッチングを行う機能を有する。
 このようなアーム部420の構成を有することにより、本実施形態に係るロボットアーム装置400ではアーム部420の駆動に対して6自由度が実現されるため、アーム部420の可動範囲内において撮像ユニット423を自由に移動させることができる。図2では、撮像ユニット423の移動可能範囲の一例として半球を図示している。半球の中心点が撮像ユニット423によって撮影される施術部位の撮影中心であるとすれば、撮像ユニット423の撮影中心を半球の中心点に固定した状態で、撮像ユニット423を半球の球面上で移動させることにより、施術部位を様々な角度から撮影することができる。
 ここで、図3を参照して、図2に示す関節部421a~421fの構成についてより詳細に説明する。なお、ここでは、図3を参照して、関節部421a~421fの構成のうち、関節部421a~421fの回転駆動に主に関係する構成であるアクチュエータの構成について説明する。
 図3は、本開示の一実施形態に係る関節部421a~421fのアクチュエータを、回転軸を通る断面で切断した様子を模式的に示す断面図である。なお、図3では、関節部421a~421fの構成のうち、アクチュエータのみを図示しているが、関節部421a~421fは、他の構成を有してもよい。例えば、関節部421a~421fは、図3に図示する構成以外にも、アクチュエータの駆動を制御するための制御部や、リンク422a~422c及び撮像ユニット423を接続、支持するための支持部材等、アーム部420の駆動に必要な各種の構成を有する。なお、ここまでの説明及び以下の説明において、アーム部の関節部の駆動とは、関節部におけるアクチュエータの駆動を意味していてもよい。
 なお、上述したように、本実施形態においては、関節部421a~421fは、下記[2-3.理想関節制御について]で後述する理想関節制御によってその駆動が制御される。従って、図3に示す関節部421a~421fのアクチュエータは、理想関節制御に対応した駆動を行えるように構成されている。具体的には、関節部421a~421fのアクチュエータは、当該関節部421a~421fにおける回転角度及び回転駆動に伴うトルクを調整できるように構成されている。また、関節部421a~421fのアクチュエータは、回転運動に対する粘性抵抗係数を任意に調整できるように構成されており、例えば外部から加えられる力に対して回転しやすい(すなわち、アーム部420を手動で移動しやすい)状態や回転し難い(すなわち、アーム部420を手動で移動し難い)状態を実現することができる。
 図3を参照すると、本実施形態に係る関節部421a~421fのアクチュエータ430は、モータ424、モータドライバ425、減速機426、エンコーダ427、トルクセンサ428及び駆動軸429を有する。図3に示すように、エンコーダ427、モータ424、減速機426及びトルクセンサ428は、駆動軸429に対して直列にこの順で連結される。
 モータ424は、アクチュエータ430における原動機であり、駆動軸429をその軸周りに回転させる。例えば、モータ424は、ブラシレスDCモータ等の電動モータである。本実施形態においては、モータ424は電流を供給されることによってその回転駆動が制御される。
 モータドライバ425は、モータ424に電流を供給することによりモータ424を回転駆動させるドライバ回路(ドライバIC(Integrated Circuit))であり、モータ424に供給する電流量を調整することにより、モータ424の回転数を制御することができる。また、モータドライバ425は、モータ424に供給する電流量を調整することにより、上述したようなアクチュエータ430の回転運動に対する粘性抵抗係数を調整することができる。
 減速機426は、駆動軸429に接続され、モータ424によって生じた駆動軸429の回転速度を所定の減速比で減速することにより、所定の値を有する回転駆動力(すなわち、トルク)を発生させる。減速機426には、バックラッシレス型の高性能減速機が用いられる。例えば、減速機426は、ハーモニックドライブ(登録商標)であってもよい。減速機426によって生成されたトルクは、減速機426の出力軸に接続されたトルクセンサ428を介して、後段の出力部材(図示せず。例えばリンク422a~422cや撮像ユニット423等の連結部材)に伝達される。
 エンコーダ427は、駆動軸429に接続され、駆動軸429の回転数を検出する。エンコーダによって検出された駆動軸429の回転数と、減速機426の減速比との関係に基づいて、関節部421a~421fの回転角度、回転角速度及び回転角加速度等の情報を得ることができる。
 トルクセンサ428は、減速機426の出力軸に接続され、減速機426によって生成されたトルク、すなわち、アクチュエータ430によって出力されるトルクを検出する。以下の説明では、アクチュエータ430によって出力されるトルクのことを単に発生トルクとも呼称する。
 このように、アクチュエータ430においては、モータ424に供給する電流量を調整することにより、モータ424の回転数を調整することがでる。ここで、減速機426における減速比は、ロボットアーム装置400の用途に応じて適宜設定可能であってよい。従って、減速機426の減速比に応じて、モータ424の回転数を適宜調整することにより、発生トルクを制御することができる。また、アクチュエータ430においては、エンコーダ427によって検出された駆動軸429の回転数に基づいて、関節部421a~421fの回転角度、回転角速度及び回転角加速度等の情報を得ることができ、トルクセンサ428によって、関節部421a~421fにおける発生トルクを検出することができる。
 また、トルクセンサ428は、アクチュエータ430による発生トルクだけでなく、外部から加えられる外トルクも検出することができる。従って、トルクセンサ428によって検出された外トルクに基づいて、モータドライバ425がモータ424に供給する電流量を調整することにより、上述したような回転運動に対する粘性抵抗係数を調整することができ、例えば外部から加えられる力に対して回転しやすい状態や回転し難い状態を実現することができる。
 ここで、図4A及び図4Bを参照して、トルクセンサ428の構成について詳細に説明する。図4Aは、図3に示すトルクセンサ428を、駆動軸429の軸方向から見た様子を模式的に示す概略図である。
 図4Aを参照すると、トルクセンサ428は、外輪部431、内輪部432、梁部433a~433d及び歪み検出素子434a~434dを有する。図4Aに示すように、外輪部431及び内輪部432は同心円状に配置される。本実施形態では、内輪部432が入力側、すなわち、減速機426からの出力軸と接続され、外輪部431が出力側、すなわち、後段の出力部材(図示せず。)と接続される。
 4本の梁部433a~433dは、同心円状に配置された外輪部431と内輪部432との間に配設され、外輪部431と内輪部432とを互いに接続する。図4Aに示すように、梁部433a~433dは、隣り合う梁部433a~433d同士が互いに90度の角度となるように、外輪部431と内輪部432との間に介設される。
 梁部433a~433dのうち、互いに向かい合う、すなわち、互いに180度の角度で設けられる2本には、歪み検出素子434a~434dが設けられる。歪み検出素子434a~434dによって検出された梁部433a~433dの変形量に基づいて、アクチュエータ430の発生トルク及び外トルクを検出することができる。
 図4Aに示す例では、梁部433a~433dのうち、梁部433aに歪み検出素子434a、434bが、梁部433cに歪み検出素子434c、434dが設けられる。また、歪み検出素子434a、434bは梁部433aを挟むように設けられ、歪み検出素子434c、434dは梁部433cを挟むように設けられる。例えば、歪み検出素子434a~434dは歪みゲージであり、梁部433a、433cの表面に貼り付けられることにより、梁部433a、433cの幾何的な変形量を電気抵抗の変化に基づいて検出する。図4Aに示すように4ヶ所に歪み検出素子434a~434dが設けられることにより、検出素子434a~434dがいわゆるホイートストンブリッジを構成する。従って、いわゆる4ゲージ法を用いて歪みを検出することができるため、歪みを検出する軸以外の他軸の干渉や駆動軸429の偏心、温度ドリフト等の影響を低減することができる。
 このように、梁部433a~433dは、歪みを検出するための起歪体の役割を果たす。なお、本実施形態に係る歪み検出素子434a~434dの種類は歪みゲージに限定されず、他の素子が用いられてもよい。例えば、歪み検出素子434a~434dは、磁気特性の変化に基づいて梁部433a~433dの変形量を検出する素子であってもよい。
 また、図3及び図4Aには図示しないが、トルクセンサ428による発生トルク及び外トルクの検出精度を向上させるために、以下に示す構成が適用されてもよい。例えば、梁部433a~433dの外輪部431と接続する部位を他の部位よりも薄肉化することにより、支持モーメントが解放されるため、検出される変形量の線形性が向上されるとともにラジアル荷重による影響が低減される。また、外輪部431及び内輪部432をともにベアリングを介してハウジングで支持することにより、入力軸及び出力軸の双方からの他軸力、モーメントの作用を排除することができる。また、外輪部431に作用する他軸モーメントを低減するために、図3に示すアクチュエータ430の他端、すなわちエンコーダ427が配設される部位に両持ち支持用ベアリングが配設されてもよい。
 以上、図4Aを参照して、トルクセンサ428の構成について説明した。以上説明したように、図4Aに示すトルクセンサ428の構成により、アクチュエータ430の発生トルク及び外トルクの検出において、高精度な検出が可能となる。
 ここで、本実施形態においては、トルクセンサ428の構成は図4Aに示す構成に限定されず、他の構成であってもよい。アクチュエータ430に適用されるトルクセンサについて、トルクセンサ428以外の他の構成の一例を、図4Bを参照して説明する。
 図4Bは、図3に示すアクチュエータ430に適用されるトルクセンサの他の構成例を示す概略図である。図4Bを参照すると、本変形例に係るトルクセンサ428aは、外輪部441、内輪部442、梁部443a~443d及び歪み検出素子444a~444dを有する。なお、図4Bでは、図4Aと同様、トルクセンサ428aを駆動軸429の軸方向から見た様子を模式的に示している。
 トルクセンサ428aにおいて、外輪部441、内輪部442、梁部443a~443d及び歪み検出素子444a~444dの機能及び構成は、図4Aを参照して説明したトルクセンサ428の外輪部431、内輪部432、梁部433a~433d及び歪み検出素子434a~434dの機能及び構成とほぼ同様である。本変形例に係るトルクセンサ428aは、梁部443a~443dと外輪部441との接続部分の構成が異なる。従って、図4Bに示すトルクセンサ428aについては、図4Aに示すトルクセンサ428との相違点である梁部443a~443dと外輪部441との接続部位の構成について主に説明を行い、重複する構成については説明を省略する。
 図4Bを参照すると、トルクセンサ428aの全体図と併せて、梁部443bと外輪部441との接続部位が拡大して図示されている。なお、図4Bでは、梁部443a~443dと外輪部441との4ヶ所の接続部位のうちの1ヶ所である梁部443bと外輪部441との接続部位のみを拡大して図示しているが、他の3ヶ所である梁部443a、443c、443dと外輪部441との接続部位も同様の構成を有している。
 図4Bにおける拡大図を参照すると、梁部443bと外輪部441との接続部位においては、外輪部441に係合凹部が設けられており、梁部443bの先端が係合凹部に係合されることにより両者が接続される。また、当該梁部443bと外輪部441との間には、間隙G1、G2が設けられる。間隙G1は梁部443bが外輪部441に向かって延伸する方向における両者の間隙を表しており、間隙G2は当該方向とは直交する方向における両者の間隙を表している。
 このように、トルクセンサ428aにおいては、梁部443a~443dと外輪部441とが、所定の間隙G1、G2を有して分離して配設される。すなわち、トルクセンサ428aにおいては、外輪部441と内輪部442とが分離している。従って、内輪部442が外輪部441に対して拘束されず動きの自由度を有するため、例えばアクチュエータ430の駆動に際して振動が生じたとしても、振動による歪み成分を内輪部442と外輪部441との間の空隙G1、G2によって吸収することができる。よって、トルクセンサ428aをアクチュエータ430のトルクセンサとして適用することにより、より高精度な発生トルク及び外トルクの検出が実現される。
 なお、図3、図4A及び図4Bに示すような、理想関節制御に対応するアクチュエータ430の構成については、例えば、本願出願人による先行特許出願である特開2009-269102号公報や特開2011-209099号公報を参照することができる。
 以上、図2、図3、図4A及び図4Bを参照して、本実施形態に係るロボットアーム装置400の概略構成について説明した。次に、本実施形態に係るロボットアーム装置400におけるアーム部420の駆動、すなわち、関節部421a~421fの駆動を制御するための全身協調制御及び理想関節制御について説明する。
 [2-2.一般化逆動力学について]
 次に、本実施形態におけるロボットアーム装置400の全身協調制御に用いられる一般化逆動力学の概要について説明する。
 一般化逆動力学は、複数のリンクが複数の関節部によって連結されて構成される多リンク構造体(例えば本実施形態においては図2に示すアーム部420)において、各種の操作空間(Operation Space)における様々な次元に関する運動目的を、各種の拘束条件を考慮しながら、複数の当該関節部に生じさせるトルクに変換する、多リンク構造体の全身協調制御における基本演算である。
 操作空間は、ロボット装置の力制御における重要な概念である。操作空間は、多リンク構造体に作用する力と多リンク構造体の加速度との関係を記述するための空間である。多リンク構造体の駆動制御を位置制御ではなく力制御によって行う際に、多リンク構造体と環境との接し方を拘束条件として用いる場合に操作空間という概念が必要となる。操作空間は、例えば、多リンク構造体が属する空間である、関節空間、デカルト空間、運動量空間等である。
 運動目的は、多リンク構造体の駆動制御における目標値を表すものであり、例えば、駆動制御によって達成したい多リンク構造体の位置、速度、加速度、力、インピーダンス等の目標値である。
 拘束条件は、多リンク構造体の形状や構造、多リンク構造体の周囲の環境及びユーザによる設定等によって定められる、多リンク構造体の位置、速度、加速度、力等に関する拘束条件である。例えば、拘束条件には、発生力、優先度、非駆動関節の有無、垂直反力、摩擦錘、支持多角形等についての情報が含まれる。
 一般化逆動力学においては、数値計算上の安定性と実時間処理可能な演算効率とを両立するため、その演算アルゴリズムは、第1段階である仮想力決定プロセス(仮想力算出処理)と、第2段階である実在力変換プロセス(実在力算出処理)によって構成される。第1段階である仮想力算出処理では、各運動目的の達成に必要な、操作空間に作用する仮想的な力である仮想力を、運動目的の優先度と仮想力の最大値を考慮しながら決定する。第2段階である実在力算出処理では、非駆動関節、垂直反力、摩擦錘、支持多角形等に関する拘束を考慮しながら、上記で得られた仮想力を関節力、外力等の実際の多リンク構造体の構成で実現可能な実在力に変換する。以下、仮想力算出処理及び実在力算出処理について詳しく説明する。なお、以下の仮想力算出処理、実在力算出処理及び後述する理想関節制御の説明においては、理解を簡単にするために、具体例として、図2及び図3に示した本実施形態に係るロボットアーム装置400のアーム部420の構成を例に挙げて説明を行う場合がある。
 (2-2-1.仮想力算出処理)
 多リンク構造体の各関節部におけるある物理量によって構成されるベクトルを一般化変数qと呼ぶ(関節値q又は関節空間qとも呼称する。)。操作空間xは、一般化変数qの時間微分値とヤコビアンJとを用いて、以下の数式(1)で定義される。
Figure JPOXMLDOC01-appb-M000001
 本実施形態では、例えば、qはアーム部420の関節部421a~421fにおける回転角度である。操作空間xに関する運動方程式は、下記数式(2)で記述される。
Figure JPOXMLDOC01-appb-M000002
 ここで、fは操作空間xに作用する力を表す。また、Λ-1は操作空間慣性逆行列、cは操作空間バイアス加速度と呼ばれるものであり、それぞれ下記数式(3)、(4)で表される。
Figure JPOXMLDOC01-appb-M000003
 なお、Hは関節空間慣性行列、τは関節値qに対応する関節力(例えば関節部421a~421fおける発生トルク)、bは重力、コリオリ力、遠心力を表す項である。
 一般化逆動力学においては、操作空間xに関する位置、速度の運動目的は、操作空間xの加速度として表現できることが知られている。このとき、上記数式(1)から、運動目的として与えられた目標値である操作空間加速度を実現するために、操作空間xに作用するべき仮想力fは、下記数式(5)のような一種の線形相補性問題(LCP:Linear Complementary Problem)を解くことによって得られる。
Figure JPOXMLDOC01-appb-M000004
 ここで、LとUはそれぞれ、fの第i成分の負の下限値(-∞を含む)、fの第i成分の正の上限値(+∞を含む)とする。上記LCPは、例えばIterative法、Pivot法、ロバスト加速度制御を応用する方法等を用いて解くことができる。
 なお、操作空間慣性逆行列Λ-1、バイアス加速度cは、定義式である上記数式(3)、(4)の通り算出すると計算コストが大きい。従って、多リンク構造体の一般化力(関節力τ)から一般化加速度(関節加速度)を得る準動力学計算(FWD)を応用することにより、操作空間慣性逆行列Λ-1の算出処理をより高速に算出する方法が提案されている。具体的には、操作空間慣性逆行列Λ-1、バイアス加速度cは、順動力学演算FWDを用いることにより、関節空間q、関節力τ、重力g等の多リンク構造体(例えば、アーム部420及び関節部421a~421f)に作用する力に関する情報から得ることができる。このように、操作空間に関する順動力学演算FWDを応用することにより、関節部の数Nに対してO(N)の計算量で操作空間慣性逆行列Λ-1を算出することができる。
 ここで、運動目的の設定例として、絶対値F以下の仮想力fviで操作空間加速度の目標値(xの2階微分に上付きバーを付して表す)を達成するための条件は、下記数式(6)で表現できる。
Figure JPOXMLDOC01-appb-M000005
 また、上述したように、操作空間xの位置、速度に関する運動目的は、操作空間加速度の目標値として表すことができ、具体的には下記数式(7)で表現される(操作空間xの位置、速度の目標値を、x、xの1階微分に上付きバーを付して表す)。
Figure JPOXMLDOC01-appb-M000006
 その他、分解操作空間の考え方を用いることにより、他の操作空間の線形和で表される操作空間(運動量、デカルト相対座標、連動関節等)に関する運動目的を設定することもできる。なお、競合する運動目的間には優先度を与える必要がある。優先度毎かつ低優先度から順に上記LCPを解き、前段のLCPで得られた仮想力を次段のLCPの既知外力として作用させることができる。
 (2-2-2.実在力算出処理)
 一般化逆動力学の第2段階である実在力算出処理では、上記(2-2-1.仮想力決定プロセス)で得られた仮想力fを、実在の関節力と外力で置換する処理を行う。仮想力による一般化力τ=J を関節部に生じる発生トルクτと外力fとで実現するための条件は、下記数式(8)で表現される。
Figure JPOXMLDOC01-appb-M000007
 ここで、添え字aは駆動関節部の集合(駆動関節集合)を表し、添え字uは非駆動関節部の集合(非駆動関節集合)を表す。すなわち、上記数式(8)の上段は非駆動関節部による空間(非駆動関節空間)の力の釣り合いを表しており、下段は駆動関節部による空間(駆動関節空間)の力の釣合いを表している。Jvu、Jvaは、それぞれ、仮想力fが作用する操作空間に関するヤコビアンの非駆動関節成分、駆動関節成分である。Jeu、Jeaは、外力fが作用する操作空間に関するヤコビアンの非駆動関節成分、駆動関節成分である。Δfは仮想力fのうち、実在力で実現不能な成分を表す。
 上記数式(8)の上段は不定であり、例えば下記数式(9)に示すような2次計画問題(QP:Quadratic Programing Problem)を解くことで、f及びΔfを得ることができる。
Figure JPOXMLDOC01-appb-M000008
 ここで、εは上記数式(8)の上段の両辺の差であり、数式(8)の等式誤差を表す。ξはfとΔfとの連結ベクトルであり、変数ベクトルを表す。Q及びQは、最小化の際の重みを表す正定値対称行列である。また、上記数式(9)の不等式拘束は、垂直反力、摩擦錐、外力の最大値、支持多角形等、外力に関する拘束条件を表現するのに用いられる。例えば、矩形の支持多角形に関する不等式拘束は、下記数式(10)のように表現される。
Figure JPOXMLDOC01-appb-M000009
 ここで、zは接触面の法線方向を表し、x及びyはzに垂直な直交2接線方向を表す。(F,F,F)及び(M,M,M)は、接触点に作用する外力及び外力モーメントである。μ及びμは、それぞれ並進、回転に関する摩擦係数である。(d,d)は支持多角形のサイズを表している。
 上記数式(9)、(10)から、最小ノルム又は最小誤差の解f、Δfが求められる。上記数式(9)から得られたf、Δfを上記数式(8)の下段に代入することにより、運動目的を実現するために必要な関節力τを得ることができる。
 基底が固定され、非駆動関節が無い系の場合は、関節力のみで全ての仮想力を置換可能であり、上記数式(8)において、f=0、Δf=0とすることができる。この場合、上記数式(8)の下段から、関節力τについて以下の数式(11)を得ることができる。
Figure JPOXMLDOC01-appb-M000010
 以上、本実施形態に係る一般化逆動力学を用いた全身協調制御について説明した。上記のように、仮想力算出処理及び実在力算出処理を順に行うことにより、所望の運動目的を達成するための関節力τを得ることができる。すなわち、逆に言えば、算出された関節力τを関節部421a~421fの運動における理論モデルに反映することにより、関節部421a~421fが、所望の運動目的を達成するように駆動される。
 なお、ここまで説明した一般化逆動力学を用いた全身協調制御について、特に、仮想力fの導出過程や、上記LCPを解き仮想力fを求める方法、QP問題の解法等の詳細については、例えば、本願出願人による先行特許出願である特開2009-95959号公報や特開2010-188471号公報を参照することができる。
 [2-3.理想関節制御について]
 次に、本実施形態に係る理想関節制御について説明する。各関節部421a~421fの運動は、下記数式(12)の二次遅れ系の運動方程式によってモデル化される。
Figure JPOXMLDOC01-appb-M000011
 ここで、Iは関節部における慣性モーメント(イナーシャ)、τは関節部421a~421fの発生トルク、τは外部から各関節部421a~421fに作用する外トルク、νは各関節部421a~421fにおける粘性抵抗係数である。上記数式(12)は、関節部421a~421fにおけるアクチュエータ430の運動を表す理論モデルとも言える。
 上記[2-2.一般化逆動力学について]で説明したように、一般化逆動力学を用いた演算により、運動目的及び拘束条件を用いて、当該運動目的を実現するために各関節部421a~421fに作用させるべき実在力であるτを算出することができる。従って、理想的には、算出された各τを上記数式(12)に適用することにより、上記数式(12)に示す理論モデルに従った応答が実現する、すなわち、所望の運動目的が達成されるはずである。
 しかし、実際には、様々な外乱の影響により、関節部421a~421fの運動と上記数式(12)に示すような理論モデルとの間には誤差(モデル化誤差)が生じる場合がある。モデル化誤差は、多リンク構造体の重量、重心、慣性テンソル等のマスプロパティに起因するものと、における関節部421a~421f内部における摩擦や慣性等に起因するものとに大別することができる。このうち、前者のマスプロパティに起因するモデル化誤差は、CAD(Computer Aided Design)データの高精度化や同定手法の適用によって、理論モデル構築時に比較的容易に低減することが可能である。
 一方、後者の関節部421a~421f内部の摩擦や慣性等に起因するモデル化誤差は、例えば関節部421a~421fの減速機426における摩擦等、モデル化が困難な現象に起因しており、理論モデル構築時に無視できないモデル化誤差が残留し得る。また、上記数式(12)におけるイナーシャIや粘性抵抗係数νの値と、実際の関節部421a~421fにおけるこれらの値との間に誤差が生じている可能性がある。これらのモデル化が困難な誤差は、関節部421a~421fの駆動制御において外乱となり得る。従って、このような外乱の影響により、実際には、関節部421a~421fの運動は、上記数式(12)に示す理論モデル通りには応答しない場合がある。よって、一般化逆動力学によって算出された関節力である実在力τを適用しても、制御目標である運動目的が達成されない場合が生じる。本実施形態では、各関節部421a~421fにアクティブな制御系を付加することで、上記数式(12)に示す理論モデルに従った理想応答を行うよう、関節部421a~421fの応答を補正することを考える。具体的には、本実施形態では、関節部421a~421fのトルクセンサ428、428aを用いた摩擦補償型のトルク制御を行うに留まらず、要求される発生トルクτ、外トルクτに対して、イナーシャI及び粘性抵抗係数νに至るまで理論値に従った理想応答を行うことが可能となる。
 本実施形態では、このように、ロボットアーム装置400の関節部421a~421fが上記数式(12)に示すような理想的な応答を行うように関節部の駆動を制御することを、理想関節制御と呼称する。ここで、以下の説明では、当該理想関節制御によって駆動が制御されるアクチュエータのことを、理想的な応答が行われることから仮想アクチュエータ(VA:Virtualized Actuator)とも呼称する。以下、図5を参照して、本実施形態に係る理想関節制御について説明する。
 図5は、本開示の一実施形態に係る理想関節制御について説明するための説明図である。なお、図5では、理想関節制御に係る各種の演算を行う概念上の演算器をブロックで模式的に図示している。
 図5を参照すると、アクチュエータ610は、図3に示すアクチュエータ430の機構を模式的に表しており、モータ(Motor)611、減速機(Reduction Gear)612、エンコーダ(Encoder)613及びトルクセンサ(Torque Sensor)614は、それぞれ、図3に示すモータ424、減速機426、エンコーダ427及びトルクセンサ428(又は図4Bに示すトルクセンサ428a)に対応している。
 ここで、アクチュエータ610が上記数式(12)で表される理論モデルに従った応答を行なうことは、上記数式(12)の右辺が与えられたときに、左辺の回転角加速度が達成されることに他ならない。また、上記数式(12)に示すように、理論モデルには、アクチュエータ610に作用する外トルク項τが含まれている。本実施形態では、理想関節制御を行うために、トルクセンサ614によって外トルクτを測定する。また、エンコーダ613によって測定されたアクチュエータ610の回転角度qに基づいて外乱に起因するトルクの推定値である外乱推定値τを算出するために、外乱オブザーバ620を適用する。
 ブロック631は、上記数式(12)に示す関節部421a~421fの理想的な関節モデル(Ideal Joint Model)に従った演算を行う演算器を表している。ブロック631は、発生トルクτ、外トルクτ、回転角速度(回転角度qの1階微分)を入力として、上記数式(12)の左辺に示す回転角加速度目標値(回転角目標値qrefの2階微分)を出力することができる。
 本実施形態では、上記[2-2.一般化逆動力学について]で説明した方法によって算出された発生トルクτと、トルクセンサ614によって測定された外トルクτが、ブロック631に入力される。一方、微分演算を行う演算器を表すブロック632に、エンコーダ613によって測定された回転角度qが入力されることにより、回転角速度(回転角度qの1階微分)が算出される。上記発生トルクτ及び外トルクτに加えて、ブロック632によって算出された回転角速度がブロック631に入力されることにより、ブロック631によって回転角加速度目標値が算出される。算出された回転角加速度目標値は、ブロック633に入力される。
 ブロック633は、アクチュエータ610の回転角加速度に基づいてアクチュエータ610に生じるトルクを算出する演算器を表す。本実施形態においては、具体的には、ブロック633は、回転角加速度目標値にアクチュエータ610における公称イナーシャ(ノミナルイナーシャ)Jを乗じることにより、トルク目標値τrefを得ることができる。理想の応答においては、アクチュエータ610に当該トルク目標値τrefを生じさせることにより、所望の運動目的が達成されるはずであるが、上述したように、実際の応答には外乱等の影響が生じる場合がある。従って、本実施形態においては、外乱オブザーバ620によって外乱推定値τを算出し、外乱推定値τを用いて当該トルク目標値τrefを補正する。
 外乱オブザーバ620の構成について説明する。図5に示すように、外乱オブザーバ620は、トルク指令値τと、エンコーダ613によって測定された回転角度qから算出される回転角速度に基づいて、外乱推定値τを算出する。ここで、トルク指令値τは、外乱の影響が補正された後の、最終的にアクチュエータ610に生じさせるトルク値である。例えば、外乱推定値τが算出されていない場合には、トルク指令値τはトルク目標値τrefとなる。
 外乱オブザーバ620は、ブロック634とブロック635とから構成される。ブロック634は、アクチュエータ610の回転角速度に基づいてアクチュエータ610に生じるトルクを算出する演算器を表す。本実施形態においては、具体的には、エンコーダ613によって測定された回転角度qから、ブロック632によって算出された回転角速度がブロック634に入力される。ブロック634は、伝達関数Jsによって表される演算を行うことにより、すなわち、当該回転角速度を微分することにより回転角加速度を求め、更に算出された回転角加速度にノミナルイナーシャJを乗じることにより、実際にアクチュエータ610に作用しているトルクの推定値(トルク推定値)を算出することができる。
 外乱オブザーバ620内では、当該トルク推定値とトルク指令値τとの差分が取られることにより、外乱によるトルクの値である外乱推定値τが推定される。具体的には、外乱推定値τは、前周の制御におけるトルク指令値τと、今回の制御におけるトルク推定値との差分であってよい。ブロック634によって算出されるトルク推定値は実際の測定値に基づくものであり、ブロック633によって算出されたトルク指令値τはブロック631に示す関節部421a~421fの理想的な理論モデルに基づくものであるため、両者の差分を取ることによって、上記理論モデルでは考慮されていない外乱の影響を推定することができるのである。
 また、外乱オブザーバ620には、系の発散を防ぐために、ブロック635に示すローパスフィルター(LPF:Low Pass Filter)が設けられる。ブロック635は、伝達関数g/(s+g)で表される演算を行うことにより、入力された値に対して低周波成分のみを出力し、系を安定化させる。本実施形態では、ブロック634によって算出されたトルク推定値とトルク指令値τrefとの差分値は、ブロック635に入力され、その低周波成分が外乱推定値τとして算出される。
 本実施形態では、トルク目標値τrefに外乱オブザーバ620によって算出された外乱推定値τを加算するフィードフォワード制御が行われることにより、最終的にアクチュエータ610に生じさせるトルク値であるトルク指令値τが算出される。そして、トルク指令値τに基づいてアクチュエータ610が駆動される。具体的には、トルク指令値τが対応する電流値(電流指令値)に変換され、当該電流指令値がモータ611に印加されることにより、アクチュエータ610が駆動される。
 以上、図5を参照して説明した構成を取ることにより、本実施形態に係る関節部421a~421fの駆動制御においては、摩擦等の外乱成分があった場合であっても、アクチュエータ610の応答を目標値に追従させることが可能となる。また、関節部421a~421fの駆動制御について、理論モデルが仮定するイナーシャI及び粘性抵抗係数νに従った理想応答を行うことが可能となる。
 なお、以上説明した理想関節制御の詳細については、例えば、本願出願人による先行特許出願である特開2009-269102号公報を参照することができる。
 以上、本実施形態において用いられる一般化逆動力学について説明するとともに、図5を参照して本実施形態に係る理想関節制御について説明した。以上説明したように、本実施形態においては、一般化逆動力学を用いることにより、アーム部420の運動目的を達成するための各関節部421a~421fの駆動パラメータ(例えば関節部421a~421fの発生トルク値)を、拘束条件を考慮して算出する、全身協調制御が行われる。また、図5を参照して説明したように、本実施形態においては、上記一般化逆動力学を用いた全身協調制御により算出された発生トルク値に対して外乱の影響を考慮した補正を行うことにより、関節部421a~421fの駆動制御において理論モデルに基づいた理想的な応答を実現する、理想関節制御が行われる。従って、本実施形態においては、アーム部420の駆動について、運動目的を達成する高精度な駆動制御が可能となる。
 [2-4.ロボットアーム制御システムの構成]
 次に、上記[2-2.一般化逆動力学について]及び上記[2-3.理想関節制御について]で説明した全身協調制御や理想関節制御がロボットアーム装置の駆動制御に適用された、本実施形態に係るロボットアーム制御システムの構成について説明する。
 図6を参照して、本開示の一実施形態に係るロボットアーム制御システムの一構成例について説明する。図6は、本開示の一実施形態に係るロボットアーム制御システムの一構成例を示す機能ブロック図である。なお、図6に示すロボットアーム制御システムでは、ロボットアーム装置のアーム部の駆動の制御に関わる構成について主に図示している。
 図6を参照すると、本開示の一実施形態に係るロボットアーム制御システム1は、ロボットアーム装置10、制御装置20及び表示装置30を備える。本実施形態においては、制御装置20によって、上記[2-2.一般化逆動力学について]で説明した全身協調制御及び上記[2-3.理想関節制御について]で説明した理想関節制御における各種の演算が行われ、その演算結果に基づいてロボットアーム装置10のアーム部の駆動が制御される。また、ロボットアーム装置10のアーム部には後述する撮像部140が設けられており、撮像部140によって撮影された画像が表示装置30の表示画面に表示される。以下、ロボットアーム装置10、制御装置20及び表示装置30の構成について詳細に説明する。
 ロボットアーム装置10は、複数の関節部と複数のリンクから構成される多リンク構造体であるアーム部を有し、当該アーム部を可動範囲内で駆動させることにより、当該アーム部の先端に設けられる先端ユニットの位置及び姿勢の制御を行う。ロボットアーム装置10は、図2に示すロボットアーム装置400に対応している。
 図6を参照すると、ロボットアーム装置10は、アーム制御部110及びアーム部120を有する。また、アーム部120は、関節部130及び撮像部140を有する。
 アーム制御部110は、ロボットアーム装置10を統合的に制御するとともに、アーム部120の駆動を制御する。アーム制御部110は、図2を参照して説明した制御部(図2には図示せず。)に対応している。具体的には、アーム制御部110は駆動制御部111を有し、駆動制御部111からの制御によって関節部130の駆動が制御されることにより、アーム部120の駆動が制御される。より具体的には、駆動制御部111は、関節部130のアクチュエータにおけるモータに対して供給される電流量を制御することにより、当該モータの回転数を制御し、関節部130における回転角度及び発生トルクを制御する。ただし、上述したように、駆動制御部111によるアーム部120の駆動制御は、制御装置20における演算結果に基づいて行われる。従って、駆動制御部111によって制御される、関節部130のアクチュエータにおけるモータに対して供給される電流量は、制御装置20における演算結果に基づいて決定される電流量である。
 アーム部120は、複数の関節部と複数のリンクから構成される多リンク構造体であり、アーム制御部110からの制御によりその駆動が制御される。アーム部120は、図2に示すアーム部420に対応している。アーム部120は、関節部130及び撮像部140を有する。なお、アーム部120が有する複数の関節部の機能及び構成は互いに同様であるため、図6では、それら複数の関節部を代表して1つの関節部130の構成を図示している。
 関節部130は、アーム部120においてリンク間を互いに回動可能に連結するとともに、アーム制御部110からの制御によりその回転駆動が制御されることによりアーム部120を駆動する。関節部130は、図2に示す関節部421a~421fに対応している。また、関節部130は、アクチュエータを有し、当該アクチュエータの構成は、例えば図3、図4A及び図4Bに示す構成と同様である。
 関節部130は、関節駆動部131及び関節状態検出部132を有する。
 関節駆動部131は、関節部130のアクチュエータにおける駆動機構であり、関節駆動部131が駆動することにより関節部130が回転駆動する。関節駆動部131は、駆動制御部111によってその駆動が制御される。例えば、関節駆動部131は、図3に示すモータ424及びモータドライバ425に対応する構成であり、関節駆動部131が駆動することは、モータドライバ425が駆動制御部111からの指令に応じた電流量でモータ424を駆動することに対応している。
 関節状態検出部132は、関節部130の状態を検出する。ここで、関節部130の状態とは、関節部130の運動の状態を意味していてよい。例えば、関節部130の状態には、関節部130の回転角度、回転角速度、回転角加速度、発生トルク等の情報が含まれる。本実施形態においては、関節状態検出部132は、関節部130の回転角度を検出する回転角度検出部133及び関節部130の発生トルク及び外トルクを検出するトルク検出部134を有する。なお、回転角度検出部133及びトルク検出部134は、図3に示すアクチュエータ430のエンコーダ427及び図4A及び図4Bに示すトルクセンサ428、428aに、それぞれ対応している。関節状態検出部132は、検出した関節部130の状態を制御装置20に送信する。
 撮像部140は、アーム部120の先端に設けられる先端ユニットの一例であり、撮影対象の画像を取得する。撮像部140は、図2に示す撮像ユニット423に対応している。具体的には、撮像部140は、撮影対象を動画や静止画の形式で撮影することのできるカメラ等である。より具体的には、撮像部140は、2次元上に配列された複数の受光素子を有し、当該受光素子における光電変換により、撮影対象の画像を表す画像信号を取得することができる。撮像部140は、取得した画像信号を表示装置30に送信する。
 なお、図2に示すロボットアーム装置400において撮像ユニット423がアーム部420の先端に設けられていたように、ロボットアーム装置10においても、実際には撮像部140がアーム部120の先端に設けられている。図6では、撮像部140が複数の関節部130及び複数のリンクを介して最終段のリンクの先端に設けられる様子を、関節部130と撮像部140との間にリンクを模式的に図示することにより表現している。
 なお、本実施形態においては、アーム部120の先端には先端ユニットとして各種の医療用器具が接続され得る。当該医療用器具としては、例えば、メスや鉗子等の各種の施術器具や、超音波検査装置の探触子等の各種の検査装置の一ユニット等、施術に際して用いられる各種のユニットが挙げられる。また、本実施形態では、図6に示す撮像部140や、内視鏡、顕微鏡等の撮像機能を有するユニットも医療用器具に含まれてよい。このように、本実施形態に係るロボットアーム装置10は、医療用器具を備えた医療用ロボットアーム装置であると言える。同様に、本実施形態に係るロボットアーム制御システム1は、医療用ロボットアーム制御システムであると言える。なお、図6に示すロボットアーム装置10は、撮像機能を有するユニットを先端ユニットとして備えるビデオ顕微鏡用ロボットアーム装置であるとも言える。また、アーム部120の先端に、2つの撮像ユニット(カメラユニット)を有するステレオカメラが設けられ、撮像対象を3D画像として表示するように撮影が行われてもよい。
 以上、ロボットアーム装置10の機能及び構成について説明した。次に、制御装置20の機能及び構成について説明する。図6を参照すると、制御装置20は、入力部210、記憶部220及び制御部230を有する。
 制御部230は、制御装置20を統合的に制御するとともに、ロボットアーム装置10におけるアーム部120の駆動を制御するための各種の演算を行う。具体的には、制御部230は、ロボットアーム装置10のアーム部120の駆動を制御するために、全身協調制御及び理想関節制御における各種の演算を行う。以下、制御部230の機能及び構成について詳しく説明するが、全身協調制御及び理想関節制御については、上記[2-2.一般化逆動力学について]及び上記[2-3.理想関節制御について]で既に説明しているため、ここでは詳しい説明は省略する。
 制御部230は、全身協調制御部240及び理想関節制御部250を有する。
 全身協調制御部240は、一般化逆動力学を用いた全身協調制御に関する各種の演算を行う。本実施形態では、全身協調制御部240は、関節状態検出部132によって検出された関節部130の状態に基づいてアーム部120の状態(アーム状態)を取得する。また、全身協調制御部240は、当該アーム状態と、アーム部120の運動目的及び拘束条件と、に基づいて、操作空間におけるアーム部120の全身協調制御のための制御値を、一般化逆動力学を用いて算出する。なお、操作空間とは、例えばアーム部120に作用する力とアーム部120に発生する加速度との関係を記述するための空間である。
 全身協調制御部240は、アーム状態取得部241、演算条件設定部242、仮想力算出部243及び実在力算出部244を有する。
 アーム状態取得部241は、関節状態検出部132によって検出された関節部130の状態に基づいて、アーム部120の状態(アーム状態)を取得する。ここで、アーム状態とは、アーム部120の運動の状態を意味していてよい。例えば、アーム状態には、アーム部120の位置、速度、加速度、力等の情報が含まれる。上述したように、関節状態検出部132は、関節部130の状態として、各関節部130における回転角度、回転角速度、回転角加速度、発生トルク等の情報を取得している。また、後述するが、記憶部220は、制御装置20によって処理される各種の情報を記憶するものであり、本実施形態においては、記憶部220には、アーム部120に関する各種の情報(アーム情報)、例えばアーム部120を構成する関節部130及びリンクの数や、リンクと関節部130との接続状況、リンクの長さ等の情報が格納されていてよい。アーム状態取得部241は、記憶部220から当該アーム情報を取得することができる。従って、アーム状態取得部241は、関節部130の状態とアーム情報とに基づいて、複数の関節部130、複数のリンク及び撮像部140の空間上の位置(座標)(すなわち、アーム部120の形状や撮像部140の位置及び姿勢)や、各関節部130、リンク及び撮像部140に作用している力等の情報をアーム状態として取得することができる。アーム状態取得部241は、取得したアーム情報を演算条件設定部242に送信する。
 演算条件設定部242は、一般化逆動力学を用いた全身協調制御に関する演算における演算条件を設定する。ここで、演算条件とは、運動目的及び拘束条件であってよい。運動目的は、アーム部120の運動に関する各種の情報であってよい。具体的には、運動目的は、撮像部140の位置及び姿勢(座標)、速度、加速度並びに力等の目標値であったり、アーム部120の複数の関節部130及び複数のリンクの位置(座標)、速度、加速度及び力等の目標値であったりしてもよい。また、拘束条件は、アーム部120の運動を制限(拘束)する各種の情報であってよい。具体的には、拘束条件は、アーム部の各構成部材が移動不可能な領域の座標や、移動不可能な速度、加速度の値、発生不可能な力の値等であってよい。また、拘束条件における各種の物理量の制限範囲は、アーム部120の構造的に実現することが不可能であることから設定されてもよいし、ユーザによって適宜設定されてもよい。また、演算条件設定部242は、アーム部120の構造についての物理モデル(例えば、アーム部120を構成するリンクの数や長さ、リンクの関節部130を介した接続状況、関節部130の可動範囲等がモデル化されたもの)を有し、当該物理モデルに、所望の運動条件及び拘束条件が反映された制御モデルを生成することにより、運動条件及び拘束条件を設定してもよい。
 本実施形態においては、運動目的及び拘束条件を適切に設定することにより、アーム部120に所望の動作を行わせることが可能となる。例えば、運動目的として、撮像部140の位置の目標値を設定することにより撮像部140をその目標の位置に移動させることはもちろんのこと、アーム部120が空間上の所定の領域内に侵入しないようにする等、拘束条件によって移動の制約を設けてアーム部120を駆動させることも可能である。
 運動目的の具体例として、例えば、運動目的は、撮像部140の撮影方向が施術部位に固定された状態で、撮像部140が施術部位を頂点とした円錐の面内を移動する、当該円錐の軸を旋回軸とした旋回動作である、ピボット動作であってもよい。また、当該ピボット動作においては、撮像部140と円錐の頂点に当たる点との距離が一定に保たれた状態で旋回動作が行われてもよい。このようなピボット動作を行うことにより、観察部位を等距離からかつ異なる角度から観察できるようになるため、手術を行うユーザの利便性を向上させることができる。
 また、他の具体例として、運動目的は、各関節部130における発生トルクを制御する内容であってもよい。具体的には、運動目的は、アーム部120に作用する重力を打ち消すように関節部130の状態を制御するとともに、更に外部から与えられた力の方向へのアーム部120の移動をサポートするように関節部130の状態を制御するパワーアシスト動作であってもよい。より具体的には、パワーアシスト動作においては、アーム部120の各関節部130における重力による外トルクを打ち消す発生トルクを各関節部130に生じさせるように各関節部130の駆動が制御されることにより、アーム部120の位置及び姿勢が所定の状態で保持される。この状態で更に外部から(例えばユーザから)外トルクが加えられた場合に、与えられた外トルクと同じ方向の発生トルクを各関節部130に生じさせるように各関節部130の駆動が制御される。このようなパワーアシスト動作を行うことにより、ユーザが手動でアーム部120を動かす場合に、ユーザはより小さい力でアーム部120を移動させることができるため、あたかも無重力下でアーム部120を動かしているような感覚をユーザに対して与えることができる。また、上述したピボット動作と当該パワーアシスト動作とを組み合わせることも可能である。
 ここで、本実施形態において、運動目的とは、全身協調制御において実現されるアーム部120の動作(運動)を意味していてもよいし、当該動作における瞬時的な運動目的(すなわち、運動目的における目標値)を意味していてもよい。例えば上記のピボット動作であれば、撮像部140がピボット動作を行うこと自体が運動目的であるが、ピボット動作を行っている最中においては、当該ピボット動作における円錐面内での撮像部140の位置や速度等の値が、瞬時的な運動目的(当該運動目的における目標値)として設定されている。また例えば上記のパワーアシスト動作であれば、外部から加えられた力の方向へのアーム部120の移動をサポートするパワーアシスト動作を行うこと自体が運動目的であるが、パワーアシスト動作を行っている最中においては、各関節部130に加えられる外トルクと同じ方向への発生トルクの値が、瞬時的な運動目的(当該運動目的における目標値)として設定されている。本実施形態における運動目的は、瞬時的な運動目的(例えばある時間におけるアーム部120の各構成部材の位置や速度、力等の目標値)と、瞬時的な運動目的が連続的に達成された結果、経時的に実現されるアーム部120の各構成部材の動作の、双方を含む概念である。全身協調制御部240における全身協調制御のための演算における各ステップでは瞬時的な運動目的がその都度設定され、当該演算が繰り返し行われることにより、最終的に所望の運動目的が達成される。
 なお、本実施形態においては、運動目的が設定される際に、各関節部130の回転運動における粘性抵抗係数も適宜設定されてよい。上述したように、本実施形態に係る関節部130は、アクチュエータ430の回転運動における粘性抵抗係数を適宜調整できるように構成される。従って、運動目的の設定に際して各関節部130の回転運動における粘性抵抗係数も設定することにより、例えば外部から加えられる力に対して回転しやすい状態や回転し難い状態を実現することができる。例えば上述したパワーアシスト動作であれば、関節部130における粘性抵抗係数が小さく設定されることにより、ユーザがアーム部120を移動させる際に要する力がより小さくてよく、ユーザに与えられる無重力感がより助長される。このように、各関節部130の回転運動における粘性抵抗係数は、運動目的の内容に応じて適宜設定されてよい。
 なお、運動目的の具体例については、下記[2-5.運動目的の具体例]で改めて詳しく説明する。
 ここで、本実施形態においては、後述するように、記憶部220には、全身協調制御に関する演算において用いられる運動目的や拘束条件等の演算条件に関するパラメータが格納されていてもよい。演算条件設定部242は、記憶部220に記憶されている拘束条件を、全身協調制御の演算に用いる拘束条件として設定することができる。
 また、本実施形態においては、演算条件設定部242は、複数の方法によって運動目的を設定することができる。例えば、演算条件設定部242は、アーム状態取得部241から送信されるアーム状態に基づいて運動目的を設定してもよい。上述したように、アーム状態には、アーム部120の位置の情報やアーム部120に対して作用する力の情報が含まれる。従って、例えばユーザがアーム部120を手動で移動させようとしている場合には、アーム状態取得部241によって、ユーザがアーム部120をどのように移動させようとしているか、に関する情報もアーム状態として取得される。従って、演算条件設定部242は、取得されたアーム状態に基づいて、ユーザがアーム部120を移動させた位置や速度、力等を瞬時的な運動目的として設定することができる。このように運動目的が設定されることにより、アーム部120の駆動は、ユーザによるアーム部120の移動を追随し、サポートするように制御される。
 また、例えば、演算条件設定部242は、入力部210からユーザによって入力される指示に基づいて運動目的を設定してもよい。後述するが、入力部210は、ユーザが制御装置20にロボットアーム装置10の駆動制御に関する情報や命令等を入力するための入力インターフェースであり、本実施形態においては、ユーザによる入力部210からの操作入力に基づいて、運動目的が設定されてもよい。具体的には、入力部210は、例えばレバー、ペダル等のユーザが操作する操作手段を有し、当該レバー、ペダル等の操作に応じて、アーム部120の各構成部材の位置や速度等が、演算条件設定部242によって瞬時的な運動目的として設定されてもよい。
 更に、例えば、演算条件設定部242は、記憶部220に記憶されている運動目的を、全身協調制御の演算に用いる運動目的として設定してもよい。例えば、空間上の所定の点で撮像部140が静止するという運動目的であれば、当該所定の点の座標を運動目的として予め設定することができる。また、例えば、撮像部140が空間上において所定の軌跡上を移動するという運動目的であれば、当該所定の軌跡を表す各点の座標を運動目的として予め設定することができる。このように、運動目的が予め設定できるものである場合には、当該運動目的が予め記憶部220に記憶されていてもよい。また、例えば上述したピボット動作であれば、運動目的は円錐の面内における位置や速度等を目標値とするものに限られるし、パワーアシスト動作であれば、運動目的は力を目標値とするものに限られる。このように、ピボット動作やパワーアシスト動作のような運動目的が予め設定されている場合には、これらの運動目的における瞬時的な運動目的として設定され得る目標値の範囲や種類等に関する情報が、記憶部220に記憶されていてもよい。演算条件設定部242は、このような運動目的に関する各種の情報も含めて、運動目的として設定することができる。
 なお、演算条件設定部242が、上記のいずれの方法で運動目的を設定するかは、ロボットアーム装置10の用途等に応じてユーザによって適宜設定可能であってよい。また、演算条件設定部242は、また、上記の各方法を適宜組み合わせることにより、運動目的及び拘束条件を設定してもよい。なお、記憶部220に格納されている拘束条件の中に運動目的の優先度が設定されていてもよく、複数の互いに異なる運動目的が存在する場合には、演算条件設定部242は、当該拘束条件の優先度に応じて運動目的を設定してもよい。演算条件設定部242は、アーム状態並びに設定した運動目的及び拘束条件を仮想力算出部243に送信する。
 仮想力算出部243は、一般化逆動力学を用いた全身協調制御に関する演算における仮想力を算出する。仮想力算出部243が行う仮想力の算出処理は、例えば、上記(2-2-1.仮想力算出処理)で説明した一連の処理であってよい。仮想力算出部243は、算出した仮想力fを実在力算出部244に送信する。
 実在力算出部244は、一般化逆動力学を用いた全身協調制御に関する演算における実在力を算出する。実在力算出部244が行う実在力の算出処理は、例えば、上記(2-2-2.実在力算出処理)で説明した一連の処理であってよい。実在力算出部244は、算出した実在力(発生トルク)τを理想関節制御部250に送信する。なお、本実施形態においては、実在力算出部244によって算出された発生トルクτのことを、全身協調制御における関節部130の制御値という意味で、制御値又は制御トルク値とも呼称する。
 理想関節制御部250は、一般化逆動力学を用いた理想関節制御に関する各種の演算を行う。本実施形態では、理想関節制御部250は、実在力算出部244によって算出された発生トルクτに対して外乱の影響を補正することにより、アーム部120の理想的な応答を実現するトルク指令値τを算出する。なお、理想関節制御部250によって行われる演算処理は、上記[2-3.理想関節制御について]で説明した一連の処理に対応している。
 理想関節制御部250は、外乱推定部251及び指令値算出部252を有する。
 外乱推定部251は、トルク指令値τと、回転角度検出部133によって検出された回転角度qから算出される回転角速度に基づいて、外乱推定値τを算出する。なお、ここでいうトルク指令値τは、最終的にロボットアーム装置10に送信されるアーム部120での発生トルクを表す指令値である。このように、外乱推定部251は、図5に示す外乱オブザーバ620に対応する機能を有する。
 指令値算出部252は、外乱推定部251によって算出された外乱推定値τを用いて、最終的にロボットアーム装置10に送信されるアーム部120に生じさせるトルクを表す指令値であるトルク指令値τを算出する。具体的には、指令値算出部252は、上記数式(12)に示す関節部130の理想モデルから算出されるτrefに外乱推定部251によって算出された外乱推定値τを加算することにより、トルク指令値τを算出する。例えば、外乱推定値τが算出されていない場合には、トルク指令値τはトルク目標値τrefとなる。このように、指令値算出部252の機能は、図5に示す外乱オブザーバ620以外の機能に対応している。
 以上説明したように、理想関節制御部250においては、外乱推定部251と指令値算出部252との間で繰り返し情報のやり取りが行われることにより、図5を参照して説明した一連の処理が行われる。理想関節制御部250は算出したトルク指令値τをロボットアーム装置10の駆動制御部111に送信する。駆動制御部111は、送信されたトルク指令値τに対応する電流量を、関節部130のアクチュエータにおけるモータに対して供給する制御を行うことにより、当該モータの回転数を制御し、関節部130における回転角度及び発生トルクを制御する。
 本実施形態に係るロボットアーム制御システム1においては、ロボットアーム装置10におけるアーム部120の駆動制御は、アーム部120を用いた作業が行われている間継続的に行われるため、ロボットアーム装置10及び制御装置20における以上説明した処理が繰り返し行われる。すなわち、ロボットアーム装置10の関節状態検出部132によって関節部130の状態が検出され、制御装置20に送信される。制御装置20では、当該関節部130の状態と、運動目的及び拘束条件とに基づいて、アーム部120の駆動を制御するための全身協調制御及び理想関節制御に関する各種の演算が行われ、演算結果としてのトルク指令値τがロボットアーム装置10に送信される。ロボットアーム装置10では、当該トルク指令値τに基づいてアーム部120の駆動が制御され、駆動中又は駆動後の関節部130の状態が、再び関節状態検出部132によって検出される。
 制御装置20が有する他の構成についての説明を続ける。
 入力部210は、ユーザが制御装置20にロボットアーム装置10の駆動制御に関する情報や命令等を入力するための入力インターフェースである。本実施形態においては、ユーザによる入力部210からの操作入力に基づいて、ロボットアーム装置10のアーム部120の駆動が制御され、撮像部140の位置及び姿勢が制御されてもよい。具体的には、上述したように、ユーザによって入力部210から入力されたアームの駆動の指示に関する指示情報が演算条件設定部242に入力されることにより、演算条件設定部242が当該指示情報に基づいて全身協調制御における運動目的を設定してもよい。このように、ユーザが入力した指示情報に基づく運動目的を用いて全身協調制御が行われることにより、ユーザの操作入力に応じたアーム部120の駆動が実現される。
 具体的には、入力部210は、例えばマウス、キーボード、タッチパネル、ボタン、スイッチ、レバー及びペダル等のユーザが操作する操作手段を有する。例えば入力部210がペダルを有する場合、ユーザは当該ペダルを足で操作することによりアーム部120の駆動を制御することができる。従って、ユーザが患者の施術部位に対して両手を使って処置を行っている場合であっても、足によるペダルの操作によって撮像部140の位置及び姿勢、すなわち、施術部位の撮影位置や撮影角度を調整することができる。
 記憶部220は、制御装置20によって処理される各種の情報を記憶する。本実施形態においては、記憶部220は、制御部230によって行われる全身協調制御及び理想関節制御に関する演算において用いられる各種のパラメータを記憶することができる。例えば、記憶部220は、全身協調制御部240による全身協調制御に関する演算において用いられる運動目的及び拘束条件を記憶していてもよい。記憶部220が記憶する運動目的は、上述したように、例えば撮像部140が空間上の所定の点で静止することのような、予め設定され得る運動目的であってよい。また、拘束条件は、アーム部120の幾何的な構成やロボットアーム装置10の用途等に応じて、ユーザによって予め設定され、記憶部220に格納されていてもよい。また、記憶部220には、アーム状態取得部241がアーム状態を取得する際に用いるアーム部120に関する各種の情報が記憶されていてもよい。更に、記憶部220には、制御部230による全身協調制御及び理想関節制御に関する演算における演算結果や演算過程で算出される各数値等が記憶されてもよい。このように、記憶部220には、制御部230によって行われる各種の処理に関するあらゆるパラメータが格納されていてよく、制御部230は、記憶部220と相互に情報を送受信しながら各種の処理を行うことができる。
 以上、制御装置20の機能及び構成について説明した。なお、本実施形態に係る制御装置20は、例えばPC(Personal Computer)やサーバ等の各種の情報処理装置(演算処理装置)によって構成することができる。次に、表示装置30の機能及び構成について説明する。
 表示装置30は、各種の情報を表示画面上にテキスト、イメージ等様々な形式で表示することにより、当該情報をユーザに対して視覚的に通知する。本実施形態においては、表示装置30は、ロボットアーム装置10の撮像部140によって撮影された画像を表示画面上に表示する。具体的には、表示装置30は、撮像部140によって取得された画像信号に各種の画像処理を施す画像信号処理部(図示せず。)や処理された画像信号に基づく画像を表示画面上に表示させる制御を行う表示制御部(図示せず。)等の機能及び構成を有する。なお、表示装置30は、上記の機能及び構成以外にも、一般的に表示装置が有する各種の機能及び構成を有してもよい。表示装置30は、図1に示す表示装置550に対応している。
 以上、図6を参照して、本実施形態に係るロボットアーム装置10、制御装置20及び表示装置30の機能及び構成について説明した。上記の各構成要素は、汎用的な部材や回路を用いて構成されていてもよいし、各構成要素の機能に特化したハードウェアにより構成されていてもよい。また、各構成要素の機能を、CPU等が全て行ってもよい。従って、本実施形態を実施する時々の技術レベルに応じて、適宜、利用する構成を変更することが可能である。
 以上説明したように、本実施形態によれば、ロボットアーム装置10における多リンク構造体であるアーム部120が、少なくとも6自由度以上の自由度を有するとともに、当該アーム部120を構成する複数の関節部130のそれぞれの駆動が駆動制御部111によって制御される。そして、当該アーム部120の先端には医療用器具が設けられる。このように、各関節部130の駆動が制御されることにより、より自由度の高いアーム部120の駆動制御が実現され、よりユーザにとって操作性の高い医療用のロボットアーム装置10が実現される。
 より具体的には、本実施形態によれば、ロボットアーム装置10において、関節状態検出部132によって関節部130の状態が検出される。そして、制御装置20において、当該関節部130の状態と、運動目的及び拘束条件とに基づいて、アーム部120の駆動を制御するための一般化逆動力学を用いた全身協調制御に関する各種の演算が行われ、演算結果としてのトルク指令値τが算出される。更に、ロボットアーム装置10において、当該トルク指令値τに基づいてアーム部120の駆動が制御される。このように、本実施形態においては、一般化逆動力学を用いた全身協調制御により、アーム部120の駆動が制御される。従って、力制御によるアーム部120の駆動制御が実現され、よりユーザにとって操作性の高いロボットアーム装置が実現される。また、本実施形態では、全身協調制御において、例えばピボット動作やパワーアシスト動作といった、よりユーザの利便性を向上させる各種の運動目的を実現する制御が可能となる。更に、本実施形態においては、例えばアーム部120を手動で移動させたり、ペダルからの操作入力により移動させたりといった、多様な駆動手段が実現されるため、ユーザの利便性の更なる向上が実現される。
 また、本実施形態においては、アーム部120の駆動制御について、全身協調制御と併せて理想関節制御が適用される。理想関節制御においては、関節部130内部の摩擦や慣性等の外乱成分を推定し、推定した外乱成分を用いたフィードフォワード制御が行われる。従って、摩擦等の外乱成分がある場合であっても、関節部130の駆動について理想的な応答を実現することができる。よって、アーム部120の駆動制御において、振動等の影響がより少ない、高精度の応答性と高い位置決め精度や安定性が実現される。
 更に、本実施形態においては、アーム部120を構成する複数の関節部130のそれぞれが、例えば図3に示すような、理想関節制御に適合した構成を有し、各関節部130における回転角度、発生トルク及び粘性抵抗係数を電流値によって制御することができる。このように、各関節部130の駆動が電流値によって制御され、また、全身協調制御により各関節部130の駆動がアーム部120全体の状態を把握しながら制御されるため、カウンターバランスが不要となり、ロボットアーム装置10の小型化が実現される。
 [2-5.運動目的の具体例]
 次に、本実施形態に係る運動目的の具体例について説明する。上記[2-4.ロボットアーム制御システムの構成]で説明したように、本実施形態においては、全身協調制御によって各種の運動目的が実現される。ここでは、本実施形態に係る運動目的の具体例として、パワーアシスト動作と、ピボット動作について説明する。なお、以下の運動目的の具体例についての説明では、図6に示す機能ブロック図における参照番号を用いて、本実施形態に係るロボットアーム制御システムの構成部材を表す。
 パワーアシスト動作は、アーム部120に作用する重力を打ち消すように関節部130の状態を制御するとともに、更に外部から与えられた力の方向へのアーム部120の移動をサポートするように関節部130の状態を制御する動作である。具体的には、ユーザがアーム部120を手動で動かす際に、ユーザによって加えられた力をサポートするようにアーム部120の駆動を制御する動作である。より具体的には、パワーアシスト動作を実現するために、まず、重力以外の力がアーム部120に作用していない状態における外トルクがトルク検出部134によって検出され、検出された外トルクを打ち消す発生トルクを各関節部130に生じさせるように、瞬時的な運動目的が設定される。この段階で、アーム部120の位置及び姿勢が所定の状態で保持される。この状態で更に外部から(例えばユーザから)外トルクが加えられた場合に、追加的に与えられた外トルクがトルク検出部134によって検出され、検出された追加的な外トルクと同じ方向の発生トルクを各関節部130に生じさせるという瞬時的な運動目的が更に設定される。このような瞬時的な運動目的に従って各関節部130の駆動が制御されることによりパワーアシスト動作が実現される。パワーアシスト動作により、ユーザはより小さい力でアーム部を移動させることができるため、あたかも無重力下でアーム部120を動かしているような感覚を得ることができ、ユーザによるアーム部120の操作性が向上する。
 ピボット動作は、アーム部120の先端に設けられる先端ユニットが、当該先端ユニットの向きが空間上の所定の点に固定された状態で、当該所定の点を頂点とした円錐の面上を移動する、当該円錐の軸を旋回軸とした旋回動作である。具体的に先端ユニットが撮像部140である場合であれば、ピボット動作は、アーム部120の先端に設けられる撮像部140が、撮像部140の撮影方向が空間上の所定の点に固定された状態で、当該所定の点を頂点とした円錐の面上を移動する、当該円錐の軸を旋回軸とした旋回動作である。ピボット動作における円錐の頂点に当たる点としては、例えば施術部位が選択される。また、ピボット動作においては、先端ユニット又は撮像部140と円錐の頂点に当たる点との距離が一定に保たれた状態で旋回動作が行われてもよい。なお、先端ユニットの向き又は撮像部140の撮影方向が空間上の所定の点(例えば施術部位)に固定されることから、ピボット動作はポイントロック動作とも呼ばれる。
 <3.操作速度に応じた制御>
 次に、本実施形態に係る、速度に応じたアーム部120の制御について説明する。前述したように、モータを動力源とするパワーアシスト型のロボットアームでは、安全かつ滑らかな操作感を実現することが難しい場合がある。例えば、操作者が過大な力をロボットアームに加えて動作させる場合、ロボットアームに過大な速度が発生して安全性が低下することが考えられる。また、操作者が急にロボットアームの動作を止める場合、ロボットアームに振動が起こり、操作性が低下することが考えられる。
 このため、本実施形態では、アーム部120を操作する速度に応じて、アーム部120を制御するための制御パラメータを変更することで、操作性及び安全性を向上させるようにしている。
 上述したように、図2に示す構成において、各関節部421a~421fのアクチュエータ430は、モータ424、モータドライバ425、減速機426、エンコーダ427、トルクセンサ428及び駆動軸429を有する。このため、アーム部120は、外力を各関節部421a~421fのトルクセンサ428で検出することができる。操作者は、アーム部120の先端または他の部位を保持し、操作力を加えることで、各関節部421a~421fに角加速度を発生させ、適切な位置へと移動させることができる。
 操作開始後、操作者は上述したようにアーム部120に力を加える。制御装置30では、与えられた操作力から、各関節部421a~421fを動作させるたに、各関節部421a~421fの角速度、角加速度、関節トルク値を算出する。そして、上述した数式(12)から目標関節角加速度(qの二階微分値、qはアーム部420の関節部421a~421fにおける回転角度)を算出する。
 なお、上述した数式(12)において、qは関節角度、qの一階微分値は関節角速度、qの2階微分値は関節角加速度、τは関節が発生すべきトルク、τeは関節に作用する外トルク、Iは関節部の慣性モーメント(イナーシャ)、νは関節部の粘性抵抗係数を表す。この慣性モーメントI、粘性抵抗係数νは関節の動特性を表している。慣性モーメントIは、加速度に対してどれだけ動きやすいかを示す値である。粘性抵抗係数νは速度に対するパラメータであり、粘性抵抗係数νの項は、数式(12)でマイナス(負)の項であるため、粘性抵抗係数νを大きくすると関節部421a~421fがより動きにくくなる。制御装置30は、数式(12)から得られた目標関節角加速度(qの二階微分値)を実現するようアーム部120の各アクチュエータ430へ指令値を送って動作させ、ユーザによる操作が終了するまで制御ループを繰り返す。なお、数式(12)において、τとτが釣り合うと関節部が静止した状態となる。
 図7は、図6の構成に対して、操作速度に応じた制御を実現するための構成を付加した構成を示す模式図である。図7に示す構成例では、図6の構成に対して、操作力制御部(パラメータ制御部)260が付加されている。操作力制御部260は、慣性モーメント制御部262、及び粘性抵抗係数制御部264を有して構成されている。
 上述したように、アーム状態取得部241は、関節状態検出部132によって検出された関節部130の状態に基づいて、アーム部120の状態(アーム状態)を取得する。ここで、アーム状態には、アーム部120の位置、速度、加速度、力等の情報が含まれる。従って、アーム状態取得部241は、ユーザによるアーム部120の操作に関するパラメータを取得することができる。
 慣性モーメント制御部262は、エンコーダ613によって測定された回転角度qから算出される回転角速度(回転角度qの1階微分)またはアームの手先速度(手先位置の1階微分)に基づいて、数式(12)の慣性モーメントIを算出する。同様に、粘性抵抗係数制御部264は、エンコーダ613によって測定された回転角度qから算出される回転角速度(回転角度qの1階微分)またはアームの手先速度(手先位置の1階微分)に基づいて、数式(12)の粘性抵抗係数νを算出する。
 また、上述したように、仮想力算出処理及び実在力算出処理を順に行うことにより、所望の運動目的を達成するための関節力τaを得ることができる。そして、実在力算出部244は、算出した実在力(発生トルク)τaを理想関節制御部250に送信する。
 また、上述したように、理想関節制御部250の指令値算出部252では、ブロック632にエンコーダ613によって測定された回転角度qが入力されることにより、回転角速度(回転角度qの1階微分)が算出される。そして、発生トルクτa及び外トルクτeに加えて、回転角速度がブロック631に入力されることにより、ブロック631によって数式(12)から回転角加速度目標値(回転角度qの2階微分)が算出される。
 指令値算出部252による回転角加速度目標値の算出において、図7に示す構成例では、慣性モーメント制御部262が算出した慣性モーメントI、及び粘性抵抗係数制御部264が算出した粘性抵抗係数νを数式(12)に代入し、回転角加速度目標値を算出する。従って、図7に示す構成例により算出された回転角加速度目標値は、ユーザの操作速度に応じたものとなり、ユーザの操作速度を反映させたものとなる。
 上述したように、指令値算出部252は、算出した回転角加速度目標値にアクチュエータ610における公称イナーシャJを乗じることにより、トルク目標値τrefを得ることができる。
 また、指令値算出部252は、算出した回転角加速度目標値を回転角速度の算出のためにフィードバックする。具体的には、図5で示したように、回転角加速度目標値から得られたトルク目標値τrefに外乱推定値τを加算することによって、アクチュエータ610に生じさせるトルク値であるトルク指令値τが算出される。トルク指令値τは図5のブロック636に入力されて回転角qにフィードバックされ、回転角qがブロック632に入力されて回転角速度が算出される。
 図8は、粘性抵抗係数制御部264が粘性抵抗係数νを算出する際に用いるマップの一例を示す模式図である。図8に示すように、回転角速度(回転角度qの1階微分)が大きくなるほど、粘性抵抗係数νが大きくなるようにマップが規定される。従って、操作者がアーム部120に過大な力を加えて動作させた場合は、回転角速度が高いため、粘性抵抗係数νが十分に大きく設定される。これにより、操作者の過大な操作力によりアーム部120の動きに過大な速度が発生した場合、アーム部120の各関節部421a~421fの粘性抵抗が高くなり、各関節部421a~421fに反力を生じさせることができる。従って、過大な速度でアーム部120が動くことを抑止でき、安全性を大幅に高めることが可能となる。なお、回転角速度(回転角度qの1階微分)が大きくなるほど、粘性抵抗係数νが小さくなるようにマップを規定しても良い。
 また、図9は、慣性モーメント制御部262が慣性モーメントIを算出する際に用いるマップの一例を示す模式図である。アクチュエータの動きはじめは慣性モーメントが大きいと動きにくいため、図9の実線の特性に示すように、回転角速度が所定値よりも小さい領域では、慣性モーメントIの値は回転角速度の増加に伴って増加する。このようなマップの特性によれば、操作者がアーム部120を操作した際に、操作を開始した直後は、回転角速度が小さいため、慣性モーメントIの値が小さい値に設定される。これにより、操作開始直後のアーム部120の操作感が軽くなり、操作開始直後にアーム部120を滑らかに動かすことが可能となる。従って、図9のマップによれば、アーム部120の動き出しの操作感を滑らかにすることができ、アーム部120が動き出した後はアーム部120を安定して動かすことが可能となる。なお、回転角速度(回転角度qの1階微分)が大きくなるほど、慣性モーメントIが小さくなるようにマップを規定しても良い。また、アーム部120が動作開始または停止する際に慣性モーメントを増減させるようにマップを規定しても良い。
 また、図9の破線の特性に示すように、慣性モーメントIは、回転角速度によらず一定値としても良い。
 アーム部120の停止状態(ブレーキ状態)から解放する際も、慣性モーメントI、粘性抵抗係数νを制御することで、滑らかに発進させることができ、操作性を向上することができる。
 また、図10は、アーム部120が停止する際に用いられるマップを示す模式図であって、アーム部120の操作中の時間の経過と、粘性抵抗係数νとの関係を示す模式図である。図10に示すように、アーム部120の停止動作に応じて、アーム部120が停止する時刻t0の直前で粘性抵抗係数νが増加するように制御を行う。これにより、操作者がアーム部120をブレーキにより急停止させようとした場合に、粘性抵抗係数νを上げて減速が行われることになり、急停止によるアーム部120の振動を抑止することができる。なお、ブレーキによる停止以外の停止時全般においても、同様の制御を行うことができる。
 <4.ロボットアーム制御方法の処理手順>
 次に、図11を参照して、本開示の一実施形態に係るロボットアーム制御方法の基本的な処理手順について説明する。図11は、本開示の一実施形態に係るロボットアーム制御方法の処理手順を示すフロー図である。なお、以下では、図6に示すロボットアーム制御システム1の構成によって本実施形態に係るロボットアーム制御方法が実現される場合を例に挙げて説明を行う。従って、本実施形態に係るロボットアーム制御方法は医療用ロボットアーム制御方法であると言える。なお、以下の本実施形態に係るロボットアーム制御方法の処理手順についての説明において、図6に示すロボットアーム制御システム1の各構成の機能については、上記[2-4.ロボットアーム制御システムの構成]で既に説明しているため、詳細な説明は省略する。
 図11を参照すると、本実施形態に係るロボットアーム制御方法では、まず、ステップS801で、関節状態検出部132によって関節部130の状態が検出される。ここで、関節部130の状態とは、例えば関節部130における回転角度、発生トルク及び/又は外トルクである。
 次にステップS803で、ステップS801で検出された関節部130の状態に基づいて、アーム状態取得部241によってアーム状態が取得される。アーム状態とは、アーム部120の運動の状態のことであり、例えばアーム部120の各構成部材の位置、速度、加速度やアーム部120の各構成部材に作用する力等であってよい。
 次にステップS805で、ステップS803で取得されたアーム状態に基づいて、演算条件設定部242によって全身協調制御における演算で用いられる運動目的及び拘束条件が設定される。なお、演算条件設定部242はアーム状態に基づいて運動目的を設定しなくてもよく、例えば、入力部210からユーザによって入力されるアーム部120の駆動についての指示情報に基づいて運動目的を設定してもよいし、記憶部220に予め格納されている運動目的を用いてもよい。更に、上記の各方法を適宜組み合わせることにより、運動目的を設定してもよい。また、演算条件設定部242は記憶部220に予め格納されている拘束条件を用いてもよい。
 次にステップS807で、アーム状態、運動目的及び拘束条件に基づいて、一般化逆動力学を用いた全身協調制御についての演算が行われ、制御値τが算出される。なお、ステップS807で行われる処理は、図6に示す仮想力算出部243及び実在力算出部244における一連の処理、すなわち、上記[2-2.一般化逆動力学について]で説明した一連の処理であってよい。
 次にステップS809で、外乱推定値τが算出され、当該外乱推定値τを用いて、理想関節制御についての演算が行われ、制御値τから指令値τが算出される。なお、ステップS809で行われる処理は、図6に示す理想関節制御部250における一連の処理、すなわち、上記[2-3.理想関節制御について]で説明した一連の処理であってよい。
 最後にステップS811で、指令値τに基づいて、駆動制御部111によって関節部130の駆動が制御される。
 以上、図11を参照して、本実施形態に係るロボットアーム制御方法の処理手順について説明した。なお、本実施形態においては、図11に示すステップS801~ステップS811における処理が、アーム部120を用いた作業が行われている間繰り返し行われる。従って、本実施形態においては、アーム部120を用いた作業が行われている間、アーム部120の駆動制御が継続的に行われる。
 次に、図11に基づいて、本実施形態に係る、操作速度に応じて粘性を制御する処理について説明する。図11は、操作速度に応じて粘性を制御する処理を示すフローチャートである。以下の処理では、操作速度に応じて慣性モーメントI(関節部のイナーシャ)、粘性抵抗係数ν(関節部の粘性抵抗値)を制御することで、アーム部120の操作性、安全性を向上させる。
 先ず、ステップS10では、操作者によるアーム部120への操作力の付加が行われる。次のステップS12では、アーム状態に基づいて関節部の回転角速度を算出する。次のステップS14では、ステップS12で算出した回転角速度に基づいて、慣性モーメントI(イナーシャ)、及び粘性抵抗係数νを算出する。慣性モーメントI、及び粘性抵抗係数νの算出は、慣性モーメント制御部262、及び粘性抵抗係数制御部264によって行われる。
 次のステップS16では、数式(12)に基づいて、ステップS14で算出した慣性モーメントI及び粘性抵抗係数νを適用することにより、回転角加速度目標値を算出する。次のステップS18では、回転角加速度目標値に基づいて、アーム部120への指令を行う。具体的には、回転角加速度目標値からトルク目標値τrefを算出し、外乱推定値τで補正することによってトルク指令値τを算出し、トルク指令値τによりアーム部120への指令を行う。
 次のステップS20では、操作者による操作が終了したか否かを判定し、操作が終了していない場合はステップS12へ戻り、以降の処理を継続する。一方、ステップS20で操作が終了したことが判定された場合は、処理を終了する。
 <5.モータ、センサー等に関する不要成分の除去>
 次に、アーム部120の関節部421a~421fのアクチュエータ430が有するモータ424、減速機426、エンコーダ427、トルクセンサ428等に関する不要成分の除去について説明する。アクチュエータ430におけるこれらの構成要素には、トルクに関する不要成分が存在する場合がある。例えば、モータ424には不要成分としてコギングトルクが存在する場合がある。また、トルクセンサ428は、駆動軸429の回転に伴いトルクムラを生じさせる場合がある。また、電流リップルによってモータ424のトルクには不要成分が生じる場合もある。
 また、モータ424によってマグネットブレーキをかける場合も、その際の反力によってもトルクに不要成分が生じる場合がある。具体的には、マグネットブレーキをかけると、その反動によって関節部421a~421fが逆方向に動いてしまう場合がある。
 本実施形態では、これらの不要成分によるトルク変動を予め取得しておき、不要成分のトルクを打ち消すようなトルクを発生させる。図11は、モータ424のコギングトルク(破線)と、コギングトルクを打ち消した場合のトルク(実線)を示す特性図である。図11に示すように、コギングトルク(破線)を打ち消すことで、トルク変動を確実に抑えることが可能となる。他の不要成分についても同様に、予め不要成分のトルクを取得しておき、取得した不要成分のトルクを打ち消すようにトルクを発生させる。これにより、不要成分のトルクを除去してより滑らかな操作を行うことが可能となる。
 不要成分のトルクの除去は、指令値算出部252が行うことができる。指令値算出部252は、算出したトルク指令値τに対し、予め取得した不要成分のトルクを打ち消すトルクで補正することで、不要成分のトルクを除去したトルク目標値を出力する。予め取得した不要成分のトルク(図11中に破線で示す特性)は、記憶部220に保持しておくことができる。
 また、外乱推定部251が不要成分のトルクを打ち消すトルクを算出することもできる。この場合、図5のブロック632によって算出された回転角速度がブロック634に入力され、ブロック634が伝達関数Jsによって表される演算を行うことにより、すなわち、当該回転角速度を微分することにより回転角加速度を求め、更に算出された回転角加速度にノミナルイナーシャJを乗じることにより、不要成分を含む実際にアクチュエータ610に作用しているトルクの推定値(トルク推定値)を算出することができる。そして、上述したように、外乱オブザーバ620内では、当該トルク推定値とトルク指令値τとの差分が取られることにより、外乱によるトルクの値である外乱推定値τdが推定される。ブロック634によって算出されるトルク推定値は不要成分を含む実際の測定値に基づくものであり、ブロック633によって算出されたトルク指令値τはブロック631に示す関節部421a~421fの理想的な理論モデルに基づくものであるため、両者の差分を取ることによって、不要成分を除去することが可能となる。
 アーム制御部110は、不要成分のトルクを除去したトルク指令値τに基づいてアーム部120を制御する。これにより、アーム部120が動作する際に、不要成分のトルクが除去され、より滑らかな動きを実現することが可能となる。上述したように、コギングトルクなどの不要成分のトルクは、予め取得しておき、記憶部220に格納しておくことができる。
 <6.ハードウェア構成>
 次に、図15を参照しながら、図6及び図7に示す、本実施形態に係るロボットアーム装置10及び制御装置20のハードウェア構成について、詳細に説明する。図15は、本開示の一実施形態に係るロボットアーム装置10及び制御装置20のハードウェア構成の一構成例を示す機能ブロック図である。
 ロボットアーム装置10及び制御装置20は、主に、CPU901と、ROM903と、RAM905と、を備える。また、ロボットアーム装置10及び制御装置20は、更に、ホストバス907と、ブリッジ909と、外部バス911と、インターフェース913と、入力装置915と、出力装置917と、ストレージ装置919と、ドライブ921と、接続ポート923と、通信装置925とを備える。
 CPU901は、演算処理装置及び制御装置として機能し、ROM903、RAM905、ストレージ装置919又はリムーバブル記録媒体927に記録された各種プログラムに従って、ロボットアーム装置10及び制御装置20内の動作全般又はその一部を制御する。ROM903は、CPU901が使用するプログラムや演算パラメータ等を記憶する。RAM905は、CPU901が使用するプログラムや、プログラムの実行において適宜変化するパラメータ等を一次記憶する。これらはCPUバス等の内部バスにより構成されるホストバス907により相互に接続されている。CPU901は、本実施形態においては、例えば、図6に示すアーム制御部110及び制御部230に対応している。
 ホストバス907は、ブリッジ909を介して、PCI(Peripheral Component Interconnect/Interface)バスなどの外部バス911に接続されている。また、外部バス911には、インターフェース913を介して、入力装置915、出力装置917、ストレージ装置919、ドライブ921、接続ポート923及び通信装置925が接続される。
 入力装置915は、例えば、マウス、キーボード、タッチパネル、ボタン、スイッチ、レバー及びペダル等、ユーザが操作する操作手段である。また、入力装置915は、例えば、赤外線やその他の電波を利用したリモートコントロール手段(いわゆる、リモコン)であってもよいし、ロボットアーム装置10及び制御装置20の操作に対応した携帯電話やPDA等の外部接続機器929であってもよい。さらに、入力装置915は、例えば、上記の操作手段を用いてユーザにより入力された情報に基づいて入力信号を生成し、CPU901に出力する入力制御回路などから構成されている。ロボットアーム装置10及び制御装置20のユーザは、この入力装置915を操作することにより、ロボットアーム装置10及び制御装置20に対して各種のデータを入力したり処理動作を指示したりすることができる。入力装置915は、本実施形態においては、例えば、図6に示す入力部210に対応する。また、本実施形態においては、入力装置915を介したユーザによる操作入力により、アーム部120の駆動における運動目的が設定され、当該運動目的に従って全身協調制御が行われてもよい。
 出力装置917は、取得した情報をユーザに対して視覚的又は聴覚的に通知することが可能な装置で構成される。このような装置として、CRTディスプレイ装置、液晶ディスプレイ装置、プラズマディスプレイ装置、ELディスプレイ装置及びランプ等の表示装置や、スピーカ及びヘッドホン等の音声出力装置や、プリンタ装置等がある。出力装置917は、例えば、ロボットアーム装置10及び制御装置20が行った各種処理により得られた結果を出力する。具体的には、表示装置は、ロボットアーム装置10及び制御装置20が行った各種処理により得られた結果を、テキスト又はイメージで表示する。他方、音声出力装置は、再生された音声データや音響データ等からなるオーディオ信号をアナログ信号に変換して出力する。本実施形態においては、アーム部120の駆動制御に関する各種の情報が、あらゆる形式で出力装置917から出力されてよい。例えば、アーム部120の駆動制御における、アーム部120の各構成部材の移動の軌跡が、グラフの形式で出力装置917の表示画面に表示されてもよい。なお、例えば、図6に示す表示装置30は、出力装置917の表示装置としての機能及び構成と、当該表示装置の駆動を制御するための制御部等の構成を備える装置であってもよい。
 ストレージ装置919は、ロボットアーム装置10及び制御装置20の記憶部の一例として構成されたデータ格納用の装置である。ストレージ装置919は、例えば、HDD(Hard Disk Drive)等の磁気記憶部デバイス、半導体記憶デバイス、光記憶デバイス又は光磁気記憶デバイス等により構成される。このストレージ装置919は、CPU901が実行するプログラムや各種データ等を格納する。ストレージ装置919は、本実施形態においては、例えば、図6に示す記憶部220に対応する。また、本実施形態においては、ストレージ装置919は、一般化逆動力学を用いた全身協調制御に関する演算における演算条件(運動目的及び拘束条件)を記憶することができ、ロボットアーム装置10及び制御装置20はストレージ装置919に記憶されているこれらの演算条件を用いて全身協調制御に関する演算を行ってもよい。
 ドライブ921は、記録媒体用リーダライタであり、ロボットアーム装置10及び制御装置20に内蔵、あるいは外付けされる。ドライブ921は、装着されている磁気ディスク、光ディスク、光磁気ディスク又は半導体メモリ等のリムーバブル記録媒体927に記録されている情報を読み出して、RAM905に出力する。また、ドライブ921は、装着されている磁気ディスク、光ディスク、光磁気ディスク又は半導体メモリ等のリムーバブル記録媒体927に記録を書き込むことも可能である。リムーバブル記録媒体927は、例えば、DVDメディア、HD-DVDメディア又はBlu-ray(登録商標)メディア等である。また、リムーバブル記録媒体927は、コンパクトフラッシュ(登録商標)(CF:CompactFlash)、フラッシュメモリ又はSDメモリカード(Secure Digital memory card)等であってもよい。また、リムーバブル記録媒体927は、例えば、非接触型ICチップを搭載したICカード(Integrated Circuit card)又は電子機器等であってもよい。本実施形態においては、アーム部120の駆動制御に関する各種の情報が、ドライブ921によって、各種のリムーバブル記録媒体927から読み出され、又は各種のリムーバブル記録媒体927に書き込まれてよい。
 接続ポート923は、機器をロボットアーム装置10及び制御装置20に直接接続するためのポートである。接続ポート923の一例として、USB(Universal Serial Bus)ポート、IEEE1394ポート、SCSI(Small Computer System Interface)ポート等がある。接続ポート923の別の例として、RS-232Cポート、光オーディオ端子、HDMI(登録商標)(High-Definition Multimedia Interface)ポート等がある。この接続ポート923に外部接続機器929を接続することで、ロボットアーム装置10及び制御装置20は、外部接続機器929から直接各種のデータを取得したり、外部接続機器929に各種のデータを提供したりする。本実施形態においては、アーム部120の駆動制御に関する各種の情報が、接続ポート923を介して、各種の外部接続機器929から読み出され、又は各種の外部接続機器929に書き込まれてよい。
 通信装置925は、例えば、通信網(ネットワーク)931に接続するための通信デバイス等で構成された通信インターフェースである。通信装置925は、例えば、有線若しくは無線LAN(Local Area Network)、Bluetooth(登録商標)又はWUSB(Wireless USB)用の通信カード等である。また、通信装置925は、光通信用のルータ、ADSL(Asymmetric Digital Subscriber Line)用のルータ又は各種通信用のモデム等であってもよい。この通信装置925は、例えば、インターネットや他の通信機器との間で、例えばTCP/IP等の所定のプロトコルに則して信号等を送受信することができる。また、通信装置925に接続される通信網931は、有線又は無線によって接続されたネットワーク等により構成され、例えば、インターネット、家庭内LAN、赤外線通信、ラジオ波通信又は衛星通信等であってもよい。本実施形態においては、アーム部120の駆動制御に関する各種の情報が、通信装置925によって、通信網931を介して外部の他の機器との間で相互に送受信されてもよい。
 以上、本開示の実施形態に係るロボットアーム装置10及び制御装置20の機能を実現可能なハードウェア構成の一例を示した。上記の各構成要素は、汎用的な部材を用いて構成されていてもよいし、各構成要素の機能に特化したハードウェアにより構成されていてもよい。従って、本実施形態を実施する時々の技術レベルに応じて、適宜、利用するハードウェア構成を変更することが可能である。なお、図15では図示しないが、ロボットアーム装置10は、図6に示すアーム部120に対応する各種の構成を当然備える。
 なお、上述のような本実施形態に係るロボットアーム装置10、制御装置20及び表示装置30の各機能を実現するためのコンピュータプログラムを作製し、パーソナルコンピュータ等に実装することが可能である。また、このようなコンピュータプログラムが格納された、コンピュータで読み取り可能な記録媒体も提供することができる。記録媒体は、例えば、磁気ディスク、光ディスク、光磁気ディスク、フラッシュメモリなどである。また、上記のコンピュータプログラムは、記録媒体を用いずに、例えばネットワークを介して配信してもよい。
 <7.まとめ>
 以上説明したように、本実施形態においては、以下の効果を得ることができる。
 以上説明したように、本実施形態によれば、ロボットアーム装置10における多リンク構造体であるアーム部120が、少なくとも6自由度以上の自由度を有するとともに、当該アーム部120を構成する複数の関節部130のそれぞれの駆動が駆動制御部111によって制御される。そして、当該アーム部120の先端には医療用器具が設けられる。このように、各関節部130の駆動が制御されることにより、より自由度の高いアーム部120の駆動制御が実現され、よりユーザにとって操作性の高い医療用のロボットアーム装置10が実現される。
 具体的には、本実施形態によれば、ロボットアーム装置10において、関節状態検出部132によって関節部130の状態が検出される。そして、制御装置20において、当該関節部130の状態と、運動目的及び拘束条件とに基づいて、アーム部120の駆動を制御するための一般化逆動力学を用いた全身協調制御に関する各種の演算が行われ、演算結果としてのトルク指令値τが算出される。更に、ロボットアーム装置10において、当該トルク指令値τに基づいてアーム部120の駆動が制御される。このように、本実施形態においては、一般化逆動力学を用いた全身協調制御により、アーム部120の駆動が制御される。従って、力制御によるアーム部120の駆動制御が実現され、よりユーザにとって操作性の高いロボットアーム装置が実現される。また、本実施形態では、全身協調制御において、例えばピボット動作やパワーアシスト動作といった、よりユーザの利便性を向上させる各種の運動目的を実現する制御が可能となる。更に、本実施形態においては、例えばアーム部120を手動で移動させたり、ペダルからの操作入力により移動させたりといった、多様な駆動手段が実現されるため、ユーザの利便性の更なる向上が実現される。
 また、本実施形態においては、アーム部120の駆動制御について、全身協調制御と併せて理想関節制御が適用される。理想関節制御においては、関節部130内部の摩擦や慣性等の外乱成分を推定し、推定した外乱成分を用いたフィードフォワード制御が行われる。従って、摩擦等の外乱成分がある場合であっても、関節部130の駆動について理想的な応答を実現することができる。よって、アーム部120の駆動制御において、振動等の影響がより少ない、高精度の応答性と高い位置決め精度や安定性が実現される。
 更に、本実施形態においては、アーム部120を構成する複数の関節部130のそれぞれが、例えば図3に示すような、理想関節制御に適合した構成を有し、各関節部130における回転角度、発生トルク及び粘性抵抗係数を電流値によって制御することができる。このように、各関節部130の駆動が電流値によって制御され、また、全身協調制御により各関節部130の駆動がアーム部120全体の状態を把握しながら制御されるため、カウンターバランスが不要となり、ロボットアーム装置10の小型化が実現される。
 このように、本実施形態によれば、上記<1.医療用ロボットアーム装置についての検討>で説明したロボットアーム装置に求められる性能を全て満たすことができる。従って、本実施形態に係るロボットアーム装置を用いた各種の施術において、より効率的に施術を行うことができ、ユーザや患者の疲労や負担をより軽減することが実現される。
 また、本実施形態では、力制御によってロボットアーム装置10のアーム部120が駆動されることにより、万が一駆動中にアーム部120が施術者やスタッフ等に干渉(接触)したとしても、アーム部120が必要以上の力を発生せず、アーム部120が安全に停止する。そして、当該干渉から解放されれば、設定された運動目的に従って所望の位置までアーム部120が移動し、施術が継続される。このように、本実施形態では、ロボットアーム装置10の駆動制御に力制御が用いられることにより、駆動中におけるアーム部120と周囲の物体との干渉に対して、より高い安全性が確保される。
 更に、本実施形態によれば、各関節部のトルクセンサ1800a,1800b,・・・,1800fがユーザの操作を検出することができるため、ロボットアーム装置10のアーム部120のどの部分を操作してもアーム部120を動かすことが可能となる。これにより、手で直接アーム部120を持たずに、腕等で押すような動作であってもアーム部120を動かすことが可能となる。
 また、ユーザによる操作の動作速度に応じた適応制御を行うことで、ロボットアーム装置10の操作性、及び安全性を向上させることができる。具体的には、動作速度に応じて関節部の慣性モーメントI及び粘性抵抗係数νを制御することにより、アーム部120の動作の滑らかな操作性を実現することが可能となり、動作速度が過大の場合に操作性及び安全性を向上することができる。また、ブレーキ時の振動抑制が可能になるため、ロボットアーム装置10の操作性、及び安全性を向上することが可能となる。
 なお、上述した実施形態では本開示を医療用のロボットアーム装置に適用した例を示したが、本開示は医療用以外の様々な用途のロボットアーム装置に適用することが可能である。
 以上、添付図面を参照しながら本開示の好適な実施形態について詳細に説明したが、本開示の技術的範囲はかかる例に限定されない。本開示の技術分野における通常の知識を有する者であれば、特許請求の範囲に記載された技術的思想の範疇内において、各種の変更例または修正例に想到し得ることは明らかであり、これらについても、当然に本開示の技術的範囲に属するものと了解される。
 例えば、上記実施形態では、ロボットアーム装置のアーム部の先端ユニットが撮像ユニットであり、図1に示すように手術時に当該撮像ユニットによって施術部位を撮影する場合について説明したが、本実施形態はかかる例に限定されない。本実施形態に係るロボットアーム制御システム1は、他の先端ユニットを有するロボットアーム装置が他の用途に用いられる場合であっても適用可能である。例えば、先端ユニットは内視鏡や腹腔鏡であってもよいし、超音波検査器や胃カメラ等、他の検査機器であってもよい。
 例えば、腹腔鏡を用いた施術では、ロボットアームで腹腔鏡を操作して患者の体内に腹腔鏡を挿入し、腹腔鏡を操作して施術部位の映像をモニタ上で観察しながら、患者の体内に挿入した鉗子や電気メスを使って処置を行う。このような施術方法においては、例えば施術部位観察用の腹腔鏡はロボットアームによって操作しながら、鉗子や電気メスを施術者が操作することができれば、1人のユーザによって施術を行うことができ、より効率的な施術が可能となる。しかしながら、一般的な既存のバランス型アームにおいては、操作性の観点から、1人のユーザが自身の手による鉗子や電気メスの操作とロボットアームによる腹腔鏡の操作とを同時に行うことは困難であった。よって、既存の方法では、複数名のスタッフが必要であり、1人の施術者が腹腔鏡を操作しながら処置を行うとともに、他の者が鉗子や電気メスを操作することが一般的であった。しかし、本実施形態に係るロボットアーム装置では、上述したように、全身協調制御による高い操作性が実現される。また、理想関節制御により、振動等の影響がより少ない、高精度の応答性と高い安定性が実現される。従って、例えば観察用の腹腔鏡を本実施形態に係るロボットアーム装置によって操作することにより、自身の手による処置用の鉗子や電気メスの操作とロボットアーム装置による観察用の腹腔鏡の操作とを、施術者1人で容易に行うことができる。
 また、本実施形態に係るロボットアーム装置は、医療以外の用途に用いられてもよい。本実施形態に係るロボットアーム装置では、理想関節制御により、高精度の応答性と高い安定性が実現されるため、例えば高い精度が求められる工業部品の加工や組み立て等の作業にも対応可能である。
 また、上記実施形態では、ロボットアーム装置の関節部が回転機構を有し、当該回転機構の回転駆動が制御されることによってアーム部の駆動が制御される場合について説明したが、本実施形態はかかる例に限定されない。例えば、本実施形態に係るロボットアーム装置においては、アーム部を構成するリンクがリンクの延伸方向に伸縮する機構を有し、リンクの長さが可変であってもよい。リンクの長さが可変である場合、例えば関節部における回転に加えてリンクの伸縮も考慮した全身協調制御によって、所望の運動目的を達成するようにアーム部の駆動が制御される。
 
 また、上記実施形態では、ロボットアーム装置におけるアーム部の自由度が6自由度以上である場合について説明したが、本実施形態はかかる例に限定されない。また、ロボットアーム装置におけるアーム部を構成する複数の関節部が全て理想関節制御に対応するアクチュエータを有する場合について説明したが、本実施形態はかかる例に限定されない。本実施形態においては、ロボットアーム装置の用途に応じて多様な運動目的が設定され得る。従って、設定された運動目的が達成可能であれば、アーム部は、6自由度よりも低い自由度を有してもよいし、アーム部を構成する複数の関節部のうちの一部が一般的な関節機構を有する関節部であってもよい。このように、本実施形態においては、アーム部の構成は、運動目的を達成可能であるように構成されればよく、ロボットアーム装置の用途に応じて適宜構成されてよい。
 なお、以下のような構成も本開示の技術的範囲に属する。
(1) 複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる複数の関節部の動作速度を取得する速度取得部と、
 前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御するパラメータ制御部と、
 を備える、ロボットアームの制御装置。
(2) 前記制御パラメータは、前記関節部の動作の粘性抵抗に関するパラメータである、前記(1)に記載のロボットアーム装置。
(3) 前記パラメータ制御部は、前記動作速度に応じて前記粘性抵抗を増減させる、前記(2)に記載のロボットアーム装置。
(4) 前記パラメータ制御部は、前記関節部が動作開始または停止する際に前記粘性抵抗を増加させる、前記(2)に記載のロボットアーム装置。
(5) 前記制御パラメータは、前記関節部の慣性モーメントである、前記(1)に記載のロボットアーム装置。
(6) 前記パラメータ制御部は、前記動作速度に応じて前記慣性モーメントを増減させる、前記(5)に記載のロボットアーム装置。
(7) 前記パラメータ制御部は、前記動作速度が所定値を超えると、前記慣性モーメントを一定値に制御する、前記(6)に記載のロボットアーム装置。
(8)前記パラメータ制御部は、前記関節部が動作開始または停止する際に前記慣性モーメントを制御する、前記(5)に記載のロボットアーム装置。
(9) 前記制御パラメータに基づいて前記関節部を駆動するためのトルク指令値を算出する指令値算出部を備える、前記(1)~(8)のいずれかに記載のロボットアームの制御装置。
(10) 前記指令値算出部は、前記関節部が動作する際のトルクに関する成分を除去する、前記(9)に記載のロボットアーム装置。
(11) 前記トルクに関する成分は、前記関節部を駆動するモータのコギングトルク、前記関節部に設けられたトルクセンサのトルクムラ、電流リップル、又は前記関節部におけるマグネットブレーキの反力の少なくとも1つを含む、前記(10)に記載のロボットアーム装置。
(12) 前記関節部は、多リンク構造体の駆動に対して少なくとも6自由度以上の自由度を実現する、前記(1)~(11)のいずれかに記載のロボットアームの制御装置。
(13) 医療処置に用いられる装置である、前記(1)~(12)のいずれかに記載のロボットアーム装置。
(14) 複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる関節部の動作速度を取得することと、
 前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御することと、
 を備える、ロボットアームの制御方法。
(15) 複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる複数の関節部の動作速度を取得する手段、
 前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御する手段、
 としてコンピュータを機能させるためのプログラム。
 1  ロボットアーム制御システム
 10  ロボットアーム装置
 20  制御装置
 130  関節部
 230  制御部
 252  指令値算出部(速度算出部)
 260  操作力制御部(パラメータ制御部)
 262  慣性モーメント制御部
 264  粘性抵抗係数制御部
 

Claims (15)

  1.  複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる関節部の動作速度を取得する速度取得部と、
     前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御するパラメータ制御部と、
     を備える、ロボットアームの制御装置。
  2.  前記制御パラメータは、前記関節部の動作の粘性抵抗に関するパラメータである、請求項1に記載のロボットアームの制御装置。
  3.  前記パラメータ制御部は、前記動作速度に応じて前記粘性抵抗を増減させる、請求項2に記載のロボットアームの制御装置。
  4.  前記パラメータ制御部は、前記関節部が動作開始または停止する際に前記粘性抵抗を増加させる、請求項2に記載のロボットアームの制御装置。
  5.  前記制御パラメータは、前記関節部の慣性モーメントである、請求項1に記載のロボットアームの制御装置。
  6.  前記パラメータ制御部は、前記動作速度に応じて前記慣性モーメントを増減させる、請求項5に記載のロボットアームの制御装置。
  7.  前記パラメータ制御部は、前記動作速度が所定値を超えると、前記慣性モーメントを一定値に制御する、請求項6に記載のロボットアームの制御装置。
  8.  前記パラメータ制御部は、前記関節部が動作開始または停止する際に前記慣性モーメントを制御する、
     請求項5に記載のロボットアームの制御装置。
  9.  前記制御パラメータに基づいて前記関節部を駆動するためのトルク指令値を算出する指令値算出部を備える、請求項1に記載のロボットアームの制御装置。
  10.  前記指令値算出部は、前記関節部が動作する際のトルクに関する成分を除去する、請求項9に記載のロボットアームの制御装置。
  11.  前記トルクに関する成分は、前記関節部を駆動するモータのコギングトルク、前記関節部に設けられたトルクセンサのトルクムラ、電流リップル、又は前記関節部におけるマグネットブレーキの反力の少なくとも1つを含む、請求項10に記載のロボットアームの制御装置。
  12.  前記関節部は、多リンク構造体の駆動に対して少なくとも6自由度以上の自由度を実現する、請求項1に記載のロボットアームの制御装置。
  13.  医療処置に用いられる装置である、請求項1に記載のロボットアームの制御装置。
  14.  複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる関節部の動作速度を取得することと、
     前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御することと、
     を備える、ロボットアームの制御方法。
  15.  複数のリンクを連結し、複数の前記リンクから構成される多リンク構造体を駆動させる複数の関節部の動作速度を取得する手段、
     前記動作速度に基づいて前記関節部の動作に関する制御パラメータを制御する手段、
     としてコンピュータを機能させるためのプログラム。
     
PCT/JP2015/055665 2014-03-12 2015-02-26 ロボットアームの制御装置、ロボットアームの制御方法及びプログラム WO2015137140A1 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2014-049039 2014-03-12
JP2014049039 2014-03-12

Publications (1)

Publication Number Publication Date
WO2015137140A1 true WO2015137140A1 (ja) 2015-09-17

Family

ID=54071588

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2015/055665 WO2015137140A1 (ja) 2014-03-12 2015-02-26 ロボットアームの制御装置、ロボットアームの制御方法及びプログラム

Country Status (1)

Country Link
WO (1) WO2015137140A1 (ja)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017104914A (ja) * 2015-12-07 2017-06-15 リバーフィールド株式会社 外力追従制御システム
WO2018159336A1 (ja) * 2017-02-28 2018-09-07 ソニー株式会社 医療用支持アームシステムおよび制御装置
TWI736358B (zh) * 2019-07-19 2021-08-11 日商三菱電機股份有限公司 參數鑑別裝置、參數鑑別方法及電腦程式
CN117140537A (zh) * 2023-10-30 2023-12-01 中国标准化研究院 一种扫地机器人用机械臂控制系统及方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS61243514A (ja) * 1985-04-22 1986-10-29 Nissan Motor Co Ltd ロボツトの制御装置
JPH07129251A (ja) * 1993-10-29 1995-05-19 Yaskawa Electric Corp 防振制御方法
JPH10230489A (ja) * 1996-12-16 1998-09-02 Sankyo Seiki Mfg Co Ltd 力補助装置の制御方法及びこの方法を利用した制御装置
JP2008110406A (ja) * 2006-10-27 2008-05-15 Yaskawa Electric Corp ロボットの直接教示装置
WO2012124342A1 (ja) * 2011-03-17 2012-09-20 パナソニック株式会社 ロボット、ロボットの制御装置、制御方法、及び制御プログラム

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS61243514A (ja) * 1985-04-22 1986-10-29 Nissan Motor Co Ltd ロボツトの制御装置
JPH07129251A (ja) * 1993-10-29 1995-05-19 Yaskawa Electric Corp 防振制御方法
JPH10230489A (ja) * 1996-12-16 1998-09-02 Sankyo Seiki Mfg Co Ltd 力補助装置の制御方法及びこの方法を利用した制御装置
JP2008110406A (ja) * 2006-10-27 2008-05-15 Yaskawa Electric Corp ロボットの直接教示装置
WO2012124342A1 (ja) * 2011-03-17 2012-09-20 パナソニック株式会社 ロボット、ロボットの制御装置、制御方法、及び制御プログラム

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2017104914A (ja) * 2015-12-07 2017-06-15 リバーフィールド株式会社 外力追従制御システム
WO2017098989A1 (ja) * 2015-12-07 2017-06-15 リバーフィールド株式会社 外力追従制御システム
WO2018159336A1 (ja) * 2017-02-28 2018-09-07 ソニー株式会社 医療用支持アームシステムおよび制御装置
TWI736358B (zh) * 2019-07-19 2021-08-11 日商三菱電機股份有限公司 參數鑑別裝置、參數鑑別方法及電腦程式
CN114127643A (zh) * 2019-07-19 2022-03-01 三菱电机株式会社 参数同定装置、参数同定方法及计算机程序
CN114127643B (zh) * 2019-07-19 2024-03-29 三菱电机株式会社 参数同定装置、参数同定方法及存储介质
CN117140537A (zh) * 2023-10-30 2023-12-01 中国标准化研究院 一种扫地机器人用机械臂控制系统及方法
CN117140537B (zh) * 2023-10-30 2024-01-16 中国标准化研究院 一种扫地机器人用机械臂控制系统及方法

Similar Documents

Publication Publication Date Title
JP6921762B2 (ja) 手術用顕微鏡装置、手術用顕微鏡装置制御システム、手術用顕微鏡装置制御方法及びプログラム
JP6586079B2 (ja) アーム装置、及びプログラム
JP6773165B2 (ja) 医療用支持アーム装置、医療用支持アーム制御方法及びプログラム
US11633245B2 (en) Robot arm apparatus and robot arm control method
JP6555248B2 (ja) 医療用アーム装置、キャリブレーション方法及びプログラム
WO2015137040A1 (ja) ロボットアーム装置、ロボットアーム制御方法及びプログラム
US20210361381A1 (en) Medical supporting arm control apparatus, medical supporting arm apparatus control method, and medical system
WO2015133291A1 (ja) アクチュエータ及びロボットアーム装置
US11950970B2 (en) Medical support arm system, medical support arm control method, and medical support arm control device
WO2015137140A1 (ja) ロボットアームの制御装置、ロボットアームの制御方法及びプログラム

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 15761973

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

NENP Non-entry into the national phase

Ref country code: JP

122 Ep: pct application non-entry in european phase

Ref document number: 15761973

Country of ref document: EP

Kind code of ref document: A1