CN116619386A - Robot system for object size measurement - Google Patents

Robot system for object size measurement Download PDF

Info

Publication number
CN116619386A
CN116619386A CN202310843958.6A CN202310843958A CN116619386A CN 116619386 A CN116619386 A CN 116619386A CN 202310843958 A CN202310843958 A CN 202310843958A CN 116619386 A CN116619386 A CN 116619386A
Authority
CN
China
Prior art keywords
target object
image information
candidate
objects
movement
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202310843958.6A
Other languages
Chinese (zh)
Inventor
出杏光鲁仙
余锦泽
金本芳树
何塞·莫雷拉·罗德里格斯
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Mujin Technology
Original Assignee
Mujin Technology
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 Mujin Technology filed Critical Mujin Technology
Publication of CN116619386A publication Critical patent/CN116619386A/en
Pending legal-status Critical Current

Links

Classifications

    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1694Programme controls characterised by use of sensors other than normal servo-feedback from position, speed or acceleration sensors, perception control, multi-sensor controlled systems, sensor fusion
    • B25J9/1697Vision controlled systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/10Segmentation; Edge detection
    • G06T7/13Edge detection
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1602Programme controls characterised by the control system, structure, architecture
    • B25J9/161Hardware, e.g. neural networks, fuzzy logic, interfaces, processor
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1612Programme controls characterised by the hand, wrist, grip control
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1628Programme controls characterised by the control loop
    • B25J9/1653Programme controls characterised by the control loop parameters identification, estimation, stiffness, accuracy, error analysis
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1656Programme controls characterised by programming, planning systems for manipulators
    • BPERFORMING OPERATIONS; TRANSPORTING
    • B25HAND TOOLS; PORTABLE POWER-DRIVEN TOOLS; MANIPULATORS
    • B25JMANIPULATORS; CHAMBERS PROVIDED WITH MANIPULATION DEVICES
    • B25J9/00Programme-controlled manipulators
    • B25J9/16Programme controls
    • B25J9/1656Programme controls characterised by programming, planning systems for manipulators
    • B25J9/1664Programme controls characterised by programming, planning systems for manipulators characterised by motion, path, trajectory planning
    • B25J9/1666Avoiding collision or forbidden zones
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T1/00General purpose image data processing
    • G06T1/0014Image feed-back for automatic industrial control, e.g. robot with camera
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/60Analysis of geometric attributes
    • 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/39Robotics, robotics to robotics hand
    • G05B2219/39107Pick up article, object, measure, test it during motion path, place it
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/40Robotics, robotics mapping to robotics vision
    • G05B2219/40006Placing, palletize, un palletize, paper roll placing, box stacking
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B2219/00Program-control systems
    • G05B2219/30Nc systems
    • G05B2219/40Robotics, robotics mapping to robotics vision
    • G05B2219/40057Contour tracking, edge following
    • 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/45056Handling cases, boxes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K15/00Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers
    • G06K15/02Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers using printers
    • G06K15/18Conditioning data for presenting it to the physical printing elements
    • G06K15/1867Post-processing of the composed and rasterized print image
    • G06K15/1869Depleting the print image
    • G06K15/1871Depleting the print image with provisions for image features conservation or enhancement, e.g. conservation or enhancement of zone edges
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2200/00Indexing scheme for image data processing or generation, in general
    • G06T2200/12Indexing scheme for image data processing or generation, in general involving antialiasing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/20Special algorithmic details
    • G06T2207/20112Image segmentation details
    • G06T2207/20164Salient point detection; Corner detection
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06VIMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
    • G06V10/00Arrangements for image or video recognition or understanding
    • G06V10/40Extraction of image or video features
    • G06V10/44Local feature extraction by analysis of parts of the pattern, e.g. by detecting edges, contours, loops, corners, strokes or intersections; Connectivity analysis, e.g. of connected components
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/40Picture signal circuits
    • H04N1/409Edge or detail enhancement; Noise or error suppression
    • H04N1/4092Edge or detail enhancement

Landscapes

  • Engineering & Computer Science (AREA)
  • Robotics (AREA)
  • Mechanical Engineering (AREA)
  • Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • General Health & Medical Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • Orthopedic Medicine & Surgery (AREA)
  • Automation & Control Theory (AREA)
  • Geometry (AREA)
  • Artificial Intelligence (AREA)
  • Evolutionary Computation (AREA)
  • Fuzzy Systems (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Manipulator (AREA)
  • Image Analysis (AREA)

Abstract

The present disclosure relates to robotic systems for object size measurement. Systems and methods for object detection and robotic control or pick-up of detected objects are provided. The systems and methods described herein provide for the determination and adjustment of a minimum feasible range on an object surface for robotic pick-up. The determination of the minimum feasible range may improve the accuracy and efficiency of robot character processing. The minimum feasible range may be used to select a grip area for the movement operation that is configured to provide supplemental image information for estimating the size of the target object.

Description

Robot system for object size measurement
The present application is a divisional application of an application patent application of 2022, 05, 17, 202280003782.7, and named "robot system for object size measurement".
Cross reference to related applications
The present application claims the benefit of U.S. provisional application No. 63/189,743, entitled "A ROBOTIC SYSTEM FOR OBJECT SIZE MEASUREMENT OR MINIMUM VIABLE REGION DETECTION," filed 5/18 of 2021, the entire contents of which are incorporated herein by reference.
Technical Field
The present technology is directed generally to robotic systems, and more particularly to systems, processes, and techniques for performing object size measurements or estimates and/or minimum feasible range (region) detection.
Background
With their ever increasing performance and decreasing cost, many robots (e.g., machines configured to automatically/autonomously perform physical actions) are now widely used in a variety of different fields. For example, robots may be used to perform various tasks (e.g., manipulating or transferring objects through space) in manufacturing and/or assembly, filling and/or packaging, transporting and/or shipping, etc. In performing tasks, robots may replicate human actions, thereby replacing or reducing human participation otherwise required to perform dangerous or repetitive tasks.
Disclosure of Invention
According to an embodiment of the present invention, a computing system is provided that includes at least one processing circuit in communication with a robot having an arm and an end effector connected to the arm and with a camera having a field of view, the at least one processing circuit configured to execute instructions stored on a non-transitory computer readable medium when one or more objects are or have been in the field of view. The instructions are for obtaining initial image information of one or more objects, wherein the initial image information is generated by a camera; detecting a plurality of corners of one or more objects based on the initial image information; identifying a target opening angle of the target object from the plurality of angles; defining a minimum feasible range (MVR) for the target object; defining a non-occlusion region based on a minimum feasible range; transmitting a positioning command for positioning an arm of the robot; transmitting a grasp command for grasping the target object within the minimum feasible range; transmitting a movement command for moving the target object based on the movement direction, the movement distance, and the movement type using the arm of the robot; acquiring supplemental image information of one or more objects; and calculating an estimated size of the target object based on the supplemental image information, wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent the arm of the robot from occluding a non-occluded area of the one or more objects.
Further embodiments provide a method of controlling a robotic system comprising a non-transitory computer readable medium, at least one processing circuit in communication with a camera having a field of view and configured to execute instructions. The method includes obtaining initial image information of one or more objects, wherein the initial image information is generated by a camera; detecting a plurality of corners of one or more objects based on the initial image information; identifying a target opening angle of the target object from the plurality of angles; defining a minimum feasible range (MVR) for the target object; defining a non-occlusion region based on a minimum feasible range; transmitting a positioning command for positioning an arm of the robot; transmitting a grasp command for grasping the target object within the minimum feasible range; transmitting a movement command for moving the target object based on the movement direction, the movement distance, and the movement type using the arm of the robot; acquiring supplemental image information of one or more objects; and calculating an estimated size of the target object based on the supplemental image information, wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent the arm of the robot from occluding a non-occluded area of the one or more objects.
In a further embodiment, a non-transitory computer-readable medium is provided. The non-transitory computer-readable medium includes instructions for execution by at least one processing circuit in communication with a camera having a field of view and configured to, when one or more objects are or have been in the field of view: acquiring initial image information of one or more objects, wherein the initial image information is generated by a camera; detecting a plurality of corners of one or more objects based on the initial image information; identifying a target opening angle of the target object from the plurality of angles; defining a minimum feasible range (MVR) for the target object; defining a non-occlusion region based on a minimum feasible range; transmitting a positioning command for positioning an arm of the robot; transmitting a grasp command for grasping the target object within the minimum feasible range; transmitting a movement command for moving the target object based on the movement direction, the movement distance, and the movement type using the arm of the robot; acquiring supplemental image information of one or more objects; and calculating an estimated size of the target object based on the supplemental image information, wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent the arm of the robot from occluding a non-occluded area of the one or more objects.
Drawings
1A-1D illustrate a system for performing or facilitating defining a minimum feasible region consistent with embodiments herein.
2A-2D provide block diagrams illustrating a computing system configured to perform or facilitate defining a minimum feasible region consistent with embodiments herein.
Fig. 2E and 2F illustrate example image information associated with an image analysis method.
Fig. 3A-3H illustrate aspects of defining a minimum feasible range according to embodiments herein.
Fig. 4 provides a flowchart illustrating a method of defining a minimum feasible range according to embodiments herein.
Fig. 5 provides a flow chart illustrating a method of estimating a size of a target object according to embodiments herein.
Fig. 6A and 6B illustrate aspects of estimating a size of a target object according to embodiments herein.
Detailed Description
Systems and methods for robotic systems with coordinated transfer mechanisms are described herein. A robotic system (e.g., an integrated system of devices each performing one or more specified tasks) configured according to some embodiments autonomously performs the integrated tasks by coordinating the operation of multiple units (e.g., robots).
The technology described herein provides a technical improvement over existing computer-based image recognition and robotics control fields. The technical improvements provide an increase in the overall speed and reliability of the gripping portion of the identified object to increase the efficiency and reliability of the robot's interaction with the object. Using image information to determine and distinguish objects present within the field of view of the camera, the process described herein also improves existing image recognition by using movement of the objects to adjust and help identify potential gripping portions of a target object.
In particular, the present technology described herein facilitates robotic system interaction with a particular object of a plurality of objects when the identity of the size (dimension) and location of each object is unknown or not exactly known. For example, if multiple objects are placed flush with each other, existing computer-based image recognition may be difficult to identify each object and reliably and accurately instruct the robotic system how to interact with the object. In particular, if the dimensions of the objects are not accurately identified, the robotic system may not know where one object ends and another object begins. Thus, the system runs the risk of trying to grasp an object at a position that intersects other objects. In such a case, the system may not be able to grasp any object. While the exact dimensions of an object may not be completely accurately known, the systems and methods provided herein provide the ability to quickly and reliably identify at least a portion (e.g., a minimum feasible range) of an object that may be grasped by a robotic arm without the need to identify or determine the exact edges of the object. Further, the system may be configured to adjust the position of the gripping object. Transporting an object may be difficult if the object is grasped at some location (e.g., an off-center location). The systems and methods provided herein may use movement of an object after initial gripping by a robotic arm to determine the exact dimensions of the object and adjust or change how the robot interacts with the object based on updated dimensions.
In the following, specific details are set forth to provide an understanding of the presently disclosed technology. In embodiments, the techniques described herein may be practiced without each specific details disclosed herein. In other instances, well-known features, such as specific functions or routines, have not been described in detail to avoid unnecessarily obscuring the present disclosure. Reference in the specification to "an embodiment," "one embodiment," etc., means that a particular feature, structure, material, or characteristic being described is included in at least one embodiment of the disclosure. Thus, the appearances of such phrases in this specification are not necessarily all referring to the same embodiment. On the other hand, such references are not necessarily mutually exclusive. Furthermore, the particular features, structures, materials, or characteristics may be combined in any suitable manner in one or more embodiments. It should be understood that the various embodiments shown in the figures are merely illustrative representations and are not necessarily drawn to scale.
For clarity, several details describing structures or processes that are well known and commonly associated with robotic systems and subsystems, but which may unnecessarily obscure some important aspects of the disclosed technology, are not set forth in the following description. Furthermore, while the following disclosure sets forth several embodiments of different aspects of the present technology, several other embodiments may have different configurations or different components than those described in this section. Thus, the disclosed techniques may have other embodiments with additional elements or without several of the elements described below.
Many of the embodiments or aspects of the disclosure described below may take the form of computer or controller executable instructions, including routines executed by a programmable computer or controller. Those skilled in the relevant art will appreciate that the disclosed techniques may be practiced on or by a computer or controller system other than those shown and described below. The techniques described herein may be embodied in a special purpose computer or data processor that is specifically programmed, configured, or constructed to perform one or more of the computer-executable instructions described below. Thus, the terms "computer" and "controller" as generally used herein refer to any data processor, and may include Internet appliances and hand-held devices (including palm-top computers, wearable computers, cellular or mobile phones, multiprocessor systems, processor-based or programmable consumer electronics, network computers, minicomputers, and the like). The information processed by these computers and controllers may be presented on any suitable display medium, including a Liquid Crystal Display (LCD). Instructions for performing computer or controller executable tasks may be stored in or on any suitable computer readable medium including hardware, firmware, or a combination of hardware and firmware. The instructions may be embodied in any suitable memory device including, for example, a flash drive, a USB device, and/or other suitable medium.
The terms "coupled" and "connected," along with their derivatives, may be used herein to describe structural relationships between components. It should be understood that these terms are not intended as synonyms for each other. Rather, in particular embodiments, "connected" may be used to indicate that two or more elements are in direct contact with each other. Unless the context clearly indicates otherwise, the term "coupled" may be used to indicate that two or more elements are in direct or indirect (with other intervening elements therebetween) contact with each other, or that two or more elements cooperate or interact with each other (e.g., as in a causal relationship, such as for signaling/receiving or function invocation), or both.
Any reference herein to image analysis by a computing system may be performed in accordance with or using spatial structure information, which may include depth information describing corresponding depth values for various locations relative to a selected point. The depth information may be used to identify objects or estimate how objects are spatially arranged. In some cases, the spatial structure information may include or may be used to generate a point cloud describing the location of one or more surfaces of the object. Spatial structure information is but one form of possible image analysis and other forms known to those skilled in the art may be used in accordance with the methods described herein.
Fig. 1A illustrates a system 1500 for performing object detection or more specifically object recognition. More particularly, system 1500 can include a computing system 1100 and a camera 1200. In this example, the camera 1200 may be configured to generate image information that describes or otherwise represents the environment in which the camera 1200 is located, or more specifically, the environment in the field of view of the camera 1200 (also referred to as the camera field of view). The environment may be, for example, a warehouse, a manufacturing facility, a retail space, or other location. In such cases, the image information may represent objects located at such locations, such as boxes, cabinets, boxes, crates, or other containers. The system 1500 may be configured to generate, receive, and/or process image information to perform object recognition or object registration based on the image information, such as by using the image information to distinguish between various objects in the camera field of view, and/or to perform a robot interaction plan based on the image information, as discussed in more detail below (the terms "and/or" and "or" are used interchangeably throughout this disclosure). The robot interaction plan may be used, for example, to control a robot at a venue to facilitate robot interaction between the robot and a container or other object. The computing system 1100 and the camera 1200 may be located at the same location or may be remote from each other. For example, computing system 1100 may be part of a cloud computing platform hosted in a data center remote from a warehouse or retail space and may communicate with cameras 1200 via a network connection.
In an embodiment, the camera 1200 (which may also be referred to as an image sensing device) may be a 2D camera and/or a 3D camera. For example, fig. 1B shows a system 1500A (which may be an embodiment of system 1500), the system 1500A including a computing system 1100 and cameras 1200A and 1200B, both cameras 1200A and 1200B may be embodiments of camera 1200. In this example, the camera 1200A may be a 2D camera configured to generate 2D image information that includes or forms a 2D image that describes the visual appearance of the environment in the field of view of the camera. The camera 1200B may be a 3D camera (also referred to as a spatial structure sensing camera or spatial structure sensing device) configured to generate 3D image information including or forming spatial structure information about an environment in a field of view of the camera. The spatial structure information may include depth information (e.g., a depth map) that describes corresponding depth values relative to various locations of the camera 1200B, such as locations on the surface of various objects in the field of view of the camera 1200. These positions in the field of view of the camera or on the surface of the object may also be referred to as physical positions. In this example, the depth information may be used to estimate how objects are spatially arranged in three-dimensional (3D) space. In some cases, the spatial structure information may include or may be used to generate a point cloud describing locations on one or more surfaces of objects in the field of view of the camera 1200B. More specifically, the spatial structure information may describe various locations on the structure of the object (also referred to as the object structure).
In an embodiment, the system 1500 may be a robot operating system for facilitating robotic interaction between a robot and various objects in the environment of the camera 1200. For example, FIG. 1C illustrates a robotic operating system 1500B, which may be an embodiment of the systems 1500/1500A of FIGS. 1A and 1B. Robot operating system 1500B can include computing system 1100, camera 1200, and robot 1300. As described above, robot 1300 may be used to interact with one or more objects in the environment of camera 1200 (such as with a box, crate, cabinet, or other container). For example, robot 1300 may be configured to pick up containers from one location and move them to another location. In some cases, robot 1300 may be used to perform a destacking operation in which a group of containers or other objects is unloaded and moved to, for example, a conveyor belt. In some implementations, the camera 1200 may be attached to the robot 1300, such as to a robotic arm 3320 of the robot 1300. In some implementations, the camera 1200 may be separate from the robot 1300. For example, the camera 1200 may be mounted to a ceiling of a warehouse or other structure, and may remain fixed relative to the structure.
In an embodiment, the computing system 1100 of fig. 1A-1C may be formed or integrated into a robot 1300, which is also referred to as a robot controller. A robot control system may be included in the system 1500B and may be configured to generate commands, such as robot interaction movement commands for controlling robot interactions between the robot 1300 and a container or other object, for example, for the robot 1300. In such embodiments, the computing system 1100 may be configured to generate such commands based on, for example, image information generated by the camera 1200. For example, the computing system 1100 may be configured to determine a motion plan based on the image information, where the motion plan may be intended for, for example, gripping or otherwise picking up an object. The computing system 1100 may generate one or more robot-interactive movement commands to execute the motion plan.
In an embodiment, the computing system 1100 may form or be part of a vision system. The vision system may be a system that generates, for example, visual information describing the environment in which robot 1300 is located, or alternatively or additionally, describing the environment in which camera 1200 is located. The visual information may include 3D image information and/or 2D image information discussed above, or some other image information. In some cases, if the computing system 1100 forms a vision system, the vision system may be part of the robotic control system discussed above, or may be separate from the robotic control system. If the vision system is separate from the robot control system, the vision system may be configured to output information describing the environment in which the robot 1300 is located. The information may be output to a robotic control system, which may receive such information from the vision system and execute a motion plan and/or generate robotic interactive movement commands based on the information. Further information about the vision system is described in detail below.
In an embodiment, computing system 1100 may communicate with camera 1200 and/or robot 1300 via a direct connection, such as via a dedicated wired communication interface, such as an RS-232 interface, a Universal Serial Bus (USB) interface, and/or a connection provided via a local computer bus, such as a Peripheral Component Interconnect (PCI) bus. In an embodiment, computing system 1100 may communicate with camera 1200 and/or with robot 1300 via a network. The network may be any type and/or form of network, such as a Personal Area Network (PAN), a Local Area Network (LAN) (e.g., intranet), a Metropolitan Area Network (MAN), a Wide Area Network (WAN)), or the internet. The network may utilize different technologies and protocol layers or protocol stacks including, for example, ethernet protocols, internet protocol suite (TCP/IP), ATM (asynchronous transfer mode) techniques, SONET (synchronous optical network) protocols or SDH (synchronous digital hierarchy) protocols.
In an embodiment, computing system 1100 may communicate information directly with camera 1200 and/or with robot 1300, or may communicate via an intermediate storage device or, more generally, via an intermediate non-transitory computer-readable medium. For example, FIG. 1D illustrates a system 1500C that may be an embodiment of system 1500/1500A/1500B, the system 1500C including a non-transitory computer readable medium 1400, which non-transitory computer readable medium 1400 may be external to the computing system 1100 and may act as an external buffer or repository for storing image information generated by, for example, the camera 1200. In such examples, computing system 1100 may retrieve or otherwise receive image information from non-transitory computer-readable medium 1400. Examples of non-transitory computer readable medium 1400 include an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination thereof. The non-transitory computer readable medium may form, for example, a computer diskette, a Hard Disk Drive (HDD), a solid state drive (SDD), a Random Access Memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or flash memory), a Static Random Access Memory (SRAM), a portable compact disc read-only memory (CD-ROM), a Digital Versatile Disc (DVD), and/or a memory stick.
As described above, the camera 1200 may be a 3D camera and/or a 2D camera. The 2D camera may be configured to generate a 2D image, such as a color image or a grayscale image. The 3D camera may be, for example, a depth sensing camera, such as a time of flight (TOF) camera or a structured light camera, or any other type of 3D camera. In some cases, the 2D camera and/or the 3D camera may include an image sensor, such as a Charge Coupled Device (CCD) sensor and/or a Complementary Metal Oxide Semiconductor (CMOS) sensor. In embodiments, the 3D camera may include a laser, a LIDAR device, an infrared device, a light/dark sensor, a motion sensor, a microwave detector, an ultrasound detector, a RADAR detector, or any other device configured to capture depth information or other spatial structure information.
As described above, image information may be processed by computing system 1100. In embodiments, computing system 1100 may include or be configured as a server (e.g., having one or more server blades, processors, etc.), a personal computer (e.g., desktop computer, laptop computer, etc.), a smart phone, a tablet computing device, and/or any other computing system. In an embodiment, any or all of the functions of computing system 1100 may be performed as part of a cloud computing platform. Computing system 1100 can be a single computing device (e.g., a desktop computer) or can include multiple computing devices.
FIG. 2A provides a block diagram illustrating an embodiment of a computing system 1100. The computing system 1100 in this embodiment includes at least one processing circuit 1110 and a non-transitory computer-readable medium (or media) 1120. In some cases, processing circuitry 1110 may include a processor (e.g., a Central Processing Unit (CPU), a special-purpose computer, and/or an on-board server) configured to execute instructions (e.g., software instructions) stored on a non-transitory computer-readable medium 1120 (e.g., a computer memory). In some embodiments, the processor may be included in a separate/stand-alone controller that is operatively coupled to other electronic/electrical devices. The processor may implement program instructions to control/interface with other devices to cause computing system 1100 to perform actions, tasks, and/or operations. In an embodiment, processing circuitry 1110 includes one or more processors, one or more processing cores, a programmable logic controller ("PLC"), an application specific integrated circuit ("ASIC"), a programmable gate array ("PGA"), a field programmable gate array ("FPGA"), any combination thereof, or any other processing circuitry.
In an embodiment, non-transitory computer-readable medium 1120 as part of computing system 1100 may be an alternative to or in addition to intermediate non-transitory computer-readable medium 1400 discussed above. The non-transitory computer-readable medium 1120 may be a storage device, such as an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination thereof, such as, for example, a computer diskette, a Hard Disk Drive (HDD), a solid state drive (SDD), a Random Access Memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or flash memory), a Static Random Access Memory (SRAM), a portable compact disc read-only memory (CD-ROM), a Digital Versatile Disc (DVD), a memory stick, any combination thereof, or any other storage device. In some cases, non-transitory computer readable medium 1120 may include a plurality of storage devices. In some implementations, the non-transitory computer readable medium 1120 is configured to store image information generated by the camera 1200 and received by the computing system 1100. In some cases, the non-transitory computer-readable medium 1120 may store one or more model templates for performing object recognition operations. The non-transitory computer readable medium 1120 may alternatively or additionally store computer readable program instructions that, when executed by the processing circuit 1110, cause the processing circuit 1110 to perform one or more methods described herein.
Fig. 2B depicts a computing system 1100A, which is an embodiment of computing system 1100 and includes a communication interface 1130. The communication interface 1130 may be configured to receive image information generated by the camera 1200 of fig. 1A-1D, for example. The image information may be received via the intermediate non-transitory computer readable medium 1400 or network discussed above, or via a more direct connection between the camera 1200 and the computing system 1100/1100A. In an embodiment, the communication interface 1130 may be configured to communicate with the robot 1300 of fig. 1C. If the computing system 1100 is external to the robotic control system, the communication interface 1130 of the computing system 1100 may be configured to communicate with the robotic control system. The communication interface 1130 may also be referred to as a communication component or communication circuit and may include, for example, communication circuitry configured to perform communications via a wired or wireless protocol. By way of example, the communication circuitry may include an RS-232 port controller, a USB controller, an Ethernet controller,A controller, a PCI bus controller, any other communication circuit, or a combination thereof.
In an embodiment, as shown in fig. 2C, the non-transitory computer-readable medium 1120 may include a template storage space 1128 configured to store one or more data objects (data objects) discussed herein. For example, the storage space may store model templates, robotic arm movement commands, and any additional data objects that computing system 1100B may need to access.
In an embodiment, the processing circuit 1110 may be programmed by one or more computer readable program instructions stored on the non-transitory computer readable medium 1120. For example, fig. 2D illustrates a computing system 1100C, which is an embodiment of the computing system 1100/1100A/1100B, in which the processing circuitry 1110 is programmed by one or more modules including an object recognition module 1121, a Minimum Viable Range (MVR) module 1122, and a motion planning module 1129.
In an embodiment, the object recognition module 1121 may be configured to acquire and analyze image information, as discussed throughout the present disclosure. The methods, systems, and techniques discussed herein with respect to image information may use an object recognition module.
The MVR determination module 1122 may be configured to calculate, determine, and/or identify a minimum feasible range from the image information and the analysis performed or obtained by the object recognition module 1121. The methods, systems, and techniques discussed herein with respect to MVR determination may be performed by MVR determination module 1122.
The motion planning module 1129 may be configured to plan movement of the robot. For example, the motion plan module 1129 may derive individual placement locations/orientations, calculate corresponding motion plans, or a combination thereof for grabbing and moving objects. The methods, systems, and techniques discussed herein with respect to robotic arm movement may be performed by the motion planning module 1129.
Referring to fig. 2E, 2F, and 3A, a method associated with an object recognition module 1121 that may be performed for image analysis is explained. Fig. 2E and 2F illustrate example image information associated with an image analysis method, while fig. 3A illustrates an example robotic environment associated with an image analysis method. References herein relating to image analysis by a computing system may be performed in accordance with or using spatial structure information, which may include depth information describing respective depth values for various locations relative to a selected point. The depth information may be used to identify objects or estimate how objects are spatially arranged. In some cases, the spatial structure information may include or may be used to generate a point cloud describing the location of one or more surfaces of the object. Spatial structure information is but one form of possible image analysis and other forms known to those skilled in the art may be used in accordance with the methods described herein.
In an embodiment, the computing system 1100 may acquire image information representing objects in a camera field of view (e.g., 3210) of the camera (e.g., 1200/3200). In some cases, the object may be a first object (e.g., 3510) of one or more objects (e.g., 3510-3540) in a camera field of view 3210 of the camera 1200/3200. While the set of objects 3000A/3000B/3000C/3000D are (or have been) in the camera field of view 3210, the image information 2600, 2700 may be generated by the camera (e.g., 1200/3200) and may describe one or more of the individual objects. Object appearance the appearance of an object 3000A/3000B/3000C/3000D is described from the point of view of camera 1200/3200. If there are multiple objects in the camera field of view, the camera may generate image information representing the multiple objects or a single object as desired. When the set of objects is (or is already) in the camera field of view, image information may be generated by the camera (e.g., 1200/3200) and may include, for example, 2D image information and/or 3D image information.
As an example, fig. 2E depicts a first set of image information, or more specifically, 2D image information 2600, which is generated by camera 3200 and represents object 3000A/3000B/3000C/3000D/3550 of fig. 3A, as described above. More specifically, the 2D image information 2600 may be a grayscale or color image and may describe the appearance of the object 3000A/3000B/3000C/3000D/3550 from the viewpoint of the camera 3200. In an embodiment, the 2D image information 2600 may correspond to a single color channel (e.g., red, green, or blue channel) of a color image. If camera 3200 is arranged over object 3000A/3000B/3000C/3000D/3550, 2D image information 2600 may represent the appearance of a corresponding top surface of object 3000A/3000B/3000C/3000D/3550. In the example of FIG. 2E, 2D image information 2600 may include respective portions 2000A/2000B/2000C/2000D/2550, also referred to as image portions, representing respective surfaces of object 3000A/3000B/3000C/3000D/3550. In fig. 2E, each image portion 2000A/2000B/2000C/2000D/2550 of the 2D image information 2600 may be an image range, or more specifically, a pixel range (if the image is formed of pixels). Each pixel in the pixel range of the 2D image information 2600 may be characterized as having a position described by a set of coordinates U, V and may have a value relative to the camera coordinate system or some other coordinate system, as shown in fig. 2E and 2F. Each pixel may also have an intensity value, such as a value between 0 and 255 or 0 and 1023. In further embodiments, each pixel may include any additional information (e.g., hue, saturation, intensity, CMYK, RGB, etc.) associated with the pixels in various formats.
As described above, in some embodiments, the image information may be all or part of an image, such as 2D image information 2600. For example, computing system 3100 may be configured to extract image portion 2000A from 2D image information 2600 to obtain image information associated only with corresponding object 3000A. For example, the computing system 3100 may extract the image portion 2000A by performing an image segmentation operation based on the 2D image information 2600 and/or the 3D image information 2700 shown in fig. 2F. In some implementations, the image segmentation operation may include detecting image locations in the 2D image information 2600 where physical edges of objects (e.g., edges of boxes) occur and using such image locations to identify image portions (e.g., 5610) that are limited to representing only a single object in the camera field of view (e.g., 3210).
Fig. 2F depicts an example in which the image information is 3D image information 2700. More particularly, 3D image information 2700 may include, for example, a depth map or point cloud indicating respective depth values for various locations on one or more surfaces (e.g., top surfaces or other outer surfaces) of object 3000A/3000B/3000C/3000D/3550. In some implementations, the image segmentation operation for extracting image information may involve detecting image locations in the 3D image information 2700 where physical edges of objects (e.g., edges of boxes) occur and using such image locations to identify image portions (e.g., 2730) that are limited to representing only a single object in the camera field of view (e.g., 3000A).
The corresponding depth values may be relative to the camera 3200 that generated the 3D image information 2700, orMay be relative to some other reference point. In some implementations, 3D image information 2700 may include a point cloud including corresponding coordinates at various locations on the structure of objects in the camera field of view (e.g., 3210). In the example of fig. 2F, the point cloud may include respective sets of coordinates describing locations on respective surfaces of object 3000A/3000B/3000C/3000D/3550. The coordinates may be 3D coordinates, such as [ X Y Z]Coordinates, and may have values relative to the camera coordinate system or some other coordinate system. For example, 3D image information 2700 may include a set of locations 2710, also referred to as physical locations, on the surface of object 3000D 1 -2710 n Is also referred to as an image portion). In addition, the 3D image information 2700 may further include second, third, and fourth portions 2720, 2730, and 2740. These portions may then also indicate that they may be represented by 2720, respectively 1 -2720 n 、2730 1 -2730 n And 2740 1 -2740 n A corresponding depth value for a set of locations represented. These figures are merely examples and any number of objects with corresponding image portions may be used. Similar to the above, the acquired 3D image information 2700 may be part of the first set of 3D image information 2700 generated by the camera in some cases. In the example of fig. 2E, if the acquired 3D image information 2700 represents the first object 3000A of fig. 3A, the 3D image information 2700 may be reduced to reference only the image portion 2710.
In an embodiment, the image normalization operation may be performed by the computing system 1100 as part of acquiring image information. The image normalization operation may involve transforming an image or image portion generated by the camera 3200 to generate a transformed image or transformed image portion. For example, if the acquired image information, which may include 2D image information 2600, 3D image information 2700, or a combination of both, may undergo an image normalization operation to attempt to cause the image information to be changed in the viewpoint, object pose, lighting conditions associated with the visual description information. Such normalization may be performed to facilitate a more accurate comparison between image information and model (e.g., template) information. The viewpoint may refer to a pose of the object relative to the camera 3200, and/or an angle at which the camera 3200 is viewing the object when the camera 3200 generates an image representing the object.
For example, image information may be generated during an object recognition operation, where the target object is in the camera field of view 3210. When the target object has a specific pose with respect to the camera, the camera 3200 may generate image information representing the target object. For example, the target object may have a pose with its top surface perpendicular to the optical axis of the camera 3200. In such examples, the image information generated by the camera 3200 may represent a particular point of view, such as a top view of the target object. In some cases, when camera 3200 generates image information during an object recognition operation, the image information may be generated under specific lighting conditions, such as lighting intensity. In such a case, the image information may represent a particular illumination intensity, illumination color, or other illumination condition.
In an embodiment, the image normalization operation may involve adjusting an image or image portion of the scene generated by the camera to better match the image or image portion to the viewpoint and/or lighting conditions associated with the information of the model template. The adjustment may involve transforming the image or image portion to generate a transformed image that matches at least one of the object pose or lighting conditions associated with the visual description information of the model template.
Viewpoint adjustment may involve processing, wrapping, and/or shifting of images of the scene such that the images represent the same viewpoints as the visual description information in the model template. For example, processing includes changing the color, contrast, or illumination of an image, wrapping of a scene may include changing the size, dimension, or scale of the image, and shifting of the image may include changing the position, orientation, or rotation of the image. In example embodiments, processing, wrapping, and/or shifting may be used to change objects in an image of a scene to have an orientation and/or size that matches or better corresponds to visual description information of a model template. If the model template describes a frontal view (e.g., top view) of an object, then the image of the scene may be wrapped to also represent the frontal view of the object in the scene.
In various embodiments, the terms "computer readable instructions" and "computer readable program instructions" are used to describe software instructions or computer code configured to perform various tasks and operations. In various embodiments, the term "module" broadly refers to a collection of software instructions or code configured to cause processing circuit 1110 to perform one or more functional tasks. When a processing circuit or other hardware component is executing a module or computer-readable instruction, the module and computer-readable instruction may be described as performing various operations or tasks.
One aspect of the present disclosure relates to a robotic system or any other computing system capable of performing object detection (also referred to as object recognition), object size measurement, and/or minimum feasible range detection. Object detection or size measurement may involve determining the size of individual objects in a scene or determining the boundaries of individual objects. The object may be part of a group of objects, such as a box that is part of a group of objects. For example, the robotic system may perform an object detection operation as part of a destacking operation, wherein the robotic system receives camera data that captures a scene having a tray of objects, wherein each layer of the tray has objects placed in close proximity to each other.
Object detection in this scenario may involve processing or analyzing camera data (image information) to distinguish among individual objects on a particular layer of the tray so that one single object can be distinguished from other objects on that layer. When such pallet objects are all placed flush with each other, problems arise that make it difficult for the robotic system to detect or separate the objects from each other. The processes described herein may allow a robotic system to identify the size and/or boundaries of an object in order to generate a plan for picking individual objects from a pallet and moving them elsewhere. In some implementations, the robotic system may identify at least one minimum feasible range for objects in the scene. The minimum feasible range is an estimate of the potential contour or size of a particular object. Thus, the robotic system can grasp a single object with an end effector device (e.g., a gripper) to the minimum feasible extent without knowing the exact size of the object. The minimum feasible range of an object represents the range on the top surface of the object that is estimated to exist entirely on the surface of a single object. Thus, attempting to grasp an object within this range ensures that the end effector device contacts only a single object and does not extend beyond the edge of the object. As discussed herein, the minimum feasible range determination may improve the accuracy and speed of the object moving robotic arm.
In the above examples, the object may be a box or other object placed beside other objects, for example on a pallet or other platform. If the camera generates an image capturing a scene with multiple objects, the image itself may not be entirely reliable for the purpose of distinguishing between different objects. For example, while some cameras may be capable of generating images that indicate depth values at various locations in a scene, if multiple objects have the same height or are otherwise the same distance from the camera, the images may indicate substantially uniform depth values that cover a range of top surfaces of the multiple objects, particularly if the multiple objects are closely packed together. Thus, such images may provide limited information for the purpose of identifying individual objects from among a plurality of objects. While some cameras may be capable of generating images that capture the visual appearance of objects, such as their top surfaces, these top surfaces may have lines or other visual indicia printed on them. Thus, such images may include lines, but each line may be associated with a boundary (e.g., a first or second edge) of one of the objects, or may simply be a visual marker (e.g., which may be a false edge). Accordingly, the systems and methods provided herein may be used to determine a minimum feasible range of an object surface. The minimum feasible range represents the range on the top surface of the object that is estimated to exist entirely on the surface of a single object. The minimum feasible range may be defined by the actual physical edges of the object and/or the false edges of the object. If the system cannot easily distinguish between false edges and physical edges, this cannot be interpreted by the method of defining the smallest possible range, as described below.
Fig. 3A-3H illustrate example environments in which the processes and methods described herein may be performed. Fig. 3A depicts an environment having a system 3500 (which may be an embodiment of the system 1500/1500A/1500B/1500C of fig. 1A-1D) including a computing system 3100 (e.g., an embodiment of computing system 1100), a robot 3300, and a camera 3200. Camera 3200 may be an embodiment of camera 1200 and may be configured to generate image information representing a scene in a camera field of view 3210 of camera 3200, or more specifically representing objects in camera field of view 3210, such as objects 3000A, 3000B, 3000C, and 3000D. In one example, each of the objects 3000A-3000D may be a container, such as a box or crate, for example, and the object 3550 may be a tray with the container disposed thereon, for example.
In an embodiment, the system 3500 of fig. 3A may include one or more light sources, such as light source 3600. Light source 3600 may be, for example, a Light Emitting Diode (LED), a halogen lamp, or any other light source, and may be configured to emit visible light, infrared radiation, or any other form of light toward a surface of objects 3000A-3000D. In some implementations, computing system 3100 may be configured to communicate with light source 3600 to control when light source 3600 is activated. In other implementations, the light source 3600 may operate independently of the computing system 3100.
In an embodiment, system 3500 may include a camera 3200 or multiple cameras 3200, including a 2D camera configured to generate 2D image information 2600 and a 3D camera configured to generate 3D image information 2700. The 2D image information 2600 (e.g., a color image or a grayscale image) may describe the appearance of one or more objects (such as objects 3000A/3000B/3000C/3000D) in the camera field of view 3210. For example, 2D image information 2600 may capture or otherwise represent visual details disposed on respective outer surfaces (e.g., top surfaces) of object 3000A/3000B/3000C/3000D, and/or contours of those outer surfaces. In an embodiment, the 3D image information may describe the structure of one or more of the objects 3000A/3000B/3000C/3000D/3550, wherein the structure of the object may also be referred to as an object structure or a physical structure of the object. For example, the 3D image information 2700 may include a depth map, or more generally, depth information, which may describe respective depth values for various locations in the camera field of view 3210 relative to the camera 3200 or relative to some other reference point. The locations corresponding to the respective depth values may be locations (also referred to as physical locations) on various surfaces in the camera field of view 3210, such as locations on the respective top surfaces of the object 3000A/3000B/3000C/3000D/3550. In some cases, 3D image information 2700 may include a point cloud that may include a plurality of 3D coordinates describing various locations on one or more outer surfaces of objects 3000A/3000B/3000C/3000D/3550 or some other object in camera field of view 3210. The point cloud is shown in fig. 2F.
In the example of fig. 3A, a robot 3300 (which may be an embodiment of robot 1300) may include a robotic arm 3320, the robotic arm 3320 having one end attached to a robot base 3310 and having another end attached to or formed by an end effector device 3330, such as a robotic gripper. The robot base 3310 may be used to mount a robotic arm 3320 and the robotic arm 3320, or more specifically, the end effector device 3330, may be used to interact with one or more objects in the environment of the robot 3300. The interactions (also referred to as robotic interactions) may include, for example, grasping or otherwise picking up at least one of the objects 3000A-3000D. For example, the robot interactions may be part of a destacking operation in which robot 3300 is used to pick up objects 3000A-3000D from a tray and move objects 3000A-3000D to a destination location. The end effector device 3330 may have a suction cup or other assembly for grasping or gripping an object. The end effector device 3330 may be configured to grasp or grasp an object by, for example, contact with a single face or surface of the object via a top surface using a suction cup or other grasping assembly.
Robot 3300 may also include additional sensors configured to obtain information for performing tasks, such as for manipulating structural members and/or for transporting robotic units. The sensors may include sensors configured to detect or measure one or more physical characteristics of the robot 3300 and/or the surrounding environment (e.g., the state, condition, and/or position of one or more structural members/joints thereof). Some examples of sensors may include accelerometers, gyroscopes, force sensors, strain gauges, tactile sensors, torque sensors, position encoders, and the like.
Fig. 3B depicts a top view of objects 3000A, 3000B, 3000C, and 3000D of fig. 3A. Each object 3000A-3000D includes a surface 3001, a plurality of corners 3002, and in this example, open corners 3004. As used herein, "open angle" refers to any angle of the plurality of angles 3002 that is not adjacent to another object 3000. The open angle may be formed by two edges of the top surface of the object, which edges are not themselves contiguous with another object. In an example, the two edges may include two horizontal edges. For angles that are considered open, it is not required that neither edge has adjacent objects. Referring to FIG. 3C, wherein a close-up top view of objects 3000A-3000D is depicted, additional features of each object 3000A-3000D are depicted. In a two-dimensional depiction, object 3000A may have a surface defined by four edges (longitudinal physical edge 3013, lateral physical edge 3015, lateral physical edge 3017, and longitudinal physical edge 3019). In the example embodiment shown, the lateral physical edge 3015 and the longitudinal physical edge 3013 are not adjacent or flush with the edges of any adjacent objects, and thus may be referred to as open edges. In the example embodiment shown, the lateral physical edge 3017 and the longitudinal physical edge 3019 are adjacent to and flush with the edges of adjacent objects 3000B and 3000D, and thus may be referred to as closed edges. The use of the terms "longitudinal" and "transverse" to refer to the above-described edges is not meant to require a specific orientation of the object and/or edge. Typically, for an approximately rectangular object, the longitudinal edges are adjacent (and nearly perpendicular) to the transverse edges. As used herein, longitudinal and transverse refer to a particular direction within the context of an object or group of objects only, and not to a particular absolute direction. The positioning of objects 3000A, 3000B, and 3000D may make it more difficult for computing system 3100 to distinguish the features of each object.
A method 4000 for determining a minimum feasible range of open angles 3004 is depicted in fig. 4. The method 4000 may be stored on a non-transitory computer-readable medium and may be performed by at least one processing circuit, where the at least one processing circuit is in communication with a camera having a field of view.
In operation, method 4000 includes an operation 4002 of acquiring image information representative of physical characteristics of one or more objects 3000 (e.g., objects 3000A-3000D). Image information is generated by the camera 3200 and describes at least an object appearance associated with one or more objects, wherein each object includes a plurality of edges. Fig. 3A depicts acquiring or generating image information. In an embodiment, the image information is acquired in three dimensions or in perspective, and in order to improve the accuracy of the method, the viewpoint is shifted to a two-dimensional view. Viewpoint adjustment may involve processing, wrapping, and/or shifting of image information. Processing may include changing the color, contrast, or illumination of the image information, wrapping of the scene may include changing the size, dimension, or scale of the image information, and shifting of the image information may include changing the position, orientation, or rotation of the image information. The wrapping may involve determining a homography that defines a wrapping transformation that transforms image information from describing the object in three dimensions to describing the object in two dimensions, e.g., a top view. In some cases, the wrapping may describe a rotation and/or translation that matches the image information with a corresponding point (e.g., angle) of the desired two-dimensional view.
In embodiments, the calculations and methods described below may be performed after the camera is no longer imaging one or more objects or after one or more objects have left the field of view.
In operation, method 4000 includes an operation 4004 for detecting a plurality of corners 3002 of a plurality of objects 3000 based on image information. To detect any angle present, the computing system 1100/3100 may use a variety of methods. For example, angle detection may involve edge detection and subsequent determination of edge intersection. Edge detection may be performed based on analysis of 2D and 3D image information (e.g., point cloud information). Edge detection may include, for example, (i) 2D image analysis to identify lines or edges within the 2D image that may represent boundaries between objects, (ii) point cloud analysis involving layer segmentation and detection of different heights/depths to detect edges, or (iii) 2D or 3D image analysis to identify open edges. The examples described herein are by way of example only, and edge detection may also suitably include alternative techniques.
Edge detection may include, for example, 2D image analysis to identify lines or edges within the 2D image that may represent boundaries between objects. Such analysis may identify visual discontinuities within the 2D image that may represent edges. Such analysis may include, for example, analysis of pixel intensity discontinuity conditions or spike pixel intensity conditions. Satisfying the defined pixel intensity discontinuity condition may include using a modification of the pixel intensity value, or more specifically, using a derivative or gradient of the pixel intensity value between ranges having different pixel intensities. The gradient or derivative may then be used to detect spikes in pixel intensity present at the edge or corner, particularly when moving perpendicular to the edge or corner. In addition, computing system 1100/3100 may apply binary thresholds to identify differences in pixel intensities in order to define spikes or discontinuities between adjacent pixels, identifying edges or corners.
Edge detection may include, for example, point cloud analysis involving layer segmentation and detection of different heights/depths to detect edges. Adjacent objects may have different heights. Thus, detection of different heights (or depths) in a point cloud (3D image information) can be used to detect edges between objects. Accordingly, the computing system 1100/3100 may detect edges from portions of the point cloud that satisfy the defined depth discontinuity condition.
In further examples, edge detection may be performed by detecting the absence of a physical edge of a neighboring object. In the case where an object lacks an adjacent object, for example, where an object is located at the outer perimeter of a group of objects, the edges of the group of objects may be detected as physical edges of the associated individual objects.
In embodiments, any of the above methods for edge detection may be combined with each or other edge detection methods to improve the accuracy or reliability of edge detection.
In operation, method 4000 includes an operation 4005 of identifying an open angle 3004 from among a plurality of angles 3002. As described above, the "open angle" refers to an angle among the plurality of angles 3002 that is not adjacent to another object 3000. In an embodiment, the system may be configured to identify a plurality of corners, and once corner 3002 is identified, select an open corner, such as target open corner 3004A, from open corners among corners 3002. In an embodiment, each of the plurality of corners 3002 may be open corners in that the corner detection operation 4004 may detect corners based on physical edges identified by the lack of adjacent objects. Further, when identifying a target opening angle, the system may identify that the opening angle is not adjacent to another object. The target m opening angle 3004A may be a single target opening angle.
Open angles (also referred to as lobes or external angles) may be identified by analysis of 3D image information (e.g., in the form of a point cloud), as described above. The opening angle may be identified, for example, by identifying vertices within the point cloud (e.g., based on edge intersection or other means) and then subjecting the identified vertices to one or more criteria (e.g., length, depth, width, orthogonality criteria) to determine whether they represent the opening angle. Additional details regarding the use of image information to identify corners and potential edges can be found in U.S. patent No. 10,614,340 issued on 7, 2020, which is incorporated by reference in its entirety.
As described above and with reference to FIG. 3C, an expanded top view of objects 3000A-3000D is depicted, with additional features of each object 3000A-3000D depicted. In a two-dimensional depiction, object 3000A may have a surface defined by four edges (longitudinal physical edge 3013, lateral physical edge 3015, lateral physical edge 3017, and longitudinal physical edge 3019). In the example embodiment shown, the lateral physical edge 3017 and the longitudinal physical edge 3019 are adjacent to and flush with the edges of adjacent objects 3000B and 3000D. As previously described, such positioning of objects 3000A, 3000B, and 3000D may make it more difficult for computing system 3100 to distinguish the features of each object.
In operation, method 4000 includes an operation 4006 of defining a minimum feasible range 3006 as shown in fig. 3E and 3G for a target opening angle 3004A. The minimum viable range 3006 represents a range on the surface 3001 of the object 3000 that may be grasped by the end effector device 3330 of the robotic arm 3320 to move the object 3000 that is associated with the target opening angle 3004A. As described above, the robotic arm 3320 may grasp an object, such as a target object including the target opening angle 3004A, using, for example, suction of the end effector device 3330 to grasp the object through the top surface. The minimum feasible range 3006 of an object represents the range on the top surface of the object that is estimated to exist entirely on the surface of a single object. Accordingly, attempting to grasp the target object within the range defined by the minimum feasible range 3006 may ensure that the end effector device 3330 only contacts the target object (e.g., a single object) and does not extend beyond the edge of the target object such that adjacent objects are not also grasped when grasping the target object. In the event that the edge of object 3000 is adjacent to or in contact with other objects, computing system 1100/3100 may have difficulty identifying or take longer to identify the exact size of the object. Thus, it may be difficult to accurately define the extent to which the robotic arm 3320 may safely grasp the object 3000 without extending beyond the edge of the object 3000 and/or contacting another individual object. Thus, the minimum viable range 3006 defines a range based on estimated or potential dimensions, where the robotic arm 3320 may grasp the object 3000 without knowing the exact dimensions of the object 3000. The minimum feasible region 3006 is intended to define a region in which the robotic arm 3320 may grasp the object 3000. It should be appreciated that the size of the minimum viable range 3006 may be different, sometimes even significantly different, than the size of the object 3000 on which it is found. Operations 4008-4016 depict how the minimum feasible region 3006 is calculated and verified.
In operation, method 4000 includes an operation 4008 for generating a plurality of candidate edge segments. The plurality of candidate edge segments may include a plurality of lateral candidate edge segments and a plurality of longitudinal candidate edge segments. The plurality of lateral candidate edge segments and the plurality of longitudinal candidate edge segments represent edges or edge portions that are candidates for corresponding to the lateral physical edge 3017 and the longitudinal physical edge 3019, respectively, of the object 3000 associated with the target opening angle 3004A. The object 3000 associated with the target open angle 3004A may be positioned adjacent or flush with other objects 3000, creating an environment that the computing system 1100/3100 may be challenged to distinguish between the location where the object 3000A ends and the other objects (3000B, 3000C, 300D, etc.) begin.
The computing system 1100/3100 may first identify a plurality of potential edge segments within the 2D image information. The potential edge segments may be identified from any type of detectable visual marker having properties that make it possible to identify them as representing the physical edges of the object. For example, visual indicia may include edges, creases, gaps, color alterations, and other discontinuities. The potential edge segments may then be further processed (e.g., by clustering techniques) to identify a plurality of candidate edge segments. Suitable clustering techniques are described, for example, in U.S. patent application Ser. No. 16/791,024, filed on even 14, 2/2020, which is incorporated herein by reference in its entirety. In an embodiment, candidate edge segments may be identified from potential edge segments based on being substantially perpendicular (e.g., within 5 degrees of perpendicular) to either the lateral physical edge 3017 (for a longitudinal candidate edge segment) or the longitudinal physical edge 3013 (for a lateral candidate edge segment). For purposes of illustration, fig. 3C shows a single lateral candidate edge segment 3009 of the plurality of lateral candidate edge segments and a single longitudinal candidate edge segment 3011 of the plurality of longitudinal candidate edge segments.
In an embodiment, the detection of multiple candidate edge segments may be limited according to minimum and maximum candidate sizes. The computing system 1100/3100 may determine minimum and maximum candidate sizes based on the expected object size. The desired object may have length, width and height dimensions. The minimum candidate size may be defined in terms of the smallest face to be found in the intended object (e.g., in terms of two of three dimensions). In some embodiments, the minimum candidate size may be defined by length and width dimensions and/or diagonal dimensions. The maximum candidate size may be defined in terms of the largest face to be found in the intended object (e.g., in terms of two of three dimensions). The minimum candidate size 3016 and the maximum candidate size 3018 are illustrated by way of example in fig. 3D. The minimum candidate size 3016 may thus be associated with a minimum possible object plane, and the maximum candidate size 3018 may thus be associated with a maximum possible object plane. The minimum candidate size 3016 may include a lateral dimension 3016A and a longitudinal dimension 3016B that represent the dimensions of the smallest possible object face, while the maximum candidate size 3018 may include a lateral dimension 3018A and a longitudinal dimension 3018B that represent the dimensions of the largest possible object face. In some embodiments, only the range between the minimum candidate size 3016 and the maximum candidate size 3018 is analyzed for the generation of potential edge segments.
In an embodiment, operation 4008 may be operative to combine the aligned candidate edge segments. For example, where one or more candidate edge segments are aligned, they may be combined by computing system 1100/3100 for further analysis. The aligned candidate edge segments may have a substantially co-linearity (also referred to as a substantially similar alignment), which may be defined according to a predefined angle threshold and/or a predefined offset threshold. The angle threshold of the two candidate edge segments may require, for example, that the angle between the two candidate edges be within the angle threshold (e.g., a number of degrees, such as 5 °, 4 °, 3 °, 2 °, or 1 °), or that the respective angle formed by each of the two candidate edge segments be within the angle threshold. The offset threshold of two candidate edge segments may require, for example, that the candidate edge have a smaller offset than the offset threshold. In an embodiment, the offset between two candidate edges may be defined by the shortest distance between corresponding lines extending or otherwise extrapolated from the candidate edges. The aligned candidate edge segments may be combined to create a larger candidate edge segment.
In operation, method 4000 includes an operation 4010 of determining a plurality of candidate edges from a plurality of candidate edge segments. Referring now to fig. 3C and 3D, the operation of selecting a candidate edge from a plurality of candidate edge segments is described. A series of thresholds or filters may be applied to exclude candidate edge segments that are unlikely, or incapable of representing the physical edges of the object under analysis. Operation 4010 may determine a plurality of candidate edges, including a plurality of lateral candidate edges (represented by a single lateral candidate edge 3008 in fig. 3C) and a plurality of longitudinal candidate edges (represented by a single longitudinal candidate edge 3010 in fig. 3C), as estimates of lateral physical edges 3017 and longitudinal physical edges 3019. Operation 4010 may select candidate edges based on the application of one or more criteria.
The first threshold or criteria may be a location criteria or a physical edge-to-segment threshold (a physical edge to segment threshold). The location criterion represents a threshold distance for whether the candidate edge segment falls within a known open physical edge (and more specifically, a known open physical edge oriented substantially perpendicular to the candidate edge segment)And (5) evaluation in-vitro. Fig. 3C shows a lateral candidate edge segment 3009 having a proximal point 3009A and a distal point 3009B and positioned substantially perpendicular to a longitudinal physical edge vector 3012 corresponding to a longitudinal physical edge 3013 that is one of the open physical edges. The proximal point 3009A is positioned proximal to the lateral candidate edge segment 3009 with respect to the longitudinal physical edge 3013 and the distal point 3009B is positioned distal to the lateral candidate edge segment 3009 with respect to the longitudinal physical edge 3013. The location criteria represents an assessment of whether the segment-to-edge distance 3030A between the proximal point 3009A and the longitudinal physical edge 3013 is within a defined minimum. The defined minimum value may be set to be defined by the scaling factor delta 1 The length of the minimum dimension (Min) of the weighted minimum candidate size 3016. Thus, the position criterion may be expressed as 0.ltoreq.distance 3030 A.ltoreq.delta 1* Min. Scaling factor delta 1 May be set to a value between 0.4 and 0.6 or between 0.4 and 0.5. The location criteria ensures that the proximal end point 3009A of the lateral candidate edge segment 3009 is spaced from the longitudinal physical edge 3013 no more than half the length of the minimum dimension (Min) of the minimum candidate size 3016. Any candidate edge segment that does not meet the location criteria may be excluded as a possible member of the plurality of candidate edges. The location criteria may also be applied to a plurality of longitudinal candidate edge segments, such as longitudinal candidate edge segment 3011 having a proximal point 3011A and a distal point 3011B. The proximal point 3011A may be evaluated based on a segment-to-edge distance 3032A based on a location criterion proximate to the lateral physical edge 3015.
In further embodiments, the distal point 3009B of the lateral candidate edge segment 3009 may be evaluated based on a location criterion of the longitudinal dimension 3018B approaching the maximum candidate size 3018 based on the segment-to-edge distance 3030B. The distal point 3011B of the longitudinal candidate edge segment may be evaluated based on the location criteria of the lateral dimension 3018A approaching the maximum candidate size 3018 based on the segment-to-edge distance 3032B. As the location criteria applied to the far end points 3009B and 3011B may be used in place of or in addition to the location criteria applied to the near end points 3009A and 3011A.
The location criteria contemplates if the lateral candidate edge segment 3009 or the longitudinal candidate edge segment 3011 corresponds to the lateral physical edge 3017 or the longitudinal physical edge 3019, the proximal point 3009A/3009B or the distal point 3011A/3011B will be positioned within a threshold distance of the physical edge or maximum candidate size of the object. Thus, the location criteria evaluates whether the potential candidate edge segment has an endpoint that is close to the known physical edge or the expected physical edge of the object being analyzed (as represented by the largest candidate size). Scaling factor delta 1 May be selected to account for or resolve noise, sensor differences, or other sources of error in identifying edge segments.
A second criterion (also referred to as a segment length criterion or segment length threshold) evaluates whether the length of the candidate edge segment exceeds a threshold. In an embodiment, the threshold may be set to be set by a scaling factor delta 2 The length of the minimum dimension (Min) of the weighted minimum candidate size 3016. Thus, the length criteria may compare the edge segment length 3051 between the proximal 3009A/3011A and distal 3009B/3011B points to the minimum candidate size 3016. If the edge segment length 3051 of the lateral candidate edge segment 3009 or the longitudinal candidate edge segment 3011 is less than a percentage of the minimum dimension length of the minimum candidate size 3016, the computing system 1100/3100 may exclude the candidate edge segment 3009/3011 from consideration as a candidate edge. The length criterion may also be written as delta 2* Min is less than or equal to edge segment length 3051. Scaling factor delta 2 May have a value in the range between 0.6 and 0.8, between 0.65 and 0.75, between 0.69 and 0.71 or near 0.7.
The second criterion expects that for a candidate edge segment corresponding to a physical edge and thus considered as a candidate edge, the candidate edge segment should be long enough to exceed a portion of the minimum size of the minimum candidate size, and thus, a candidate edge segment that does not meet the segment length threshold may not be considered a candidate that potentially represents a physical edge. Scaling factor delta 2 May be selected to account for or resolve noise, sensor differences, or other sources of error in identifying edge segments.
A third criterion (also referred to as an orthogonality criterion or segment orthogonality threshold) evaluates whether the candidate line segment is substantially perpendicular to the longitudinal physical edge 3013 or the lateral physical edge 3015. As used herein, the term substantially perpendicular means within 5 degrees of exact perpendicular. For example, the lateral candidate edge segment 3009 is compared to the longitudinal physical edge 3013 to determine a substantial perpendicularity or substantial orthogonality, and the longitudinal candidate edge segment 3011 is compared to the lateral physical edge 3015 to determine a substantial perpendicularity or substantial orthogonality. The third criterion contemplates that for a lateral candidate edge segment 3009 or a longitudinal candidate edge segment 3011 corresponding to a lateral physical edge 3017 or a longitudinal physical edge 3015, respectively, the potential edge should be substantially perpendicular to the physical edge from which it extends. Candidate edge segments that do not meet the orthogonality criteria may be excluded as potential candidate edges.
The candidate edges may be selected or determined from a plurality of candidate edge segments that meet each of three criteria: position criteria, length criteria, and orthogonality criteria. The plurality of candidate edges may include a plurality of lateral candidate edges and a plurality of longitudinal candidate edges. Fig. 3C shows a single lateral candidate edge 3008 and a single longitudinal candidate edge 3010. The lateral candidate edges 3008 are aligned with the associated lateral candidate edge segments 3009 and extend substantially perpendicularly from the longitudinal physical edges 3013. The longitudinal candidate edges 3010 are aligned with the associated longitudinal candidate edge segments 3011 and extend substantially perpendicular to the lateral physical edges 3015.
In operation, method 4000 includes an operation 4012 for generating a plurality of intersections 3024 between respective ones of the plurality of lateral candidate edges and the plurality of longitudinal candidate edges. The intersection point 3024 is defined as the location at which any one of the plurality of lateral candidate edges or projections thereof intersects any one of the plurality of longitudinal candidate edges or projections thereof. The projection may be used in cases where the identified candidate edges do not extend far enough to intersect one of the vertically oriented candidate edges. A single intersection point 3024 between the lateral candidate edge segment 3009 and the longitudinal candidate edge segment 3011 is depicted in fig. 3C. As shown in fig. 3E, each of the lateral candidate edges 3008A, 3008B, 3008C and the longitudinal candidate edges 3010A, 3010B, 3010C may be associated with a plurality of intersection points 3024A-3024I. For example, the lateral candidate edge 3008A intersects the longitudinal candidate edges 3010A, 3010B, and 3010C to create three different intersections 3024A, 3024D, and 3024G. Each of these intersections 3024A-3024I represents the potential angle of the target object relative to the target opening angle 3004A.
In operation, method 4000 includes an operation 4014 of generating a candidate minimum feasible range associated with a target opening angle 3004A. As described above, the minimum viable range 3006 (shown in fig. 3C) represents a range on the surface 3001 of the object 3000 that may or may not be used for the robotic arm 3320 to grasp or grasp in order to move the object 3000 associated with the target opening angle 3004A. In applications where the associated object 3000 is adjacent to or in contact with other objects in the target opening angle 3004A, the computing system 3100 may not be able to accurately and/or precisely estimate the dimensions of the object 3000 and, therefore, it may be difficult to accurately define the range in which the robotic arm 3320 may safely grasp the object 3000. Thus, the minimum viable range 3006 defines a range over which the robotic arm 3320 may grasp the object 3000 without knowing the exact size, based on estimated or potential sizes. The minimum feasible region 3006 is the area on the surface 3001 of the object 3000 defined by the target opening angle 3004A, the lateral candidate edges 3008 of the plurality of lateral candidate edges, the longitudinal candidate edges 3010 of the plurality of longitudinal candidate edges, and the intersection point 3024.
As described above, the plurality of lateral candidate edges 3008A, 3008B, 3008C, the plurality of longitudinal candidate edges 3010A, 3010B, 3010C, and the plurality of intersection points 3024A-3024I are identified in previous operations. The plurality of lateral candidate edges 3008A, 3008B, 3008C, the plurality of longitudinal candidate edges 3010A, 3010B, 3010C, and the plurality of intersection points 3024A-3024I together may define a set of potential minimum feasible range candidates 3066, each of which (e.g., potential minimum feasible range candidates 3006A-3006G) is shown in fig. 3E. In an embodiment, the minimum feasible range candidates associated with the target opening angle 3004A may be identified from the intersection points 3024, as each intersection point 3024 also specifies the lateral candidate edge 3008 and the longitudinal candidate edge 3010 it is formed from. As depicted in fig. 3E, many potential minimum feasible ranges 3006 may be associated with a single lateral candidate edge 3008A, 3008B, 3008C or a single longitudinal candidate edge 3010A, 3010B, 3010C. Further, each of the set of potential minimum feasible range candidates 3066 is associated with a single intersection point 3024. As described above, each of the set of potential minimum feasible range candidates 3066 fits within the minimum candidate size 3016 associated with the smallest possible object and the maximum candidate size 3018 associated with the largest possible object.
The potential minimum feasible range candidates 3066 of fig. 3E are presented in table 1 below as a combination of lateral candidate edges 3008A, 3008B, 3008C and longitudinal candidate edges 3010A, 3010B, 3010C.
TABLE 1
The candidate minimum feasible range 3067 may be selected from the set of potential minimum feasible range candidates 3066 based on the potential minimum feasible range candidates 3006A, 3006B, etc., having a minimum diagonal distance between the target opening angle 3004A and the associated intersection point 3024. The minimum distance may be used as a primary factor in determining the candidate minimum feasible range 3067. Due to scaling factor delta 2 For length criteria, the candidate minimum feasible range 3067 may be smaller than the minimum candidate size 3016. In further embodiments, the minimum candidate size 3016 may be set to the minimum size of the potential minimum feasible range candidates 3066 to be selected as the candidate minimum feasible range 3067.
By selecting the minimum diagonal distance for the candidate minimum feasible range 3067, the system determines that the candidate minimum feasible range 3067 is not greater than the actual object 3000 in which it is located. Although the identified edges forming the candidate minimum feasible range 3067 may not represent the actual size of the target object 3000A, they do represent possible edges of the target object 3000A. By selecting the minimum diagonal distance between the target opening angle 3004A and the associated intersection point 3024, the computing system 1100/3100 determines an area with increased likelihood of being present only on the target object 3000A, i.e., the candidate minimum feasible range 3067. In an embodiment, the system may determine that the candidate minimum feasible range 3067 does not intersect more than one object. Thus, gripping the target object 3000A within the candidate minimum feasible range 3067 increases the reliability of the gripping operation by reducing the likelihood that the robotic arm will attempt to grip more than one object 3000 at a time.
Various other methods of determining the minimum feasible range candidate from the set of potential minimum feasible range candidates 3066 may be used. For example, if the potential minimum feasible range candidate includes an intersection point 3024 that is also the previously identified open angle 3004, the potential minimum feasible range candidate may be selected because it may be assumed to be related to the entire surface 3001 of the object 3000. Alternatively, if the potential minimum feasible range candidate has a substantially similar size as the minimum candidate size 3016 or the maximum candidate size 3018, e.g., within a certain percentage threshold, it may be assumed that object 3000 may be the minimum candidate size 3016 or the maximum candidate size 3018, respectively, and the potential minimum feasible range candidate may be selected. In some embodiments, the candidate minimum feasible region 3067 to be selected from the set of potential minimum feasible region candidates 3066 may be based on the largest or median area of the set of potential minimum feasible region candidates 3066 of potential minimum feasible region candidates 3006A, 3006B, etc. In some embodiments, the candidate minimum feasible range 3067 to be selected from the set of potential minimum feasible range candidates 3066 may have an intersection point 3024 associated with the shortest candidate edge based on the potential minimum feasible range candidates 3006A, 3006B, etc.
In operation, the method 4000 includes an operation 4016 of validating or adjusting the minimum feasible range candidate 3067 to generate a minimum feasible range 3006. Verification of the minimum feasible range candidate 3067 may include one or more techniques, as described below. The verified and/or adjusted minimum feasible range candidate 3067 may thus be defined as a minimum feasible range 3006 and may be used by the computing system 1100/3100 as a detection hypothesis or to enhance a detection hypothesis for identifying an object. As used herein, the term detection hypothesis refers to a hypothesis regarding the size or shape of an object determined by the computing system 1100/3100. In embodiments, the detection hypothesis may be confirmed via further analysis (e.g., using additional image analysis techniques), by robotic manipulation, and/or by additional means.
A minimum feasible range candidate 3067 may be found for each open angle 3004 identified in operation 4004 (according to operations 4006-4014), and the minimum feasible range candidate 3067 so detected may be verified by comparison with other minimum feasible ranges 3607. For example, the computing system 1100/3100 may perform overlap verification or occlusion verification. The computing system 1100/3100 may determine whether a portion of the minimum feasible range candidates 3067 for the target opening angle 3004A intersect with the minimum feasible range candidates 3067 associated with different opening angles 3004. In such a case, a comparison between the minimum feasible range candidate 3067 of the target opening angle 3004A and the minimum feasible range candidate 3067 of a different opening angle 3004 may determine that the opening angle 3004/3004A belongs to the same object 3000A (occlusion verification), or that the opening angle 3004/3004A belongs to a different object 3000 (overlap verification).
In the case of a shared object, the computing system 1100/3100 may perform occlusion verification. Two minimum feasible range candidates 3067 belonging to the same target object 3000A may be occluded from each other. The computing system 1100/3100 may combine the information of the two minimum feasible range candidates 3067 to generate the minimum feasible range 3006, or may adjust the minimum feasible range candidates 3067 of the target opening angle 3004A to incorporate the information 3004 of the minimum feasible range candidates 3067 of different opening angles 3004 to create a more accurate minimum feasible range 3006 of the object 3000A.
Alternatively, if the corners do not belong to the same object 3000, the computing system 1100/3100 may decrease the confidence level associated with the smallest feasible range candidate 3067 of the two overlaps. In determining which of the minimum feasible range candidates 3067 to designate as the minimum feasible range 3006 for further processing, the computing system 1100/3100 may select the minimum feasible range candidate 3067 with the highest confidence level (e.g., with little or no overlap with other minimum feasible range candidates 3067).
In an embodiment, the accuracy of the minimum feasible range candidate 3067 may also be increased using additional factors. For example, if a pallet is known to contain a uniform type of object (e.g., an object having a single SKU), the minimum feasible range for each object (and in particular, the minimum feasible range that matches the object size) may be expected to be substantially uniform. In such a case, several different techniques may be used to identify and verify the minimum viable range candidate 3067 from the potential minimum viable range candidates 3066. The single SKU or unified object method may include one or more of a template verification operation, a packing (packing) verification operation, and an angle classification operation.
Referring now to fig. 3F, in an embodiment, for an object store (e.g., a tray, container, or other object store) containing uniform types of objects, a minimum viable range candidate 3067 may be identified and verified from potential viable range candidates 3066 based on a template verification operation. Aspects of the object recognition methods performed herein are described in more detail in U.S. application Ser. No. 16/991,510, filed on 8/12/2020, and U.S. application Ser. No. 16/991,466, filed on 8/12/2020, each of which is incorporated herein by reference. The template verification operation is based on the assumption that the unified object will have similar dimensions and visual characteristics. Portions of the image information defined by the potential minimum feasible range candidates 3066 may be analyzed to generate templates 3068 corresponding to each potential minimum feasible range candidate 3066. Each template 3068 may include information generated from the associated image portion including at least texture values, color values, and size values. The texture value may define whether the image portion of the potential minimum viable range candidate 3066 identifies a textured surface or an untextured surface. The color value may define a color of the image portion representing the potential minimum feasible range candidate 3066. The size value may represent the edge size and/or area of the potential minimum feasible range candidate 3066. Templates 3068 may be compared to one another to identify templates 3068 that match in one or more of texture values, color values, and size values. A match in one or more of these values may indicate that the potential minimum feasible range candidate 3066 associated with the matching template 3068 represents the real physical object 3000. Where objects 3000 are of a uniform type, they are expected to have matching templates 3068. Thus, by identifying a matching template 3068, one or more minimum feasible range candidates 3067 may be identified from the potential minimum feasible range candidates 3066. In an embodiment, the identified one or more minimum feasible range candidates 3067 may also be verified as a minimum feasible range 3006 based on a template verification operation.
Referring now to fig. 3G and 3H, in an embodiment, for an object store 3090 (e.g., a tray, container, or other object store) containing unified type objects 3091, a minimum viable range candidate 3067 (not shown herein) may be identified and/or verified from potential minimum viable range candidates 3066 based on a fill verification operation. If the known object store 3090 is completely filled (e.g., has a layer that is completely occupied by objects) or the known object store is filled around edges, this information may be used to help or enhance identifying and verifying the minimum viable range candidate 3067 from the potential minimum viable range candidates 3066 in several ways.
First, the fill verification operation may use the total area of the filled object store 3090 to help identify and verify the minimum viable range candidate 3067. If the object store 3090 is completely filled, the total surface area of the objects 3091 located thereon will be divided evenly by the surface area of the individual objects 3091. In the example shown in fig. 3G, the total surface area of the objects 3091 divided by the surface area of the individual objects 3091 is 8. The area of the potential minimum viable range candidate 3066 may be compared to the total surface area of the object 3091 to identify a minimum viable range candidate 3067 having an area that is an integer divided total surface area. A threshold factor (e.g., 95%, 98%, 99%, etc.) may be applied to the division operation to account for noise and other sources of measurement error. According to further methods described herein, the identified minimum viable range candidate 3067 may also be validated to determine a minimum viable range 3006.
Second, the fill verification operation may use the size of the filled object repository 3090 to help identify and verify the minimum viable range candidate 3067. In a particular arrangement in which the objects 3091 are arranged in an equal number of rows and columns, the size of the potential minimum viable range candidate 3066 may be compared to the size of the object store 3090 to identify and/or verify the minimum viable range candidate 3067. For example, the lateral dimension X1 and the longitudinal dimension X2 of the object store 3090 will be divisible by the size of the potential minimum feasible range candidate 3066 that matches the size of the object 3091. The potential minimum feasible range candidate 3066 is shown in fig. 3G as having dark borders with dimensions D1 and D2. If x1=m×d1, where m is an integer (m=2 in the example of fig. 3G) and x2=n×d2, where n is an integer (n=4 in the example of fig. 3G), it may indicate that the potential minimum feasible range candidate 3066 represents the true size of the object 3091 on the object repository 3090 and may be identified as the minimum feasible range candidate 3067. If the size of the potential minimum viable range candidate 3066 does not meet these conditions, it is unlikely to represent the true size of the object 3091 on the object store 3090. In an embodiment, a percentage threshold (e.g., 95%, 98%, 99%) may be used in the equations for X1 and X2 to account for potential measurement errors due to noise and other factors. According to further methods described herein, the identified minimum viable range candidate 3067 may also be validated to determine a minimum viable range 3006.
Third, the fill verification operation may use the size of the object repository 3090 to help identify and verify the minimum feasible range candidate 3067 for a more general arrangement. In the general arrangement shown in fig. 3H, where the objects 3091 are arranged in unequal numbers of rows and columns (sometimes referred to as pinwheel pattern) that completely fill the edges of the object store 3090, the length of each side of the object store 3090 should be equal to an integer of the lateral dimension of the object 3091 plus an integer of the longitudinal dimension of the object 3091. Whether or not the object store 3090 is completely filled, a general placement filling operation may be used as long as the edges are completely filled. The size of the potential minimum viable range candidate 3066 is compared to the size of the object repository 3090 to identify and/or verify the minimum viable range candidate 3067 using a pair of equations that account for both the width and length of the object 3091. The potential minimum feasible region candidate 3066 is shown in fig. 3H as having dark borders with dimensions D1 and D2. In a general arrangement, the equation that should be satisfied is as follows. X1=m1×d1+n1×d2, where both m1 and n1 are integers (m1=1 and n1=3 in the example of fig. 3H) and x2=m2×d1+n2×d2, where both m2 and n2 are integers (m2=1 and n2=3 in the example of fig. 3H). If both equations can be satisfied by the size of the potential minimum feasible range candidate 3066, it may indicate that the potential minimum feasible range candidate 3066 represents the true size of the object 3091 on the object store 3090 and may be identified as the minimum feasible range candidate 3067. If the size of the potential minimum viable range candidate 3066 does not meet these conditions, it is unlikely that the true size of the object 3091 on the object store 3090 will be represented. In an embodiment, a percentage threshold (e.g., 95%,98%, 99%) may be used in the equations for X1 and X2 to account for potential measurement errors due to noise and other factors. According to further methods described herein, the identified minimum viable range candidate 3067 may also be validated to determine a minimum viable range 3006.
In an embodiment, the corner classification operation may be performed by the computing system 1100/3100 on an object repository 3090 having uniform types of objects 3091. Because the objects 3091 are uniform, it is contemplated that objects 3091 identifiable at open corners may have some common characteristics. For example, the angle type of the object 3091 may be compared between the angles of the object repository 3090. Corner types may include, for example, rectangular, octagonal, and circular. In some cases, it may be difficult to distinguish between different types of object corners at the corners of the object store 3090 due to measurement errors. For example, it may be difficult to determine whether an object angle is octagonal or circular. In such a case, the object angles at each corner of the object store 3090 may be compared, and the most frequently identified object angle may be determined as the object angle type of the object 3091 in the object store 3090. Similar techniques may be used to determine textured or non-textured classifications of objects 3000 located at corners of object store 3090.
The method 5000 detailed below describes a method for estimating the size of a target object. In an embodiment, method 5000 may utilize a minimum feasible range as defined in method 4000. In an embodiment, once the robotic arm has begun interacting with the object, the method 5000 may estimate the size of the target object. In particular, it is possible that the minimum feasible range defined in method 4000 may be of an incorrect size due to noise, false edges or other inaccuracies. Thus, the robotic arm may be indicated to grasp the object in a weak position, which increases the risk of damage to the object or the environment. For example, grasping an object at an off-center location may result in an unacceptable level of torque at the grasping point when attempting to lift. To more accurately estimate the object size, the robotic arm may move the gripped object to expose a gap between the object and an adjacent object, which allows a more accurate approximation of the size of the object to be determined. The defined minimum feasible range and the newly identified target object size may then be compared to determine the accuracy of the defined minimum feasible range, and if the discrepancy is significant, the robotic arm may release and re-grasp the object based on the defined size.
A method 5000 for estimating the size of an object is shown in fig. 5. The method 5000 is based on moving or repositioning the target object to achieve a better view of the physical dimensions of the object. In method 5000, a minimum feasible range of target opening angles for a target object is first determined. The minimum feasible range of the target object represents an estimate of the target object size. For example, the minimum feasible range may be estimated by the method 4000 described above. The target object is then grabbed based on the minimum feasible range. To improve the accuracy of the target object size estimation, the method 5000 may include moving or dragging the target object relative to surrounding objects to expose gaps between the objects. The gap may then be used to determine the size of the target object and may be used by the computing system (e.g., by adjusting the minimum feasible range, e.g., as generated in method 4000). The method 5000 may be stored on a non-transitory computer readable medium and may be performed by at least one processing circuit in communication with a camera having a field of view. The estimated size of the target object generated by method 5000 may be compared to a minimum feasible range determined, for example, by method 4000, in order to ensure that the robotic arm firmly grips the target object before lifting and moving the object.
As described above, although the minimum feasible region calculation performed by method 4000 ensures that the minimum feasible region exists only on a single object, the center of the minimum feasible region may not be near the center of the target object due to potentially including false edges or other sources of error. Thus, grasping an object in the center of the smallest possible range may result in decentering and difficulty in lifting the object. If the adjusted minimum feasible range of the method does not adequately estimate the target object size, the method 5000 may instruct the robotic arm to re-grip the target object based on the newly generated target object size.
In an embodiment, the method 5000 may be performed with, after, and/or in combination with the method 4000 for identifying the smallest feasible range. In such an embodiment, the operation of method 5000 may be the same as the operation of method 4000. For example, operations 4002 and 5002, operations 4004 and 5004, and operations 4005 and 5005 may coincide and/or be the same operation. Operation 5006 of method 5000 may incorporate all or some of operations 4006, including operations 4008-4016.
Method 5000 includes an operation 5002 of acquiring initial image information representing physical characteristics of one or more objects 3000 of fig. 3 (e.g., objects 3000A-3000D). The initial image information is generated by the camera 3200 and describes at least an object appearance associated with one or more objects, wherein each object includes a plurality of edges. Operation 5002 for acquiring initial image information may include any or all of the methods and techniques discussed above with respect to operation 4002. The initial image information may be the same initial image information collected in method 4000, or it may be newly collected initial image information. For clarity, any of the initial image information sources acquired in operation 5002 may be referred to as initial image information. The method 5000 described herein may be performed by at least one processing circuit of a computing system.
In operation, method 5000 includes operation 5004 for detecting a plurality of corners 3002. To detect any angle present, the computing system 3100 may use a variety of methods, including any and all of the methods and techniques discussed above with respect to operation 4004. Operation 5004 described herein may be performed by at least one processing circuit of a computing system.
In operation, the method 5000 includes an operation 5005 for identifying a target open angle 3004A from the plurality of angles 3002. Operation 5005 may include any and all methods and techniques described above with respect to operation 4005. Operation 5005 described herein may be performed by at least one processing circuit of a computing system.
In operation, the method 5000 includes an operation 5006 for defining a minimum feasible range 3006 for the target opening angle 3004A. Operation 5006 may include performing one or more portions of method 4000, particularly operations 4006 through 4016, to determine a minimum feasible range 3006 of target opening angle 3004A. The minimum viable range 3006 represents a range on the surface 3001 of the object 3000 that may be grasped by the robotic arm 3320 to move the object 3000 that is associated with the target opening angle 3004A.
The minimum feasible range 3006 defined in operation 5006 may be the verified minimum feasible range 3006 defined by method 4000 (e.g., by one or more of operations 4006 through 4016). In further embodiments, the candidate minimum feasible range determined by operation 4014 may be selected for continued use in method 5000. As described above, defining the minimum feasible range for the target opening angle 3004A includes defining an intersection angle 3024, where the intersection angle is opposite the target opening angle 3004A. As used herein, the term "opposite" with respect to the target opening angle 3004A and the intersection angle 3024 refers to the location of these angles at opposite corners of the surface (e.g., top surface) of the target object, where the opposite corners do not have a common edge extending therefrom. As discussed above, each minimum viable range 3006 is defined by a target opening angle 3004A, a portion of a longitudinal physical edge 3013, a portion of a lateral physical edge 3015, a lateral candidate edge 3008, a longitudinal candidate edge 3010, and an intersection point 3024 associated with the lateral candidate edge 3008 and the longitudinal candidate edge 3010. As shown in fig. 3E, a number of minimum feasible ranges 3006A, 3006B, 3006C, etc. may be associated with a single lateral candidate edge 3008A, 3008B, 3008C or a single longitudinal candidate edge 3010A, 3010B, 3010C. Furthermore, each minimum feasible region 3006 is associated with only a single intersection point 3024. Operation 5006 described herein may be performed by at least one processing circuit of a computing system.
Referring now to FIG. 6A, in operation, method 5000 includes an operation 5008 for defining a non-occlusion region 3027 based on a minimum feasible range 3006. During execution of the method 5000, the robotic arm 3320 may move in the space between the field of view 3210 of the camera 3200 and the object 3000 associated with the open angle 3004A. During this movement, the robotic arm 3320 may block or obstruct features for detecting target objects within the field of view 3210 of the camera 3200. As discussed below, the method 5000 involves the capture of subsequent image information, for example, at operation 5016. In order to accurately capture subsequent image information describing the size and minimum feasible range 3006 of target object 3000A, it is desirable that specific portions or features of object 3000A remain non-occluding and positioned so as to be viewable by camera 3200.
The non-occlusion region 3027 is a two-dimensional range of the surface of a group of objects for which an image is desired during the supplemental image information collection operation, as discussed below. A non-occluded region, three-dimensional space, between non-occluded region 3027 and camera 3200, wherein positioning of robotic arm 3320 during an imaging operation should be avoided so as to not occlude or occlude camera 3200 from acquiring supplemental image information of non-occluded region 3027. Blocking the non-occluded region 3027 as referred to herein refers to blocking the non-occluded region 3027 from view by the camera 3200.
The characteristics of the non-occlusion region 3027 may be defined in terms of a minimum feasible range 3006. Thus, one or more edges of the minimum feasible region 3006 may be the basis for defining the non-occlusion region 3027. Features for inclusion in the non-occlusion region 3027 may include a lateral candidate edge 3008 extending from the intersection point 3024, and a longitudinal candidate edge 3010 extending from the intersection point 3024 substantially perpendicular to the lateral candidate edge 3008. Additional portions of the non-occlusion region 3027 may include extensions of the physical edges 3013/3015 defining the minimum feasible range 3006. The physical edge extension included in the non-occluded region 3027 is the portion of the physical edge 3013/3015 of the object stack that extends beyond the boundary of the minimum feasible range 3006. Physical edge extension is the portion of the physical edge 3013/3015 that extends beyond the intersection of the physical edge 3013/3015 and the candidate edge 3008/3010.
An example of a non-occluded region 3027 is shown in FIG. 6A. For purposes of illustration, the non-occluded region 3027 is shown to include four separate strips 3028A-3028D. Each stripe 3028 is a range that extends parallel to and corresponds to a known physical edge or candidate edge of the target object. For example, with respect to target object 3000A, stripe 3028 continues parallel to and corresponding to lateral candidate edge 3008, longitudinal candidate edge 3010, longitudinal physical edge 3013, or lateral physical edge 3015. For example, as shown in fig. 6A, stripe 3028A corresponds to longitudinal physical edge 3013, stripe 3028B corresponds to lateral candidate edge 3008, stripe 3028C corresponds to longitudinal candidate edge 3010, and stripe 3028D corresponds to lateral physical edge 3015. Each stripe 3028 has a length and a width and is positioned such that at least a portion of its corresponding edge (physical or candidate) is included within the area of the stripe 3028.
The length of each stripe 3028 may be a fixed distance or may be based on a maximum candidate size. For example, referring to fig. 6A, stripe 3028A is positioned to correspond to lateral candidate edge 3008 and extends beyond lateral candidate edge 3008 until stripe 3028A encounters the boundary of maximum candidate size 3018. The strips 3028 may have various widths, such as 5mm, 4mm, 3mm, depending on the application. The larger the width of the band 3028, the greater the chance that the gap 3026 may be detected when the object 3000A is moved or dragged. However, a larger width may occur at the expense of an increased likelihood of noise or signal errors. The smaller the area of the strap 3028, the greater the degree of freedom of movement the robotic arm 3320 may have, as the smaller the area the robotic arm 3320 is to avoid. Furthermore, smaller occlusion areas may reduce computational load. Operation 5008 described herein may be performed by at least one processing circuit of a computing system.
In operation, the method 5000 includes an operation 5010 for sending a positioning command for positioning the robotic arm 3320 of the robot 3300. Positioning commands may be sent by computing system 1100/3100 to position robotic arm 3320 in a position to grasp target object 3000A and move target object 3000A. The positioning command may cause the robotic arm 3320 to be positioned outside of the non-occluded area so that the robotic arm 3320 and/or end effector device 3330 do not occlude the non-occluded area 3027 from view by the camera. The positioning command may be sent by at least one processing circuit of the computing system.
In operation, the method 5000 includes an operation 5012 for sending a Minimum Viable Range (MVR) grip command for grabbing, picking up, gripping, etc., the target object 3000A from a location within the minimum viable range 3006 of the target object 3000A. For example, the center or approximate center of the minimum viable range 3006 may be selected by the computing system 1100/3100 for grasping the target object 3000A. As discussed above, the end effector device 3330 may employ suction cups or other grasping tools that are capable of grasping or securing an object by contact via the object surface. In an embodiment, the grip command may be configured to cause the robotic arm 3320 and end effector device 3330 to remain outside of the non-occluded region during a gripping operation.
In operation, method 5000 includes operation 5014 for sending a move command for moving target object 3000A. As discussed above, the target object 3000A may be moved to open one or more gaps between the target object 3000A and adjacent objects, allowing the computing system 1100/3100 to more accurately estimate the size of the target object 3000A. The movement command may include three aspects of a movement distance, a movement direction, and a movement type. The distance and direction of movement, as discussed in more detail below, may be determined from information about adjacent objects, as discussed below. The movement type may include a lifting motion or a dragging motion.
In an embodiment, the generation of the movement command may include a determination of a movement type of the movement command. The determination of the type of movement may include determining whether to cause the robotic arm 3320 to use a lifting motion or a gripping motion. To decide which type of movement to use, the computing system 1100/3100 may compare the minimum feasible range 3006 (e.g., as acquired in operation 5006) to the maximum candidate size 3018. If the minimum feasible range 3006 is small when compared to the maximum candidate size 3018, the risk of the minimum feasible range 3006 determined in operation 5006 erroneously estimating the size of the target object 3000A by representing only a small angle increases. If the robotic arm 3320 lifts the target object 3000A from the minimum feasible range 3006 representing only a small angle of the target object 3000A, the target object 3000A or the environment may be damaged due to the increased torque imposed on the end effector apparatus 3330. Alternatively, if the minimum feasible range 3006 is comparable to the maximum candidate size 3018, then the confidence that the minimum feasible range 3006 accurately depicts the target object 3000A is higher. Thus, the range candidate ratio between the minimum feasible range 3006 and the maximum candidate size 3018 may be used to determine whether to select a lifting motion or a gripping motion for a movement command. If the range candidate ratio is greater than or equal to a certain threshold, the computing system may select the lifting motion. Example thresholds include 50% or greater, 60% or greater, 70% or greater, 80% or greater, and 90% or greater. When the range candidate ratio exceeds a threshold, the computing system 1100/3100 may select a lifting motion because the comparable relative size between the minimum viable range 3006 and the maximum candidate size 3018 increases the confidence that the robotic arm 3032 will be able to firmly grasp the target object 3000A without a high risk of damaging the object 3000A or the environment by increasing torque. Selecting a lifting motion as the type of movement in such a case may also allow computing system 3100 to measure the size of target object 3000A, as well as the weight of target object 3000A, as described below.
If the range candidate ratio is less than the threshold, the drag motion may be selected as the movement type of the movement command. The computing system 1100/3100 may select the dragging motion because if the threshold is not exceeded, the minimum feasible range accurately represents that the certainty of the size of the target object 3000A is low, which increases the risk of damage to either the target object 3000A or the environment. In an embodiment, the movement command may be configured to cause the robotic arm 3320 to provide a small lifting force to reduce friction when performing the dragging motion. Selecting the drag motion may allow computing system 1100/3100 to measure the size of target object 3000A, but not the weight of target object 3000A, as described below.
The movement distance and direction of movement of the movement command may be determined to allow the target object 3000A to move relative to surrounding or adjacent objects 3000B-3000D to expose the gap 3026 between the edges of the object 3000. In the embodiment, the moving distance and moving direction of the target object 3000A are based on the moving distance and direction of the target opening angle 3004A. The moving distance may be determined according to the moving amount required to expose the gap. The moving direction may be determined based on the possibility of exposing the gap and the possibility of avoiding collision with the object 3000 adjacent to the target object 3000A.
The determination of the movement distance may be determined based on the amount of movement required to expose the gap. To expose gap 3026, target object 3000A may select a distance of movement sufficient to expose gap 3026 that exceeds a gap width threshold (see below for further details). In an embodiment, the distance of movement may be selected based on the size of the object (e.g., a larger object may require a larger distance of movement to create the identifiable gap 3026). In some embodiments, in which the gap 3026 is viewed during execution of the move command, there may be no preset movement distance. The distance of movement may be dynamically determined based on a determination that a sufficient gap size (exceeding a gap width threshold) has been detected.
The direction of movement may be selected to move target object 3000A away from adjacent object 3000 to expose gap 3026 while avoiding potential collisions. In an embodiment, the direction of movement may be selected as a combination of vectors, each vector representing a direction away from an adjacent object. Thus, the object 3000A can move in the diagonal direction 3029. Diagonal direction 3029 represents a combination of a horizontal vector in a direction opposite to lateral physical edge vector 3014 and a vertical vector in a direction opposite to longitudinal physical edge vector 3012. Once exposed, the gap 3026 may be used by the computing system 1100/3100 to estimate the size of the target object 3000A, as explained in more detail below. Operation 5014 described herein may be performed by at least one processing circuit of a computing system.
In an embodiment, the computing system 1100/3100 may adjust the move command during execution of the move command. Adjustment of the movement command may take into account whether dragging of the object 3000A is obstructed by an obstacle such as a heavy object when determining the movement command. To avoid damage to either the robotic arm 3320 or the object 3000A, the system may include, for example, a force sensor that detects when the drag force or resistance exceeds a defined threshold. The defined threshold may be selected based on a safety factor associated with robot 3300, arm 3320, and/or end effector device 3330. The defined threshold may also be selected based on a security factor associated with the object 3000A and/or the type of object to be moved. If the defined threshold is exceeded, the robotic arm 3320 may be commanded to attempt to perform dragging in a direction and distance different from the original direction and distance of movement, and/or the robotic arm 3320 may be commanded to change the position of the gripping object 3000A. In embodiments where a large amount of drag force or resistance has been detected, the robotic arm 3320 may remain grasping the object 3000A until the force subsides, in order to reduce the risk of the object 3000A inadvertently and accidentally moving due to the force. For example, in the case where the target object 3000A is piled on a plurality of objects, excessive drag force or resistance may cause instability among the objects 3000 located below the target object 3000A.
The processing circuitry may be configured to control the robotic arm 3320 of the robot 3300 to avoid occluding or obscuring the non-occluded region 3027 during operations 5010, 5012, and 5014 (discussed below) so that the camera 3200 may maintain the visibility of the non-occluded region 3027. The computing system 3100 can generate positioning, gripping, and movement commands for the end effector device 3330 and/or the robotic arm 3320 of the robot 3300 to avoid obscuring the non-occluded regions 3027 (e.g., the bands 3028A-3028D) from view by the camera 3320. In an embodiment, the positioning, gripping and movement commands may be configured to allow occlusion of the non-occluded area during the positioning and gripping commands and during at least a portion of the movement commands. For example, the end effector device 3330 of the robotic arm 3320 may be positioned for grasping the target object 3000A, and the target object 3000A may be grasped while at least a portion of the robotic arm 3320 is blocking a non-occluded region. After grasping target object 3000A, robotic arm 3320 may also be positioned so as to avoid occluding non-occluded region 3027. In further embodiments, the movement command may begin when the robotic arm 3320 is blocking the non-occluded area 3027, and execution of the movement command causes the robotic arm 3320 to move further to a position that avoids blocking the non-occluded area 3027. In further embodiments, the position of the robotic arm 3320 portions may be adjusted during execution of the movement command to ensure that the supplemental image information does not occlude non-occluded areas when they are captured at operation 5016.
In embodiments, there may be situations where it is not possible or feasible to perform positioning, gripping, and movement commands without the robotic arm 3320 of the robot 3300 partially or completely occluding the non-occluded region from the camera field of view 3210. In such a case, the computing system 1100/3100 generates a movement command or instruction for the robotic arm 3320 of the robot 3300 that allows the robotic arm 3320 to partially occlude the non-occluded region 3027 because the computing system 1100/3100 can accurately estimate the size of the target object 3000 as long as certain aspects of the non-occluded region 3027 remain unobstructed. In particular, the intersection point 3024, at least a portion of the lateral candidate edge 3008, and at least a portion of the longitudinal candidate edge 3010 that lie within the field of view 3210 of the camera 3200 may allow the computing system 1100/3100 to estimate the target object 3000A size. In the case of partial occlusion, as discussed in more detail below, the computing system 1100/3100 may be configured to infer or project an estimated object size of the target object 3000A from the intersection point 3024, a portion of the lateral candidate edge 3008, and a portion of the longitudinal candidate edge 3010 within the field of view 3210 of the camera 3200. Accordingly, the computing system 1100/3100 may be configured to cause execution of positioning, gripping, and movement commands to allow partial occlusion that nevertheless leaves the intersection point 3024, at least a portion of the lateral candidate edge 3008, and at least a portion of the longitudinal candidate edge 3010 unobstructed from view by the camera 3200.
In operation, method 5000 includes operation 5016 for acquiring subsequent image information of one or more objects 3000. Subsequent image information is acquired to identify movement of one or more objects 3000, specifically target object 3000A (which occurs in operation 5014). The subsequent image information includes information representing the changed position of the one or more objects after operation 5014. Similar to operation 5002, subsequent image information is collected or captured by camera 3200, as shown in fig. 3A. In capturing the supplemental image information, operation 5016 may include any or all of the methods and techniques discussed above with respect to operations 4002 and 5002. Further, as discussed above, previously executed robot movement commands (positioning, gripping, moving) may be executed such that the non-occluded areas are not occluded or at least partially not occluded, as described above.
Further, capturing the supplementary image information may be performed after or during the execution of the above-described robot movement command. For example, the supplemental image information may be captured after execution of the motion command. In another example, the supplemental image information may be captured during execution of the motion command. The supplementary image information captured after the motion command is completed may be referred to as supplementary still image information, and the supplementary image information captured during the execution of the motion command may be referred to as supplementary moving image information. Operation 5016 described herein may be accomplished by at least one processing circuit of a computing system.
In operation, method 5000 includes operation 5018 for estimating a size of target object 3000A based on the supplemental image information. Fig. 6B depicts subsequent image information after the target object 3000A is dragged according to operation 5014. The operation 5018 for estimating the size of the target object 3000A may use supplementary still image information, supplementary moving image information, or both.
Estimating the size of the target object 3000A from the supplemental still image information includes detecting the presence of a gap 3026 between the target object 3000A and any adjacent objects 3000 depicted within the subsequent image information after the robot movement associated with the movement command is completed. For the presence of a gap 3026, subsequent image information is analyzed at the non-occlusion region 3027 or the stripes 3028A-3028D as shown in fig. 6A and 6B. Gap 3026 may be detected from the supplemental image information according to any of the image analysis techniques described herein (e.g., edge detection, point cloud analysis, etc.). Gap 3026 indicates that the boundary or edge of target object 3000A is separated from the boundary or edge of an adjacent object. In fig. 6B, target object 3000A is shown separated from objects 3000B and 3000D, which create gaps 3026A and 3026B, respectively.
Each gap 3026A, 3026B, after identification, may additionally be analyzed to measure its width and determine if the gap width exceeds a gap width threshold. The gap width threshold may be set between 1cm and 3cm, between 1.5cm and 2.5cm, or near 2cm. Other gap width thresholds may be used as appropriate. In embodiments, the gap width threshold may be selected based on the size of the object being analyzed (a larger object having a larger threshold) or based on the capabilities of the camera and other sensors involved in the system (a more accurate camera and sensor allows a smaller threshold). For example, a gap 3026 having a width exceeding a gap width threshold may be determined to correspond to an edge of the object 3000, while a gap 3026 that does not exceed the gap width threshold may be ignored due to imaging noise, vibration, or other inaccuracies. In this example, the strips 3028A-3028D of the non-occlusion region 3027 may be analyzed by the computing system 3100 to indicate or detect whether a gap 3026 is present that exceeds a gap width threshold. Referring to fig. 6B, strips 3028A and 3028C surround gap 3026A, and strips 3028B and 3028D surround gap 3026B. Once gaps 3026 exceeding the gap width threshold are detected, they may be used to define the physical edges of both target object 3000A and adjacent object 3000. The physical edges identified based on the gap 3026 may additionally be used to distinguish or identify the objects 3000 from one another and to estimate the size of the target object 3000A.
The identification of the gap 3026 allows the computing system 1100/3100 to determine the true physical edge of the target object 3000A. Based on the actual physical edges of target object 3000A, computing system 1100/3100 can estimate the size of target object 3000A.
In an embodiment, operation 5018 for estimating the size of target object 3000A may be operative to detect and analyze the gap 3026 and the movement of object 3000 during the robot motions caused by the execution of the movement commands. Operation 5018 described herein may be accomplished by at least one processing circuit of a computing system. Such analysis may be based on supplemental moving image information captured during operation 5016. As described above, gap detection based on the supplemental moving image information may be used in addition to or instead of gap detection based on the supplemental still image information. The computing system 1100/3100 may perform such gap and object motion detection based on identifying clusters of points positioned within the bands 3028A-3028D. The computing system 1100/3100 may search along the strips 3028A-3028D during the movement command causing the robot motion to detect whether a point (e.g., a point in a point cloud) is moving in conjunction with either of a drag or a lift motion of the object 3000A.
The tracked points may coincide with locations on the surface 3001 of any object 3000. The computing system 3100 may group identified points that move in the same direction and by the same amount into clusters. Clusters can be used to identify objects and distinguish between adjacent objects based on movement of the clusters. The movement of each cluster may be compared to the movement of each other cluster. If two or more clusters show comparable movement, each cluster may be associated with the same object. For example, a first cluster point may be associated with a physical edge 3013 of target object 3000A and a second cluster point may be associated with a lateral physical edge 3015 of target object 3000A. In such an example, the movement of the first cluster and the second cluster would be comparable, and thus, the computing system 3100 may associate these clusters with the same target object 3000A.
The information collected during the cluster tracking described above can be used in two ways. First, cluster tracking may be used in an independent manner to identify gaps 3026 between objects and to identify the actual physical edges of the objects. For example, four perpendicular edges showing similar motion may be understood as the actual physical edges of an object. Second, cluster tracking may be used to supplement information acquired by the gap detection method based on the supplemental still image information. For example, a portion of the object may have visual characteristics similar to the gap. Therefore, according to the supplementary still image information, the portion of the object may be erroneously identified as a gap. However, if the portion of the object coincides with one of the bands 3028A-3028D being imaged and monitored during execution of the movement command, it may be determined that all of the dot clusters associated with the error gap move in a similar manner. Thus, an erroneous gap may be identified as erroneous because if the gap is real, some clusters associated with the gap will show no movement because those clusters will be points on the surface of adjacent, non-moving objects.
In operation, the method 5000 may include an operation 5020 for sending a release command for causing the end effector device 3330 of the robot 3300 to release the target object 3000A. Operation 5020 is an optional operation that may be performed if the estimated size of the target object 3000A exceeds the tolerance threshold compared to the minimum viable range 3006. In operation 5012, as discussed above, the robotic arm 3320 is commanded to grasp the target object 3000A based on the minimum feasible range 3006 defined in operation 5006. As described above, the minimum feasible range 3006 defined in operation 5006 may be selected based on the potential candidate minimum feasible range having the smallest area. As described above with respect to operation 5014, there is a case where the minimum feasible range 3006 underestimates the size of the target object 3000A. In such a case, the robotic arm 3320 of the robot 3300 may grasp the object 3000 in an unstable manner (e.g., too close to an edge or off-center), which may result in damage to the target object 3000A, the environment, or the robot 3300 itself.
For example, target object 3000A may have two tabs coupled together using a strip of adhesive tape. During operation 5006, the computing system 1100/3100 may incorrectly consider the gap between the two wings of the single target object 3000A to be the edge of the target object 3000A, which results in a minimum viable range 3006 that may not be securely gripped by the arm 3320 of the robot 3300. In such a case, the off-center grip may cause the robotic arm 3320 of the robot 3300 to inadvertently tear the tab. Based on the size differences, as discussed above with respect to operation 5014, the computing system 1100/3100 drags the robotic arm 3320 of the pointing robot 3300 instead of lifting the object, which reduces the risk of damage.
After more accurately estimating the size of target object 3000A, computing system 1100/3100 may determine whether to release and re-grip the object. The minimum feasible region 3006 may be compared to the estimated size of the target object 3000A. If the difference between the minimum feasible range 3006 and the estimated size of the target object 3000A exceeds the tolerance threshold, the robotic arm 3320 of robot 3300 may be commanded to release the target object 3000A. The tolerance threshold may be selected based on a ratio of the minimum feasible range 3006 to the estimated size of the target object 3000A and/or the weight of the target object 3000A. In particular, the tolerance threshold may be set so as to be exceeded when the estimated size of the target object 3000A is significantly greater than the minimum feasible range 3006. Some examples of tolerance thresholds include: the estimated size of the target object 3000A is 1.25x, 1.5x, 2x, 2.5x, or 3x that is greater than the minimum feasible size 3006. If the result of the comparison is outside the tolerance threshold and a release command is sent, an operation 5022 for re-grasping the target object 3000A as described below is performed. If the comparison yields a result within the tolerance threshold, then a release command is not sent and operation 5022 is skipped and operation 5024, described below, is performed. Operations 5020 described herein may be performed by at least one processing circuit of a computing system.
In operation, the method 5000 includes operation 5022 for sending a re-grip command for the robotic arm 3320 of the robot 3300 to re-grip the target object 3000A within the estimated size of the target object 3000A. The re-grip command may be performed after the robotic arm 3320 of the robot 3300 has released the target object 3000A. Operation 5022 may occur when operation 5020 determines that the tolerance threshold is exceeded and then the robotic arm 3320 of robot 3300 has released the object 3000A. Once the target object 3000A is released, the robotic arm 3320 of the robot 3300 is repositioned and instructed to grasp the target object 3000A again based on the estimated size of the target object 3000A. For example, the robotic arm 3320 may be instructed to grasp the target object 3000A at or near the estimated center of the target object 3000A. The additional step of re-gripping the target object 3000A ensures a more stable grip before lifting the target object 3000A. Operations 5022 described herein may be performed by at least one processing circuit of a computing system.
In operation, the method 5000 includes an operation 5024 for sending a transfer command to the robotic arm 3320. The transfer command may be sent in two cases. First, if it is determined at operation 5018 that a release command is necessary (e.g., the estimated size of the target object exceeds a threshold value with respect to the minimum possible range), a transfer command is sent after the robotic arm 3320 is determined to be firmly gripping the target object 3000A as a result of operation 5022. Second, if it is determined at operation 5018 that the release command is unnecessary (e.g., the estimated size of the target object does not exceed a threshold with respect to the minimum possible range), then the transfer command may be sent without transmitting the release command. The computing system 1100/3100 is configured to send a transfer command for the robotic arm 3320 to lift the target object 3000A and transfer the target object to the destination. By lifting object 3000A, additional information about the weight and size of target object 3000A may be determined. The weight of target object 3000A may be used to alter the instructions that computing system 1100/3100 provides to robot 3300 in further operation, and the weight may be used to help classify and identify target object 3000A. Operations 5024 described herein may be performed by at least one processing circuit of a computing system.
In an embodiment, the system may perform a destacking operation based on methods 4000 and 5000. The destacking operation may involve iteratively performing methods 4000 and 5000 to identify and estimate the size of objects on the trays in order to safely and securely perform the destacking operation. Each object is identified and evaluated according to the MVR and size estimation techniques described herein such that transport of the object can be accomplished without damaging the object, the environment, and/or the robotic arm. The methods described herein may be particularly useful where it is desired to identify the size, shape, and weight of pallet objects as they are destacked.
It will be apparent to one of ordinary skill in the relevant art that other suitable modifications and adaptations to the methods and applications described herein may be made without departing from the scope of any embodiments. The above embodiments are illustrative examples and should not be construed as limiting the invention to these specific embodiments. It should be understood that the various embodiments disclosed herein may be combined in different combinations than specifically presented in the specification and drawings. It should also be appreciated that, depending on the example, certain acts or events of any of the processes or methods described herein can be performed in a different order, may be added, combined, or omitted entirely (e.g., all of the described acts or events may not be necessary to perform the processes or methods). Furthermore, although certain features of the embodiments herein may be described as being performed by a single component, module, or unit for clarity, it should be understood that the features and functions described herein may be performed by any combination of components, units, or modules. Accordingly, various changes and modifications may be effected by one skilled in the art without departing from the spirit or scope of the invention as defined in the appended claims.
Embodiment 1 is a computing system comprising a non-transitory computer-readable medium; at least one processing circuit in communication with a camera having a field of view, the at least one processing circuit configured to execute instructions stored on a non-transitory computer-readable medium when one or more objects are or have been in the field of view for: acquiring initial image information of one or more objects, wherein the initial image information is generated by a camera; detecting a plurality of corners of one or more objects based on the initial image information; identifying a target opening angle of the target object from the plurality of angles; defining a minimum feasible range (MVR) for the target object; defining a non-occlusion region based on a minimum feasible range; transmitting a positioning command for positioning an arm of the robot; transmitting a grasp command for grasping the target object within the minimum feasible range; transmitting a movement command for moving the target object based on the movement direction, the movement distance, and the movement type using the arm of the robot; acquiring supplemental image information of one or more objects; and calculating an estimated size of the target object based on the supplemental image information, wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent the arm of the robot from occluding a non-occluded area of the one or more objects.
Embodiment 2 is the computing system of embodiment 1, wherein the at least one processing circuit is further configured to send a release command for causing the end effector of the robot to release the target object if the area defined by the estimated size exceeds a tolerance threshold compared to a minimum feasible range.
Embodiment 3 is the computing system of embodiment 2, wherein the at least one processing circuit is further configured to send a re-grip command for the end effector of the robot to grip the target object within the estimated size.
Embodiment 4 is the computing system of any of embodiments 1-3, wherein the at least one processing circuit is further configured to send a transfer command for the arm of the robot to transfer the target object if the estimated size is within a tolerance threshold compared to a minimum feasible range.
Embodiment 5 is the computing system of any of embodiments 1-4, wherein defining a minimum feasible range for the target opening angle includes defining an intersection angle opposite the target opening angle.
Embodiment 6 is the computing system of any of embodiments 1-5, wherein defining the minimum feasible region further includes identifying a physical edge of the target object.
Embodiment 7 is the computing system of any of embodiments 1-6, wherein defining a minimum feasible range for the target opening angle includes defining a first candidate edge extending from the intersection angle in a first direction and defining a second candidate edge extending from the intersection angle in a second direction substantially perpendicular to the first direction.
Embodiment 8 is the computing system of any of embodiments 1-7, wherein the non-occluded region includes an intersection angle and at least a portion of the first candidate edge and the second candidate edge.
Embodiment 9 is the computing system of any of embodiments 1-8, wherein the at least one processing circuit is further configured to send the positioning command, the gripping command, and the movement command such that the arm of the robot does not obstruct the non-occluded area when the supplemental image information is acquired.
Embodiment 10 is the computing system of any of embodiments 1-9, wherein the at least one processing circuit is further configured to detect at least one gap between the target object and an object adjacent to the target object based on the supplemental image information.
Embodiment 11 is the computing system of any of embodiments 1-10, further comprising: identifying a first physical edge of the target object from the initial information; a second physical edge of the target object is identified based on the at least one gap, wherein calculating the estimated size of the target object is performed based on the first physical edge and the second physical edge.
Embodiment 12 is the computing system of any of embodiments 1-11, wherein the distance and direction of movement are determined based on avoiding collisions with objects adjacent to the target object.
Embodiment 13 is the computing system of any of embodiments 1-12, wherein acquiring the supplemental image information is performed during movement of the robotic arm caused by execution of the movement command.
Embodiment 14 is the computing system of any of embodiments 1-13, wherein the at least one processing circuit is further configured to identify the physical edge of the target object from comparable movements during movement of the robotic arm caused by execution of the movement command.
Embodiment 15 is the computing system of any of embodiments 1-14, wherein the at least one processing circuit is further configured to determine the type of movement as a lifting movement or a dragging movement based on a comparison between the MVR and a maximum candidate size of the target object.
Embodiment 16 is a method of controlling a robotic system including a non-transitory computer readable medium, at least one processing circuit in communication with a camera having a field of view and configured to execute instructions, the method comprising: acquiring initial image information of one or more objects, wherein the initial image information is generated by a camera; detecting a plurality of corners of one or more objects based on the initial image information; identifying a target opening angle of the target object from the plurality of angles; defining a minimum feasible range (MVR) for the target object; defining a non-occlusion region based on a minimum feasible range; transmitting a positioning command for positioning an arm of the robot; transmitting a grasp command for grasping the target object within the minimum feasible range; transmitting a movement command for moving the target object based on the movement direction, the movement distance, and the movement type using the arm of the robot; acquiring supplemental image information of one or more objects; and calculating an estimated size of the target object based on the supplemental image information, wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent the arm of the robot from occluding a non-occluded area of the one or more objects.
Embodiment 17 is the method of embodiment 16, wherein defining the minimum feasible range for the target opening angle comprises: defining an intersection angle relative to the target opening angle; identifying a physical edge of the target object; defining a first candidate edge extending in a first direction from the angle of intersection; and defining a second candidate edge extending from the intersection angle in a second direction substantially perpendicular to the first direction.
Embodiment 18 is the method of embodiment 16, further comprising: detecting at least one gap between the target object and an object adjacent to the target object based on the supplemental image information; identifying a first physical edge of the target object from the initial information; and identifying a second physical edge of the target object based on the at least one gap, wherein calculating the estimated size of the target object is performed from the first physical edge and the second physical edge.
Embodiment 19 is the method of embodiment 16, wherein the acquiring the supplemental image information is performed during movement of the robotic arm caused by execution of the movement command, the method further comprising identifying a physical edge of the target object based on a comparable movement during movement of the robotic arm caused by execution of the movement command.
Embodiment 20 is a non-transitory computer-readable medium comprising instructions for execution by at least one processing circuit in communication with a camera having a field of view and configured to, when one or more objects are or have been in the field of view, configure to: acquiring initial image information of one or more objects, wherein the initial image information is generated by a camera; detecting a plurality of corners of one or more objects based on the initial image information; identifying a target opening angle of the target object from the plurality of angles; defining a minimum feasible range (MVR) for the target object; defining a non-occlusion region based on a minimum feasible range; transmitting a positioning command for positioning an arm of the robot; transmitting a grasp command for grasping the target object within the minimum feasible range; transmitting a movement command for moving the target object based on the movement direction, the movement distance, and the movement type using the arm of the robot; acquiring supplemental image information of one or more objects; and calculating an estimated size of the target object based on the supplemental image information, wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent the arm of the robot from occluding a non-occluded area of the one or more objects.
Embodiment 21 is a computing system comprising a non-transitory computer-readable medium; at least one processing circuit in communication with a camera having a field of view, the at least one processing circuit configured to execute instructions stored on a non-transitory computer-readable medium when one or more objects are or have been in the field of view for: obtaining image information representative of one or more objects, each object having a plurality of edges, wherein the image information is generated by a camera and describes at least an object appearance associated with the one or more objects; detecting a plurality of corners of one or more objects based on the image information; identifying a target open angle from the plurality of angles; defining a minimum feasible range for the target opening angle, wherein the minimum feasible range is defined by: generating a plurality of candidate edge segments; determining a plurality of candidate edges from the plurality of candidate edge segments; defining a plurality of intersections between respective candidate edges of the plurality of candidate edges; defining a set of potential minimum feasible range candidates based on the plurality of intersection points; and selecting a minimum feasible range candidate for the target open angle of the plurality of angles from the set of potential minimum feasible range candidates; and verifying the minimum feasible range candidate as the minimum feasible range of the target opening angle.
Embodiment 22 is the computing system of embodiment 21, wherein the image information is wrapped from a three-dimensional view to a two-dimensional view.
Embodiment 23 is the computing system of embodiment 21 or 22, wherein generating the plurality of edge segments includes generating the plurality of edge segments within a range defined by a minimum candidate size and a maximum candidate size.
Embodiment 24 is the computing system of embodiments 21-23, wherein the minimum feasible range candidate is selected from the set of potential minimum feasible range candidates based on the minimum area.
Embodiment 25 is the computing system of embodiments 21-24, wherein identifying the target opening angle includes identifying that the selected opening angle is not adjacent to another object.
Embodiment 26 is the computing system of embodiments 21-25, wherein verifying the minimum feasible range candidate as the minimum feasible range comprises: overlapping verification of the minimum feasible range candidate with at least one other minimum feasible range candidate is performed.
Embodiment 27 is the computing system of embodiments 21-26, wherein determining a plurality of candidate edges from the plurality of candidate edge segments comprises: a plurality of candidate edge segments are evaluated according to segment length criteria.
Embodiment 8 is the computing system of embodiments 21-27, wherein determining a plurality of candidate edges from the plurality of candidate edge segments comprises: a plurality of candidate edge segments are evaluated according to an orthogonality criterion.
Embodiment 29 is the computing system of embodiments 21-28, wherein determining a plurality of candidate edges from the plurality of candidate edge segments comprises: a plurality of candidate edge segments is evaluated based on the location criteria.
Embodiment 30 is the computing system of embodiments 21-29, wherein verifying the minimum feasible region candidate is performed in accordance with a fill verification operation.
Embodiment 31 is a method of controlling a robotic system that includes a non-transitory computer-readable medium, at least one processing circuit in communication with a camera having a field of view, and configured to execute instructions. The method includes obtaining image information representative of one or more objects, each object having a plurality of edges, wherein the image information is generated by a camera and describes at least an object appearance associated with the one or more objects; detecting a plurality of corners of one or more objects based on the image information; identifying a target open angle from the plurality of angles; defining a minimum feasible range for the target opening angle, wherein the minimum feasible range is defined by: generating a plurality of candidate edge segments; determining a plurality of candidate edges from the plurality of candidate edge segments; defining a plurality of intersections between respective candidate edges of the plurality of candidate edges; defining a set of potential minimum feasible range candidates based on the plurality of intersection points; and selecting a minimum feasible range candidate for the target open angle of the plurality of angles from the set of potential minimum feasible range candidates; and verifying the minimum feasible range candidate as the minimum feasible range of the target opening angle.
Embodiment 32 is the method of embodiment 31, wherein generating the plurality of edge segments includes generating the plurality of edge segments within a range defined by a minimum candidate size and a maximum candidate size.
Embodiment 33 is the method of embodiment 31 or 32, wherein the minimum feasible region candidate is selected from the set of potential minimum feasible region candidates based on the minimum area.
Embodiment 34 is the method of embodiments 31-33, wherein identifying the target opening angle includes identifying that the selected opening angle is not adjacent to another object.
Embodiment 35 is the method of embodiments 31-34, wherein verifying the minimum feasible range candidate as the minimum feasible range comprises: overlapping verification of the minimum feasible range candidate with at least one other minimum feasible range candidate is performed.
Embodiment 36 is the method of embodiments 31-35, wherein determining a plurality of candidate edges from the plurality of candidate edge segments comprises: a plurality of candidate edge segments are evaluated according to segment length criteria.
Embodiment 37 is the method of embodiments 31-36, wherein determining a plurality of candidate edges from the plurality of candidate edge segments comprises: a plurality of candidate edge segments are evaluated according to an orthogonality criterion.
Embodiment 38 is the method of embodiments 31-37, wherein determining a plurality of candidate edges from the plurality of candidate edge segments comprises: a plurality of candidate edge segments is evaluated based on the location criteria.
Embodiment 39 is the method of embodiments 31-38, wherein verifying the minimum feasible range candidate is performed in accordance with a fill verification operation.
Embodiment 40 is a non-transitory computer-readable medium comprising instructions for execution by at least one processing circuit in communication with a camera having a field of view and configured to, when one or more objects are or have been in the field of view: obtaining image information representative of one or more objects, each object having a plurality of edges, wherein the image information is generated by a camera and describes at least an object appearance associated with the one or more objects; detecting a plurality of corners of one or more objects based on the image information; identifying a target open angle from the plurality of angles; defining a minimum feasible range for the target opening angle, wherein the minimum feasible range is defined by: generating a plurality of candidate edge segments; determining a plurality of candidate edges from the plurality of candidate edge segments; defining a plurality of intersections between respective candidate edges of the plurality of candidate edges; defining a set of potential minimum feasible range candidates based on the plurality of intersection points; and selecting a minimum feasible range candidate for the target open angle of the plurality of angles from the set of potential minimum feasible range candidates; and verifying the minimum feasible range candidate as the minimum feasible range of the target opening angle.

Claims (20)

1. A computing system, comprising:
at least one processing circuit in communication with a robot having an arm and an end effector connected to the arm and with a camera having a field of view, the at least one processing circuit configured to execute instructions stored on a non-transitory computer readable medium when one or more objects are or have been in the field of view for:
acquiring initial image information of one or more objects, wherein the initial image information is generated by the camera;
detecting a plurality of corners of the one or more objects based on the initial image information;
identifying a target opening angle of a target object from the plurality of angles;
defining a minimum feasible range (MVR) for the target object;
defining a non-occlusion region based on the minimum feasible range;
transmitting a positioning command for positioning an arm of the robot;
sending a grasp command for grasping the target object within the minimum feasible range;
transmitting a movement command for moving the target object based on a movement direction, a movement distance, and a movement type using an arm of the robot;
acquiring supplemental image information of the one or more objects; and
Calculating an estimated size of the target object based on the supplemental image information,
wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent an arm of the robot from blocking the non-occluded area of the one or more objects.
2. The computing system of claim 1, wherein the at least one processing circuit is further configured to: if the area defined by the estimated size exceeds a tolerance threshold compared to the minimum feasible range, a release command is sent for causing the end effector of the robot to release the target object.
3. The computing system of claim 2, wherein the at least one processing circuit is further configured to: a re-grip command is sent for the end effector of the robot to grip the target object within the estimated size.
4. The computing system of claim 1, wherein the at least one processing circuit is further configured to: if the estimated size is within a tolerance threshold compared to the minimum feasible range, a transfer command is sent for the arm of the robot to transfer the target object.
5. The computing system of claim 1, wherein defining the minimum feasible region for the target opening angle comprises defining an intersection angle opposite the target opening angle.
6. The computing system of claim 5, wherein defining the minimum feasible range further comprises identifying a physical edge of the target object.
7. The computing system of claim 6, wherein defining the minimum feasible region for the target opening angle comprises: a first candidate edge extending from the angle of intersection in a first direction is defined and a second candidate edge extending from the angle of intersection in a second direction substantially perpendicular to the first direction is defined.
8. The computing system of claim 7, wherein the non-occlusion region includes the intersection angle and at least a portion of a first candidate edge and a second candidate edge.
9. The computing system of claim 1, wherein the at least one processing circuit is further configured to: the positioning command, the gripping command, and the movement command are transmitted such that the arm of the robot does not block the non-occlusion region when the supplemental image information is acquired.
10. The computing system of claim 1, wherein the at least one processing circuit is further configured to: at least one gap between the target object and an object adjacent to the target object is detected based on the supplemental image information.
11. The computing system of claim 10, further comprising:
identifying a first physical edge of the target object from the initial image information;
a second physical edge of the target object is identified based on the at least one gap, wherein calculating the estimated size of the target object is performed from the first physical edge and the second physical edge.
12. The computing system of claim 1, wherein the distance of movement and the direction of movement are determined based on avoiding collisions with the object adjacent to the target object.
13. The computing system of claim 1, wherein the acquiring of the supplemental image information is performed during movement of an arm of the robot caused by execution of the movement command.
14. The computing system of claim 13, wherein the at least one processing circuit is further configured to: a physical edge of the target object is identified from a comparable movement during movement of an arm of the robot caused by execution of the movement command.
15. The computing system of claim 1, wherein the at least one processing circuit is further configured to: the type of movement is determined as a lifting movement or a dragging movement based on a comparison between the MVR and a maximum candidate size of the target object.
16. A method of controlling a robotic system comprising a non-transitory computer-readable medium, at least one processing circuit in communication with a camera having a field of view and configured to execute instructions, the method comprising:
acquiring initial image information of one or more objects, wherein the initial image information is generated by the camera;
detecting a plurality of corners of the one or more objects based on the initial image information;
identifying a target opening angle of a target object from the plurality of angles;
defining a minimum feasible range (MVR) for the target object;
defining a non-occlusion region based on the minimum feasible range;
transmitting a positioning command for positioning an arm of the robot;
sending a grasp command for grasping the target object within the minimum feasible range;
transmitting a movement command for moving the target object based on a movement direction, a movement distance, and a movement type using an arm of the robot;
acquiring supplemental image information of the one or more objects; and
calculating an estimated size of the target object based on the supplemental image information,
wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent an arm of the robot from blocking a non-occluded area of the one or more objects.
17. The method of claim 16, wherein defining the minimum feasible region for the target opening angle comprises:
defining an intersection angle relative to the target opening angle;
identifying a physical edge of the target object;
defining a first candidate edge extending in a first direction from the intersection angle; and
a second candidate edge is defined extending from the intersection angle in a second direction substantially perpendicular to the first direction.
18. The method of claim 16, further comprising:
detecting at least one gap between the target object and an object adjacent to the target object based on the supplemental image information;
identifying a first physical edge of the target object from the initial information; and
identifying a second physical edge of the target object based on the at least one gap,
wherein calculating the estimated size of the target object is performed based on a first physical edge and a second physical edge.
19. The method of claim 16, wherein acquiring the supplemental image information is performed during movement of a robotic arm caused by execution of the movement command, the method further comprising: a physical edge of the target object is identified from a comparable movement during movement of an arm of the robot caused by execution of the movement command.
20. A non-transitory computer-readable medium comprising instructions for execution by at least one processing circuit in communication with a camera having a field of view and configured to, when one or more objects are or have been in the field of view, configure to:
acquiring initial image information of one or more objects, wherein the initial image information is generated by the camera;
detecting a plurality of corners of the one or more objects based on the initial image information;
identifying a target opening angle of a target object from the plurality of angles;
defining a minimum feasible range (MVR) for the target object;
defining a non-occlusion region based on the minimum feasible range;
transmitting a positioning command for positioning an arm of the robot;
sending a grasp command for grasping the target object within the minimum feasible range;
transmitting a movement command for moving the target object based on a movement direction, a movement distance, and a movement type using an arm of the robot;
acquiring supplemental image information of the one or more objects; and
calculating an estimated size of the target object based on the supplemental image information,
Wherein at least one of the positioning command, the gripping command, and the movement command is configured to prevent an arm of the robot from blocking a non-occluded area of the one or more objects.
CN202310843958.6A 2021-05-18 2022-05-17 Robot system for object size measurement Pending CN116619386A (en)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US202163189743P 2021-05-18 2021-05-18
US63/189,743 2021-05-18
PCT/US2022/029654 WO2022245842A1 (en) 2021-05-18 2022-05-17 A robotic system for object size measurement
CN202280003782.7A CN115643800A (en) 2021-05-18 2022-05-17 Robot system for measuring object size

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
CN202280003782.7A Division CN115643800A (en) 2021-05-18 2022-05-17 Robot system for measuring object size

Publications (1)

Publication Number Publication Date
CN116619386A true CN116619386A (en) 2023-08-22

Family

ID=84060666

Family Applications (3)

Application Number Title Priority Date Filing Date
CN202310843958.6A Pending CN116619386A (en) 2021-05-18 2022-05-17 Robot system for object size measurement
CN202280003782.7A Pending CN115643800A (en) 2021-05-18 2022-05-17 Robot system for measuring object size
CN202210542953.5A Pending CN115366091A (en) 2021-05-18 2022-05-18 Robot system for detecting size of object

Family Applications After (2)

Application Number Title Priority Date Filing Date
CN202280003782.7A Pending CN115643800A (en) 2021-05-18 2022-05-17 Robot system for measuring object size
CN202210542953.5A Pending CN115366091A (en) 2021-05-18 2022-05-18 Robot system for detecting size of object

Country Status (5)

Country Link
US (2) US12136223B2 (en)
EP (1) EP4341053A1 (en)
JP (4) JP7201189B2 (en)
CN (3) CN116619386A (en)
WO (1) WO2022245842A1 (en)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10614340B1 (en) * 2019-09-23 2020-04-07 Mujin, Inc. Method and computing system for object identification
KR102528797B1 (en) * 2021-08-10 2023-05-03 세메스 주식회사 Assembly and method for transferring substrate
US12076869B2 (en) * 2021-11-29 2024-09-03 Fanuc Corporation Effective calculation method of the minimum distance to dynamic objects

Family Cites Families (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH11333770A (en) * 1998-03-20 1999-12-07 Kobe Steel Ltd Loading position and attitude recognizing device
US7084386B2 (en) * 2003-05-02 2006-08-01 International Business Machines Corporation System and method for light source calibration
JP4665857B2 (en) * 2006-07-19 2011-04-06 トヨタ自動車株式会社 Mobile body capable of guiding arm and method for guiding arm
US9607239B2 (en) * 2010-01-20 2017-03-28 Faro Technologies, Inc. Articulated arm coordinate measurement machine having a 2D camera and method of obtaining 3D representations
FI20106387A (en) * 2010-12-30 2012-07-01 Zenrobotics Oy Method, computer program and device for determining the site of infection
US9165188B2 (en) * 2012-01-12 2015-10-20 Kofax, Inc. Systems and methods for mobile image capture and processing
DE112013000947T5 (en) * 2012-02-10 2015-02-05 Zachary T. Bonefas System and method for material transport with one or more imaging devices on the transferring vehicle and the receiving vehicle for controlling the distribution of material in the hold of the receiving vehicle
KR102081139B1 (en) * 2014-03-12 2020-02-25 한국전자통신연구원 Object peaking system, object detecting device and method thereof
WO2018162080A1 (en) * 2017-03-10 2018-09-13 Abb Schweiz Ag Method and device for identifying objects
US10455222B2 (en) * 2017-03-30 2019-10-22 Intel Corporation Technologies for autonomous three-dimensional modeling
JP6548312B2 (en) * 2017-09-19 2019-07-24 株式会社Subaru Image processing device
DE112019000125B4 (en) 2018-10-30 2021-07-01 Mujin, Inc. SYSTEMS, DEVICES AND METHODS FOR AUTOMATED PACKAGING REGISTRATION
US10369701B1 (en) * 2018-10-30 2019-08-06 Mujin, Inc. Automated package registration systems, devices, and methods
JP7097799B2 (en) * 2018-11-21 2022-07-08 Thk株式会社 Image information processing device, gripping system, and image information processing method
US10576630B1 (en) * 2019-05-31 2020-03-03 Mujin, Inc. Robotic system with a robot arm suction control mechanism and method of operation thereof
US11389965B2 (en) 2019-07-26 2022-07-19 Mujin, Inc. Post-detection refinement based on edges and multi-dimensional corners
US11345029B2 (en) * 2019-08-21 2022-05-31 Mujin, Inc. Robotic multi-gripper assemblies and methods for gripping and holding objects
US11694452B1 (en) * 2019-10-07 2023-07-04 Deshazo, LLC Crane-mounted system for automated object detection and identification
US11006039B1 (en) * 2020-02-13 2021-05-11 Mujin, Inc. Method and system for determining occlusion within a camera field of view
US11403764B2 (en) * 2020-02-14 2022-08-02 Mujin, Inc. Method and computing system for processing candidate edges
US20220289502A1 (en) * 2021-03-15 2022-09-15 Dexterity, Inc. Adaptive robotic singulation system
US11905115B2 (en) * 2021-04-30 2024-02-20 Dexterity, Inc. Robotic system for identifying items

Also Published As

Publication number Publication date
JP2023016882A (en) 2023-02-02
JP2022177834A (en) 2022-12-01
JP2023024554A (en) 2023-02-16
CN115366091A (en) 2022-11-22
JP7189586B2 (en) 2022-12-14
JP2022177833A (en) 2022-12-01
US20220375097A1 (en) 2022-11-24
CN115643800A (en) 2023-01-24
EP4341053A1 (en) 2024-03-27
WO2022245842A1 (en) 2022-11-24
US20220371200A1 (en) 2022-11-24
JP7201189B2 (en) 2023-01-10
US12136223B2 (en) 2024-11-05

Similar Documents

Publication Publication Date Title
US11797926B2 (en) Robotic system with automated object detection mechanism and methods of operating the same
US11883966B2 (en) Method and computing system for performing object detection or robot interaction planning based on image information generated by a camera
JP7433609B2 (en) Method and computational system for object identification
CN116619386A (en) Robot system for object size measurement
JP7398662B2 (en) Robot multi-sided gripper assembly and its operating method
US20240221350A1 (en) Method and computing system for generating a safety volume list for object detection
JP7175487B1 (en) Robotic system with image-based sizing mechanism and method for operating the robotic system
WO2021246476A1 (en) Method and computing system for performing or facilitating physical edge detection
US12138815B2 (en) Method and computing system for performing motion planning based on image information generated by a camera
JP7191352B2 (en) Method and computational system for performing object detection

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination