AUDIO EVENTS TRIGGERING VIDEO ANALYTICS

Abstract
A system, apparatus, method, and computer readable medium for using an audio trigger for surveillance in a security system. The method including receiving an audio input stream via a microphone. Dividing the audio input stream into audio segments. Filtering high energy audio segments from the audio segments. If a high energy audio segment includes speech, then determining if the speech is recognized as the speech of users of the system. If the high energy audio segment does not include the speech, then classifying the high energy audio segment as an interesting sound or an uninteresting sound. Determining whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.
Description
TECHNICAL FIELD

Embodiments generally relate to audio signal processing. More particularly, embodiments relate to audio events triggering video analytics.


BACKGROUND

Current methods used for security analytics are constrained in terms of energy efficiency, connectivity, occlusion and privacy. Capturing, processing, and sending video streams to the cloud requires a great deal of energy. In addition, if a house is instrumented with many cameras, the computational and power cost for transmitting all the video streams continuously may be prohibitive for the consumer.


It is more desirable to process data locally rather than send video streams to the cloud. For security cameras that send data to the cloud, it is often desirable not to transmit videos of normal household activity. Moreover, cameras are not advisable in sensitive areas like bathrooms, locker rooms, bedrooms, etc. Also, camera-only security solutions are limited based on the placement of the camera, lighting conditions and other obstructions.





BRIEF DESCRIPTION OF THE DRAWINGS

The various advantages of the embodiments will become apparent to one skilled in the art by reading the following specification and appended claims, and by referencing the following drawings, in which:



FIG. 1 is a diagram illustrating an example security system incorporating audio events to trigger video analytics for surveillance according to an embodiment;



FIG. 2 is a block diagram illustrating an example audio processing pipeline for deciding when to turn on the video for surveillance in a security system according to an embodiment;



FIG. 3 is a flow diagram of an example method of an audio process to determine when to turn on video based on audio analysis according to an embodiment;



FIG. 4 is a block diagram of an example of a security system according to an embodiment;



FIG. 5 is an illustration of an example of a semiconductor package apparatus according to an embodiment;



FIG. 6 is a block diagram of an exemplary processor according to an embodiment; and



FIG. 7 is a block diagram of an exemplary computing system according to an embodiment.





In the following detailed description, reference is made to the accompanying drawings which form a part hereof wherein like numerals designate like parts throughout, and in which is shown by way of illustration embodiments that may be practiced. It is to be understood that other embodiments may be utilized and structural or logical changes may be made without departing from the scope of the present disclosure. Therefore, the following detailed description is not to be taken in a limiting sense, and the scope of embodiments is defined by the appended claims and their equivalents.


DESCRIPTION OF EMBODIMENTS

Embodiments relate to technology that enhances the functionality of video security camera analytics by incorporating audio processing to trigger when to turn on video. A security system includes a plurality of microphones interspersed throughout a surveillance area to extend the surveillance range to additional areas and to enable audio analytics to enhance surveillance insights in certain areas where placing a camera is neither desirable nor possible due to privacy or other considerations. The security system includes an audio classifier that is trained to detect interesting sounds (i.e., alarming sounds) as well as uninteresting sounds (i.e., unalarming sounds). The system also includes an automatic speaker recognition engine that is trained on the voices of registered users to detect when they are present. The decision to turn on the video depends on speaker recognition and audio classification results. In addition, other contextual data may be incorporated to help determine when to turn on the video. The other contextual data may include the location of the camera within the surveillance area, the time of day, user behavior patterns, and other sensor data that may exist within the system. Such sensor data may include, for example, a motion sensor, a proximity sensor, etc. The combination of the contextual data with the audio recognition capability may enable anomaly detection, such that when unusual patterns are heard in a location and time of day that is out of the ordinary, the video modality may be put on alert.


When an interesting sound is detected and the system does not detect any voices of any registered users, the video may be turned on. When an interesting sound is detected in a location in which the system only detects voices of the registered users in a manner that depicts a typical user behavior pattern for that time of day, the video may not be turned on. But, when an interesting sound is detected in a location and at a time of day that is an anomaly, the video modality may be put on alert to enable quick turn on if necessary. If there are no interesting sounds detected, the video remains off to ensure user privacy.


Various operations may be described as multiple discrete actions or operations in turn, in a manner that is most helpful in understanding the claimed subject matter. However, the order of description should not be construed as to imply that these operations are necessarily order dependent. In particular, these operations may not be performed in the order of presentation. Operations described may be performed in a different order than the described embodiment. Various additional operations may be performed and/or described operations may be omitted in additional embodiments.


References in the specification to “one embodiment,” “an embodiment,” “an illustrative embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may or may not necessarily include that particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described. Additionally, it should be appreciated that items included in a list in the form of “at least one of A, B, and C” can mean (A); (B); (C); (A and B); (B and C); (A and C); or (A, B, and C). Similarly, items listed in the form of “at least one of A, B, or C” can mean (A); (B); (C); (A and B); (B and C); (A and C); or (A, B, and C).


The disclosed embodiments may be implemented, in some cases, in hardware, firmware, software, or any combination thereof. The disclosed embodiments may also be implemented as instructions carried by or stored on one or more transitory or non-transitory machine-readable (e.g., computer-readable) storage medium, which may be read and executed by one or more processors. A machine-readable storage medium may be embodied as any storage device, mechanism, or other physical structure for storing or transmitting information in a form readable by a machine (e.g., a volatile or non-volatile memory, a media disc, or other media device). As used herein, the term “logic” and “module” may refer to, be part of, or include an application specific integrated circuit (ASIC), an electronic circuit, a processor (shared, dedicated, or group), and/or memory (shared, dedicated, or group) that execute one or more software or firmware programs having machine instructions (generated from an assembler and/or a compiler), a combinational logic circuit, and/or other suitable components that provide the described functionality.


In the drawings, some structural or method features may be shown in specific arrangements and/or orderings. However, it should be appreciated that such specific arrangements and/or orderings may not be required. Rather, in some embodiments, such features may be arranged in a different manner and/or order than shown in the illustrative figures. Additionally, the inclusion of a structural or method feature in a particular figure is not meant to imply that such feature is required in all embodiments and, in some embodiments, it may not be included or may be combined with other features.



FIG. 1 is a diagram illustrating an example security system 100 incorporating audio events to trigger video analytics for surveillance according to an embodiment. The security system 100 comprises two cameras 102a and 102b, two microphones 104a and 104b, an on-premise processing module/hub 106, local storage 108, a companion device 110 and cloud processing module and storage 112. Although the system 100 only shows two cameras 102a and 102b and two microphones 104a and 104b, embodiments are not limited to two cameras and two microphones. In fact, embodiments may have more than two cameras or less than two cameras (i.e., one camera) and more than two microphones or less than two microphones (i.e., one microphone). The microphones 104a and 104b may be wired or wireless. In embodiments, the microphones may be located in areas where a camera may be prohibited (due to privacy or other considerations) to extend the surveillance range to additional areas. In other embodiments, cameras and microphones may be co-located. In yet other embodiments, there may be a combination of microphones remotely located from cameras as well as microphones co-located with cameras. Cameras 102a and 102b may also be wired or wireless. The cameras 102a and 102b are coupled to the on-premise processing module/hub 106 via a wired or wireless connection. The microphones 104a and 104b are coupled to the on-premise processing module/hub 106 via wired or wireless connection. The on-premise processing module/hub 106 is coupled to the local storage 108. The on-premise processing module/hub 106 may include a network interface card (NIC) to enable wireless communication with the cloud processing and storage module 112. The companion device 110 may be a computing device, such as, for example, a mobile phone, a tablet, a wearable device, a laptop computer or any other computing device capable of controlling the on-premise processing module/hub 106 and the cloud processing module and storage 112. An application running on the companion device 110 allows the companion device 110 to configure and control both the on-premise processing module/hub 106 and the cloud processing module and storage 112.


Security system 100 may be placed in the homes, office buildings, parking lots, and other locations in which surveillance is needed. Embodiments of security system 100 use audio analytics as an additional modality to improve false accept and false reject rates and cut down on the amount of computation required with camera only solutions by turning the video on only when an interesting sound occurs. The system is pretrained to detect interesting sounds, such as, for example, dogs barking, glass breaking, gun shots, screaming, etc. and uninteresting sounds, such as, for example, leaves blown by the wind, typical household sounds (vacuum cleaner, washing machine, dryer, dishwasher), etc.


A huge concern for consumers is privacy. For home installations in particular, households do not want to transmit videos of normal household activities to the cloud. Security system 100 applies speaker recognition techniques to the audio streams having speech to detect when users of the system are present. If a user of the system is present when a sound of interest occurs and the system 100 has prior knowledge of household patterns, the video may be kept off if nothing else out of the ordinary is occurring to preserve the privacy of the user.


Audio streams coming from the microphones 104a and 104b to the on-premise processing module/hub 106 are processed and analyzed to determine if an audio event of interest has been detected, if any speech has been detected, and if speech is detected, can the speech be identified as coming from one of the registered users. Based on the type of audio event and the speaker identification, along with other parameters, such as, for example, the location of the camera, the time of day, user behavior patterns, and other types of sensors (motion, proximity, etc.) that may be included in the system (but not shown in FIG. 1), the on-premise processing module/hub 106 may determine whether the video camera should be activated. If the camera 102a and/or 102b is activated, the video stream(s) received from the camera 102a and/or 102b may be filtered based on context information received from the audio streams (glass breaking, car alarm, conversation between users in the home, etc.) to decide whether the video streams need to be saved locally in local storage 108 to keep the private videos on-premises or may be sent to the cloud for storage.


The on-premises processing module 106 and the cloud processing module and storage 112 can be configured and controlled using an application running on the companion device 110. In addition, the on-premises processing module 106 and the cloud processing and storage module 112 may send notifications and alerts to the companion device 110 when user attention is necessary.



FIG. 2 is a block diagram 200 illustrating an audio processing pipeline for deciding when to turn on the video for surveillance in a security system according to an embodiment. Block diagram 200 includes a microphone 202, an audio segmentation 204, an audio filter 206, an audio classifier 208, a speaker recognition engine 210 and decision logic 212. The microphone 202 is coupled to the audio segmentation 204. The audio segmentation 204 is coupled to the audio filter 206. The audio filter 206 is coupled to the audio classifier 208. The audio classifier 208 is coupled to the speaker recognition engine 210 and the decision logic 212. The speaker recognition engine 210 is coupled to the decision logic 212.


The microphone 202 receives audio input in the form of an audio stream. If the microphone 202 is an analog microphone, the microphone 202 will include an analog to digital converter (ADC) to convert the analog audio stream to a digital audio stream. In an embodiment where the microphone 202 is a digital microphone, an ADC is not needed.


The audio segmentation 204 receives the digitized audio stream and divides the audio stream into short audio segments, i.e., audio blocks, approximately matching the time resolution necessary for the decision logic 212. In one embodiment, the audio segments may be 0.25 to several seconds in length.


The audio filter 206 may be used to filter high energy audio segments for processing. The low energy audio segments (i.e., background noise) are ignored. In an embodiment, the standard deviation of the audio received by the system is continuously taken and a baseline is determined as to what may be considered background noise (i.e., ambient background noise). When the system receives an audio segment that is significantly greater than the ambient background noise, the audio segment is identified as a high energy audio segment.


The audio classifier 208 may be used to classify the high energy audio segments. The high energy audio segments may be classified as speech, an alarming sound, or a non-alarming sound. The audio classifier 208 may be trained to recognize speech, alarming sounds, and non-alarming sounds prior to installation of the security system. Training may continue after installation to enable the system to adapt to the surroundings in which it is installed as well as learn other interesting sounds that may be of importance to the users of the system. In one embodiment, the audio classifier 208 may be trained at the factory. Alarming sounds may include, for example, dog barking, glass breaking, baby crying, person falling, person screaming, car alarms, loud car crashes, gun shots, or any other sounds that may cause one to be alarmed, frightened or terrified. Non-alarming sounds may include, for example, leaves blowing in the wind, vacuum cleaner running, dishwasher/washing machine/dryer running, and other typical noises critical to one's environment that would not cause one to be alarmed.


The audio classifier 208 extracts spectral features, such as, for example, Mel Frequency Cepstral Coefficients (MFCC), Perceptual Linear Prediction (PLP), etc. of the high energy audio segments that represent an alarming or an unalarming sound. The features may be computed in predetermined time frames and then concatenated with a longer context, such as, for example, +/−15 frames, to form a richer feature that captures temporal variations. In embodiments, the predetermined time frames may be 10 ms, 20 ms, 30 ms, or 40 ms. These features are then fed into a classifier, such as, for example, Gaussian Mixture Model (GMM), Support Vector Machine (SVM), a Deep Neural Network (DNN), a Convolutional Neural Network (CNN), a Recurrent Neural Network (RNN), etc. For deep learning classifiers such as DNN, CNN, or RNN, it is possible to use raw samples as inputs rather than spectral features. The output from the deep learning classifier may predict which one of the N possible classes (i.e., the alarming sounds) the network was trained to recognize for the input audio. If one of the alarming sounds is chosen, this information is used by the decision logic 212 to determine whether to turn on one or more video cameras.


The speaker recognition engine 210 may be used to determine if the high energy audio segments identified by the audio classifier 208 as speech belong to any of the registered users of the system. The system, in order to work efficiently, must be able to recognize the voices of the registered users of the system. Registered users of the system may enroll their voices into the speaker recognition engine 210 to enable the system to develop speaker models for each user using machine learning techniques. This allows the speaker recognition engine 210 to recognize a registered user's voice when received via any one of the microphones of the security system. In one embodiment, video may be used by the system to aid in learning a registered user's voice. When a registered user is speaking and their lips are moving (captured by video), the audio is captured to enroll the person's voice. In another embodiment, the registered users may engage in an enrollment process where they are asked to read several phrases and passages while their voice is being recorded.


The speaker recognition engine 210 may extract spectral features, similar to those extracted by the audio classification 208, such as, for example, MFCC, PLP, etc., every 10 ms frames of an utterance. In other embodiments, the spectral features may be extracted at time frames other than every 10 ms. The frames are then fed into backend classifiers, such as, for example, Gaussian Mixture Models-Universal Background Model (GMM-UBM), Gaussian Mixture Models-Support Vector Machine (GMM-SVM), a deep neural network or i-vector Probabilistic Linear Discriminant Analysis (PLDA). For deep neural network classifiers, it is possible to feed raw samples as input rather than spectral features. The output of the backend classifier is a speaker score. A high score may indicate a close match to a speaker model of a registered user. If the speaker recognition engine 210 recognizes the speech as one of the registered users, then privacy issues come into play when deciding whether to turn one or more video cameras on and whether to process the video locally or in the cloud.


The decision to turn on a video camera depends on the results of the audio classification 208 and the speaker recognition engine 210. In addition, other contexts are incorporated, such as, for example, the location of the camera within a surveillance area in which the audio was heard, the time of day, user behavior patterns, proximity sensor data, motion sensor data, etc. The decision logic 212 takes the audio classification 208 output, the speaker recognition engine 210 output and the context data input, and determines whether to turn one or more video cameras on, to leave the cameras off, or to put one or more video cameras on alert.


The decision logic 212 may be based on a set of rules, which can be adjusted by the registered users. The rule set may be based on a combination of the audio classification, speech recognition, and contextual data. Alternatively, to make the system user-friendly, it can incorporate a machine learning (ML) algorithm trained by decision preferences labeled by a large set of potential users. The ML algorithm can take as input the audio analysis from the audio classification 208, the speaker recognition engine 210 and the other contexts to generate a yes/no decision. Such algorithms may include, but are not limited to, decision tree, random forest, support vector machine (SVM), logistic regression, and a plurality of neural networks. A pre-trained generic model could incorporate the preferences of many users (for example, from the large set of potential users) intended to work well for most people out of the box. The generic model may be improved over time as it receives input from the registered users and learns the behavior patterns of the registered users.


A combination of the other contexts with the audio recognition capability (i.e., audio classification 208 and speaker recognition engine 210) can not only determine whether to turn on one or more video cameras in the system, but can also enable anomaly detection such that when unusual patterns are heard in a location and at a time of day that is suspicious, the video modality may be put on alert. In embodiments where the security system is a home security system and the camera in question is located inside the house, the decision to turn on the video camera must take into consideration whether or not speech of a household member has been heard, and if so, should the video remain off. In one embodiment, the video may remain off if the user behavior patterns dictate normal behavior and the alarming sound is not an extreme alarm, such as, for example, a dog barking with sounds of human laughter. But in the case where the alarming sound is an extreme alarm, such as, for example, a gun shot, all of the video cameras in the system may be turned on at that time.



FIG. 3 is a flow diagram of an example method of an audio process to determine when to turn on video based on audio analysis according to an embodiment. The method 300 may generally be implemented in a system such as, for example, the example security system 100 as shown in FIG. 1, having an audio pipeline as described in FIG. 2. More particularly, the method 300 may be implemented in one or more modules as a set of logic instructions stored in a machine- or computer-readable storage medium such as random access memory (RAM), read only memory (ROM), programmable ROM (PROM), firmware, flash memory, etc., in configurable logic such as, for example, programmable logic arrays (PLAs), field programmable gate arrays (FPGAs), complex programmable logic devices (CPLDs), and fixed-functionality logic hardware using circuit technology such as, for example, application specific integrated circuit (ASIC), complementary metal oxide semiconductor (CMOS) or transistor-transistor logic (TTL) technology, or any combination thereof.


For example, computer program code to carry out operations shown in the method 400 may be written in any combination of one or more programming languages, including an object-oriented programming language such as JAVA, SMALLTALK, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. Additionally, logic instructions might include assembler instruction, instruction set architecture (ISA) instructions, machine instruction, machine depended instruction, microcode, state setting data, configuration data for integrated circuitry, state information that personalizes electronic circuitry and/or other structural components that are native to hardware (e.g., host processor, central processing unit (CPU), microcontroller, digital signal processor (DSP), etc.).


The process begins in block 302, where the process proceeds to block 304. In block 304, a microphone receives an audio stream. If the microphone is an analog microphone, the microphone may include an ADC to convert the analog audio stream to a digital audio stream. If the microphone is a digital microphone, then the ADC is not required. The process then proceeds to block 306.


In block 306, the digital audio stream is divided into short audio segments, i.e., audio blocks, approximately matching the time resolution of the decision logic used to determine whether or not to turn on the video. In one embodiment, the audio segments may be 0.25 to several seconds in length. The process then proceeds to block 308.


In block 308, the audio segments are filtered to obtain high energy audio segments for further processing. In one embodiment, the remaining low energy audio segments (i.e., background noise) are ignored. In another embodiment, the remaining low energy audio segments are discarded.


In an embodiment, the standard deviation of the audio signals received by the system is continuously measured. Based on the standard deviation, a baseline is determined as to what may be considered ambient background noise. When the system receives an audio segment that is significantly greater than the ambient background noise, the audio segment is identified as a high energy audio segment. The process then proceeds to decision block 310.


In decision block 310, it is determined whether the high energy audio segment is speech. If the high energy audio segment is speech, the process proceeds to block 312.


In block 312, it is determined whether the speech is from a registered user of the security system. If the speech is from a registered user, the privacy of the registered user is taken into consideration when deciding whether to turn on the video. In this instance, an indication that the speech is from a registered user is sent to block 316. If the speech is not from a registered user, an indication that the speech does not come from a registered user is sent to block 316.


Returning to decision block 310, if the high energy audio segment is not speech, the process proceeds to block 314. In block 314, classification of the high energy audio segment is performed. Classification of the high energy audio segment as one of the sounds of interest to the security system may require the video to be turned on for surveillance. Sounds of interest refer to alarming sounds such as, but are not limited to, dog barking, glass breaking, baby crying, person falling, person screaming, car alarms, loud car crashes, gun shots, and/or any other sounds that may cause one to be alarmed, frightened or terrified. The classification of the high energy audio segment is sent to block 316.


In block 316, a determination is made whether to keep the video off or turn the video on based on audio classification results from block 314, speaker recognition results from block 312, and contextual data input to block 316. This may include turning on more than one camera at the same time based on the severity of the classification of the high energy audio segment as an alarm.


In an embodiment, if the audio classification of the high energy audio segment is not an alarming sound, the video may remain off or be turned off If the audio classification of the high energy audio segment is an alarming sound and there is no speaker recognition of a user of the security system, then the video may be turned on. Because there is no speaker recognition of a user and, therefore, no privacy issues, the video may be processed in the cloud or locally at the discretion of the owner.


If the audio classification of the high energy audio segment is an alarming sound and there is speaker recognition of a user, then whether to turn the video on or allow the video to remain off is more of a grey area and may be based on contextual data. For example, if the security system is a home security system and the location of one or more cameras is inside the home, the decision to turn on the video should be tilted more toward privacy, such that when speech of household members is identified repeatedly and the user behavior patterns are normal, the video may remain off. For example, if the system detects a dog barking or glass breaking and it is around the normal time in which a family is having dinner, and speaker recognition includes family members having a normal conversation over dinner, the system may prevent the video from being turned on in the kitchen during dinner time. In another example, if the system detects the dog barking and glass breaking, and the glass break sounds more like the kitchen window being shattered than a drinking glass breaking (which may be indicative of a break-in), and the speaker recognition includes family member voices in a panic rather than having a normal conversation over dinner, the system may turn on the video in the kitchen, and may also turn on all the video cameras in the house to determine if a break-in is occurring in other rooms of the home. In this instance, the video data can either be processed locally or sent to the cloud. To protect the privacy of the family members in the video, the video data may be processed locally instead of being sent to the cloud.



FIG. 4 shows a system 400 that may be readily substituted for the security system shown above with reference to FIG. 1. The illustrated system 400 includes a processor 402 (e.g., host processor, central processing unit/CPU) having an integrated memory controller (IMC) 404 coupled to a system memory 406 (e.g., volatile memory, dynamic random access memory/DRAM). The processor 402 may also be coupled to an input/output (I/O) module 408 that communicates with network interface circuitry 410 (e.g., network controller, network interface card/NIC) and mass storage 612 (non-volatile memory/NVM, hard disk drive/HDD, optical disk, solid state disk/SSD, flash memory). The network interface circuitry 410 may receive audio input streams from at least one microphone such as, for example, audio streams from microphone 104a and/or 104b (shown in FIG. 1), wherein the system memory 406 and/or the mass storage 412 may be memory devices that store instructions 414, which when executed by the processor 402, cause the system 400 to perform one or more aspects of the method 300 (FIG. 3), already discussed. Thus, execution of the instructions 414 may cause the system 400 to divide the audio input stream into audio segments, filter high energy audio segments from the audio segments, if a high energy audio segment includes speech, determine if the speech is recognized as a user of the security system, if a high energy audio segment does not include speech, classify the high energy audio segment as an interesting sound or an uninteresting sound, and determine whether to turn video on based on classification of the high energy audio segment as an interesting sound, speech recognition of a user, and contextual data. The processor 402 and the 10 module 408 may be incorporated into a shared die 416 as a system on chip (SoC).



FIG. 5 shows a semiconductor package apparatus 500 (e.g., chip) that includes one or more substrates 502 (e.g., silicon, sapphire, gallium arsenide) and logic 504 (e.g., transistor array and other integrated circuit/IC components) coupled to the one or more substrates 502. The logic 504, which may be implemented in configurable logic and/or fixed-functionality logic hardware, may generally implement one or more aspects of the method 300 (FIG. 3), already discussed.



FIG. 6 illustrates a processor core 600 according to one embodiment. The processor core 600 may be the core for any type of processor, such as a micro-processor, an embedded processor, a digital signal processor (DSP), a network processor, or other device to execute code. Although only one processor core 600 is illustrated in FIG. 6, a processing element may alternatively include more than one of the processor core 600 illustrated in FIG. 6. The processor core 600 may be a single-threaded core or, for at least one embodiment, the processor core 600 may be multithreaded in that it may include more than one hardware thread context (or “logical processor”) per core.



FIG. 6 also illustrates a memory 670 coupled to the processor core 600. The memory 670 may be any of a wide variety of memories (including various layers of memory hierarchy) as are known or otherwise available to those of skill in the art. The memory 670 may include one or more code 605 instruction(s) to be executed by the processor core 600, wherein the code 605 may implement the method 300 (FIG. 3), already discussed. The processor core 600 follows a program sequence of instructions indicated by the code 605. Each instruction may enter a front end portion 610 and be processed by one or more decoders 620. The decoder 620 may generate as its output a micro operation such as a fixed width micro operation in a predefined format, or may generate other instructions, microinstructions, or control signals which reflect the original code instruction. The illustrated front end portion 610 also includes register renaming logic 625 and scheduling logic 630, which generally allocate resources and queue the operation corresponding to the convert instruction for execution.


The processor core 600 is shown including execution logic 650 having a set of execution units 655-1 through 655-N. Some embodiments may include a number of execution units dedicated to specific functions or sets of functions. Other embodiments may include only one execution unit or one execution unit that can perform a particular function. The illustrated execution logic 650 performs the operations specified by code instructions.


After completion of execution of the operations specified by the code instructions, back end logic 660 retires the instructions of the code 605. In one embodiment, the processor core 600 allows out of order execution but requires in order retirement of instructions. Retirement logic 665 may take a variety of forms as known to those of skill in the art (e.g., re-order buffers or the like). In this manner, the processor core 600 is transformed during execution of the code 605, at least in terms of the output generated by the decoder, the hardware registers and tables utilized by the register renaming logic 625, and any registers (not shown) modified by the execution logic 650.


Although not illustrated in FIG. 6, a processing element may include other elements on chip with the processor core 600. For example, a processing element may include memory control logic along with the processor core 600. The processing element may include I/O control logic and/or may include I/O control logic integrated with memory control logic. The processing element may also include one or more caches.


Referring now to FIG. 7, shown is a block diagram of a computing system 700 in accordance with an embodiment. Shown in FIG. 7 is a multiprocessor system 700 that includes a first processing element 770 and a second processing element 780. While two processing elements 770 and 780 are shown, it is to be understood that an embodiment of the system 700 may also include only one such processing element.


The system 700 is illustrated as a point-to-point interconnect system, wherein the first processing element 770 and the second processing element 780 are coupled via a point-to-point interconnect 750. It should be understood that any or all of the interconnects illustrated in FIG. 7 may be implemented as a multi-drop bus rather than point-to-point interconnect.


As shown in FIG. 7, each of processing elements 770 and 780 may be multicore processors, including first and second processor cores (i.e., processor cores 774a and 774b and processor cores 784a and 784b). Such cores 774a, 774b, 784a, 784b may be configured to execute instruction code in a manner similar to that discussed above in connection with FIG. 6.


Each processing element 770, 780 may include at least one shared cache 796a, 796b. The shared cache 796a, 796b may store data (e.g., instructions) that are utilized by one or more components of the processor, such as the cores 774a, 774b and 784a, 784b, respectively. For example, the shared cache 796a, 796b may locally cache data stored in a memory 732, 734 for faster access by components of the processor. In one or more embodiments, the shared cache 796a, 796b may include one or more mid-level caches, such as level 2 (L2), level 3 (L3), level 4 (L4), or other levels of cache, a last level cache (LLC), and/or combinations thereof.


While shown with only two processing elements 770, 780, it is to be understood that the scope of the embodiments are not so limited. In other embodiments, one or more additional processing elements may be present in a given processor. Alternatively, one or more of processing elements 770, 780 may be an element other than a processor, such as an accelerator or a field programmable gate array. For example, additional processing element(s) may include additional processors(s) that are the same as a first processor 770, additional processor(s) that are heterogeneous or asymmetric to processor a first processor 770, accelerators (such as, e.g., graphics accelerators or digital signal processing (DSP) units), field programmable gate arrays, or any other processing element. There can be a variety of differences between the processing elements 770, 780 in terms of a spectrum of metrics of merit including architectural, micro architectural, thermal, power consumption characteristics, and the like. These differences may effectively manifest themselves as asymmetry and heterogeneity amongst the processing elements 770, 780. For at least one embodiment, the various processing elements 770, 780 may reside in the same die package.


The first processing element 770 may further include memory controller logic (MC) 772 and point-to-point (P-P) interfaces 776 and 778. Similarly, the second processing element 780 may include a MC 782 and P-P interfaces 786 and 788. As shown in FIG. 7, MC's 772 and 782 couple the processors to respective memories, namely a memory 732 and a memory 734, which may be portions of main memory locally attached to the respective processors. While the MC 772 and 782 is illustrated as integrated into the processing elements 770, 780, for alternative embodiments the MC logic may be discrete logic outside the processing elements 770, 780 rather than integrated therein.


The first processing element 770 and the second processing element 780 may be coupled to an I/O subsystem 790 via P-P interconnects 776786, respectively. As shown in FIG. 7, the I/O subsystem 790 includes P-P interfaces 794 and 798. Furthermore, I/O subsystem 790 includes an interface 792 to couple I/O subsystem 790 with a high performance graphics engine 738. In one embodiment, bus 749 may be used to couple the graphics engine 738 to the I/O subsystem 790. Alternately, a point-to-point interconnect may couple these components.


In turn, I/O subsystem 790 may be coupled to a first bus 716 via an interface 796. In one embodiment, the first bus 716 may be a Peripheral Component Interconnect (PCI) bus, or a bus such as a PCI Express bus or another third generation I/O interconnect bus, although the scope of the embodiments are not so limited.


As shown in FIG. 7, various I/O devices 714 (e.g., biometric scanners, speakers, cameras, sensors) may be coupled to the first bus 716, along with a bus bridge 718 which may couple the first bus 716 to a second bus 720. In one embodiment, the second bus 720 may be a low pin count (LPC) bus. Various devices may be coupled to the second bus 720 including, for example, a keyboard/mouse 712, communication device(s) 726, and a data storage unit 719 such as a disk drive or other mass storage device which may include code 730, in one embodiment. The illustrated code 730 may implement the method 300 (FIG. 3), already discussed, and may be similar to the code 605 (FIG. 6), already discussed. Further, an audio I/O 724 may be coupled to second bus 720 and a battery 710 may supply power to the computing system 700.


Note that other embodiments are contemplated. For example, instead of the point-to-point architecture of FIG. 7, a system may implement a multi-drop bus or another such communication topology. Also, the elements of FIG. 7 may alternatively be partitioned using more or fewer integrated chips than shown in FIG. 7.


ADDITIONAL NOTES AND EXAMPLES

Example 1 may include a security system having audio analytics comprising network interface circuitry to receive an audio input stream via a microphone, a processor coupled to the network interface circuitry, one or more memory devices coupled to the processor, the one or more memory devices including instructions, which when executed by the processor cause the system to divide the audio input stream into audio segments, filter high energy audio segments from the audio segments, if a high energy audio segment includes speech, determine if the speech is recognized as the speech of users of the system, if the high energy audio segment does not include the speech, classify the high energy audio segment as an interesting sound or an uninteresting sound, and determine whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.


Example 2 may include the security system of Example 1, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.


Example 3 may include the security system of Example 1, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, the instructions, which when executed by the processor further cause the system to turn the video on.


Example 4 may include the security system of Example 1, wherein if the classification of the high energy audio segment comprises the uninteresting sound, the instructions, which when executed by the processor further cause the system to turn the video off or keep the video off.


Example 5 may include the security system of Example 1, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, the instructions, which when executed by the processor further cause the system to turn the video off or keep the video off to maintain privacy of the user.


Example 6 may include the security system of Example 1, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, the instructions, which when executed by the processor further cause the system to put video modality on alert.


Example 7 may include the security system of Example 1, wherein to classify the high energy audio segment as an interesting sound or an uninteresting sound further comprises instructions, which when executed by the processor cause the system to extract spectral features from the high energy audio segment in predetermined time frames, concatenate the predetermined time frames with a longer context of +/− a predetermined number of frames to form a richer feature that captures temporal variations, and feed the richer feature into a classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 8 may include the security system of Example 1, wherein to classify the high energy audio segment as an interesting sound or an uninteresting sound further comprises instructions, which when executed by the processor cause the system to feed raw samples of the high energy audio segment into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 9 may include the security system of Example 1, wherein to determine if the speech is recognized as the speech of users of the system further comprises instructions, which when executed by the processor cause the system to extract spectral features from the high energy audio segment in predetermined time frames of an utterance, feed the frames into a backend classifier to obtain a speaker score, and determine if the speaker score matches a speaker model of the users of the system.


Example 10 may include the security system of Example 1, wherein to determine if the speech is recognized as the speech of users of the system further comprises instructions, which when executed by the processor cause the system to feed raw samples of the high energy audio segment into a deep learning neural network classifier to obtain a speaker score, and determine if the speaker score matches a speaker model of the users of the system.


Example 11 may include the security system of any one of Examples 9 to 10, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 12 may include the security system of Example 9, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 13 may include the security system of Example 10, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 14 may include an apparatus for using an audio trigger for surveillance in a security system comprising one or more substrates, and logic coupled to the one or more substrates, wherein the logic includes one or more of configurable logic or fixed-functionality hardware logic, the logic coupled to the one or more substrates to receive an audio input stream via a microphone, divide the audio input stream into audio segments, filter high energy audio segments from the audio segments, if a high energy audio segment includes speech, determine if the speech is recognized as the speech of users of the system, if the high energy audio segment does not include the speech, classify the high energy audio segment as an interesting sound or an uninteresting sound, and determine whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.


Example 15 may include the apparatus of Example 14, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.


Example 16 may include the apparatus of Example 14, wherein if the classification of the high energy audio segment is one of the interesting sounds and the speech is not recognized as a user, the logic coupled to the one or more substrates to turn the video on.


Example 17 may include the apparatus of Example 14, wherein if the classification of the high energy audio segment is not one of the interesting sounds, the logic coupled to the one or more substrates to turn the video off or keep the video off.


Example 18 may include the apparatus of Example 14, wherein if the classification of the high energy audio segment is one of the interesting sounds, the speech is recognized as a user, and the contextual data indicates a normal user behavior pattern, the logic coupled to the one or more substrates to turn the video off or keep the video off to maintain privacy of the user.


Example 19 may include the apparatus of Example 14, wherein if the classification of the high energy audio segment is one of the interesting sounds, the speech is recognized as a user, and the contextual data indicates an abnormal user behavior pattern, the logic coupled to the one or more substrates to put video modality on alert.


Example 20 may include the apparatus of Example 14, wherein to classify the high energy audio segment as an interesting sound or an uninteresting sound further comprises logic coupled to the one or more substrates to extract spectral features from the high energy audio segment in predetermined time frames, concatenate the predetermined time frames with a longer context of +/− a predetermined number of frames to form a richer feature that captures temporal variations, and feed the richer feature into a classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 21 may include the apparatus of Example 14, wherein to classify the high energy audio segment as an interesting sound or an uninteresting sound further comprises logic coupled to the one or more substrates to feed raw samples of the high energy audio segment into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 22 may include the apparatus of Example 14, wherein to determine if the speech is recognized as the speech of users of the system further comprises logic coupled to the one or more substrates to extract spectral features from the high energy audio segment in predetermined time frames of an utterance, feed the frames into a backend classifier to obtain a speaker score, and determine if the speaker score matches a speaker model of the users of the system.


Example 23 may include the apparatus of Example 14, wherein to determine if the speech is recognized as the speech of users of the system further comprises logic coupled to the one or more substrates to feed raw samples of the high energy audio segment into a deep learning neural network classifier to obtain a speaker score, and determine if the speaker score matches a speaker model of the users of the system.


Example 24 may include the apparatus of any one of Examples 22 to 23, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 25 may include the apparatus of Example 22, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 26 may include the apparatus of Example 23, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 27 may include a method for using an audio trigger for surveillance in a security system comprising receiving an audio input stream via a microphone, dividing the audio input stream into audio segments, filtering high energy audio segments from the audio segments, if a high energy audio segment includes speech, determining if the speech is recognized as the speech of users of the system, if the high energy audio segment does not include the speech, classifying the high energy audio segment as an interesting sound or an uninteresting sound, and determining whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.


Example 28 may include the method of Example 27, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.


Example 29 may include the method of Example 27, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, the method further comprising turning the video on.


Example 30 may include the method of Example 27, wherein if the classification of the high energy audio segment comprises the uninteresting sound, the method further comprising turning the video off or keeping the video off.


Example 31 may include the method of Example 27, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, the method further comprising turning the video off or keeping the video off to maintain privacy of the user.


Example 32 may include the method of Example 27, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, the method further comprising putting video modality on alert.


Example 33 may include the method of Example 27, wherein classifying the high energy audio segment as an interesting sound or an uninteresting sound comprises extracting spectral features from the high energy audio segment in predetermined time frames, concatenating the predetermined time frames with a longer context of +/−15 frames to form a richer feature that captures temporal variations, and feeding the richer feature into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 34 may include the method of Example 27, wherein classifying the high energy audio segment as an interesting sound or an uninteresting sound comprises feeding raw samples of the high energy audio segment into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 35 may include the method of Example 27, wherein determining if the speech is recognized as the speech of users of the system comprises extracting spectral features from the high energy audio segment in predetermined time frames of an utterance, feeding the frames into a backend classifier to obtain a speaker score, and determining if the speaker score matches a speaker model of the users of the system.


Example 36 may include the method of Example 27, wherein determining if the speech is recognized as the speech of users of the system comprises feeding raw samples of the high energy audio segment into a deep learning neural network classifier to obtain a speaker score and determining if the speaker score matches a speaker model of the users of the system.


Example 37 may include the method of any one of Examples 35 to 36, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 38 may include the method of Example 35, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 39 may include the method of Example 36, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 40 may include one or more computer readable medium, comprising a set of instructions, which when executed by a computing device, cause the computing device to receive an audio input stream via a microphone, divide the audio input stream into audio segments, filter high energy audio segments from the audio segments, if a high energy audio segment includes speech, determine if the speech is recognized as the speech of users of the system, if the high energy audio segment does not include the speech, classify the high energy audio segment as an interesting sound or an uninteresting sound, and determine whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.


Example 41 may include the one or more computer readable medium of Example 40, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.


Example 42 may include the at least one computer readable medium of Example 40, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, the instructions, which when executed by the computing device, further cause the computing device to turn the video on.


Example 43 may include the at least one computer readable medium of Example 40, wherein if the classification of the high energy audio segment comprises the uninteresting sound, the instructions, which when executed by the computing device, further cause the computing device to turn the video off or keep the video off.


Example 44 may include the at least one computer readable medium of Example 40, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, the instructions, which when executed by the computing device, further cause the computing device to turn the video off or keep the video off to maintain privacy of the users.


Example 45 may include the at least one computer readable medium of Example 40, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, the instructions, which when executed by the computing device, further cause the computing device to put video modality on alert.


Example 46 may include the at least one computer readable medium of Example 40, wherein to classify the high energy audio segment as an interesting sound or an uninteresting sound further comprises instructions, which when executed by the computing device, cause the computing device to extract spectral features from the high energy audio segment in predetermined time frames, concatenate the predetermined time frames with a longer context of +/− a predetermined number of frames to form a richer feature that captures temporal variations, and feed the richer feature into a classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 47 may include the at least one computer readable medium of Example 40, wherein to classify the high energy audio segment as an interesting sound or an uninteresting sound further comprises instructions, which when executed by the computing device, cause the computing device to feed raw samples of the high energy audio segment into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 48 may include the at least one computer readable medium of Example 40, wherein to determine if the speech is recognized as the speech of users of the system further comprises instructions, which when executed by the computing device, cause the computing device to extract spectral features from the high energy audio segment in predetermined time frames of an utterance, feed the frames into a backend classifier to obtain a speaker score, and determine if the speaker score matches a speaker model of the users of the system.


Example 49 may include the at least one computer readable medium of Example 40, wherein to determine if the speech is recognized as the speech of users of the system further comprises instructions, which when executed by the computing device cause the computing device to feed raw samples of the high energy audio segment into a deep learning neural network classifier to obtain a speaker score, and determine if the speaker score matches a speaker model of the users of the system.


Example 50 may include the at least one computer readable medium of any one of Examples 48 to 49, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 51 may include the at least one computer readable medium of Example 48, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 52 may include the at least one computer readable medium of Example 49, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 53 may include an apparatus for using an audio trigger for surveillance in a security system comprising means for receiving an audio input stream via a microphone, means for dividing the audio input stream into audio segments, means for filtering high energy audio segments from the audio segments, if a high energy audio segment includes speech, means for determining if the speech is recognized as the speech of users of the system, if the high energy audio segment does not include the speech, means for classifying the high energy audio segment as an interesting sound or an uninteresting sound, and means for determining whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.


Example 54 may include the apparatus of Example 53, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.


Example 55 may include the apparatus of Example 53, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, further comprising means for turning the video on.


Example 56 may include the apparatus of Example 53, wherein if the classification of the high energy audio segment comprises the uninteresting sound, further comprising means for turning the video off or keeping the video off.


Example 57 may include the apparatus of Example 53, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, further comprising means for turning the video off or keeping the video off to maintain privacy of the user.


Example 58 may include the apparatus of Example 53, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, further comprising means for putting video modality on alert.


Example 59 may include the apparatus of Example 53, wherein means for classifying the high energy audio segment as an interesting sound or an uninteresting sound further comprises means for extracting spectral features from the high energy audio segment in predetermined time frames, means for concatenating the predetermined time frames with a longer context of +/− a predetermined number of frames to form a richer feature that captures temporal variations, and means for feeding the richer feature into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 60 may include the apparatus of Example 53, wherein means for classifying the high energy audio segment as an interesting sound or an uninteresting sound further comprises means for feeding raw samples of the high energy audio segment into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.


Example 61 may include the apparatus of Example 53, wherein means for determining if the speech is recognized as the speech of users of the system further comprises means for extracting spectral features from the high energy audio segment in predetermined time frames of an utterance, means for feeding the frames into a backend classifier to obtain a speaker score, and means for determining if the speaker score matches a speaker model of the users of the system.


Example 62 may include the apparatus of Example 53, wherein means for determining if the speech is recognized as the speech of users of the system comprises means for feeding raw samples of the high energy audio segment into a deep learning neural network classifier to obtain a speaker score and means for determining if the speaker score matches a speaker model of the users of the system.


Example 63 may include the apparatus of any one of Examples 61 to 62, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 64 may include the apparatus of Example 61, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 65 may include the apparatus of Example 62, wherein the users of the system enroll their voices into a speaker recognition engine to enable the system to develop the speaker model for each of the users using machine learning techniques.


Example 66 may include at least one computer readable medium comprising a set of instructions, which when executed by a computing system, cause the computing system to perform the method of any one of Examples 27 to 39.


Example 67 may include an apparatus comprising means for performing the method of any one of Examples 27 to 39.


Embodiments are applicable for use with all types of semiconductor integrated circuit (“IC”) chips. Examples of these IC chips include but are not limited to processors, controllers, chipset components, programmable logic arrays (PLAs), memory chips, network chips, systems on chip (SoCs), SSD/NAND controller ASICs, and the like. In addition, in some of the drawings, signal conductor lines are represented with lines. Some may be different, to indicate more constituent signal paths, have a number label, to indicate a number of constituent signal paths, and/or have arrows at one or more ends, to indicate primary information flow direction. This, however, should not be construed in a limiting manner. Rather, such added detail may be used in connection with one or more exemplary embodiments to facilitate easier understanding of a circuit. Any represented signal lines, whether or not having additional information, may actually comprise one or more signals that may travel in multiple directions and may be implemented with any suitable type of signal scheme, e.g., digital or analog lines implemented with differential pairs, optical fiber lines, and/or single-ended lines.


Example sizes/models/values/ranges may have been given, although embodiments are not limited to the same. As manufacturing techniques (e.g., photolithography) mature over time, it is expected that devices of smaller size could be manufactured. In addition, well known power/ground connections to IC chips and other components may or may not be shown within the figures, for simplicity of illustration and discussion, and so as not to obscure certain aspects of the embodiments. Further, arrangements may be shown in block diagram form in order to avoid obscuring embodiments, and also in view of the fact that specifics with respect to implementation of such block diagram arrangements are highly dependent upon the computing system within which the embodiment is to be implemented, i.e., such specifics should be well within purview of one skilled in the art. Where specific details (e.g., circuits) are set forth in order to describe example embodiments, it should be apparent to one skilled in the art that embodiments can be practiced without, or with variation of, these specific details. The description is thus to be regarded as illustrative instead of limiting.


The term “coupled” may be used herein to refer to any type of relationship, direct or indirect, between the components in question, and may apply to electrical, mechanical, fluid, optical, electromagnetic, electromechanical or other connections. In addition, the terms “first”, “second”, etc. may be used herein only to facilitate discussion, and carry no particular temporal or chronological significance unless otherwise indicated.


As used in this application and in the claims, a list of items joined by the term “one or more of” may mean any combination of the listed terms. For example, the phrases “one or more of A, B or C” may mean A; B; C; A and B; A and C; B and C; or A, B and C.


Those skilled in the art will appreciate from the foregoing description that the broad techniques of the embodiments can be implemented in a variety of forms. Therefore, while the embodiments have been described in connection with particular examples thereof, the true scope of the embodiments should not be so limited since other modifications will become apparent to the skilled practitioner upon a study of the drawings, specification, and following claims.

Claims
  • 1. A security system having audio analytics comprising: network interface circuitry to receive an audio input stream via a microphone;a processor coupled to the network interface circuitry;one or more memory devices coupled to the processor, the one or more memory devices including instructions, which when executed by the processor cause the system to:divide the audio input stream into audio segments;filter high energy audio segments from the audio segments;if a high energy audio segment includes speech, determine if the speech is recognized as the speech of users of the system;if the high energy audio segment does not include the speech, classify the high energy audio segment as an interesting sound or an uninteresting sound; anddetermine whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.
  • 2. The security system of claim 1, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.
  • 3. The security system of claim 1, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, the instructions, which when executed by the processor further cause the system to turn the video on.
  • 4. The security system of claim 1, wherein if the classification of the high energy audio segment comprises the uninteresting sound, the instructions, which when executed by the processor further cause the system to turn the video off or keep the video off.
  • 5. The security system of claim 1, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, the instructions, which when executed by the processor further cause the system to turn the video off or keep the video off to maintain privacy of the user.
  • 6. The security system of claim 1, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, the instructions, which when executed by the processor further cause the system to put video modality on alert.
  • 7. An apparatus for using an audio trigger for surveillance in a security system comprising: one or more substrates; andlogic coupled to the one or more substrates, wherein the logic includes one or more of configurable logic or fixed-functionality hardware logic, the logic coupled to the one or more substrates to:receive an audio input stream via a microphone;divide the audio input stream into audio segments;filter high energy audio segments from the audio segments;if a high energy audio segment includes speech, determine if the speech is recognized as the speech of users of the system;if the high energy audio segment does not include the speech, classify the high energy audio segment as an interesting sound or an uninteresting sound; anddetermine whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.
  • 8. The apparatus of claim 7, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.
  • 9. The apparatus of claim 7, wherein if the classification of the high energy audio segment is one of the interesting sounds and the speech is not recognized as a user, the logic coupled to the one or more substrates to turn the video on.
  • 10. The apparatus of claim 7, wherein if the classification of the high energy audio segment is not one of the interesting sounds, the logic coupled to the one or more substrates to turn the video off or keep the video off.
  • 11. The apparatus of claim 7, wherein if the classification of the high energy audio segment is one of the interesting sounds, the speech is recognized as a user, and the contextual data indicates a normal user behavior pattern, the logic coupled to the one or more substrates to turn the video off or keep the video off to maintain privacy of the user.
  • 12. The apparatus of claim 7, wherein if the classification of the high energy audio segment is one of the interesting sounds, the speech is recognized as a user, and the contextual data indicates an abnormal user behavior pattern, the logic coupled to the one or more substrates to put video modality on alert.
  • 13. A method for using an audio trigger for surveillance in a security system comprising: receiving an audio input stream via a microphone;dividing the audio input stream into audio segments;filtering high energy audio segments from the audio segments;if a high energy audio segment includes speech, determining if the speech is recognized as the speech of users of the system;if the high energy audio segment does not include the speech, classifying the high energy audio segment as an interesting sound or an uninteresting sound; anddetermining whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.
  • 14. The method of claim 13, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.
  • 15. The method of claim 13, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, the method further comprising turning the video on.
  • 16. The method of claim 13, wherein if the classification of the high energy audio segment comprises the uninteresting sound, the method further comprising turning the video off or keeping the video off.
  • 17. The method of claim 13, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, the method further comprising turning the video off or keeping the video off to maintain privacy of the user.
  • 18. The method of claim 13, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, the method further comprising putting video modality on alert.
  • 19. The method of claim 13, wherein classifying the high energy audio segment as an interesting sound or an uninteresting sound comprises: extracting spectral features from the high energy audio segment in predetermined time frames;concatenating the predetermined time frames with a longer context of +/−15 frames to form a richer feature that captures temporal variations; andfeeding the richer feature into a deep learning classifier to enable classification of the high energy audio segment as one of the interesting sound or the uninteresting sound.
  • 20. At least one computer readable medium, comprising a set of instructions, which when executed by a computing device, cause the computing device to: receive an audio input stream via a microphone;divide the audio input stream into audio segments;filter high energy audio segments from the audio segments;if a high energy audio segment includes speech, determine if the speech is recognized as the speech of users of the system;if the high energy audio segment does not include the speech, classify the high energy audio segment as an interesting sound or an uninteresting sound; anddetermine whether to turn video on based on classification of the high energy audio segment as the interesting sound, speech recognition of the speech as the speech of the users of the system, and contextual data.
  • 21. The at least one computer readable medium of claim 20, wherein an interesting sound includes one or more of a dog barking, glass breaking, baby crying, person falling, person screaming, car alarm sounding, loud car crash, gun shot, or any other sounds that cause one to be alarmed.
  • 22. The at least one computer readable medium of claim 20, wherein if the classification of the high energy audio segment comprises the interesting sound and the speech is not recognized as the speech of the users of the system, the instructions, which when executed by the computing device, further cause the computing device to turn the video on.
  • 23. The at least one computer readable medium of claim 20, wherein if the classification of the high energy audio segment comprises the uninteresting sound, the instructions, which when executed by the computing device, further cause the computing device to turn the video off or keep the video off.
  • 24. The at least one computer readable medium of claim 20, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates a normal user behavior pattern, the instructions, which when executed by the computing device, further cause the computing device to turn the video off or keep the video off to maintain privacy of the users.
  • 25. The at least one computer readable medium of claim 20, wherein if the classification of the high energy audio segment comprises the interesting sound, the speech is recognized as the speech of the users of the system, and the contextual data indicates an abnormal user behavior pattern, the instructions, which when executed by the computing device, further cause the computing device to put video modality on alert.