This invention relates to kitchen apparatuses to assist with preparing food, and in particular to apparatuses for assisting food preparation and cooking in a restaurant kitchen environment.
It is not uncommon for cooking errors to occur in the commercial kitchen or restaurant environment because many of the food preparation steps rely on the human worker. The human worker is responsible for many tasks including: recognizing each new order, identifying the food items and preparation steps necessary to complete the order, carrying out each of the steps to complete the order, timing each of the steps, and executing each of the above steps in parallel for multiple orders.
Depending on the skill level of the human worker, the number of orders at a time, and complexity of the recipes, a number of problems arise during the food preparation not the least of which is a lack of precision and consistency in the completed entrée. The human worker may forget to flip the steak or remove the steak weight at the precise time, resulting in an incorrect cooking level of the steak.
Another important shortcoming in a typical restaurant kitchen is inefficiency. Human workers are generally unskilled at carrying out multiple orders in parallel, and maximizing overall efficiency. On one hand, the human worker may have a sense or gut instinct based on experience to fill a grill with steaks for a dinner rush in order to accommodate the multiple orders, but doing so is prone to error, leading to food waste for those food items not used or alternatively, inadvertently missing an order. In either case, efficiency can be improved.
Consequently, there is still a need for improved systems for assisting human workers to prepare food in the kitchen environment.
A method for assisting a human worker with preparing food comprises aiming a combination of cameras or sensors at a food preparation area; inspecting the food preparation area using the sensors to obtain image data information; determining identity and position information of the food item or food preparation item based on the image data information from the inspecting step; and tracking the food item or food preparation item.
In embodiments, the method further comprises determining an output to command a robotic arm, instruct a kitchen worker, or otherwise assist in food preparation. In embodiments, the command is an instruction to perform a step in a food preparation process for an identified food item consistent with recipe information provided during set-up.
In embodiments, a plurality of the same types of sensors are aimed at the food items. In other embodiments, a combination of different types of sensors are aimed at the food items. The sensors can be selected from the group consisting of an infrared (IR) camera, an RGB camera, and a depth sensor at the food preparation area.
In embodiments, the method further comprises pre-processing the image data from the sensors prior to sending the image data to a trained model.
In embodiments, the image data from the sensors is transformed into a top perspective view of the grill.
In embodiments, the step of determining the identity and position information of the food item or food preparation item is performed using a trained neural network.
In embodiments, the step of tracking evaluates whether a food object is occluded, and updates the location of food objects that are not occluded.
In embodiments, the step of tracking computes a predicted location of the food object, and bases the computation of the predicted location on whether food object is stationary.
In embodiments, an automated kitchen assistant system comprises a plurality of sensors to inspect a food preparation area in the kitchen environment. The plurality of sensors may include a combination of the same or different types of sensors. In one embodiment, the sensors include a plurality of cameras operable to obtain image data of light in the visible spectrum wavelength range. In embodiments, the system further includes one or more processors to pre-process the image data to a common perspective view. The processor(s) is further operable to automatically recognize and provide location information for the at least one food item or food preparation item using the image data.
In embodiments, the combination of sensors further includes a third sensor which is a depth sensor and image data from the depth sensor is combined with the image data from the first and second sensor.
In embodiments, the image data from each of the sensors is made suitable to serve as an input layer for a single computer vision model (e.g., a CNN) capable of recognizing and providing location information for the at least one food item or food preparation item using the image data.
In embodiments, the image data from each of the cameras is transformed to another perspective (e.g., a top view of the grill) prior to inputting the information to the food item recognition model. Transforming the perspective from each of the cameras to a common view allows for use of one trained model, thereby increasing computing speed and efficiency.
In embodiments, the image data is transformed from the RGB space to the HSV space prior to inputting the information to the food item recognition model. Transforming to the HSV space has been found to improve detection of various cooking by-products or cooking by-matter that is not always readily detectable using only the RGB image data. Cooking by-products include matter that is created during the cooking process whether inadvertently, accidentally, or anticipated. Examples of cooking by-products include, without limitation, smoke, steam, fire, liquid drippings from cooking meats, and char on the grill.
In embodiments, the processor is operable to automatically recognize food objects in the food preparation area including food items, kitchen implements, a kitchen worker, or an appendage of a kitchen worker.
In embodiments, the processor employs a trained convolutional neural network to obtain identity and position information of the food item or food preparation item.
In embodiments, multiple processors are used to perform the various steps performed by the processor.
In embodiments, after the kitchen assistant has been set up including the aiming of the combination of sensors at the food preparation area and a calibration process, it can operate in an autonomous manner. In embodiments, the kitchen assistant is adapted to perform the steps of sensing, inspecting, determining identity and position information, tracking, and determining an output to command automatically and without human intervention or assistance. In embodiments, the kitchen assistant is further able to determine if a food preparation command has been performed and automatically determine a second food preparation command.
In embodiments instructions and information are be displayed on a tablet or monitor for the human worker to follow.
The description, objects and advantages of the present invention will become apparent from the detailed description to follow, together with the accompanying drawings.
Before the present invention is described in detail, it is to be understood that this invention is not limited to particular variations set forth herein as various changes or modifications may be made to the invention described and equivalents may be substituted without departing from the spirit and scope of the invention. As will be apparent to those of skill in the art upon reading this disclosure, each of the individual embodiments described and illustrated herein has discrete components and features which may be readily separated from or combined with the features of any of the other several embodiments without departing from the scope or spirit of the present invention. In addition, many modifications may be made to adapt a particular situation, material, composition of matter, process, process act(s) or step(s) to the objective(s), spirit or scope of the present invention. All such modifications are intended to be within the scope of the claims made herein.
Methods recited herein may be carried out in any order of the recited events which is logically possible, as well as the recited order of events. Furthermore, where a range of values is provided, it is understood that every intervening value, between the upper and lower limit of that range and any other stated or intervening value in that stated range is encompassed within the invention. Also, it is contemplated that any optional feature of the inventive variations described may be set forth and claimed independently, or in combination with any one or more of the features described herein.
All existing subject matter mentioned herein (e.g., publications, patents, patent applications and hardware) is incorporated by reference herein in its entirety except insofar as the subject matter may conflict with that of the present invention (in which case what is present herein shall prevail).
Reference to a singular item, includes the possibility that there are plural of the same items present. More specifically, as used herein and in the appended claims, the singular forms “a,” “an,” “said” and “the” include plural referents unless the context clearly dictates otherwise. It is further noted that the claims may be drafted to exclude any optional element. As such, this statement is intended to serve as antecedent basis for use of such exclusive terminology as “solely,” “only” and the like in connection with the recitation of claim elements, or use of a “negative” limitation. Last, it is to be appreciated that unless defined otherwise, all technical and scientific terms used herein have the same meaning as commonly understood by one of ordinary skill in the art to which this invention belongs.
The following application are incorporated by reference in their entirety for all purposes: US Patent Publication No. 20200121125; US Patent Publication No. 20210030199; and US Patent Publication No. 20180345485.
Apparatus Overview
System 100 is shown having a plurality of sensors 110, a robotic arm 120, and an enclosure 130 for housing a processor and other hardware which are operable, as described further herein, to receive data from the sensors 110, process the data, and to recognize and locate the food 140, 144. Although food 140,144 are shown as a bun and burger respectively, it is to be understood that the types of food contemplated herein may vary widely. Examples of food items include, without limitation, meat, burgers, steaks, chicken, turkey, fish, pastries, baked goods, vegetables, potatoes, fries, pizza, seasonings, sauces, frostings, fruits, starches, water, oils and other ingredients or combinations thereof.
Additionally, in embodiments, the system 100 is operable to automatically control the robotic arm 120 to carry out one or more steps in preparing the food.
Additionally, the motion and configuration of the robotic arm may vary widely. Examples of robotic arms, motion, training, and systems are shown and described in US Patent Publication No. 202001211253 to Zito; US Patent Publication No. 2017/0252922 to Levine et al.; and U.S. Pat. No. 9,785,911 to Galluzzo et al., each of which is incorporated by reference in its entirety.
In embodiments, the tablet is programmed with an application (“App”) or otherwise to wirelessly or through a wired connection communicate with the processor, accept input from the user, and to send or display various information as described further herein.
The number and types of sensors 110 may vary widely. Examples of sensors include, without limitation, visible spectrum cameras (e.g., a black and white, or RGB camera), a depth sensors, and an infrared (IR) cameras.
In embodiments, the sensors include one or more visible spectrum cameras such as a RGB camera. Preferably, the RGB camera obtains an image comprising a 960 by 540 grid with intensity data for red, green, and blue portions of the spectrum for each pixel in the form of 8-bit unsigned integers. In embodiments, the focal length of the camera lens and orientation of the optics have been set such that area imaged includes the work surface. An exemplary visible spectrum sensor is the Kinect One sensor manufactured Microsoft Corporation (Redmond, Washington). In embodiments, a black and white visible spectrum camera is used.
The infrared or IR camera generates IR image data by measuring the intensity of infrared waves and providing data representing such measurements over the observed area. In embodiments, the focal length of the camera lens and orientation of the optics has been set such that area imaged includes the work area. Preferably, the IR camera is adapted to measure the intensity of IR waves (typically in the range of 7.2 to 13 microns, but other wavelengths in the IR may be used) over an area and generates IR image data. An exemplary IR sensor is the CompactPro high resolution thermal imaging camera manufactured by Seek Thermal Corporation (Santa Barbara, CA), which can provide an image of size 320×240 with each value a 16-bit unsigned integer representing measured IR intensity.
A depth sensor incorporates a time of flight (TOF) camera to generate data on the distance of each point in the field of view from the camera. The TOF camera is a range imaging camera system that resolves distance based on the known speed of light, measuring the time-of-flight of a light signal between the camera and the subject for each point of the image. In embodiments, the image comprises a 960 by 540 grid with a value of the distance from the sensor for each point in the form of a 16-bit unsigned integer. An exemplary depth sensor is the Kinect One sensor manufactured Microsoft Corporation (Redmond, Washington). In embodiments, other types of depth sensors are employed, such as devices using texturing (typically performed with an IR or near IR projector and two sensors) and stereo reconstruction, lidar, and stereoscopic cameras.
Without intending to be bound to theory, we have discovered the IR camera sensors providing IR image data have the potential to mitigate or overcome smoke, moisture, and other elements associated with conventional automated cooking equipment that reduce the quality of the image data. Due to the temperature differences typically present when an uncooked food is placed on a hot grill or other high temperature cooking surface or when a kitchen worker or kitchen worker's appendage is imaged against a predominantly room temperature background, IR camera sensors are able to provide high contrast and high signal-to-noise image data that is an important starting point for determining identity and location of kitchen objects, including food items, food preparation items and human workers. In contrast, the signal-to-noise ratio is significantly lower using only traditional RGB images than if using IR images. This occurs because some kitchen backgrounds, work surfaces, and cooking surfaces can be similar to food items in color, but temperatures are generally significantly different. Based on the foregoing, some embodiments of the invention include IR-camera sensors in combination with other types of sensors as described herein.
Optionally, and as shown in
The embodiment shown in
Optionally, and with reference again to
Optionally, each camera may be attached to a computer which is operable to communicate with other computers to compute and display information.
In preferred embodiments, the food preparation system takes or receives orders from a system that collects customer orders, and then, as described further herein, projects meaningful visual information onto the work areas (either directly with projected light, for instance, or virtually with AR glasses) to help guide kitchen workers in the preparation of food items. The food preparation system is operable to determine which instructions to project (and when and where to project the instructions) based on various types of information including knowledge of the current state of the grill, status of food items being prepared, information collected by cameras and other sensors, recipes for various food items, past orders, and other information. In embodiments, the system automatically monitors the work area for evidence that the step has been completed and then projects a next step. A wide variety of augmented reality systems may be incorporated into the system including use of AR-style goggles in which case a beacon 80 serves to assist with location or registration information. Although the beacon 80 is shown affixed to the side of the grill in
Step 202 states to provide a sensor assembly. The sensor assembly may include a plurality of sensors, at least one of which is an RGB or IR camera as described herein. In embodiments, and as shown in
In embodiments, cameras are installed above and lateral of the target cooking area in order to obtain opposing top side perspective views of the cooking area. Obtaining images from opposing side angles of the cooking area reduces or eliminates the risk of failing to track an object in the cooking area due to obstruction of vision from human workers and other obstructions.
Step 204 states to inspect the food preparation work area to obtain sensor image data. As described further herein, in embodiments, the sensors generate data in the form of image data of an area.
Step 206 states to process the image data from the sensors. In embodiments the image data may be processed to reduce noise, crop size, adjust contrast, etc. Additionally, as described herein, the image data from different cameras or perspectives may be transformed into a single perspective view, preferably a top view of the grill.
Step 208 states to compute identity and location information of the food item or food preparation item. As described further herein, the image data is input to a model, engine, or module such as a trained convolutional neural network or another means for object recognition and tracking. In embodiments, a probability of the identity and area within which the food item or food preparation item is located is computed by a Kitchen Scene Understanding Engine.
It is to be understood that in addition to identifying and locating food, step 208 is equally applicable to identify and locate kitchen implements, and other objects detected by the sensors such as, without limitation, the kitchen worker or a part of the kitchen worker, such as his hand. Additionally, by “food preparation items” it is meant to include kitchen worker, or a portion of the kitchen worker, robot, or a portion of the robot, and kitchen implements including, without limitation, appliances, dishware, and tools used in the preparation of food. Additionally, by “kitchen object” it is meant to include either a food item or food preparation item.
Optionally, and as discussed further herein, the identity and location information may be used to instruct a human worker, control a robotic arm or otherwise carry out a desired food preparation step, such as for example, turning on an appliance. Optionally, the control of the robotic arm is done autonomously or automatically, namely, without human instruction to carry out particular movements.
The computer 212 is shown connected to sensors 220, restaurant's point of sale (POS) system 222, human input device 224, display 250, and data log 240. Optionally, the system can have robotic arm 232 and dedicated controller 230 for the robotic arm.
Additionally, in embodiments, one component or device may serve more than one function in the system such as, for example, a tablet in which case the tablet can be programmed to serve as a display 240 and an input device 224. Instructions, alerts, status, orders, inventory, and other types of information may be shown to the human worker. Inputs may be accepted by the tablet or input device including over-ride commands, cook level, recipe or cooking adjustments, cook time adjustments, etc.
In embodiments, one or more of the components are remote and connected to the other components of the robotic kitchen assistant system via the Internet or other type of communication channel. For example, computer 212 may communicate with a remote (e.g., cloud-based) server to exchange data, recipes, cooking equipment specifications, provide software updates, send commands, backup local storage, and carry out one or more of the modules described herein.
In embodiments, the Kitchen Scene Understanding Engine 310 serves to detect and track all relevant objects in the work area, including but not limited to food items, kitchen implements, and human workers or parts thereof. Data on these objects including but not limited to their identity and location are provided to the Food Preparation Supervisory System 320, which generates the instructions for preparing the food item. These instructions are provided to either or both the Robotic Food Preparation System 350 and to the human worker. Instructions may be provided to the human worker by, for example, display. In embodiments, the display is a touch screen tablet or another device adapted to receive input and display information with the human worker.
In some embodiments, the Food Preparation Supervisory System 320 determines the presence of new food preparation items (based on, amongst other things, data from the kitchen scene understanding engine 310) and automatically begins the food preparation process. In some embodiments, the Food Preparation Supervisory Systems 320 is operable to (a) instruct a human worker via the display (or otherwise) to retrieve raw ingredients from nearby cold or dry storage based on an order received from the restaurant's POS system, flip a food item, place or remove a food item, or, (b) in the case a robotic arm is present, to signal the Robotic Food Preparation System 350 to control the robot arm to carry out a food preparation or cooking step.
In embodiments, once the appropriate food preparation item is recognized by the Kitchen Scene Understanding Engine 310, the Food Preparation Supervisory System 320 begins the food preparation process for that item. For example, in embodiments, the processor is operable to use recipe data to select actions and to: (a) instruct the human worker to perform a task by displaying information on the display or, in the case the system includes a robotic arm, (b) send information to a controller to generate motion by the robot arm that manipulates the food on the work surface.
The Food Preparation Supervisory System 320 shown in
Step 440 states to pre-process the sensor image data 420. Non-limiting examples of types of pre-processing include adjusting image size, contrast, aligning or registering, and reducing noise.
Step 442 states to perform a perspective transformation (e.g., overhead perspective transformation) of the image data from the various sensors. A perspective transformation serves to simplify the training and use of the CNN, discussed herein. For example, by transforming the upper side view to a top view of the grill, the view of the target area is normalized regardless of where the sensor is mounted or aimed. One model can thus be trained for multiple cameras placed at different angles and locations with respect to the cooking area.
It is to be understood the number of cameras or sensors may vary. Additionally, the types of cameras or sensors may vary. In one embodiment, the system comprises two cameras for capturing images of light having wavelengths in the visible spectrum. In another embodiment, the system comprises RGB, depth, and IR sensors, wherein the RGB and depth data are preferably transformed into the IR reference frame to make up the input layer to the CNN, discussed herein.
The modified image data 450 is sent to object detector engine 460. In embodiments, the object detector engine 460 is a trained convolutional neural network (CNN) such as RetinaNet with ResNet-18. See, e.g., Lin, Tsung-Yi, et al. “Focal loss for dense object detection.” Proceedings of the IEEE international conference on computer vision. 2017. However, it is to be understood that the invention is not so limited and the type of object detector may vary. In embodiments, the object detector is a combination of a region proposal network and CNN. An example of region proposal network and CNN is described in Shaoqing Ren, Kaiming He, Ross Girshick, and Jian Sun, “Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks Faster”, IEEE Transactions on Pattern Analysis and Machine Intelligence, Volume 39 Issue 6, June 2017, which is hereby incorporated by reference in its entirety. Examples of other types of convolutional neural networks are described in Patent Publication Nos. US 20170169315 entitled “Deeply learned convolutional neural networks (CNNs) for object localization and classification”; 20170206431 entitled “Object detection and classification in images”, and U.S. Pat. No. 9,542,621 entitled “Spatial pyramid pooling networks for image processing”, each of which is herein incorporated by reference in its entirety.
In embodiments, the object detector is trained to identify food items and food preparation items, kitchen items, and other objects as may be necessary for the preparation of food items. Such items include but are not limited to human workers, kitchen implements, cooking by-products, and food.
For each set of image input data provided as an input layer to the object detector 460, the object detector outputs the location in the image data and associated confidence levels for objects it has been trained to recognize. In embodiments, the object detector 460 outputs location data in the form of a “bounding box” in the image data defined by two corners of a rectangle. The output also includes a prediction of the class identity of the object.
In embodiments, multiple data pipelines are executed in parallel corresponding to the number of cameras or sensors. In embodiments, first and second data pipelines are generated in which the trained detector outputs a first and second output layer corresponding to each of the first and second cameras.
Optionally, the accuracy of the object's location within the CNN output layer may be further computed. For example, IR image data measured within the area defined by the bounding box taken from the CNN output layer is further processed to more accurately determine an object's location. Techniques to do so include various computer vision and segmentation algorithms known in the art such as Ohta et al. “Color information for region segmentation.” Computer graphics and image processing 13.3 (1980): 222-241; and Beucher, Serge, and Fernand Meyer. “The morphological approach to segmentation: the watershed transformation.” Optical Engineering-New York-Marcel Dekker Incorporated-34 (1992): 433-433.
In a preferred embodiment, the processor is programmed to compare or aggregate the output of the detector (e.g., CNN output) from each of the first and second detection pipelines for the presence of a food item. In some cases, the highest confidence score for class identity is used. The confidence of classification of an object is the belief that the object is indeed the measured class. In embodiments, detections are filtered out that are below a certain confidence threshold value. In preferred embodiments, detections that are below 90% confidence are filtered out.
Aggregating the output data of the detector model may be performed in various manners including, for example, selecting the highest confidence score for each detected food item (or deleting the lower confidence score). Collecting image data from multiple cameras arranged at different perspective views of the working area provides additional (sometimes redundant) information of the scene to enable robust tracking, discussed herein, and minimizes false negatives arising from worker obstructions.
In another embodiment, the system designates a primary camera or pipeline, and a second or ancillary camera to confirm or correct the confidence level of a food item determined from the first camera data. As discussed herein the cameras are preferably placed above the grill, and are laterally spaced from one another to obtain upper side perspective views of the entire grill. Consequently, food items on the grill are visible by at least one of the cameras.
Next and with reference to
Optionally, the location data of the identified objects given in the two dimensional coordinate system from the tracker can be translated into a three dimensional coordinate system such as a world coordinate frame or system reference frame. In embodiments, and when a robotic arm is present, the world coordinate frame is the same frame used by the robotic arm. However, in other embodiments, the 3D transformation is not necessary. For example, when only a 2D view of the food items is desired for observation or providing instructions to a human worker, the 3D transformation can be eliminated.
Initially, an object prediction module 610 calculates a predicted object position. With reference to step 614, the object prediction module computes the object's current position (e.g., a bounding box) based on past measurements of the object for each frame received from the buffer (step 604). By “frame” it is meant a set of measurements all taken at a specified point in time. For a video stream, for example, an image is a frame (the pixels are the individual measurements). However, in preferred embodiments of the invention, a frame is a list of bounding boxes with associated class identity. In embodiments, each frame has a header which contains a timestamp and (monotonically incrementing) sequence number. Examples of algorithms/techniques to predict the current position are described in Simon, Dan. “Kalman filtering.” Embedded systems programming 14.6 (2001): 72-79.
Step 616 queries whether the object is stationary. If the object is stationary, a first type of filter (step 617) is applied (e.g., the measurements may be averaged). If the object is not stationary, a second type of filter (step 618) is applied (e.g., a Kalman type of filter may be applied). A Kalman filter is an algorithm for improving signal tracking. A Kalman filter generally includes a physical model of an object and uses the physical model to predict the next measurement (e.g., to where did the object move). Examples of types of Kalman filters that can be used in embodiments of the invention include, without limitation, the Extended Kalman Filter and the Unscented Kalman Filter. Without intending to being bound to theory, Applicant has found adding a step for querying whether the object is stationary, and applying stationary-based filters increases computing efficiency, and especially for tracking numerous objects as is the case in the kitchen working areas. Indeed, a large grill may have upwards to 50 burgers or steaks and other food items at one time. Applying different types of filters for predicting tracks enables use of a fast type filter on a substantial number of the objects. A more comprehensive and relatively slow filter can be applied to the moving objects without sacrificing computer power or time. Notwithstanding the above, it is to be understood a wide variety of types of filters may be applied in embodiments of the invention and the invention is intended to be limited only as recited in any appended claims.
Step 619 states to update the predicated location for the track. By “track” it is meant a list of measurements over time that correspond to a distinct object. A track is typically created when a measurement is found that doesn't represent any known object.
If another track is present, the object prediction sub-module repeats, returning to step 614. If another track does not exist, the updated prediction for the track computed in step 619 is sent for matching, described herein.
Sub-module 620 evaluates whether a track matches with current measurements. Particularly, step 622 evaluates each track for a match with a current measurement and separates the results into a plurality of categories including: observed, unobserved, and unmatched. By “observed”, it is meant matched pairs of tracks/measurements. By “unobserved”, it is meant tracks with no measurements. By “unmatched”, it is meant measurements with no track.
Optionally, and with reference to step 624, one or more custom matching resolution rules are applied. For example, if a steak weight is detected on the grill, and a steak is not detected, assume a steak is present under the steak weight, at least for the purposes of cooking. This type of custom rule provides a uniform way of adding known structure to the tracking algorithm to improve tracking accuracy.
Sub-module 630 is an occlusion mask module and states to ignore occluded objects. Marking objects as occluded is important during the tracking process because the objects may in fact be present but not observed. Objects may not be observed because something (e.g., the human worker) is between the camera and object being tracked. Without accounting for occlusion, a false negative may be generated.
To account for the unobserved object, and with reference to step 632, an occlusion mask is created from the observed objects and the unmatched objects. For example, a mask may be created for (1) a steak weight which may have measurements and a matching track and (2) a human worker or portion of the human worker which may have measurements unmatched to a track. In embodiments, an occlusion mask comprises an image mask data set where each pixel in the mask image has a binary value of 1 or 0. The value of ‘1’ is assigned to each pixel in the image where the occluding object is not present. The value of ‘0’ is assigned to each pixel in the image where the object is present. This mask often has a coarser resolution than the image to which it applies.
Next, with reference to steps 636, each unobserved object is evaluated for whether it is occluded based on the occlusion mask computed in the steps described above.
If the unobserved object is deemed occluded, step 638 marks the track as occluded and is not updated. Otherwise, the process continues to the next track update sub-module 640, described herein.
The track update sub-module 640 serves to update each track according to its category: observed, unobserved, and unmatched.
As described above, the observed category 650 includes tracks matched with the current measurement. The current measurement is appended to the existing track according to step 654 before proceeding to updating the confidence of existence in step 680, discussed herein.
The unobserved category 660 includes tracks not matched to a current measurement. Step 664 queries whether the tracked object is occluded. If the tracked object is occluded, the current measurement is ignored and the process proceeds to step 680 for updating the confidence of existence, discussed herein. If the track is not occluded, the missing measurement is appended to the track per step 666 before proceeding to step 680 to update the confidence level.
The unmatched category 670 includes measured objects lacking tracks. For this category, a new track is created for the current measurement according to step 674. Then, the track and measurement are sent for updating the confidence of existence according to step 680, discussed herein.
Step 680 states to update the confidence of existence. The confidence of existence of an object is the probability that the object exists. With each observation, the confidence increases. Conversely, with each missed observation, the confidence decreases. In the case of an occluded object (and especially where the occluded objects are stationary such as a steak under a steak weight), the confidence level for the occluded object should not degrade for a missed observation because the object was merely occluded.
A wide variety of algorithms may be employed to compute the probability based on the prior conditions including, for example, Bayes' Theorem. With reference to
The output of the belief update rules or law is a set of new or updated beliefs 560.
The updated new beliefs are shown being sent to a state machine 570. The state machine 570 or finite state machine is a model of computation. The state machine maintains state variables to keep track of the environment and whatever else is necessary for the system to perform the necessary functionality (e.g., how long has a steak been cooking). In addition, a state machine can have a transition function which updates the state based on the previous state and new inputs (e.g., a frame of measurements from the detector). The state machine includes identity and location of all known objects in the observation area. It includes an atlas or aggregated set of information on the types of food, kitchen implements, time counts, and workers within the work space. An example of a final set of beliefs can be represented as a list of objects that are believed to exist with associated classification confidences, time counts, and location estimates. As described above, the aggregated set of food items and or kitchen objects can be used by the Food Supervisory System to calculate instructions and commands, described herein.
Food Preparation Supervisory System
With reference again to
In embodiments, the food preparation supervisory system automatically determines the set time based on the type of food item and cook level selected by the human worker or order, discussed further below.
The food preparation supervisory system 494 then sends a command or instruction to the display or another device (e.g., audio, optical projection, etc.) to communicate with the human worker or, in the case of preparing the food using a robotic arm, the food preparation supervisory system sends a signal to the controller to cause the robotic arm to carry out the applicable step. An example of a next step is to remove the food item from the grill, to flip the food item, or to place or remove a utensil such as a steak weight from the food item on the grill.
CNN Detail
With reference to
In embodiments, the output layer of the CNN is the prediction vector which gives the objects recognized by the CNN, along with a confidence level (e.g., from zero to one), and their location in the two-dimensional image data. In embodiments, the location is characterized using a bounding box and denoting two corner points of the bounding box in the image plane.
The length of the output vector is equal to the number of objects that the CNN has been trained to identify. In embodiments, the length of the output vector ranges from 1 to 500, preferably from 50 to 200, and most preferably from 75 to 125.
Training the CNN
Step 810 states to install cameras. Cameras are set up and aimed at the work area. In embodiments, the work area is a grill, stove, fryer, or preparation area.
Step 820 states calibration. Calibration is performed to determine the extrinsic and intrinsic parameters for the sensors. Camera/sensor calibration may be performed as described herein, or otherwise as is known in the art.
Data Collection
With reference to step 830, target objects of interest are placed in the work area and image input data is generated and collected which comprises an image of multiple channels representing the intensity of light at various wavelengths (e.g., red, green, blue, IR) and optionally depth. In embodiments, the CNN is trained on food items and utensils shown on a grill during the day. Examples of food items include, without limitation, steaks, burgers, burgers with cheese, chicken breasts, sausages, onions, and fish fillets placed on the grill. Examples of utensils include, without limitation, steak weights, spatulas, plates, bowls, and tongs. In embodiments, the CNN is trained on types of cuts of meat. In embodiments, the CNN is trained on classifying a food item as a fillet mignon, porterhouse, ribeye, skirt, New York, breast, leg, fillet, etc. Images are obtained showing one or more steak weights on the grill and on steaks.
Additionally, in embodiments, the CNN is trained on cooking various by-matter arising from cooking. By-matter may be anticipated such as char on the grill or liquid drippings from cooking meat, or it may be unanticipated such as smoke or fire. In embodiments, the image data is transformed from the RGB to the HSV space for detection of the by-matter.
Labeling
With reference to step 840, the image data or a portion of the image data is presented to a human user who identifies relevant objects in the image (classifies) and creates bounding boxes for the images (locates). The data from the human user is then recorded into the form of the output layer that the CNN should create when presented with the input image data.
Training and Data Augmentation
With reference to step 850, the input images and output layer are divided into training, validation and test sets. The training data set is presented to the model and periodically compared with the validation data set. The parameters of the CNN are adjusted based on the results of the validation set. The process is repeated multiple times (multi-stage). With each iteration, the weighting factors of the CNN can be modified. Examples of weighting factors adjusted to tune the model include, without limitation, learning rate, momentum, and batch size.
Semi-Manual Training
In embodiments, and subsequent to the first stage of training described above, a second semi-manual training comprises the following:
Additionally, in some embodiments, the collected data are used to generate synthetic data by using photorealistic rendering where objects are placed over a variety of backgrounds to create novelty. An example of such a rendering is a ribeye steak on a grill. These synthetic data can be combined with real data to increase the detection and classification accuracy and decrease the data collection and labeling costs of neural networks. In embodiments, synthetic data is combined with real data according to a specified ratio which can be tuned depending on the situation to achieve the requisite accuracy. A preferred ratio of synthetic data to real data is 80/20 or greater.
In some embodiments, the collected data are used to generate synthetic data by using generative adversarial networks (GANs) where one neural network is trained to generate images and another neural network is trained to detect if the generated images are real. These networks can be trained together to obtain a system which produces synthetic data with a high degree of realism. These synthetic data can be combined with real data to increase the detection and classification accuracy and decrease the data collection and labeling costs of neural networks. In embodiments, GAN-based synthetic data is combined with real data according to a ratio of that is varied based on the situation. The more synthetic data, the lower the cost of data. A preferred ratio of GAN-based synthetic data to real data is 80/20 or greater. Examples of GANs algorithms/techniques are described in Goodfellow et al., Generative adversarial networks, Communications of the ACM, Volume 63, Issue 11, November 2020 pp 139-144.
In embodiments, specific categories of data are generated synthetically. In a preferred embodiment, dangerous types of by-matter data are generated synthetically such as fire and smoke in the kitchen, and the food and kitchen implements are generated using real data.
In a preferred embodiment, automated food preparation assistants are deployed in various kitchens and each automated food preparation assistant is operable to communicate with a central server such as a remote cloud based server. For example, a plurality of restaurants may each install the automated food preparation assistant as described herein and each of the automated food assistants is programmed to continuously send image data of the food items to the central server. The central server uses the different sets of image data for training (whether unsupervised training or other training techniques) a universal food item recognition model.
The local automated food preparation assistants are periodically updated with the improved food item recognition mode.
Additionally, in embodiments, the output vector from the CNN object detector can comprise multiple instances of known food items that are differentiated by the degree that they are cooked (namely, “degree of doneness”). In embodiments, the measure of cooking is the internal temperature of the object, such as a steak cooked to medium rare corresponding to an internal temperature of 130 to 135 degrees Fahrenheit. In embodiments, the CNN is trained to detect not just individual objects and their location, but the internal temperature of the objects. Measurements of the internal temperature of the food item can be taken with temperature sensors and used in the output vector for the training of the CNN. In some embodiments, these temperature measurements are taken dynamically by a thermocouple that is inserted into the food item.
In embodiments, an alternate or additional contact-less thermal model is used to track the estimated internal temperature of various food items to determine when they are cooked to the appropriate level. In these cases, data can be provided by the Kitchen Scene Understanding Engine on how long the various items have been cooked and their current surface temperature and or temperature history as measured by the IR camera.
Calibration
A wide variety of techniques may be employed to calibrate the cameras or sensors.
In embodiments, each camera or sensor is calibrated with a calibration target capable of obtaining known high signal-to-noise ratio observations in a known coordinate frame.
In other embodiments, two or more cameras are calibrated by observing the tracked object over time with each of the cameras. The Perspective-n-Point problem is solved to determine where in space each food item is relative to each camera. Knowing the 3D coordinates of the food item(s) for each camera allows the cameras to be calibrated to one another. An example technique for solving the Perspective-n-Point is described in Xiao-Shan Gao et al. “Complete solution classification for the perspective-three-point problem,” in IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 25, no. 8, pp. 930-943, August 2003.
In other embodiments, two or more cameras can be calibrated through stereo pair matching, by looking for features which are similar between views and corresponding them.
The GUI 900 shows an order window 910, grill window 920, and assembly window 930.
Order window 910 shows, in real time, different types of customer order information such as an eat in order 912 and to go order 914. Each order may feature identifying label, a food item, menu item, topping or other modification. As orders are received, the robotic kitchen assistant carries out the methods described herein and posts the status of the order in the order window 910. As orders are completed, the robotic kitchen assistant removes the order from the screen or otherwise identifies it as completed.
Grill window 920 shows a real time image of the grill including all food items placed thereon 922. As described herein, the food items are recognized and located as they are placed on the grill. In the embodiment shown in
Grill window 920 also indicates instructions to add new food items such as to add chicken 924, or add burger, or add bun in view of the customer order information, timing estimates, state status of the food items, and recipe information. Exemplary instructions for the grill window include, without limitation, remove steak, flip steak, remove steak weight, add steak, etc.
Grill window 920 additionally shows a real time infrared image 926 of the grill and a computed temperature associated with the grill. The use of infrared cameras or sensors assist not only for temperature evaluation, but also in food item recognition and location and for monitoring internal temperature of the food items on the grill.
Assembly window 930 shows, in real time, the food and assembly area including food item bins 932 and augments the image with instructions requesting more ingredients when an ingredient is below a threshold amount. For example, the instruction to “ADD LETTUCE” (corresponding to reference numeral 934) is displayed over the low/empty lettuce bin.
Additionally, a portion of the workspace accessible by a robotic kitchen assistant is shown divided into a grid 936 and food items can be transferred to spaces A-H in the grid and additional preparation instructions can be displayed that reference the position of particular items in the grid.
The GUI 950 shows a real time image of the grill 960 including all food items 962 placed thereon. In the embodiment shown in
As described above, the kitchen scene understanding engine, and particularly, the object tracker continuously updates the state of the system for all objects on the grill including their identity, location, and elapsed time. The food preparation supervisory engine determines what steps are to be completed next. For example, the food preparation supervisory engine alerts the human worker to remove or flip a steak. The information can be displayed on the GUI to the human worker.
GUI 950 additionally shows a tab for “free cook.” By activating “free cook” the human worker can turn off the kitchen assistant timer or alerts in order to cook the food item as desired/customized to a level outside of the system's predetermined options. Indeed, embodiments of the invention are operable to prompt the human worker for a wide range of inputs, each of which is used in computing instructions and preparing food as described herein.
Still other modifications and variations can be made to the disclosed embodiments without departing from the subject invention. In embodiments, the processor is operable to transform and process the image data from the RGB cameras to a different or second color space such as the hue shift, saturation, and value (HSV) space. In the HSV color space, we have found that certain by-products generated in the kitchen are easier to detect including (a) smoke and fire arising from the grill, (b) char build up on the grill, and (c) liquids such as liquid dripping from the meats as they are cooked on the grill. In embodiments, the processor is programmed and operable to utilize this HSV color space data as inputs or features to the models and modules discussed herein to assist in determining: (i) occlusion decisions (e.g., detect smoke occlusion for use in the occlusion mask module 630), (ii) tracking rules (e.g., detect a dripping steak can be applied as a custom rule 624 for matching, and result in a higher probability to be a tracked based on detecting drippings), (iii) worker alerts for fire (e.g., detect excess smoke arising from cooking equipment—send/display instruction to worker to immediately attend to fire), and (iv) worker alerts for the food preparation equipment condition (e.g., grill contains char marks—send/display instruction to worker to clean grill). Indeed, the processor may be operable to provide a wide range of alerts based on processing the image data in a second color space including without limitation smoke alerts, grill-clean alerts, and liquid or fire alerts.
This application claims priority to application No. 63/196,636, filed Jun. 3, 2021, entitled “AUTOMATED KITCHEN SYSTEM FOR ASSISTING HUMAN WORKER PREPARE FOOD.”
Number | Name | Date | Kind |
---|---|---|---|
1760462 | Yeo | May 1930 | A |
2658444 | Wheeler | Nov 1953 | A |
3302871 | Kettering et al. | Feb 1967 | A |
4015494 | Spooner et al. | Apr 1977 | A |
4052319 | Friedman | Oct 1977 | A |
4545723 | Clark | Oct 1985 | A |
4853771 | Witriol et al. | Aug 1989 | A |
4919950 | Mak | Apr 1990 | A |
4922435 | Cahlander et al. | May 1990 | A |
4979864 | Cahlander et al. | Dec 1990 | A |
5132914 | Cahlander et al. | Jul 1992 | A |
5230279 | McFadden et al. | Jul 1993 | A |
5285604 | Carlin | Feb 1994 | A |
5386762 | Gokey | Feb 1995 | A |
5389764 | Nishii et al. | Feb 1995 | A |
5458384 | Liu et al. | Oct 1995 | A |
5466025 | Mee | Nov 1995 | A |
5833295 | Farlow, Jr. | Nov 1998 | A |
5893051 | Tomohiro | Apr 1999 | A |
D412642 | King | Aug 1999 | S |
D492112 | Hardy | Jun 2004 | S |
7174830 | Dong | Feb 2007 | B1 |
7383963 | Svabek et al. | Jun 2008 | B2 |
7920962 | D'Andrea et al. | Apr 2011 | B2 |
7971450 | Furlanetto et al. | Jul 2011 | B2 |
8276505 | Buehler | Oct 2012 | B2 |
8610037 | Polt | Dec 2013 | B2 |
D702084 | Matos | Apr 2014 | S |
8820313 | Lutes | Sep 2014 | B1 |
9220371 | Demirakos et al. | Dec 2015 | B1 |
9233470 | Bradski et al. | Jan 2016 | B1 |
9285589 | Osterhout et al. | Mar 2016 | B2 |
9483875 | Theimer et al. | Nov 2016 | B2 |
9538880 | Riefenstein | Jan 2017 | B2 |
9542621 | He et al. | Jan 2017 | B2 |
9785911 | Galluzzo et al. | Oct 2017 | B2 |
9815191 | Oleynik et al. | Nov 2017 | B2 |
10005184 | Gerio et al. | Jun 2018 | B2 |
D825266 | Iorio et al. | Aug 2018 | S |
10112771 | D'andrea et al. | Oct 2018 | B2 |
10154756 | Hall et al. | Dec 2018 | B2 |
10293488 | Hall et al. | May 2019 | B2 |
10422870 | Mindell et al. | Sep 2019 | B2 |
10682765 | Mirkhaef et al. | Jun 2020 | B2 |
10919144 | Sinnet et al. | Feb 2021 | B2 |
11167421 | Sinnet | Nov 2021 | B2 |
11192258 | Sinnet et al. | Dec 2021 | B2 |
11518044 | Liu et al. | Dec 2022 | B2 |
11577401 | Sinnet et al. | Feb 2023 | B2 |
11738934 | Jain et al. | Aug 2023 | B2 |
20020028127 | Hart et al. | Mar 2002 | A1 |
20020082924 | Koether | Jun 2002 | A1 |
20040011321 | Hawaj | Jan 2004 | A1 |
20040111321 | Kargman | Jun 2004 | A1 |
20040154474 | Chan | Aug 2004 | A1 |
20040172380 | Zhang et al. | Sep 2004 | A1 |
20050036668 | McLennan | Feb 2005 | A1 |
20050049940 | Tengler et al. | Mar 2005 | A1 |
20050193901 | Buehler | Sep 2005 | A1 |
20060278216 | Gagas et al. | Dec 2006 | A1 |
20070122000 | Venetianer et al. | May 2007 | A1 |
20080110347 | Wong | May 2008 | A1 |
20090192921 | Hicks | Jul 2009 | A1 |
20090210090 | Takemitsu et al. | Aug 2009 | A1 |
20090262206 | Park | Oct 2009 | A1 |
20100132692 | Shaffer | Jun 2010 | A1 |
20100182136 | Pryor | Jul 2010 | A1 |
20100296903 | Shah et al. | Nov 2010 | A1 |
20110153614 | Solomon | Jun 2011 | A1 |
20110264266 | Kock | Oct 2011 | A1 |
20120024170 | Fritz-Jung et al. | Feb 2012 | A1 |
20130033057 | Markham | Feb 2013 | A1 |
20130275236 | Koke et al. | Oct 2013 | A1 |
20130302483 | Riefenstein | Nov 2013 | A1 |
20140031978 | Takata | Jan 2014 | A1 |
20140062112 | Cho | Mar 2014 | A1 |
20140089299 | Kamei et al. | Mar 2014 | A1 |
20140157698 | Cihak et al. | Jun 2014 | A1 |
20140184496 | Gribetz et al. | Jul 2014 | A1 |
20140203012 | Corona et al. | Jul 2014 | A1 |
20140234066 | Mathi et al. | Aug 2014 | A1 |
20140324607 | Frehn et al. | Oct 2014 | A1 |
20140334691 | Cho et al. | Nov 2014 | A1 |
20140351068 | Renfroe | Nov 2014 | A1 |
20140363266 | Cooper | Dec 2014 | A1 |
20150019354 | Chan et al. | Jan 2015 | A1 |
20150290795 | Oleynik | Oct 2015 | A1 |
20150310624 | Bulan et al. | Oct 2015 | A1 |
20160037958 | Freymiller et al. | Feb 2016 | A1 |
20160078694 | Swift | Mar 2016 | A1 |
20160180546 | Kim | Jun 2016 | A1 |
20160239705 | Masood et al. | Aug 2016 | A1 |
20160293470 | Oremus et al. | Oct 2016 | A1 |
20160307459 | Chestnut et al. | Oct 2016 | A1 |
20160327279 | Bhogal et al. | Nov 2016 | A1 |
20160327281 | Bhogal | Nov 2016 | A1 |
20160334799 | D'Andrea et al. | Nov 2016 | A1 |
20160368742 | Maile | Dec 2016 | A1 |
20170011319 | Elliot et al. | Jan 2017 | A1 |
20170024789 | Frehn et al. | Jan 2017 | A1 |
20170030515 | Johnson et al. | Feb 2017 | A1 |
20170116661 | Sundaram | Apr 2017 | A1 |
20170130968 | Nagraj et al. | May 2017 | A1 |
20170154803 | Wang et al. | Jun 2017 | A1 |
20170169315 | Vaca Castano et al. | Jun 2017 | A1 |
20170178070 | Wang et al. | Jun 2017 | A1 |
20170206431 | Sun et al. | Jul 2017 | A1 |
20170252922 | Levine et al. | Sep 2017 | A1 |
20170290345 | Garden et al. | Oct 2017 | A1 |
20170305015 | Krasny et al. | Oct 2017 | A1 |
20170348854 | Oleynik | Dec 2017 | A1 |
20170364073 | Guy | Dec 2017 | A1 |
20180046978 | Tartal et al. | Feb 2018 | A1 |
20180150661 | Hall et al. | May 2018 | A1 |
20180339463 | Stone et al. | Nov 2018 | A1 |
20180345485 | Sinnet et al. | Dec 2018 | A1 |
20180365630 | Seals et al. | Dec 2018 | A1 |
20190176338 | Zito et al. | Jun 2019 | A1 |
20190256301 | Hashimoto et al. | Aug 2019 | A1 |
20190297899 | Weiss | Oct 2019 | A1 |
20190352028 | Mirkhaef et al. | Nov 2019 | A1 |
20190389082 | Higo | Dec 2019 | A1 |
20200009638 | Asada et al. | Jan 2020 | A1 |
20200030966 | Hasegawa et al. | Jan 2020 | A1 |
20200046168 | Sinnet et al. | Feb 2020 | A1 |
20200047349 | Sinnet et al. | Feb 2020 | A1 |
20200054175 | Roy et al. | Feb 2020 | A1 |
20200087069 | Johnson et al. | Mar 2020 | A1 |
20200121125 | Zito et al. | Apr 2020 | A1 |
20200238534 | Goldberg et al. | Jul 2020 | A1 |
20200254641 | Hocker et al. | Aug 2020 | A1 |
20200337343 | Cretors | Oct 2020 | A1 |
20210030199 | Olson et al. | Feb 2021 | A1 |
20210094188 | Rodionov et al. | Apr 2021 | A1 |
20210107724 | Cohen | Apr 2021 | A1 |
20210208171 | Guarracina et al. | Jul 2021 | A1 |
20210276756 | Dunkel | Sep 2021 | A1 |
20210394371 | Ishizu et al. | Dec 2021 | A1 |
Number | Date | Country |
---|---|---|
110279287 | Sep 2019 | CN |
202014001807 | Mar 2014 | DE |
1324865 | Jul 2003 | EP |
2578717 | Sep 1986 | FR |
2004062750 | Feb 2004 | JP |
2008296308 | Dec 2008 | JP |
2009106734 | May 2009 | JP |
2009297880 | Dec 2009 | JP |
4655912 | Mar 2011 | JP |
5814305 | Nov 2015 | JP |
0170087 | Sep 2001 | WO |
2006006624 | Jan 2006 | WO |
2012020858 | Feb 2012 | WO |
2015100958 | Jul 2015 | WO |
2015143800 | Oct 2015 | WO |
2016040361 | Mar 2016 | WO |
2015125017 | Jun 2016 | WO |
2016140622 | Sep 2016 | WO |
2017114014 | Jul 2017 | WO |
2017103682 | Aug 2017 | WO |
2017218548 | Dec 2017 | WO |
2018031489 | Feb 2018 | WO |
2018165038 | Sep 2018 | WO |
2018165105 | Sep 2018 | WO |
2019079345 | Apr 2019 | WO |
PCTUS2272666 | Jun 2022 | WO |
2022256799 | Dec 2022 | WO |
Entry |
---|
B. Siciliano & 0. Khatib, Handbook of Robotics, published by Springer-Verlag Berlin (2008). |
Beucher, Serge, and Fernand Meyer. “The morphological approach to segmentation: the watershed transformation.” Optical Engineering-New Yark-Marcel Dekker Incorporated—34 (1992): 433-433. |
Bonanni et al., “Counterintelligence: Augmented Reality Kitchen”, CHI 2005, Portland, Oregon, USA. (Apr. 2, 2005), URL: http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.88.2875, (Jun. 12, 2018), XP055559956. |
International Search Report and Written Opinion of ISA dated Jul. 11, 2018 for PCT/US2018/020948. |
International Search Report and Written Opinion of ISA dated Jul. 20, 2018 for PCT/US2018/021066. |
International Search Report and Written Opinion of ISA dated Aug. 17, 2022 for PCT/US2022/072666. |
Kaiming He, Georgia Gkioxari, Piotr Dollar, and Ross B. Girshick, Mask R-CNN, arXiv, 2017. |
Krystal B., The magic of Eatsa, explained, (Mar. 2, 2017), URL: https://www.washingtonpost.com/goingoutguide/the-magic-of-eatsa-explained-order-on-a-screen-pick-up-at-a-cubby/2017/03/02/57c95fb0-f55a-11e6-b9c9-e83fce42fb61_story.html. |
Lucas, Bruce D., and Takeo Kanade. “An iterative image registration technique with an application to stereo vision.” (1981): 674-679. |
Ohta, Yu-Ichi, Takeo Kanade, and Toshiyuki Sakai. “Color information for region segmentation.” Computer graphics and image processing 13.3 (1980): 222-241. |
Shaoqing Ren, Kaiming He, Ross Girshick, and Jian Sun, “Faster R-CNN: Towards Real-Time Object Detection with Region Proposal Networks Faster”, IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 39 Issue 6, Jun. 2017. |
Goodfellow et al., Generative adversarial networks, Communications of the ACM, vol. 63, Issue 11, Nov. 2020 pp. 139-144. |
Ju Yong Chang, Haesol Park, In Kyu Park, Kyoung Mu Lee, Sang Uk Lee, GPU-friendly multi-view stereo reconstruction using surfel representation and graph cuts, Computer Vision and Image Understanding, vol. 115, Issue 5, 2011, pp. 620-634. |
Lin, Tsung-Yi, et al. “Focal loss for dense object detection.” Proceedings of the IEEE international conference on computer vision. 2017. |
Robot Frying Basket, 2018. |
Simon, Dan. “Kalman filtering.” Embedded systems programming 14.6 (2001): 72-79. |
Xiao-Shan Gao et al. “Complete solution classification for the perspective-three-point problem,” in IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 25, No. 8, pp. 930-943, Aug. 2003. |
Number | Date | Country | |
---|---|---|---|
20220386807 A1 | Dec 2022 | US |
Number | Date | Country | |
---|---|---|---|
63196636 | Jun 2021 | US |