The subject matter disclosed herein relates generally to optical area monitoring, and, more particularly, to an imaging sensor capable of performing selective time-of-flight (TOF) analysis on specified portions of a pixel array.
The following presents a simplified summary in order to provide a basic understanding of some aspects described herein. This summary is not an extensive overview nor is it intended to identify key/critical elements or to delineate the scope of the various aspects described herein. Its sole purpose is to present some concepts in a simplified form as a prelude to the more detailed description that is presented later.
In one or more embodiments, an imaging sensor device is provided comprising a pixel array component configured to, for a pixel array of an image captured by the imaging sensor device, group pixels of the pixel array to yield a first subset of the pixels on which two-dimensional (2D) analysis is to be performed and a second subset of the pixels on which three-dimensional (3D) analysis is to be performed; a 2D image analysis component configured to perform 2D analysis on the first subset of the pixels; and a distance determination component configured to perform 3D analysis on the second subset of the pixels.
Also, one or more embodiments provide a method for monitoring image data, comprising collecting image data by an imaging sensor device comprising at least one processor; generating a pixel array based on the image data; grouping pixels of the pixel array into at least one first pixel group and at least one second pixel group; performing two-dimensional (2D) imaging analysis on the at least one first pixel group; and performing time-of-flight (TOF) analysis on the at least one second pixel group.
Also, according to one or more embodiments, a non-transitory computer-readable medium is provided having stored thereon instructions that, in response to execution, cause an imaging sensor device to perform operations, the operations, comprising receiving image data representing an image of a viewing space; determining values of respective pixels of a pixel array based on the image data; identifying a first subset of the pixels on which two-dimensional (2D) analysis is to be performed; identifying a second subset of the pixels on which time-of-flight (TOF) analysis is to be performed; performing the 2D analysis on the first subset of the pixels; and performing the TOF analysis on the second subset of the pixels.
To the accomplishment of the foregoing and related ends, certain illustrative aspects are described herein in connection with the following description and the annexed drawings. These aspects are indicative of various ways which can be practiced, all of which are intended to be covered herein. Other advantages and novel features may become apparent from the following detailed description when considered in conjunction with the drawings.
The subject disclosure is now described with reference to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding thereof. It may be evident, however, that the subject disclosure can be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to facilitate a description thereof.
As used in this application, the terms “component,” “system,” “platform,” “layer,” “controller,” “terminal,” “station,” “node,” “interface” are intended to refer to a computer-related entity or an entity related to, or that is part of, an operational apparatus with one or more specific functionalities, wherein such entities can be either hardware, a combination of hardware and software, software, or software in execution. For example, a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical or magnetic storage medium) including affixed (e.g., screwed or bolted) or removable affixed solid-state storage drives; an object; an executable; a thread of execution; a computer-executable program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Also, components as described herein can execute from various computer readable storage media having various data structures stored thereon. The components may communicate via local and/or remote processes such as in accordance with a signal having one or more data packets (e.g., data from one component interacting with another component in a local system, distributed system, and/or across a network such as the Internet with other systems via the signal). As another example, a component can be an apparatus with specific functionality provided by mechanical parts operated by electric or electronic circuitry which is operated by a software or a firmware application executed by a processor, wherein the processor can be internal or external to the apparatus and executes at least a part of the software or firmware application. As yet another example, a component can be an apparatus that provides specific functionality through electronic components without mechanical parts, the electronic components can include a processor therein to execute software or firmware that provides at least in part the functionality of the electronic components. As further yet another example, interface(s) can include input/output (I/O) components as well as associated processor, application, or Application Programming Interface (API) components. While the foregoing examples are directed to aspects of a component, the exemplified aspects or features also apply to a system, platform, interface, layer, controller, terminal, and the like.
As used herein, the terms “to infer” and “inference” refer generally to the process of reasoning about or inferring states of the system, environment, and/or user from a set of observations as captured via events and/or data. Inference can be employed to identify a specific context or action, or can generate a probability distribution over states, for example. The inference can be probabilistic—that is, the computation of a probability distribution over states of interest based on a consideration of data and events. Inference can also refer to techniques employed for composing higher-level events from a set of events and/or data. Such inference results in the construction of new events or actions from a set of observed events and/or stored event data, whether or not the events are correlated in close temporal proximity, and whether the events and data come from one or several event and data sources.
In addition, the term “or” is intended to mean an inclusive “or” rather than an exclusive “or.” That is, unless specified otherwise, or clear from the context, the phrase “X employs A or B” is intended to mean any of the natural inclusive permutations. That is, the phrase “X employs A or B” is satisfied by any of the following instances: X employs A; X employs B; or X employs both A and B. In addition, the articles “a” and “an” as used in this application and the appended claims should generally be construed to mean “one or more” unless specified otherwise or clear from the context to be directed to a singular form.
Furthermore, the term “set” as employed herein excludes the empty set; e.g., the set with no elements therein. Thus, a “set” in the subject disclosure includes one or more elements or entities. As an illustration, a set of controllers includes one or more controllers; a set of data resources includes one or more data resources; etc. Likewise, the term “group” as utilized herein refers to a collection of one or more entities; e.g., a group of nodes refers to one or more nodes.
Various aspects or features will be presented in terms of systems that may include a number of devices, components, modules, and the like. It is to be understood and appreciated that the various systems may include additional devices, components, modules, etc. and/or may not include all of the devices, components, modules etc. discussed in connection with the figures. A combination of these approaches also can be used.
Two-dimensional (2D) imaging sensors are generally used to detect and identify shape and/or surface characteristics of objects within a viewing field of the sensor.
Three-dimensional (3D) image sensors, also known as time-of-flight (TOF) sensors, are designed to generate distance information as well as two-dimensional shape information for objects and surfaces within the sensor's viewing field. Some types of TOF sensors determine a distance of an object using phase shift monitoring techniques, whereby a beam of light is emitted to the viewing field, and the measured phase shift of light reflected from the object relative to the emitted light is translated to a distance value. Other types of TOF sensors that employ pulsed light illumination measure the elapsed time between emission of a light pulse to the viewing field and receipt of a reflected light pulse at the sensor's photo-receiver. Since this time-of-flight information is a function of the distance of the object or surface from the sensor, the sensor is able to leverage the TOF information to determine the distance of the object or surface point from the sensor.
Three-dimensional image analysis—which entails measurement of time-of-flight information and subsequent calculation of distance information—is generally more processing intensive than 2D image analysis. The additional processing time and power required for 3D analysis may render 3D image sensors unsuitable for certain types of applications that require fast, reliable response times. However, there are certain types of applications that could benefit from 3D image analysis, but which require fast and reliable decision-making and response times. For example, industrial safety monitoring applications must be able to reliably detect the presence of human beings within a potentially hazardous area, and to respond with appropriate safety control outputs (e.g., commands to stop or slow a running machine, to remove power from hazardous machinery, etc.) with minimal delay to prevent injury.
To address these and other issues, one or more embodiments of the present disclosure provide an imaging sensor capable of performing 3D image analysis on selected subsets or portions of the sensor's pixel array. In one or more embodiments, the imaging sensor allows one or more specified portions of the pixel array to be selected for 3D (time-of-flight) analysis in order to obtain distance information for pixels in that portion of the pixel array, while the remaining pixel array areas will be processed using 2D image analysis. For example, after the imaging sensor is trained on the area of interest, a user may select a horizontal stripe of pixels across a middle section (or an upper or lower edge) of the pixel array for 3D analysis, so that distance information as well as object identification information can be obtained and managed for the area corresponding to the selected stripe of pixels. The imaging sensor will apply 2D analysis (e.g., grayscale or RGB analysis) to the remaining, non-selected areas of the pixel array in order to detect, identify, classify, and/or correlate objects within the viewing area. Since 2D imaging processes more quickly than 3D processing, processing load is reduced and sensor response time is improved by limiting 3D analysis to only those areas of the scene for which distance information is required. The imaging sensor can also be configured to correlate results of the 2D and 3D analysis so that the identity, speed, distance, and trajectory of an object within the viewing space can be obtained with a high level of safety integrity.
In some embodiments, the imaging sensor may be configured to dynamically select or modify the portion of the pixel array to which 3D analysis is to be applied; e.g., based on detection of an object within the viewing area that satisfies one or more criteria. For example, during normal operation, the imaging sensor may be configured to perform continuous 2D analysis on the entire pixel array until an object or collection of objects having a certain defined classification (e.g., a person, a trolley, etc.) is detected. When such an object is detected—e.g., when a person enters the viewing area of the sensor—the sensor may define a portion of the pixel array corresponding to an area around the object for 3D analysis, so that TOF (distance) information for the object can be tracked. The imaging sensor may dynamically change this defined pixel area to move with object so that distance and speed information can be monitored for the object as long as the object remains within the viewing area.
In one or more embodiments, the imaging sensor may also be configured to, for a given image, identify non-contiguous groups of pixels that belong to a single object of a defined classification. This can allow the imaging sensor to identify the presence of a person within the viewing area even if the person is partially obscured within the image. For example, the imaging sensor may be trained to identify the presence of two separate visible objects corresponding to human legs, and to correlate these two objects within the image as belonging to a human being who is within the viewing area but partially obscured. The sensor can track these correlated objects as necessary (e.g., by performing 3D analysis on the pixel areas corresponding to the two objects) so that appropriate safety output or feedback information can be generated based on the location and speed of the person within the area.
Imaging sensor device 302 can include an illumination component 304, a pixel array component 306, a distance determination component 310, an image analysis component 312, a hazard analysis and decision component 314, a safety component 316, one or more processors 318, and memory 320. In various embodiments, one or more of the illumination component 304, pixel array component 306, distance determination component 310, image analysis component 312, hazard analysis and decision component 314, safety component 316, the one or more processors 318, and memory 320 can be electrically and/or communicatively coupled to one another to perform one or more of the functions of the imaging sensor device 302. In some embodiments, components 304, 306, 310, 312, 314, and 316 can comprise software instructions stored on memory 320 and executed by processor(s) 318. Imaging sensor device 302 may also interact with other hardware and/or software components not depicted in
Illumination component 304 can be configured to control emission of light by the sensor device. Imaging sensor device 302 may comprise a laser or light emitting diode (LED) light source under the control of illumination component 304. In some embodiments, illumination component 304 may generate pulsed light emissions directed to the viewing field, so that time-of-flight information for the reflected light pulses can be generated by the sensor device. The pixel array component 306 can be configured to process and analyze a pixel array corresponding to an image of the viewing field monitored by the sensor device. For example, the pixel array component 306 may control which subset of pixels will be processed using 3D analysis. The subset of pixels to which 3D analysis is to be applied may be fixed (e.g., preconfigured via user input); alternatively, the pixel array component 306 may select the subset of pixels for 3D analysis dynamically according to one or more defined criteria (e.g., human or facial recognition, object classification, etc.).
Distance determination component 310 can be configured to derive distance information by performing 3D analysis on all or selected portions of the pixel array data. Any suitable analysis technique can be implemented by distance determination component, including but not limited to phase shift monitoring or pulsed time of flight analysis.
The image analysis component 312 can be configured to perform 2D analysis on portions of the pixel array that have not been selected for 3D analysis. The hazard analysis and decision component 314 can be configured to analyze and control one or more sensor outputs based on results generated by the pixel array component 306, distance determination component 310, image analysis component 312, and the safety component 316. This can include, for example, sending a control signal to a control or supervisory device (e.g., an industrial controller, an on-board computer mounted in a mobile vehicle, etc.) to perform a control action, initiating a safety action (e.g., removing power from a hazardous machine, switching an industrial system to a safe operating mode, etc.), sending a feedback message to one or more plant personnel via a human-machine interface (HMI) or a personal mobile device, sending data over a safety network, or other such output. Safety component 316 can be configured to implement one or more safety and/or redundancy features within the imaging sensor device 302 to render the sensor device suitable for use in safety applications (e.g., industrial safety applications designed to monitor a hazardous area and reliably perform automated control actions to mitigate risk of injury in response to detection of a potentially unsafe human presence or action, automobile safety applications in which one or more imaging sensors mounted on a vehicle control breaking of the vehicle based on detected risk conditions, etc.). By implementing such safety and redundancy functions, the imaging sensor device 302 can monitor a two-dimensional plane and a three-dimensional volume and respond to detected conditions with a high safety integrity level (e.g., SIL or ASIL), making the sensor device suitable for use in some safety application as an alternative to light curtains or other such sensors.
The one or more processors 318 can perform one or more of the functions described herein with reference to the systems and/or methods disclosed. Memory 320 can be a computer-readable storage medium storing computer-executable instructions and/or information for performing the functions described herein with reference to the systems and/or methods disclosed.
Upon receipt of reflected light at the photo-receivers of the imaging sensor device 302, pixel data is generated based on the light intensity measured at each photo-receiver, and pixel array block 406 performs processing on the resulting pixel array data comprising the image. This can include, for example, identifying a first subset of pixels in the array on which 3D processing is to be performed, and designating a remaining second subset of pixels for 2D imaging analysis. Subsequent processing of each pixel depends upon the type of analysis (2D or 3D) to be performed on that pixel.
For a pixel selected for 3D (distance or depth) analysis, 3D distance analysis 410 determines a distance of an object or surface in the viewing field corresponding to the pixel, e.g., using phase shift time-of-flight analysis on a light beam reflected by the object, or using pulsed time-of-flight analysis on a light pulse reflected from the object. Performing distance calculations for each pixel of the 3D analysis portion(s) of the pixel array yields a 3D point cloud for the selected areas of the viewing field.
2D imaging block 412 performs 2D image analysis on the portion(s) of the pixel array for which 3D analysis is not performed. 2D image analysis can comprise RGB or grayscale analysis of the image portions corresponding to the non-3D pixels, including but not limited to edge detection, contour analysis, image sharpening, contrast adjustment, difference and additive imaging, etc. The imaging sensor device 302 can employ 2D image analysis to identify objects within the viewing area and determine whether the identified objects correspond to one or more defined object classifications (e.g., a human being, a forklift or trolley, a machined part on a conveyor, a pallet containing packaged products, etc.). In some embodiments, the imaging sensor device 302 may also be configured to perform facial recognition using 2D image analysis, which is useful for applications in which a control decision or operator feedback output is dependent upon an identity of the person detected within the viewing field.
Imaging sensor device 302 can correlate results of the 2D and 3D analysis to yield object data at object data block 414. Object data can include, for example, a location, speed, an acceleration and/or trajectory of an identified object within the three-dimensional viewing space. Depending on the type of application, a hazard analysis and decision block 418 can generate suitable outputs or operator feedback based on the correlated object data. In some embodiments, imaging sensor device 302 can interface with an industrial control or safety system, a vehicle safety system, or other such system to implement control features based on object detection. Accordingly, outputs generated by the sensor device can include control instructions to an associated control or safety system (e.g., a programmable logic controller or other safety automation controller, an engine control unit of a mobile vehicle, etc.) to alter operation of a machine or system based on the object data, safety outputs to an associated safety system (e.g., a safety relay) that place an industrial system in a safe state based on the presence and movements of a human being within the viewing field, or other such outputs. Imaging sensor device can also include a safety block 420 that monitors and diagnoses internal components and faults of the sensor device, including but not limited to power monitoring, vibration monitoring, and temperature monitoring. Accordingly, control outputs and messages generated by the hazard analysis and decision block 418 can additionally be a function of the diagnosis results generated by the safety block 420.
In some embodiments, illumination component 304 may uniformly illuminate the viewing field using a laser, LED, or remote phosphor light source. Alternatively, some embodiments of illumination component 304 may employ a patterned illumination technique whereby, rather than uniformly illuminating the viewing area, the illumination component 304 concentrates light in spots spaced with a certain distance over the viewing area. This technique can improve reliability of detection of small objects and of objects with low reflectivity. In such embodiments, the size of each spot of light can be defined based on the effective size of the pixels and the optical characteristics of the receiving element 508 of the sensor device. The receiving element 508 is sized relative to the spot size such that the image of a spot on the receiving element 508 covers at least the light sensitive area of one pixel. In a variation of this technique, the illumination component 304 or the lens design can also be configured to modulate the illumination intensity of the emitted spots, such that high brightness spots and low brightness spots are interlaced across the viewing area simultaneously. This technique can facilitate reliable detection of bright and dark objects within a single image frame. In an example implementation, the focused spots of illumination can be achieved by placing a squared lenslet comprising square or rectangular apertures in front of the LED, laser, or remote phosphor light source. The locations of the apertures on the lenslet define the spot pattern. To ensure accurate detection with small object sizes, the spot pattern can be defined such that at least two horizontal spots and two vertical spots cover the minimum size of object at the given distance from the lens element 508.
Lens element 508 receives light reflected from the viewing field, and pixel array component 306 performs processing on the pixels of the resulting image data. As noted above, imaging sensor device 302 allows portions of the resulting pixel array 502 to be selected for 3D (distance or depth) processing and analysis, while the remaining portions of the pixel array are processed using 2D (imaging) analysis. In the example depicted in
Although
In an example scenario wherein the imaging sensor device 302 is used to monitor an area of an industrial facility, it may be known that certain areas of the viewing field correspond to potentially hazardous zones, while other areas of the viewing field correspond to safe zones that pose little or no risk to operators. Accordingly, a system designer may define a section of the pixel array that encompasses the known hazardous areas for 3D analysis. These pixel area definitions can be stored in configuration profile 510 and leveraged by pixel array component 306 to group pixels of the pixel array accordingly for group analysis. Portions of the pixel array 502 that are not selected for 3D analysis will be processed using 2D analysis, which is less computationally intensive than 3D analysis. By limiting 3D analysis to crucial subsets of the pixel array 502 and performing 2D analysis on the remaining portions of the array, overall processing time can be reduced relative to performing 3D analysis on the entire image.
In another example, a ceiling-mounted imaging sensor may be oriented to face downward with the line of site substantially perpendicular to the floor, in order to monitor traffic through an entrance gate to a room or zone of interest. In this example, it may only be necessary to perform 3D analysis on a middle band of the pixel array corresponding to the pathway to the entrance gate. Accordingly, a system designer can define this area of the pixel array 502 and save these settings in the configuration profile 510.
Imaging sensor device 302 can support any suitable technique for allowing a user to define 3D zones on the pixel array 502. For example, an interface application executable on a personal computing device (e.g., tablet computer, laptop computer, desktop computer, mobile phone, etc.) may be used to facilitate data exchange between the computing device and the imaging sensor device 302. The interface application can generate and render configuration display screens capable of receiving input data from a user that set configuration parameters and definitions for the sensor. One or more configuration display screens may allow a user to define the areas of 3D analysis by entering x-y coordinates that define the sections of the pixel array 502 for which 3D analysis is to be performed. Alternatively, the configuration display screens may allow the user to draw (using a mouse or stylus) boundary lines (either linear or curved) that define the areas of 3D analysis. If the imaging sensor device 302 has been trained on the viewing area, the configuration screens can display a live image or a screenshot of the viewing area and allow the user to draw the 3D analysis boundary lines as an overlay on the image or screenshot.
Upon receipt of live pixel array data, and after the pixel array component 306 has grouped the pixels into respective 3D and 2D zones, image analysis component 312 performs 2D imaging analysis on those portions of pixel array 502 that were not designated by pixel array component 306 for 3D analysis. As noted above, imaging sensor device 302 can employ 2D imaging analysis to identify and classify objects within the image frame. Classification of objects can be based on pre-defined classes of objects that the imaging sensor device 302 has been trained to identify, including but not limited to human beings, particular types of vehicles (e.g., forklifts, trolleys, etc.), a manufactured part, a pallet, or other such object classifications.
In some embodiments, one or both of the pixel array component 306 or the image analysis component 312 can be configured to recognize instances in which two or more non-contiguous groups of pixels of the pixel array 502 belong to a common object or person that may be partially obscured within the image. In an example scenario, an operator may enter the image frame, but may be partially obscured by another object within the frame such that only portions of the operator's legs or feet are directly visible to the sensor device. The pixels of the pixel array 502 corresponding to the operator's left and right legs or feet may comprise separate, non-contiguous pixel groups, since the operator is obscured above the knees. The image analysis component 312 may be trained recognize lower-body human features, and therefore recognizes that two separate detected objects identified as human legs which are oriented a certain way with respect to one another within the frame belong to a common person, and are indicative of a human presence within the image. Accordingly, image analysis component 312 can identify and classify the two objects as human legs, and instruct the pixel array component 306 to associate the two detected objects for collective analysis under the assumption that the two objects correspond to a human being.
Concurrently or in coordination with the 2D image analysis, distance determination component 310 can perform 3D analysis on the pixels comprising the defined 3D portion of the pixel array 502 to determine a distance value associated with each of those pixels. The distance value represents the distance of the object or surface corresponding to the pixel from the sensor device. The analysis technique employed by the distance determination component 310 depends on the type of illumination and 3D analysis supported by the device. For example, for imaging sensor devices that employ phase shift analysis, the distance determination component 310 can monitor the phase shift of a reflected light beam received at a photo-receiver and compare this phase shift with the phase of the light beam emitted by the illumination component 304. The distance is then determined as a function of the relative phase shift between the emitted and received light. Other types of imaging sensor that employ pulsed light illumination measure the time duration between emission of a light pulse by the illumination component and receipt of a reflected light pulse at the photo-receiver for each pixel, and determining the distance as a function of this duration. In such embodiments, the distance determination component 310 may monitor the electrical output of the photo-receiver (which is a function of the intensity of light incident on the surface of the photo-receiver) and generate a waveform representing the reflected light pulse. The front edge of the returned light pulse can then be identified based on analysis of the waveform data, which represents the time at which the light pulse was received at the lens element 508. The distance determination component 310 can then compare this time with the time at which the emitted light pulse was sent by the illumination component 304. The difference between the two times represents the time-of-flight for the pulse, from which the distance information for the pixel corresponding to the photo-receiver can be derived. By performing waveform reconstruction and distance determination for each pixel in the 3D analysis portions of the pixel array 502, a 3D point cloud can be derived for the selected areas of the pixel array 502.
Some embodiments of imaging sensor device 302 may support dynamic definition of 3D analysis zones based on object detection and classification by the 2D image analysis component. For example, during normal operation the imaging sensor device 302 may perform 2D analysis on the entire pixel array 502 until an object of a specified classification is detected within the viewing field. In response to detection of such an object (e.g., a person, a vehicle, etc.) within the viewing field, the image analysis component 312 may provide information to pixel array component 306 identifying the object and its location within the pixel array 502. Pixel array component 306 can then define one or more pixel groups corresponding to the identified object, and instruct distance determination component 310 to begin performing 3D analysis on those groups of pixels, so that both the location and distance of the object can be tracked. In some embodiments, the pixel array component 306 and image analysis component 312 can operate in conjunction to move the defined 3D analysis portion of the pixel array 502 to track with the detected object as long as the object remains within the frame. Thus, embodiments of the imaging sensor device 302 can use 2D imaging analysis to recognize objects of interest within the frame, and instruct pixel array component 306 where 3D analysis should be performed. In this way, the imaging sensor device 302 can continuously collect TOF information for objects of interest while substantially minimizing the areas of the pixel array 502 on which 3D analysis is performed, optimizing processing and response times.
The imaging sensor device 302 can correlate results of the 2D and 3D analyses and determine suitable control or messaging outputs based on object classification, location, velocity, and/or trajectory.
In a non-limiting example of 2D and 3D result correlation, image analysis component 312 may identify objects within the image frame that correspond to a class of objects for which 3D analysis is required. In response, the imaging sensor device can apply 3D analysis to the region of the pixel array 502 corresponding to the detected object to obtain distance information for the object over time, while 2D analysis can track the x-y location of the object within the frame. By correlating these results, the object's instantaneous position, velocity, acceleration, and trajectory within the three-dimensional viewing space can be determined. For embodiments in which the imaging sensor device supports prediction of future object position, the sensor may also determine whether the object is predicted to be within a particular subspace of the three-dimensional viewing field based on the current location, speed, and trajectory, and generate a control or feedback output based on risk analysis using this prediction.
In another example, the imaging sensor device may coordinate object classification and edge detection (2D analysis results) with depth analysis (a 3D analysis result) in order to obtain depth information for all pixels enclosed within the edges of an identified object. For example, when an object enters the viewing field, the imaging sensor may leverage 2D imaging analysis to identify and classify the object as corresponding to a defined object class requiring 3D analysis. The 2D analysis may further include edge detection, which identifies the visible edges or boundaries of the object. The imaging sensor can then perform selective 3D analysis on all pixels within the object boundaries identified via 2D analysis.
Returning now to
The object detection and tracking features described above, together with the reduced processing load and commensurate improvement in decision-making and response time that results from minimizing the amount of 3D processing required, render the imaging sensor devices described herein suitable for safety applications, which require a high degree of safety integrity and fast response times in order to mitigate risk of injuries. To ensure safety integrity of the imaging sensor device, one or more embodiments may include a safety component 316 that implements one or more features for ensuring reliability and accuracy of the sensor in a range of operating conditions, improving the safety integrity of the sensor device. In general, safety component 316 is configured to perform fault monitoring and diagnostic analysis on a range of conditions that may impact the integrity of the sensor operation, and trigger actions designed to mitigate hazards that may arise when a monitored deviates from a safe state (e.g., instruct the hazard analysis and decision component 314 to switch a machine to a safe state, output a warning message, etc.)
Temperatures within the sensor device may have an impact on the distance values generated by the sensor components. Accordingly, safety component 316 can include a temperature control component 802 configured to adjust the distance values generated by distance determination component 310 to compensate for measured deviations in temperature. Some embodiments of temperature control component 802 can also include mechanisms to regulate the sensor's internal temperature to maintain a specified optimal operating temperature, as well as redundant fault detection mechanisms to ensure that the temperature compensation meets or exceeds a defined minimum safety integrity level (e.g. SIL 2, SIL 3, ASIL C, ASIL D, etc.).
Safety component 316 can also include a power monitoring component 804 configured to monitor the internal rails that provide power to crucial components, and perform compensation actions in response to detected voltage deviations from rated tolerances. In this regard, some embodiments of imaging sensor device 302 may include a redundant power supply to ensure that a failure of the main supply does not prevent continued operation of the sensor device. Vibration compensation component 806 can be configured to perform appropriate compensation actions in response to monitored vibrations induced on the sensor.
Fault detection component 808 can be configured to monitor and diagnose internal sensor faults, and to generate information or instructions to the hazard analysis and decision component 314 based on the fault information. Also, to further comply with safety integrity level requirements, processor(s) 318 can be specified as a SIL- or ASIL-rated processor to ensure that the imaging sensor conforms to required safety standards.
Embodiments of the imaging sensor device 302 that include sufficient safety components to meet or exceed a defined SIL or ASIL rating can be suitably implemented as components of a safety system (e.g., an industrial safety system, an on-board automotive safety system, etc.). For example, embodiments of the imaging sensor device described herein can be used in place of a light curtain to perform safety detection in industrial environments. Use of an imaging sensor device to perform safety monitoring can offer advantages over traditional light curtains or other presence sensing devices by supporting object identification and classification, human recognition, and other features not supported by conventional presence sensors.
Imaging sensor device 302 is mounted such that the light emitter and receiving lens face directly downward toward the conveyor. The light beam 908 is aimed toward the area directly in front of gateway 906. Using the technique described above, imaging sensor device 302 can identify and classify objects passing through light beam 908 as the objects approach gateway 906. Using this configuration, imaging sensor device 302 can simulate light curtain muting features, such that product 914 is permitted to pass through gateway 906 without halting operation of robot 902, but detection of a human operator approaching gateway 906 will cause the robot 902 to switch to a safe mode (e.g., halted or slowed).
To this end, the imaging sensor device 302 can identify and classify objects passing through light beam 908 using one or more techniques described above. For example, imaging sensor device 302 can be trained to identify product 914 as a first object class (“product”), and to identify human operator 910 as a second object class (“human”). When product 914 passes through light beam 908, imaging sensor device 302 can perform 2D analysis on the resulting image to identify the object, determine that the object belongs to the product classification, and allow the product 914 to proceed through gateway 906 to the hazardous area without disabling the robot 902 or conveyor 912. If an operator 910 standing on the conveyor 912 passes through light beam 908, the imaging sensor device 302 identifies the operator as belonging to the human classification and generates a control output placing the system in a safe mode. This may comprise, for example, sending a control output to industrial controller 904 instructing the controller to disable the robot 902 and to halt the conveyor 912.
To improve reliability of human detection while minimizing processing load and maintaining acceptable response times, imaging sensor device 302 can be configured to perform selective 3D analysis on a narrow strip through the middle of the image frame corresponding to the conveyor path, while performing faster 2D analysis on the remaining portions of the image frame. Performing depth (distance) analysis on the areas corresponding to the conveyor path can assist the imaging sensor device 302 in accurately identifying the presence of a human on the conveyor, since object height can be used to distinguish between a valid product 914 and a human being or an improper object on the conveyor 912.
In an alternative configuration, the imaging sensor device 302 may be configured to perform 2D analysis over the entire pixel array of the image during normal operation until an object that does not conform to the “product” classification enters the viewing field. In response to detection of a non-product object entering the viewing field, the pixel array component 306 of the sensor can designate an area of the pixel array corresponding to the object for 3D analysis in order to obtain height information and profile over time for the new object, which can be used by the sensor to assist in determining whether the new object corresponds to the “human being” classification. The pixel array component 306 can dynamically move the portion of the image designated for 3D analysis to track with the object as it moves through the viewing field (e.g., based on object detection information provided by the image analysis component 312).
In another example of dynamic hazard analysis, the imaging sensor device 302 may be configured to adjust the size of the 3D analysis pixel area (e.g., the hazard zone) based on a current hazard level determined via 2D image analysis. For example, an area of the pixel array designated for 3D analysis may correspond to an area surrounding a hazardous area (e.g., a machine or traffic area). Based on 2D analysis of the pixel array, the imaging sensor device 302 may determine a speed of objects (e.g., machine components, mobile vehicles, objects on a conveyor, etc.) within the hazardous area. If the speed of objects is determined to exceed a threshold, implying a higher risk of injury, the portion of the pixel array for which 3D analysis is performed may be increased to a larger area surrounding the hazardous zone. When slower objects are detected within the hazardous zone (e.g., when the determined speed falls below the threshold), the risk level is assumed to be lessened, and the 3D analysis portion of the pixel array is made smaller to allow operators freedom to approach the hazardous area more closely.
The configuration depicted in
The imaging sensor device 302 can also be used in other types of monitoring applications. For example, imaging sensor device 302 can be used to monitor access to particular areas of an industrial facility. In an example access monitoring application, an imaging sensor device 302 can be mounted on the ceiling above an entryway to an area to be monitored. Similar to the configuration illustrated in
At 1108, three-dimensional (3D) analysis is performed on a second subset of the pixel array to determine distance information for spaces within the viewing area corresponding to the second subset of the pixel array. In some embodiments, the second subset of the pixel array on which 3D analysis is to be performed can be defined by a system designer prior to operation and recorded in a configuration profile, which can be read by a pixel array component of the imaging sensor device in order to group the first and second subsets of the pixel array for respective 2D and 3D analysis. Alternatively, the imaging sensor device can dynamically select the second subset of the pixel array for 3D analysis based on results of the 2D analysis performed at step 1106. For example, if the 2D analysis determines that an object of a certain classification has entered the viewing field, the imaging sensor device may define an area of the pixel array corresponding to the newly identified object and begin performing 3D analysis on the object in order to obtain spatial information for the object.
At 1110, at least one of a control output or feedback information is generated by the imaging sensor device based on correlation of information generated by the 2D analysis and the 3D analysis. For example, the imaging sensor device may correlate the 2D and 3D analysis results to yield an identity position, speed, acceleration, orientation, and/or trajectory for the object and generate a control or message output based on one or more of these measured factors. The control output may comprise, for example, an instruction to an industrial controller to transition a hazardous industrial machine to a safe mode, to lock an entry door to a hazardous area to prevent access, or other such control output.
At 1210, a determination is made regarding whether the classification of the object determined at step 1208 requires 3D (distance) analysis. For example, the sensor device may be trained to identify when a human has entered the viewing area. Accordingly, the sensor can determine that an object having a “human” classification has entered the viewing area based on the 2D analysis and object classification performed at steps 1206 and 1208.
If the object classification does not require 3D analysis, the methodology returns to step 1202 and continues monitoring received image data. Alternatively, if the object classification is determined to require 3D analysis, the methodology moves to step 1212, where a subset of the pixel array corresponding to an area of the image surrounding the object is identified. At 1214, 3D analysis is performed on the subset of the pixel array identified at step 1212 in order to determine distance information for the object. At 1216, at least one of a control output or feedback information is generated by the imaging sensor device based on correlation of information generated by the 2D analysis of step 1206 and the 3D analysis of step 1214. This may include, for example, identifying a potentially hazardous condition or risk based on correlation of the 2D and 3D results and sending an instruction to a separate controller (e.g., an industrial controller, a safety relay, a control computer of an automotive vehicle, etc.) that is communicatively connected to the imaging sensor to perform an action designed to mitigate the detected hazard. The action may comprise, for example, switching an industrial machine or system to a safe state (e.g., stopping the machine, switching the machine to a slow operation mode, returning the machine to the home position, etc.), instructing a vehicle's braking system to slow or stop the vehicle, or other such action.
Embodiments, systems, and components described herein, as well as control systems and automation environments in which various aspects set forth in the subject specification can be carried out, can include computer or network components such as servers, clients, programmable logic controllers (PLCs), automation controllers, communications modules, mobile computers, on-board computers of or mobile vehicles, wireless components, control components and so forth which are capable of interacting across a network. Computers and servers include one or more processors—electronic integrated circuits that perform logic operations employing electric signals—configured to execute instructions stored in media such as random access memory (RAM), read only memory (ROM), a hard drives, as well as removable memory devices, which can include memory sticks, memory cards, flash drives, external hard drives, and so on.
Similarly, the term PLC or automation controller as used herein can include functionality that can be shared across multiple components, systems, and/or networks. As an example, one or more PLCs or automation controllers can communicate and cooperate with various network devices across the network. This can include substantially any type of control, communications module, computer, Input/Output (I/O) device, sensor, actuator, and human machine interface (HMI) that communicate via the network, which includes control, automation, and/or public networks. The PLC or automation controller can also communicate to and control various other devices such as standard or safety-rated I/O modules including analog, digital, programmed/intelligent I/O modules, other programmable controllers, communications modules, sensors, actuators, output devices, and the like.
The network can include public networks such as the internet, intranets, and automation networks such as control and information protocol (CIP) networks including DeviceNet, ControlNet, safety networks, and Ethernet/IP. Other networks include Ethernet, DH/DH+, Remote I/O, Fieldbus, Modbus, Profibus, CAN, wireless networks, serial protocols, and so forth. In addition, the network devices can include various possibilities (hardware and/or software components). These include components such as switches with virtual local area network (VLAN) capability, LANs, WANs, proxies, gateways, routers, firewalls, virtual private network (VPN) devices, servers, clients, computers, configuration tools, monitoring tools, and/or other devices.
In order to provide a context for the various aspects of the disclosed subject matter,
With reference to
The system bus 1318 can be any of several types of bus structure(s) including the memory bus or memory controller, a peripheral bus or external bus, and/or a local bus using any variety of available bus architectures including, but not limited to, 8-bit bus, Industrial Standard Architecture (ISA), Micro-Channel Architecture (MSA), Extended ISA (EISA), Intelligent Drive Electronics (IDE), VESA Local Bus (VLB), Peripheral Component Interconnect (PCI), Universal Serial Bus (USB), Advanced Graphics Port (AGP), Personal Computer Memory Card International Association bus (PCMCIA), and Small Computer Systems Interface (SCSI).
The system memory 1316 includes volatile memory 1320 and nonvolatile memory 1322. The basic input/output system (BIOS), containing the basic routines to transfer information between elements within the computer 1312, such as during start-up, is stored in nonvolatile memory 1322. By way of illustration, and not limitation, nonvolatile memory 1322 can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable PROM (EEPROM), or flash memory. Volatile memory 1320 includes random access memory (RAM), which acts as external cache memory. By way of illustration and not limitation, RAM is available in many forms such as synchronous RAM (SRAM), dynamic RAM (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM).
Computer 1312 also includes removable/non-removable, volatile/nonvolatile computer storage media.
It is to be appreciated that
A user enters commands or information into the computer 1312 through input device(s) 1336. Input devices 1336 include, but are not limited to, a pointing device such as a mouse, trackball, stylus, touch pad, keyboard, microphone, joystick, game pad, satellite dish, scanner, TV tuner card, digital camera, digital video camera, web camera, and the like. These and other input devices connect to the processing unit 1314 through the system bus 1318 via interface port(s) 1338. Interface port(s) 1338 include, for example, a serial port, a parallel port, a game port, and a universal serial bus (USB). Output device(s) 1340 use some of the same type of ports as input device(s) 1336. Thus, for example, a USB port may be used to provide input to computer 1312, and to output information from computer 1312 to an output device 1340. Output adapters 1342 are provided to illustrate that there are some output devices 1340 like monitors, speakers, and printers, among other output devices 1340, which require special adapters. The output adapters 1342 include, by way of illustration and not limitation, video and sound cards that provide a means of connection between the output device 1340 and the system bus 1318. It should be noted that other devices and/or systems of devices provide both input and output capabilities such as remote computer(s) 1344.
Computer 1312 can operate in a networked environment using logical connections to one or more remote computers, such as remote computer(s) 1344. The remote computer(s) 1344 can be a personal computer, a server, a router, a network PC, a workstation, a microprocessor based appliance, a peer device or other common network node and the like, and typically includes many or all of the elements described relative to computer 1312. For purposes of brevity, only a memory storage device 1346 is illustrated with remote computer(s) 1344. Remote computer(s) 1344 is logically connected to computer 1312 through a network interface 1348 and then physically connected via communication connection 1350. Network interface 1348 encompasses communication networks such as local-area networks (LAN) and wide-area networks (WAN). LAN technologies include Fiber Distributed Data Interface (FDDI), Copper Distributed Data Interface (CDDI), Ethernet/IEEE 802.3, Token Ring/IEEE 802.5 and the like. WAN technologies include, but are not limited to, point-to-point links, circuit switching networks like Integrated Services Digital Networks (ISDN) and variations thereon, packet switching networks, and Digital Subscriber Lines (DSL).
Communication connection(s) 1350 refers to the hardware/software employed to connect the network interface 1348 to the system bus 1318. While communication connection 1350 is shown for illustrative clarity inside computer 1312, it can also be external to computer 1312. The hardware/software necessary for connection to the network interface 1348 includes, for exemplary purposes only, internal and external technologies such as, modems including regular telephone grade modems, cable modems and DSL modems, ISDN adapters, and Ethernet cards.
What has been described above includes examples of the subject innovation. It is, of course, not possible to describe every conceivable combination of components or methodologies for purposes of describing the disclosed subject matter, but one of ordinary skill in the art may recognize that many further combinations and permutations of the subject innovation are possible. Accordingly, the disclosed subject matter is intended to embrace all such alterations, modifications, and variations that fall within the spirit and scope of the appended claims.
In particular and in regard to the various functions performed by the above described components, devices, circuits, systems and the like, the terms (including a reference to a “means”) used to describe such components are intended to correspond, unless otherwise indicated, to any component which performs the specified function of the described component (e.g., a functional equivalent), even though not structurally equivalent to the disclosed structure, which performs the function in the herein illustrated exemplary aspects of the disclosed subject matter. In this regard, it will also be recognized that the disclosed subject matter includes a system as well as a computer-readable medium having computer-executable instructions for performing the acts and/or events of the various methods of the disclosed subject matter.
In addition, while a particular feature of the disclosed subject matter may have been disclosed with respect to only one of several implementations, such feature may be combined with one or more other features of the other implementations as may be desired and advantageous for any given or particular application. Furthermore, to the extent that the terms “includes,” and “including” and variants thereof are used in either the detailed description or the claims, these terms are intended to be inclusive in a manner similar to the term “comprising.”
In this application, the word “exemplary” is used to mean serving as an example, instance, or illustration. Any aspect or design described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other aspects or designs. Rather, use of the word exemplary is intended to present concepts in a concrete fashion.
Various aspects or features described herein may be implemented as a method, apparatus, or article of manufacture using standard programming and/or engineering techniques. The term “article of manufacture” as used herein is intended to encompass a computer program accessible from any computer-readable device, carrier, or media. For example, computer readable media can include but are not limited to magnetic storage devices (e.g., hard disk, floppy disk, magnetic strips . . . ), optical disks [e.g., compact disk (CD), digital versatile disk (DVD) . . . ], smart cards, and flash memory devices (e.g., card, stick, key drive . . . ).
This application claims priority to U.S. Provisional Application Ser. No. 62/000,483, filed on May 19, 2014, entitled “OPTICAL SAFETY MONITORING WITH SELECTIVE PIXEL ARRAY ANALYSIS,” the entirety of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62000483 | May 2014 | US |