People are increasingly utilizing portable electronic devices to perform a wide variety of tasks. As an example, people can utilize a camera of such a device to capture an image of an object. For example, a user can use a camera to capture a still image or video on things in the environment in the camera's field of view. There might be multiple objects in an image or video, and the user may not be able to determine what the objects are or know much about them. People may also desire to identify objects in images obtained from sources other than a device's camera.
For a more complete understanding of the present disclosure, reference is now made to the following description taken in conjunction with the accompanying drawings.
Computing devices may assist users in identifying previously unidentified documents or objects in image(s). The devices may also identify certain text in images and provide the user with a device-executable action associated with the object and/or text. Certain devices have been configured to recognize objects in an image feed from a device-associated camera, such as a built-in camera in a phone or tablet device. For other video or image watching systems, particularly those that draw on pre-recorded video, video-on-demand, broadcast television, or the like, a different configuration for object recognition may be desired.
The present system describes image recognition in an image feed from a source that may be separate from an attached camera. Such an image feed may come from, for example, a television broadcast, cable television source, video-on-demand source, or similar video feed. Images from the video feed are stored in a buffer on a device. Certain processing may be performed on the buffered images as described below. In response to receipt of a user-initiated indication to recognize objects, for example from a remote control, touch interface, etc., the system may perform object recognition. Upon receiving the indication the system may analyze previously stored images in the buffer and determine one or more selected images from which objects may be recognized. The one or more selected images may be images that meet certain image metric criteria (for example being a clear, in-focus image) and/or meet other criteria (such as being part of the image feed at a certain configured time prior to receipt of the indication). The system may send image data from the one or more images (along with potential metadata regarding the images) from a device that receives the user indication to an object recognition server. The server may then perform object recognition and send object data to the device, which will then display the object data so that a user may review it. The user may then navigate the object data through an interface of the device and perform other actions (such as requesting even further information/supplemental content, purchasing a product, etc.).
In recognition systems, such as that disclosed herein, a computing device may be enabled to analyze information, such as image data stored in an image buffer, to attempt to identify one or more objects represented in the image data. The system may then obtain supplemental content, or suggest potential functions for user execution, based on the object(s) represented in the information. Supplemental content may include information about a recognized object that is not otherwise discernable from the information available to the user's device absent the object recognition system. The objects can include tangible and/or intangible objects, such as may include, for example, text strings, bar codes, products, individuals (for example persons identifiable using facial recognition techniques), etc. The system may match the recognized object to other information sources and retrieve information from those sources to present to the user. This matching may occur substantially in real-time, to provide the user with an experience of having supplemental content/functionality available while engaging with primary content (such as the video feed).
As illustrated in
The video signal may continue to be displayed on the television 110b until the system receives (156) an indication to identify object(s) in one or more images of the video signal. For example, a user 102 may be watching a television program and see an object that he/she wishes to learn more about. The user may then push a button on the remote control 125 which sends an indication to the set-top box 110a to perform object recognition. Upon receipt of the indication, the set-top box 110a may determine (158) image data from the buffer. The determined image data may be image data corresponding to images that were stored in the buffer prior to the time the indication was received or prior to the time the indication was made (if the indication is associated with a timestamp or other time indicator). The system 100 (through the set-top box 110a) may then go backwards through the buffer to determine what image(s) were intended to be recognized by the user, what image(s) may be processable by the recognition server 140b, what image(s) are likely to include recognizable object(s), etc. The system 100 may then send (160) the determined image data (which may include images, portions of images, metadata related to images, etc.) to the recognition server 140b for processing. The recognition server is capable of running one or more image recognition or analysis algorithms on the image data to attempt to recognize objects in the image as well as identify text within the image. This can include, for example, at least one optical character recognition (OCR) algorithm.
The recognition server 140b may receive the image data (and any accompanying data) and process that data to recognize object(s) represented in the image data. In
Although not illustrated in
A device may enter a discovery/recognition mode in response to a user selection (such as selecting a discovery launch button), in response to power on (or wake up) of the device or through some other way. The system may even perform object recognition or identification (and supplemental content identification) on content items before they are even accessed by a user device, for example using images in an image buffer in anticipation of eventually receiving a user-instigated command to perform object identification and/or recognition. For present purposes, object identification refers to the process of determining the presence of a potentially recognizable object in an image and object recognition refers to the process of determining what the object is. (I.e., an image recognition process may determine that there are two objects in an image and an object recognition process may determine that the first image is an Amazon Kindle Paperwhite and the other object is a coffee mug.) Either recognition and identification may be used when generally describing the operation of the system. However, when one operation is to be distinguished from the other, appropriate distinctions will be described in the text.
Different recognition algorithms and/or services may be used to perform object recognition to recognize different types of objects. For example, a string might be recognized as text that matches a determined pattern, such as a pattern indicating the text is a phone number or URL. Accordingly, information for these objects might be processed by a different algorithm or process. The different types of processing therefore can result, in at least some aspects, in different objects being recognized at different times. Similarly, different objects might be recognized at different times due to changes in the image that enable different portions to be recognized at different times, among other such options.
In response to a second object being recognized, as illustrated in the example situation 240 of
In various aspects, a type of the object can also be determined. In at least some aspects, this can include at least an “actionable” or a “non-actionable” type, or equivalent(s). For example, a text string such as “to entertainment” might be a portion of text that can be handled as normal text, such as for copying and pasting, which might not be considered an actionable object/text in at least some aspects (while being considered actionable in others). Objects/text such as a phone number or URL might be considered to be actionable objects as the computing device can perform at least one specific function with respect to each of these objects that might be of interest to a user. For each actionable object, every recognized object, or at least one recognized actionable object, for example, the interface can provide a user-selectable input, icon, or element associated with the representation of that object. In other aspects, a user-selectable input or element might be provided for each recognized object, or a specific subset of recognized objects, among other such options. Objects such as barcodes and quick response (QR) codes might be considered either actionable or not actionable objects in different aspects. Similarly, objects such as songs might be considered actionable if the software is linked to a song identification and/or purchasing source, and text might be considered actionable if a translation is available.
In various aspects, the user-selectable icon can take the form of what will be referred to herein as a “ribbon” 244, although various other types of elements or objects can be utilized as well within the scope of the various aspects as discussed and suggested elsewhere herein. In this aspect, a ribbon 244 may be comprised of at least two parts: information about the object and information about at least one action that can be taken. As illustrated, the ribbon can list the phone number that was recognized, such that the user can determine whether the phone number was properly recognized before using the number. The ribbon can also identify the action that can be taken, in this case using a phone icon and including the word “dial,” although various other indications can be used as well. In some aspects the user might be able to select from different options or cause a specific action to be associated with a type of object, such as where a user would like to send a text, or make a video call instead of a conventional phone call, among other such options. In certain embodiments, such as an embodiment where the ribbons are displayed on a limited functionality device, such as a television set, certain functionality options may be removed in order to improve the user experience (for example by removing functionality that would be difficult to execute using remote control 125).
In some aspects, such as when operating on a touch sensitive device, a ribbon might have two touch targets: a first target that comprises approximately 80% of the area of the ribbon that enables the user to select the primary action, and a second target of approximately 20% of the ribbon area that enables the user to go to a detail card, or other such element, that provides other actions or plugins applicable to that object, as well as potentially a copy of the image that was used to recognize the object for context, among other such possibilities. As discussed, a ribbon in some aspects can include at least three things to display: an image relating to the object, a title or name of the object, and a source of disambiguation, such as an author or artist name to help a user distinguish that object from other objects with the same or similar names or titles, etc. Ribbons (or other user-selectable icons) can also provide different actions for various types of objects. For example, a ribbon can include an action to purchase or download a song that was recognized from audio data, or to play a movie that was recognized from audio data and/or video data captured by one or more sensors of the device.
As illustrated in the example situation 260 of
As illustrated in the example situation 280 of
In many instances, as mentioned, there can be multiple actions that can be taken. For example, a phone number might be used for text messaging, a voice call, or a video call. If a URL contains a foreign word, actions might include opening the URL in a Web browser or translating the word. Various other actions can apply as well. Accordingly, in at least some aspects the types of action may be selectable by a user, or the algorithms for suggesting these actions might be ranked or otherwise prioritized. For example, an object being recognized as a URL might always take precedence over the object being identified to contain a foreign term, as the user will be more likely on average to want to follow the URL than to translate it. In some cases, such as where a user can make a voice, video, or VoIP call, for example, the device might analyze the user's historical usage or present the user with options or preferences, for example, that can determine which action to provide to the user in a ribbon. In at least some aspects, the ribbon can contain an option that enables the user to view other available actions, and select one or more of those actions to be performed.
The various processing steps described here may be performed entirely by one device or divided among multiple devices. For example, a local user computing device may perform certain functions (such as identifying that objects appear in an image) and a remote server may perform other functions (such as recognizing what the objects are). In a remote computing configuration, more complex processing tasks, such as image processing, recognizing actionable objects within content, etc. may be performed by a remote server. The same remote server (or group of servers) may perform object recognition on images from an image feed, such as images stored in a buffer.
In order to provide at least some of the functionality discussed herein, in at least some aspects an amount of image processing (or pre-processing) can be performed on the local (i.e., user) computing device. This can include, for video data, identifying regions such as edges or sharp transitions that are likely to correspond to recognizable objects. For example, the detection of unique or interesting features or characteristics can be performed on the local device, in order to determine whether there is sufficient data to warrant sending an image (or data extracted from the image) to a remote server. In some embodiments, there can be an amount of pattern matching performed on the device to determine whether the features likely correspond to a representation of a recognizable object, in order to cause the fireflies to move to that location before a full recognition is done and/or image data is sent to a server. Further, basic pattern matching can help the device to determine a likely type of object, such as whether the object is a body or string of text, a quick response (QR) code, etc. The behavior and/or characteristics of the graphical elements may then change as appropriate before data is sent to and/or received back from a server, reducing the lag time experienced by users of the device. Similarly, if a quick match on the device can identify an object as something already recognized, for which there is data stored on the device, the graphical elements may use a color, shape, and/or size appropriate for that object, for example, and a corresponding ribbon can be presented without need to contact a remote server or service, etc. Further, a local device may be configured to perform object identification on images in a buffer, including determining coordinate(s) associated with identified objects. The local device may then send image data along with metadata that may include the coordinate(s) data to a remote server for object recognition. By performing object identification ahead of time, object recognition in response to a user indication may be performed more quickly. This is described further in reference to
The buffer described herein may maintain a certain number of images from the video signal in a circular fashion and may overwrite older images as new images in the series are received. An indication to perform object recognition may be associated with a time, be that the time the indication is made (for example, the time the button on the remote control 125 is pushed) or the time the indication is received (for example, when the indication is received by the device). To preserve the time the indication is made the remote control 125 may be equipped to create a timestamp associated with the indication. The timestamp may then also be sent from the remote control 125 to the device 110. If the device is a touchscreen device, such as a tablet 110c, the time the indication is received may be the same as the time the indication is made.
When the indication is received, a device may go through the buffer of stored images to identify one or more images that were stored in the buffer prior to the indication being received/made. This is so the system can determine an image(s) to select that may contain the object the user wished to identify that led to the indication. Determining the selected image may include analyzing the image metrics of the images to determine what images may be likely for a recognition server 140b to process.
Although described in reference to image data, object recognition may also be performed for audio objects detected in the video signal. In such an operation, audio data may be buffered and sent from the device 110 to the recognition server
For example, as shown in
As part of determining images and image data that will be processed for object recognition, a local device 110 may perform certain operations prior to sending image data to a recognition server 140b. In certain embodiments a local device may perform some pre-processing to assist the recognition server 140b and to generally reduce the amount of time it takes to perform object recognition tasks, thus reducing any lag noticeable to a user. Such pre-processing may take a number of forms. In one example, a device 110 may perform preliminary object identification processing, where the device 110 analyzes images in the buffer to determine where objects may be located in an image. Such pre-processing may be performed even before an indication is received, such as from remote control 125, to perform object recognition. In this way the device 110 may preliminarily determine where in an image object(s) are located. Such pre-processing may create metadata that is associated with the video signal, for example, metadata associated with each individual image. The metadata may then be stored by the device 110 and associated with the respective image in the buffer. When an indication to perform object recognition is received, the metadata may be sent to a recognition server 140b along with the image data to assist in the object recognition process.
The metadata may include various different types of data. For example, the metadata may include processed representations of images in the buffer, for example a binarized e.g., black and white) version of an image. Other examples of metadata may include image metric data relating to an image, timestamp information relating to an image's position in the buffer and/or in the video signal, feature vectors describing an image, or the like. The metadata may also include data relating to audio portions of the video signal. For example, compressed or otherwise processed audio, timestamp data describing the position of the audio in the buffer and/or in the video signal, feature vectors describing the audio of the signal, etc. The metadata may be sent to the server along with image data and/or audio data for purposes of performing object recognition.
One process for performing the pre-processing is described in reference to
After receiving an indication to perform object recognition, a system may identify a range of images that is located a certain time from the indication, for purposes of object recognition. For example, if an indication is received at time X, the system may identify images from a range between X-2 seconds and X-1 seconds, to account for a delay in a desired image being displayed and the user executing an action to generate the indication. A flowchart for performing such an operation is shown in
An example of this is shown in
As noted above, if an indication to perform object recognition is received at time T5, the system may look backward in the buffer according to the time offset to identify images to be sent for recognition. For example, the system may be configured, based on the playback rate, to look four time steps backwards. Thus in response to an indication received at time T5, the system may analyze image 1 802 from time T1 as a potential image to send to the recognition server 140b. The length of the backward time offset is configurable, and may depend on a number of considerations such as user settings, determined user response time, previously selected objects during object recognition, etc. The images selected may then provide image data (such as the images themselves, portions thereof, metadata, etc.) to be sent to the recognition server 140b.
When the indication is received, the device may pause playback of the video series until the object recognition process is completed. The paused image frame may be associated with the receipt of the indication or may be associated an image in the buffer related to how far back the system searches for object recognition purposes. This is illustrated in
Upon receipt of the object data, the system may display a user interface including the paused image and/or other user interface elements related to the recognized objects, such as the ribbons discussed above. The user interface may also include a visually enhanced representation of the recognized object(s). An example such user interface shown on a display is shown in FIG. 8C. As shown, the display may include the original image 1 and pause indicator 812. The user interface may also include a ribbon 816 indicating a recognized object and certain object data (in this case a picture of the object and a description of the object). The user interface also includes the recognized object highlighted, in this case frame 814, shown in dotted lines to represent highlighting. As noted above, other forms of visual enhancement are also possible.
In another embodiment the user interface may also display ribbons associated with multiple different images from the video signal. Referring again to
For example,
One example user interface is illustrated in
The device 110 may also display an image including user navigable UI elements so that the user may perform additional operations regarding the recognized objects. For example, as shown in
The user interface showing the ribbons may be operable by a user according to navigation commands received from a remote control, input onto a touchscreen, or the like. As shown in
As shown in
When the user navigates to a desired object, the user may press a “select” or similar button on the remote control 125. The remote control 125 may then send the second indication, which is received (1018) by the device. The device may then send a request for further information about the selected object (in the case of
As described above, object recognition from images in a video signal is also possible when the device is touchscreen enabled, such as with a tablet 110c. As shown in
To create the user interface for the screens shown above a device may overlay an image display by injecting code into an image file and displaying the altered image file. Such operations may be allowed by certain operating systems (e.g., Android) and/or certain applications (such as a Chrome browser) or languages (e.g., HTML), etc. Techniques for performing such operations are known in the art.
In one configuration, objects recognized by the system 100 may be associated with some linking factor, such as a user ID, household ID, etc. and stored in a retrievable manner, for example through the user ID. In such a configuration, objects that are recognized by the system 100 may be tracked as associated with the user ID and may be stored, for example, by a remote server, and accessible using a particular notepad function, or other application, for later retrieval. Such a configuration may assist when multiple objects are detected during an object recognition process (for example multiple products, songs, etc.) making it difficult for a user to navigate when viewing a television 110b. The recognized objects (or identifying information thereof) may thus be stored for later perusal by a user. Such a configuration may also assist if functionality regarding a found object (e.g., making a telephone call to a recognized number), is difficult in a current viewing environment.
In such an embodiment, the device may use back-end cloud-based information to enhance the user experience when performing object recognition. A first device, such as a television, tablet, etc. may be associated with a user or household ID. That user ID may be linked to a number of other devices. Or, a user may be operating two different devices (either simultaneously or at different times) and be able to access a remote account that is linked to objects recognized during the user's operation of one or more of the devices. For example, a user may perform object recognition while watching a video and the recognized objects may be linked to the user's account or user profile and stored remotely. The user may then access the recognized objects using another network accessible device.
For example, as shown in
As shown in
Using the situation illustrated in
As noted above, object information may be stored for later retrieval. The organization of the stored object information may depend on the objects found. While all object information may be made available through a single interface (for example, an object notebook or the like), different objects may be accessed in different ways depending on the objects. For example, a purchasable object may be associated with a shopping application using the individual product identification number associated with the recognized object, recognized music may be associated with a music application (or device), a recognized telephone number may be associated with a telephone application (or device), a recognized uniform resource locator (URL) may be associated with an internet browsing application (or device), or the like. Object information may also be organized by program. For example, all objects recognized in a certain program of the video signal may be organized together so the user may later browse those objects together. For example, the user may browse all objects recognized in season 1, episode 3 of “Mozart in the Jungle.” The user may also select which object(s) to save, thus creating a save-for-later “wish list” or similar record rather than the system saving information about every recognized object. In this manner the user may customize what objects are saved for later reference. When later browsing an object list, the system may redisplay portions of the video signal (including image and/or audio data) from where the object was recognized, thus improving user recall of the object. Thus individual object data may be stored with other information, such as a timestamp (which may relate to a broadcast time, viewing time, or other time), associated program, product/object ID, user ID, video signal information, etc.
Each of the device 110 and the server 140 may include one or more controllers/processors 1304/1404 comprising one-or-more central processing units (CPUs) for processing data and computer-readable instructions, and a memory 1306/1406 for storing data and instructions. The memory 1306/1406 may include volatile random access memory (RAM), non-volatile read only memory (ROM), non-volatile magnetoresistive (MRAM) and/or other types of memory. The device 110 and the server 140 may also include a data storage component 1308/1408 for storing data and processor-executable instructions. The data storage component 1308/1408 may include one or more non-volatile storage types such as magnetic storage, optical storage, solid-state storage, etc. The device 110 and server 140 may also be connected to a removable or external non-volatile memory and/or storage (such as a removable memory card, memory key drive, networked storage, etc.) through the input/output device interfaces 1302/1402.
Executable instructions for operating the device 110, the server 140, and their various components may be executed by the controller(s)/processor(s) 1304/1404, using the memory 1306/1406 as temporary “working” storage at runtime. The executable instructions may be stored in a non-transitory manner in non-volatile memory 1306/1406, storage 1308/1408, or an external device. Alternatively, some or all of the executable instructions may be embedded in hardware or firmware in addition to or instead of software.
Referring to
The server 140 may include an address/data bus 1324 for conveying data among components of the server 140. Each component within the server 140 may also be directly connected to other components in addition to (or instead of) being connected to other components across the bus 1324.
The server 140 may further include a recognition module 1330 that performs recognition on content captured by or available to the device 110, such as the recognition operations discussed above. For example, the device 110 may send image data (either raw or processed) to the server 140 for the server to perform recognition on the image data. The image data may include single still images, a video feed, or portions of still images or a video feed, such as isolated or processed portions thereof. The recognition module 1330 may include a variety of components, including an image recognition engine 1360, OCR engine 1362, recognition database 1330, or other components such as an audio recognition module (not shown) or the like. The recognition database 1368 may store data used by the various engines/processors of the recognition module 1330 such as image data, audio data, OCR language models, OCR dictionaries, and the like.
The recognition module 1330 may also be configured to perform recognition on audio portions of a video signal. For example, if a particular song, jingle, or other musical composition is included in a video signal discussed above, the system (for example using the recognition engine 1360) may be configured to recognize the musical composition and interact with other components of the system (the supplemental content module 1380, the function module 1370, the device 110, etc.) to display information regarding the musical composition, and allow the user to perform additional actions regarding the musical composition (for example, adding it to a playlist, purchasing a song, etc.). The recognition module 1330 may also be configured to recognize words included in audio (even if not part of a musical composition). Those recognized words may also be processed by the system to determine additional information/functionality based on those words and to display those for further user navigation/selection. For example, if an audio portion of the video signal mentions a specific travel destination, the system may be configured to recognize the location, and in response to a user indication, display navigable information regarding the destination. Such recognizable items in an audio signal (music, locations, etc.) may also be considered recognizable objects as described above. Information about such objects may also be displayed and navigated as described above in reference to objects found in image portions of the video signal. The recognition module 1330 may communicate with the supplemental content module 1380.
The supplemental content module 1380 may identify supplemental content related to objects recognized by the recognition module 1330. Such supplemental content may include other content or information related to objects recognized by the recognition module 1330 where the supplemental content is not necessarily included in the specific content item in which the recognized object is found. For example, if a landmark is recognized in a video, supplemental content may include general information about the landmark, other images of the landmark, calendar entries of a user corresponding to visits to the city in which the landmark is located, social media content discussing the landmark or the landmark's location where the social media content is associated with the user (for example, posts by the user's friends or family), or the like. In another example, if a specific song is recognized in audio data, supplemental content may include the name of the composer of the song, a band name, an album title, other versions of the song, a list of social media contacts who have the song in their music collections, concert dates for the band, etc. The supplemental content engine 1382 may cross reference an identified object with one or more information sources, including a supplemental content database 1388, which may include database entries tracking certain potential recognized objects or object classes (e.g., person, place, song, product, etc.) and their corresponding supplemental content or potential supplemental content types. Given the vast amount of information that may qualify as supplemental content, the supplemental content module 1380 may communicate with a multitude of other information sources including those located remotely from the server 140. For example, the supplemental content module 1380 may communicate with Internet sources, retailers, library catalogs, etc. to identify supplemental content. Once supplemental content related to a recognized object is identified, it may be sent to the device 110.
In addition to supplemental content, the recognition system may determine one or more potential user-selectable function based on recognized objects. The-user selectable function causes the system (upon selection by the user) to perform some action based on the particular recognized object. Such potential user-selectable functions may be presented to the user on the mobile device, for example using the ribbons discussed above. The function module 1370 operates to select one or more functions to present to a user, for example in ribbons 244, 264, or 282. The functions may be based on objects recognized in a content item stored on or otherwise accessible to the device 110. Selection of one of the functions by the user leads to execution of the function by the device 110, server 140, or other device. Accordingly, the function module 1370 may communicate with one or more other components such as application modules of the device 110, other servers, etc. For example, if a function module 1370 determines that based on recognition of a telephone number by recognition module 1330, the user should be presented with options to dial a telephone number or add the number to a contact, the function module 1370 may send a command to a telephone application of a device 110 if the user selects the function to make a call, or the function module 1370 may send a command to a contact module (located either at the device 110 or elsewhere) if the user selects the function to add to a contact. The function module 1370 may communicate with the supplemental content module 1380 to offer the user different functions based on identified supplemental content. The function module may include components such as a function selection engine 1352 which analyzes the recognition and supplemental content data to select one or more functions to offer to a user and their relative priority and a function database 1358 which stores information used by the function selection engine 1352. Although multiple storage entities are illustrated, the various storage/databases 1358, 1368, 1388, and/or 1308 may be combined in various configurations.
The server 140 may also include a user information database 1390. The user information database 1390 may include user identification information (such as user ID numbers), user profile information, and other user information that may be used in sharing object data between devices, for example as described above in reference to
Referring to
The antenna 1422 and related components (e.g., radio transmitter/receiver/transceiver, modem, etc.) may be configured to operate with a wireless local area network (WLAN) (such as WiFi), Bluetooth, and/or wireless networks, such as a Long Term Evolution (LTE) network, WiMAX network, 3G network, etc. The antenna 1422 may also be capable of receiving television or other image broadcast signals.
The audio capture component may be, for example, a microphone 1450 or array of microphones, a wired headset (not illustrated), a wireless headset (not illustrated), etc. If an array of microphones is included, approximate distance to a sound's point of origin may be performed acoustic localization based on time and amplitude differences between sounds captured by different microphones of the array.
The touch interface 1414 may be integrated with a surface of a display 1412 or may be separate (e.g., a touch pad). The touch interface may be of any technology such as capacitive, resistive, optical/infrared, thermal/temperature, piezoelectric, etc. Other pointing devices for interacting with a graphical user interface (GUI) may be included, such as a touchpad, a trackball, or a mouse.
The global positioning module 1462 provides an interface for acquiring location information, such as information from satellite geographic positioning system(s). For example, the global positioning module 1462 may include a Global Positioning System (GPS) receiver and/or a Global Navigation Satellite System (GLONASS) receiver. The global positioning module 1462 may also acquire location-based information using other radio sources (e.g., via antenna 1422), such as mapping services that triangulate off of known WiFi service set identifiers (SSIDs) or cellular towers within range of the device 110.
The field sensor module 1464 provides directional data. The field sensor module 864 may include a 3-axis magnetometer that measures magnetic fields and may serve as a compass. The field sensor module 1464 may also include a dedicated gravity sensor to determine up-and-down.
The motion sensor module 1466 provides inertial data, and may include 3-axis accelerometer and a 3-axis gyroscope.
Examples of other sensors include an electronic thermometer to measure ambient temperature and a proximity sensor to detect whether there is an object within a certain distance of the device 110.
Sensors may be communicatively coupled with other components of system 100 via input/output (I/O) device interfaces 1402 and/or via an address/data bus 1424. The address/data bus 1424 conveys data among components of the device 110. Each component within the device 110 may also be directly connected to other components in addition to (or instead of) being connected to other components across the bus 1424.
The I/O device interfaces 1402 may connect to a variety of components and networks. Among other things, the I/O device interfaces 1402 may include an interface for an external peripheral device connection such as universal serial bus (USB), FireWire, Thunderbolt or other connection protocol. The input/output device interfaces 1402 may also support a variety of networks via an Ethernet port and antenna 1422.
The device 110 may also include a video output component for displaying images, such as display 1412. The video output component may be a display of any suitable technology, such as a liquid crystal display, an organic light emitting diode display, electronic paper, an electrochromic display, a pico projector, etc. The video output component may be integrated into the device 110 or may be separate.
The device 110 may also include an audio output component such as a speaker 1418, a wired headset (not illustrated), or a wireless headset (not illustrated). Other output devices include a haptic effect generator (not illustrated). The haptic effect generator may be of any haptic technology, including technologies to vibrate the entire device 110 (e.g., electromagnetic technologies such as vibratory motor or a coil with a central mass) and/or may comprise technologies allowing the haptic effect to be localized to a position of the touch interface 1414, such as electroactive polymers, piezoelectrics, electrostatics, subsonic audio wave surface actuation, etc.
As discussed above, device 110 includes controller(s)/processors 1404, memory 1406, and storage 1408. In addition, the mobile device may include an identification module 1430 which may comprise processor-executable instructions stored in storage 1408 to be executed by controller(s)/processor(s) 1404 (e.g., software, firmware), hardware, or some combination thereof. For example, components of the identification module 1430 may be part of a software application running in the foreground and/or background on the device 110.
The device 110 may include buffer 1440 which may store portions of the received video signal as discussed above. The buffer 1440 may store images, image data, or audio portions of the video signal. Buffered audio may also be processed by the system to recognize audio objects, as described above with regard to the recognition module 1330. The buffer 1440 may be a set memory size (for example a certain number of MB, GB, etc.) or may be configured to store a certain number of video frames and their corresponding audio data based on the configuration of the video signal. For example, the buffer 1440 may be configured to hold 2 minutes of the video signal, so the size of the buffer may increase or decrease depending on how much memory each frame of video signal requires (for example if the video signal is a standard definition signal, high definition signal, 4K signal, MPEG-4 signal, etc.). In such a configuration other memory (for example, certain portions of memory 1406) may be allocated to the buffer 1440 as needed based on the configuration of the video signal. In other configurations the size of the buffer 1440 may be configured by the device 110, the user 102, or by some other component of the system 100.
The identification module 1430 may include a processing engine 1432 and processing database 1434. In one example, the processing engine 1432 may perform a certain amount of processing of image data prior to sending to the server 140. For example, if a server 140 was configured for OCR processing of the image data, the processing engine 1432 may convert color image data to black and white image data e.g., binarizing) to both assist with OCR processing and reduce the bandwidth consumed when sending image data to the server. The processing engine 1432 may also identify sections of image data including objects and isolate those portions for sending to the server 140 to reduce bandwidth usage and/or speed recognition processing, for example as described above and in reference to
Although not illustrated, the device 110 may also include a function module, such as function module 1370 configured to determine, select, and/or potentially execute potential user-selected functions based on recognized objects found in image data, such as that described above.
Referring to
The concepts disclosed herein may be applied within a number of different devices and computer systems, including, for example, general-purpose computing systems, speech processing systems, and distributed computing environments.
The above aspects of the present disclosure are meant to be illustrative. They were chosen to explain the principles and application of the disclosure and are not intended to be exhaustive or to limit the disclosure. Many modifications and variations of the disclosed aspects may be apparent to those of skill in the art. Persons having ordinary skill in the field of computers and speech processing should recognize that components and process steps described herein may be interchangeable with other components or steps, or combinations of components or steps, and still achieve the benefits and advantages of the present disclosure. Moreover, it should be apparent to one skilled in the art, that the disclosure may be practiced without some or all of the specific details and steps disclosed herein.
The various aspects can be further implemented in a wide variety of operating environments, which in some cases can include one or more user computers or computing devices which can be used to operate any of a number of applications. User or client devices can include any of a number of general purpose personal computers, such as desktop or laptop computers running a standard operating system, as well as cellular, wireless and handheld devices running mobile software and capable of supporting a number of networking and messaging protocols. Such a system can also include a number of workstations running any of a variety of commercially-available operating systems and other known applications for purposes such as development and database management. These devices can also include other electronic devices, such as dummy terminals, thin-clients, gaming systems and other devices capable of communicating via a network.
Most aspects utilize at least one network that would be familiar to those skilled in the art for supporting communications using any of a variety of commercially-available protocols, such as TCP/IP, FTP, UPnP, NFS, and CIFS. The network can be, for example, a local area network, a wide-area network, a virtual private network, the Internet, an intranet, an extranet, a public switched telephone network, an infrared network, a wireless network and any combination thereof.
In aspects utilizing a Web server, the Web server can run any of a variety of server or mid-tier applications, including HTTP servers, FTP servers, CGI servers, data servers, Java servers and business application servers. The server(s) may also be capable of executing programs or scripts in response requests from user devices, such as by executing one or more Web applications that may be implemented as one or more scripts or programs written in any programming language, such as Java®, C, C# or C++ or any scripting language, such as Perl, Python or TCL, as well as combinations thereof. The server(s) may also include database servers, including without limitation those commercially available from Oracle®, Microsoft®, Sybase® and IBM®.
The environment can include a variety of data stores and other memory and storage media as discussed above. These can reside in a variety of locations, such as on a storage medium local to (and/or resident in) one or more of the computers or remote from any or all of the computers across the network. In a particular set of aspects, the information may reside in a storage-area network (SAN) familiar to those skilled in the art. Similarly, any necessary files for performing the functions attributed to the computers, servers or other network devices may be stored locally and/or remotely, as appropriate. Where a system includes computerized devices, each such device can include hardware elements that may be electrically coupled via a bus, the elements including, for example, at least one central processing unit (CPU), at least one input device (e.g., a mouse, keypad, controller, touch-sensitive display element or keypad) and at least one output device (e.g., a display device, printer or speaker). Such a system may also include one or more storage devices, such as disk drives, optical storage devices and solid-state storage devices such as random access memory (RAM) or read-only memory (ROM), as well as removable media devices, memory cards, flash cards, etc.
Such devices can also include a computer-readable storage media reader, a communications device (e.g., a modem, a network card (wireless or wired), an infrared communication device) and working memory as described above. The computer-readable storage media reader can be connected with, or configured to receive, a non-transitory computer-readable storage medium representing remote, local, fixed and/or removable storage devices as well as storage media for temporarily and/or more permanently containing, storing, and retrieving computer-readable information. The system and various devices also typically will include a number of software applications, modules, services or other elements located within at least one working memory device, including an operating system and application programs such as a client application or Web browser. It should be appreciated that alternate aspects may have numerous variations from that described above. For example, customized hardware might also be used and/or particular elements might be implemented in hardware, software (including portable software, such as applets) or both. Further, connection to other computing devices such as network input/output devices may be employed.
Storage media and other non-transitory computer-readable media for containing code, or portions of code, can include any appropriate media known or used in the art, including storage media and communication media, such as but not limited to volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data, including RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disk (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices or any other medium which can be used to store the desired information and which can be accessed by a system device. Based on the disclosure and teachings provided herein, a person of ordinary skill in the art will appreciate other ways and/or methods to implement the various aspects.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereunto without departing from the broader spirit and scope of the invention as set forth in the claims.
Number | Name | Date | Kind |
---|---|---|---|
20070078732 | Crolley | Apr 2007 | A1 |
Entry |
---|
Tivo. “About Tivo Premiere and Premiere XI.” Mar. 6, 2010. Accessed Aug. 18, 2016, http://www3.tivo.com/buytivo/faqs/aboutpremiere/ index.html. |