Modern industrial and manufacturing facilities can include robotics, machinery, and various other components of complex physical systems. Machine manufacturers may be required to satisfy threshold safety requirements to ensure the safety of humans present in such environments. Safety systems, whether directly implemented in machinery or as auxiliary environment components, can be used to address dangerous environment scenarios and override (e.g., force-stop) machine behavior to prevent human harm.
Certain examples are described in the following detailed description and in reference to the drawings.
In the design of modern environment layouts, human safety is becoming an increasingly relevant and important consideration. With ever-increasing advances in robotic systems, manufacturing machinery capabilities, and automated industrial system flows, the operational complexity of industrial environments is continually increasing. Ensuring that human operators present in such environments are not harmed by machine behavior is a necessary, yet challenging objective. As the operational capabilities and degrees of freedom of modern machinery increase, detection of human presences proximate to operational machinery may be required to address how such physical systems react and preserve human safety.
Basic safety and automation functions can be implemented in logic controllers or other machine components. For example, fail-safe devices, e.g., implemented as part of programmable logic controllers (PLCs), can be used to ensure the safety of human operators and factory personnel of a given environment. Fail-safe triggers in systems can be hardware based, and otherwise established for operator safety. However, conventional triggers to execute fail-safe actions in an environment may be simplistic and indiscriminate. As an illustrative example, optical systems such as light curtains or laser scanners can emit light beams in delineated areas of a factory floor. Interruptions to one or more of the light beams can indicate an object has entered into a restricted or unsafe portion of the factory floor, causing a fail-safe trigger or action to take place.
While light curtains and other optical systems can provide a measure of environment safety, such conventional solutions may be incapable of distinguishing between human and non-human intrusion into restricted environment areas. In such cases, fail-safe triggers may be issued even when non-human objects interrupt light beams of optical systems, causing machinery shut-downs and other responsive actions even when human safety is not at issue. For example, an automated guided vehicle (AGV) may traverse a factor floor and trigger a light curtain interruption, even though in this situation no human is in danger and the AGV may be programmed to avoid machinery collisions. Such indiscriminate fail-safe reactions, even though no human is in danger, may reduce the machinery uptime and operational efficiency of industrial environments. Some human detection technologies exist, but can be limited to binary outputs which can cause false positives and make troubleshooting and validation difficult.
The disclosure herein may provide systems, methods, devices, and logic that support machine learning-based environment fail-safes through multiple camera views. As described in greater detail herein, the machine learning-based environment fail-safe technology of the present disclosure may provide capabilities to utilize multiple camera views to train machine-learning models for human detection in various environment settings. The machine learning-based environment fail-safe technology may further provide increased capability and accuracy in detecting humans in video streams or other camera data, for example through application of Bayesian probabilistic modeling techniques and ensuring that multiple camera views confirm a target object is human beyond a threshold probability. As yet another feature of the machine learning-based environment fail-safe technology presented herein, triangulation techniques may be applied to determine proximity to fail-safe boundaries in an environment. Through a combination of human presence and proximity conditions to trigger fail-safe responses, machine learning-based environment fail-safe features may reduce false positives in safety programs, which can in-turn improve factory and industrial environment performance.
In some implementations, the machine learning-based environment fail-safe technology disclosed herein may generate training data for human detection models through simulation environments in which specific manufacturing scenarios and proper safety outcomes can be accounted for. Through such simulation environments, a wealth of simulation scenarios and large amounts of training data can be generated to train human detection models and improve human detection processes for fail-safe responses. Through any combination of precise object location determinations, end-to-end-simulation frameworks, and improved machine learning-based human detection capabilities as described herein, the machine learning-based environment fail-safe features of the present disclosure can detect human presences in environments with increased speed, reliability, and energy-efficiency, without reduced false positives and oversensitivity that can reduce unneeded fail-safe interruptions and improve production efficiency.
These and other features as well as technical benefits of the disclosed machine learning-based environment fail-safe technology are described in greater detail herein.
The computing system 100 may be implemented in various ways to provide any of the machine learning-based environment fail-safe features described herein. As an example implementation, the computing system 100 shown in
In operation, the fail-safe learning engine 110 may access camera data captured by multiple cameras positioned within an environment during a learning phase, generate training data based on the camera data captured by the multiple cameras, and construct a human detection model using the training data. The human detection model may be configured to provide a determination indicative of whether a given object within a view of a camera in the environment is a human or not. In operation, the fail-safe trigger engine 112 may access camera data captured by the multiple cameras positioned within the environment during an active phase, and the camera data captured during the active phase may include a target object. The fail-safe trigger engine 112 may further provide, as an input to the human detection model, the camera data that includes the target object and execute a fail-safe action in the environment responsive to the determination, provided by the human detection model, indicating that the target object is a human.
These and other machine learning-based environment fail-safe features according to the present disclosure are described in greater detail next. Example features with regards to training human detection models in learning phases are described with reference to
In a learning phase of model construction, the fail-safe learning engine 110 may construct machine learning models (e.g., human detection models) by training the machine learning models with training data comprised of captured camera data. To illustrate through
The fail-safe learning engine 110 may construct (e.g., train) human detection models through training data. In
Through the training data 220 (e.g., labeled camera frames), the fail-safe learning engine 110 may train the human detection model 230. The fail-safe learning engine 110 may itself implement or otherwise construct the human detection model 230 as any type of machine-learning model trained according to any combination of machine-learning techniques, processes, or algorithms. As such, the human detection model 230 may implement or provide any number of machine learning techniques to analyze and interpret camera data, doing so specifically for human detection. For instance, the human detection model 230 may implement any number of supervised, semi-supervised, unsupervised, or reinforced learning models to interpret labeled or unlabeled video frames captured by the multiple cameras 201-204 positioned within the environment 200. In some implementations, the fail-safe learning engine 110 may implement the human detection model 230 as a convolutional neural network model, any type of classification model, or as any other suitable machine learning model.
By utilizing training data 220 (and underlying camera data 210) obtained from different perspectives, angles, and orientations from a multi-camera system positioned within the environment 200, the fail-safe learning engine 110 may construct the human detection model 230 to output human presence determinations with increased reliability. Human feature information in each of the various video streams captured by the cameras 201-204 may be accounted for in training the human detection model 230. As one example, the human detection model 230 may analyze training data 220 (e.g., labeled camera frames) to learn human movement features as a human operator in the environment 200 traverses down a hallway or floor path of the environment 200 and is sequentially captured by various individual cameras of a multi-camera system. As such and through sequential human features captured by sequential camera views, the human detection model 230 may improve machine learning-based determinations that a moving object in the environment 200 is a human (and not another mobile component of an industrial system, such as an AGV). Such a sequential nature of human movement (and corresponding object features) may be leveraged by the fail-safe learning engine 110 through probabilistic indicators and weighting applied by the human detection model 230.
In some implementations, the fail-safe learning engine 110 may construct the human detection model 230 such that the determination provided by the human detection model 230 is a probability indicator indicative of a probability that a given object within a view of a camera in the environment 200 is a human or not. As opposed to some conventional machine learning techniques and classification models that provide a binary indicator output (e.g., human or not-human), the fail-safe learning engine 110 may implement the human detection model 230 to output probabilistic indicators. To do so, the fail-safe learning engine 110 may implement any number of Bayesian update capabilities in the human detection model 230, e.g., as a Bayesian neural network. Instead of point estimate weights in a neural network, the human detection model 230 constructed by the fail-safe learning engine 110 may be configured to approximate or generate a probabilistic distribution of weights, e.g., as a Gaussian or normal distribution with multiple hyperparameters (such as mean and standard deviation), doing so based on prior information and data included in the camera data 210 captured by the cameras 201-204.
Through probabilistic weighting or Bayesian updates, the human detection model 230 may adaptively learn and optimize human detection capabilities in analysis of video streams from a multi-camera system. For a given input camera stream, the human detection model 230 may implement or formulate a local probability distribution function using human detection probabilities from multiple other camera streams, considering the presence of human feature information in these other camera streams (or lack thereof). The objective of the local probability distribution of the human detection model 230 may be configured to compute a sequential Bayesian update based on camera data captured from multiple cameras in the environment 200, and doing so may aid in increasing coverage of considered portions/video data of the environment 200 in which human presence has been determined by the human detection model 230 with high certainty (e.g., beyond a probability threshold, such as >95% probability or any other configurable threshold). The sequential nature of such a probability distribution function may be leveraged by the fail-safe learning engine 110 (via the human detection model 230) as each of the multiple cameras 201-204 may capture objects (e.g., humans) at a given location, and human detection at other preceding locations may be used as a prior in initializing or specifying the probability distribution function for a given camera stream analyzed by the human detection model 230.
In any of the ways described herein, the fail-safe learning engine 110 may construct the human detection model 230 using training data 220 generated via camera data 210 captured by a multi-camera system of an environment 200. Note that the fail-safe learning engine 110 may obtain camera data 210 that captures an environment 200 physically, virtually, or as a combination of both. For virtually-obtained camera data, the fail-safe learning engine 110 may utilize a simulation framework in which avatar movements are simulated in a virtual version of the environment 200. To utilize such virtual environments, the fail-safe learning engine 110 may obtain motion data from human users, e.g., captured via vision sensors. Such captured motion data may mimic, target, or correlate to actual motions of human operators within the environment 200. The fail-safe learning engine 110 may extract skeletal information from the motion data, e.g., using a skeleton pose estimator algorithm, such as Open Pose or any other viable algorithm. Through the skeletal information or motion data, the fail-safe learning engine 110 may configure and animate avatars within a virtual version of the environment 200. In this virtual version of the environment 200, virtual versions of the cameras 201-204 may be positioned at positions to the physical environment. As such, the virtual view captured at these camera positions may be virtual camera data depicting animated or virtual human avatar movement.
Through such virtual environments, real-time video streams of a simulated environment with simulated human activity can be captured from the different perspectives of the multiple (virtual) cameras positioned within the virtual environment. Such camera data may be used by the fail-safe learning engine 110 to construct training data to train human detection models. Thus, learning phases for construction human detection models may be supported through simulation frameworks. As simulated activity of avatars within a virtual environment can be configured to include any number of scenarios, poses, and movements, virtual or simulation-based training of human detection models may increase the learning capabilities of such machine learning models and support human presence determinations with increased accuracy and robustness. Moreover, such a simulation framework need not be programmed with explicit rules, but the human detection model 230 (e.g., implemented as a neural network) may be trained with massive amounts of simulation data that can depict nearly every possible environment scenario, even prior to active phase deployments into real-time or live fail-safe scenarios in the environment 200.
Thus, the fail-safe learning engine 110 may construct human detection models during a learning phase of the machine learning-based environment fail-safe technology described herein. In an active phase, a fail-safe trigger engine 112 may utilize constructed human detection models to monitor environments and execute fail-safe actions using the constructed human detection models. Example features of fail-safe triggers according to the present disclosure are described next with reference to
In the example shown in
The fail-safe trigger engine 112 may issue or execute fail-safe actions responsive to satisfaction of a human presence condition and a proximity condition. For instance, responsive to a determination that an object included in captured camera data of the environment 200 is a human and that the human is within a threshold distance from the fail-safe boundary 312, the fail-safe trigger engine 112 may execute a fail-safe action (e.g., machinery shut down). To provide an illustrative example, the environment 200 depicted in
To determine human presence in the environment 200, the fail-safe trigger engine 112 may process captured camera data via the human detection model 230. In doing so, the fail-safe trigger engine 112 may the access camera data 310 captured by some or all of the multiple cameras 201-204 positioned within the environment 200 during an active phase and provide the camera data 310 as an input to the human detection model 230. The camera data 310 in
In
In some implementations, the fail-safe trigger engine 112 may identify a particular camera in the multi-camera system of an environment 200 as the primary camera for a given fail-safe boundary. In the example of
Such multi-tiered consideration of a target object 314 for human presence determinations may increase the accuracy and reliability of fail-safe technology in the environment 200. With a lesser number of false positives through multi-view analysis, the machine learning-based environment fail-safe features of the present disclosure may more accurately determine human presence in environments, and thus increase the efficacy of fail-safe activations and factory efficiencies. Moreover, through probabilistic machine learning techniques (e.g., Bayesian updates), the machine learning-based environment fail-safe technology of the present disclosure may support human presence determinations through probabilistic determinations across multiple camera views, which may improve the accuracy of such determinations as compared to binary human determinations of conventional technologies based on single camera views.
As one implementation example, the fail-safe trigger engine 112 may access primary camera data captured by a primary camera of the multiple cameras in an environment 200, the primary camera data including the target object 314 and provide, as the input to the human detection model 230, the primary camera data. In response to a probability indicator, provided by the human detection model 230 for the primary camera data, indicating that the probability that the target object 314 is a human is greater than a probabilistic threshold, the fail-safe trigger engine 112 may access secondary camera data captured by a secondary camera of the multiple cameras (e.g., the camera 202, 203, or 204). The secondary camera data may include the target object 314 at a different perspective from the primary camera data. Then, the fail-safe trigger engine 112 may provide, as another input to the human detection model 230, the secondary camera data. The fail-safe trigger engine 112 may determine the target object 314 as a human responsive to the probability indicator, provided by the human detection model 230 for the secondary camera data, indicating that the probability that the target object 314 is a human is also greater than the probabilistic threshold. In other examples, the fail-safe trigger engine 112 may apply a different probabilistic threshold to the secondary camera data, whether more restrictive of more relaxed as compared to the probabilistic threshold applied to the primary camera data.
In any such way, the fail-safe trigger engine 112 may determine whether the target object 314 included in camera data 310 captured for the environment 200 is a human or not (e.g., beyond a probabilistic threshold). In parallel or in sequence, the fail-safe trigger engine 112 may determine whether the target object 314 is within a threshold distance from the fail-safe boundary 312 of the environment 200. Both a human presence condition and proximity condition may need to be satisfied in order for the fail-safe trigger engine 112 to execute a fail-safe action. Put another way, the fail-safe trigger engine 112 may execute a fail-safe action in the environment 200 responsive to both (1) a determination, provided by the human detection model 230, indicating that the target object 314 is a human and (2) a determination that a position of the target object 314 within the environment 200 is within a threshold distance from the fail-safe boundary 312 in the environment 200. As such, the fail-safe trigger engine 112 may determine that a human presence condition and that a proximity condition has been satisfied for a target object in order to trigger execution of a fail-safe action in the environment 200.
For position determinations within the environment 200, the fail-safe trigger engine 112 may employ any number of triangulation techniques. The fail-safe trigger engine 112 may be configured to determine the position of the target object 314 within the environment 200 through a triangulation process via the camera data 310 captured from the multiple cameras 201-204 in the environment 200. For example, the fail-safe trigger engine 112 may perform a triangulation process by accessing a first 2-dimensional (2D) camera frame of the camera data 310 that depicts the target object 314, wherein the first 2D camera frame is captured by a first camera of the multiple cameras, accessing a second 2D camera frame of the camera data 310 that depicts the target object 314, wherein the second 2D camera frame is captured by a second camera of the multiple cameras different from the first camera, and triangulating a 3-dimensional position of the target object 314 from the first 2D camera frame and the second 2D camera frame based on positioning of the first and second cameras within the environment 200.
Camera perspectives and locations of the cameras 201-204 may be determined by the fail-safe trigger engine 112 via YOLO3 or any other viable camera or video technologies. Camera parameters such as optical axes orientations, focal lengths, baselines, corresponding image points in the triangulated camera frames, and more may be used by the fail-safe trigger engine 112 to determine the 3D position of the target object 314 via triangulation. Through the determined 3D position of the target object 314 in the environment 200, the fail-safe trigger engine 112 may make a location determination for the target object 314 with respect to the fail-safe boundary 312. When the location of the target object 314 is within the threshold distance of the fail-safe boundary 312 (e.g., crossing the fail-safe boundary 312), the fail-safe trigger engine 112 may determine that the proximity condition for fail-safe activation has been satisfied.
Responsive to a determination that both the human presence condition (e.g., via the human detection model 230 through primary and secondary camera data) and the proximity condition (e.g., via triangulation of multiple camera frames) have been satisfied for the target object 314, the fail-safe trigger engine 112 may execute a fail-safe action. Any suitable fail-safe action is contemplated herein, and the fail-safe trigger engine 112 may execute a fail-safe action by issuing commands to machinery or other physical components in the environment 200. In the example of
As the fail-safe trigger engine 112 may apply both a human presence condition and a proximity condition, the machine learning environment fail-safe technology of the present disclosure may improve environment efficiency by reducing false-positives as compared to indiscriminate conventional safety technologies (like light curtains). If either of the human presence condition or proximity condition are not satisfied, the fail-safe trigger engine 112 may determine not to execute the fail-safe action. Thus, even if a target object is proximate to a given environment location, the machine learning environment fail-safe technology of the present disclosure need not execute fail-safe actions unless the target object is also determined to be human. By doing so, AGVs or other non-human components of the environment 200 need not trigger costly fail-safe actions that can greatly reduce productivity and output yields of industrial environments. Even if human presence is detected within the environment 200, fail-safe actions may be performed only when such human detection is proximate to fail-safe boundaries, which may also reduce unwarranted machinery shut-downs or other fail-safe triggers. Through continuous or real-time monitoring of environments during such an active phase, the machine learning environment fail-safe technology of the present disclosure may provide improved fail-safe implementations for environments of any type.
While many machine learning-based environment fail-safe features have been described herein through illustrative examples presented through various figures, the fail-safe learning engine 110 and fail-safe trigger engine 112 may implement any combination of the machine learning-based environment fail-safe features described herein.
In implementing the logic 400, the fail-safe learning engine 110 may access camera data captured by multiple cameras positioned within an environment (402), for example doing so during a learning phase. The fail-safe learning engine 110 may further generate training data based on the camera data captured by the multiple cameras (404) and construct a human detection model using the training data (406). The fail-safe learning engine 110 may do so in any of the various ways described herein. As such, the fail-safe learning engine 110 may train human detection models configured to provide a determination of whether a given object within a view of a camera in the environment is a human or not.
In implementing the logic 500, the fail-safe trigger engine 112 may access camera data captured by the multiple cameras positioned within the environment during an active phase (502), and the camera data captured during the active phase may include a target object. The fail-safe trigger engine 112 may further provide the camera data that includes the target object as an input to a human detection model (504) as well as execute a fail-safe action in the environment responsive to a determination, provided by the human detection model, indicating that the target object is a human (506). In such a way, the fail-safe trigger engine 112 may execute a fail-safe action based on a human presence condition for a target object in the environment. Note that the fail-safe trigger engine 112 engine may also apply a proximity condition for the target object as well, and execute the fail-safe action responsive to a determination that both the human presence and proximity conditions are satisfied.
The logic shown in
The computing system 600 may execute instructions stored on the machine-readable medium 620 through the processor 610. Executing the instructions (e.g., the fail-safe learning instructions 622 and fail-safe trigger instructions 624) may cause the computing system 600 to perform any of the machine learning-based environment fail-safe features described herein, including according to any of the features with respect to the fail-safe learning engine 110, the fail-safe trigger engine 112, or combinations of both.
For example, execution of the fail-safe learning instructions 622 by the processor 610 may cause the computing system 600 to access camera data captured by multiple cameras positioned within an environment during a learning phase, generate training data based on the camera data captured by the multiple cameras, and construct a human detection model using the training data. The human detection model may be configured to provide a determination indicative of whether a given object within a view of a camera in the environment is a human or not. Execution of the fail-safe trigger instructions 624 by the processor 610 may cause the computing system 600 to access camera data captured by the multiple cameras positioned within the environment during an active phase, and the camera data captured during the active phase may include a target object. Execution of the fail-safe trigger instructions 624 may further cause the computing system 600 provide, as an input to the human detection model, the camera data that includes the target object and execute a fail-safe action in the environment responsive to the determination, provided by the human detection model, indicating that the target object is a human.
Any additional or alternative features as described herein may be implemented via the fail-safe learning instructions 622, fail-safe trigger instructions 624, or a combination of both.
The systems, methods, devices, and logic described above, including the fail-safe learning engine 110 and the fail-safe trigger engine 112, may be implemented in many different ways in many different combinations of hardware, logic, circuitry, and executable instructions stored on a machine-readable medium. For example, the fail-safe learning engine 110, the fail-safe trigger engine 112, or combinations thereof, may include circuitry in a controller, a microprocessor, or an application specific integrated circuit (ASIC), or may be implemented with discrete logic or components, or a combination of other types of analog or digital circuitry, combined on a single integrated circuit or distributed among multiple integrated circuits. A product, such as a computer program product, may include a storage medium and machine-readable instructions stored on the medium, which when executed in an endpoint, computer system, or other device, cause the device to perform operations according to any of the description above, including according to any features of the fail-safe learning engine 110, the fail-safe trigger engine 112, or combinations thereof.
The processing capability of the systems, devices, and engines described herein, including the fail-safe learning engine 110 and the fail-safe trigger engine 112, may be distributed among multiple system components, such as among multiple processors and memories, optionally including multiple distributed processing systems or cloud/network elements. Parameters, databases, and other data structures may be separately stored and managed, may be incorporated into a single memory or database, may be logically and physically organized in many different ways, and may be implemented in many ways, including data structures such as linked lists, hash tables, or implicit storage mechanisms. Programs may be parts (e.g., subroutines) of a single program, separate programs, distributed across several memories and processors, or implemented in many different ways, such as in a library (e.g., a shared library).
While various examples have been described above, many more implementations are possible.
Number | Name | Date | Kind |
---|---|---|---|
11295139 | Khadloya | Apr 2022 | B2 |
11321873 | Bauer | May 2022 | B1 |
20150269427 | Kim et al. | Sep 2015 | A1 |
20160070991 | Galera | Mar 2016 | A1 |
20190007659 | Neubauer | Jan 2019 | A1 |
20200349249 | Weston et al. | Nov 2020 | A1 |
Number | Date | Country |
---|---|---|
2020088739 | May 2020 | WO |
2021110226 | Jun 2021 | WO |
Number | Date | Country | |
---|---|---|---|
20230069482 A1 | Mar 2023 | US |