The present disclosure relates generally to methods of collection of data of an environment and/or of objects in the environment, and more particularly, to generating a knowledge graph of an environment or an object including data organized in a hierarchical semantic manner to illustrate relationships between the object and the environment.
With increased usage of computing networks, such as the Internet, people have access to an overwhelming amount of information from various structured and unstructured sources. However, information gaps are present as users may try to piece together what they can find that they believe to be relevant during searches for information on various subjects. Generally, searching on the Internet using a search engine results in many hits, and often times, a specific item of interest cannot be found.
Search engines sometimes reference knowledge graphs to provide search results with semantic search information, and the information can be gathered from a wide variety of sources. A knowledge graph includes data organized in a meaningful way to show connections between the data. Effectiveness of the knowledge graph is based on an amount of information contained in the graph as well as an amount of detail among the links between the data.
As mentioned, knowledge graphs are generated by gathering information from a. wide variety of sources. Typically, a knowledge graph is generated by performed web crawling of the Internet or other networks to obtain as much information as possible about a topic or object of interest. However, even still, much information can be missing in the knowledge graph such that a complete data set of the topic or object of interest cannot be found. Improvements are therefore desired.
In one example, a computer-implemented method is described. The computer-implemented method comprises obtaining, using a camera of a computing device, a two-dimensional (2D) image of an object, receiving, from a server, an identification of the object based on the 2D image of the object, obtaining, using one or more sensors of the computing device, additional data of the object, obtaining, using the one or more sensors of the computing device, additional data of a surrounding environment of the object, and generating a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object.
In another example, a computing device is described. The computing device comprises a camera, one or more sensors, at least one processor, memory, and program instructions, stored in the memory, that upon execution by the at least one processor cause the computing device to perform operations. The operations comprise obtaining, using the camera, a two-dimensional (2D) image of an object, receiving, from a server, an identification of the object based on the 2D image of the object, obtaining, using the one or more sensors, additional data of the object, obtaining, using the one or more sensors, additional data of a surrounding environment of the object, and generating a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object.
In still another example, a non-transitory computer-readable medium is described having stored therein instructions, that when executed by a computing device, cause the computing device to perform functions. The functions comprise obtaining, using a camera of the computing device, a two-dimensional (2D) image of an object, receiving, from a server, an identification of the object based on the 2D image of the object, obtaining, using one or more sensors of the computing device, additional data of the object, obtaining, using the one or more sensors of the computing device, additional data of a surrounding environment of the object, and generating a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object.
The features, functions, and advantages that have been discussed can be achieved independently in various examples or may be combined in yet other examples further details of which can be seen with reference to the following description and figures.
The novel features believed characteristic of the illustrative examples are set forth in the appended claims. The illustrative examples, however, as well as a preferred mode of use, further objectives and descriptions thereof, will best be understood by reference to the following detailed description of an illustrative example of the present disclosure when read in conjunction with the accompanying figures, wherein:
Disclosed examples will now be described more fully hereinafter with reference to the accompanying figures, in which some, but not all of the disclosed examples are shown. Indeed, several different examples may be provided and should not be construed as limited to the examples set forth herein. Rather, these examples are provided so that this disclosure will be thorough and complete and will fully convey the scope of the disclosure to those skilled in the art.
Described herein are systems and methods for generating a knowledge graph and/or modifying an existing knowledge graph. Methods include obtaining, using a camera of a computing device, a two-dimensional (2D) image of an object, and receiving an identification of the object based on the 2D image of the object. The methods further include obtaining, using one or more sensors of the computing device, additional data of the object, and additional data of a surrounding environment of the object. Following, methods include generating a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object.
One example method involves obtaining additional data of the object such as images of the object from additional points of view. Another example method involves obtaining additional data of the object such as depth images of the object. Still another example involves obtaining additional data of the object such as, using the microphone, obtaining audio from the surrounding environment of the object.
In an example scenario, the computing device is or includes a robotic device operable to move throughout an environment, and the robotic device moves around the object to collect additional data of the object using one or more sensors on-board the robotic device.
Additional data of an object or of an environment of the object may include data of any kind such as images, audio, location data, contextual data, and semantic data. In some examples, a person can be associated with the object, and the additional data includes information indicating the person who is associated with the object to label the object as belonging to the person.
One example device includes a computing device having a camera, one or more sensors, at least one processor, memory, and program instructions, stored in the memory, that upon execution by the at least one processor cause the computing device to perform operations of obtaining, using the camera, a two-dimensional (2D) image of an object, and receiving an identification of the object based on the 2D image of the object. The device then obtains, using the one or more sensors, additional data of the object, and additional data of a surrounding environment of the object. The device may then generate a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object.
Advantageously, the systems and methods disclosed herein may facilitate generation of a knowledge graph, and enable collection of data in a variety of manners to collect a full data set of the object or the environment. Data collection may be performed autonomously by a robotic device, or manually by a user using a computing device.
Using the example systems and methods, new and existing datasets of objects and environments can be further semantically labeled to create or modify a knowledge graph and start a tree of knowledge, and as well as link new observations off of the existing graphs. New observations can include new types of information, namely, depth image data, audio data, activity data, contextual data, etc. Further, observations of contextual data that led up to detecting the object can be associated with the object in the graph.
Various other features of these systems and methods are described hereinafter with reference to the accompanying figures.
Referring now to
Robotic devices 102a, 102b may be any type of device that has at least one sensor and is configured to record sensor data in accordance with the embodiments described herein. In some cases, the robotic devices 102a, 102b, may also include locomotion capability (e.g., drive systems) that facilitate moving within an environment.
As shown in
Server device 104 may be any type of computing device configured to carry out computing device operations described herein. For example, server device 104 can include a remote server device and may be referred to as a “cloud-based” device. In some examples, server device 104 may include a cloud-based server cluster in which computing tasks are distributed among multiple server devices. In line with the discussion above, server device 104 may be configured to send data 114 to and/or receive data 112 from robotic device 102a via communications network 110. Server device 104 can include a machine learning server device that is configured to train a machine learning model.
Like server device 104, host device 106 may be any type of computing device configured to carry out the computing device operations described herein. However, unlike server device 104, host device 106 may be located in the same environment (e.g., in the same building) as robotic device 102a. In one example, robotic device 102a may dock with host device 106 to recharge, download, and/or upload data.
Although robotic device 102a is capable of communicating with server device 104 via communications network 110 and communicating with host device 106, in some examples, robotic device 102a may carry out the computing device operations described herein. For instance, robotic device 102a may include an internal computing system and memory arranged to carry out the computing device operations described herein.
In some examples, robotic device 102a may wirelessly communicate with robotic device 102b via a wireless interface. For instance, robotic device 102a and robotic device 102b may both operate in the same environment, and share data regarding the environment from time to time.
The computing device 108 may perform all functions as described with respect to the robotic devices 102a, 102b except that the computing device 108 may lack locomotion capability (e.g., drive systems) to autonomously move within an environment. The computing device 108 may take the form of a desktop computer, a laptop computer, a mobile phone, a PDA, a tablet device, a smart watch, wearable computing device, handheld camera computing device, or any type of mobile computing device, for example. The computing device 108 may also send data 116 to and/or receive data 118 from the server device 104 via communications network 110.
The communications network 110 may correspond to a local area network (LAN) a wide area network (WAN), a corporate intranet, the public internet, or any other type of network configured to provide a communications path between devices. The communications network 110 may also correspond to a combination of one or more LANs, WANs, corporate intranets, and/or the public Internet. Communications among and between the communications network 110 and the robotic device 102a, the robotic device 102b, and the computing device 108 may be wireless communications (e.g., WiFi, Bluetooth, etc.).
The computing device 108 is shown to include a processor(s) 120, and also a communication interface 122, data storage (memory) 124, an output interface 126, a display 128, a camera 130, and sensors 132 each connected to a communication bus 134. The computing device 108 may also include hardware to enable communication within the computing device 108 and between the computing device 108 and other devices (not shown). The hardware may include transmitters, receivers, and antennas, for example.
The communication interface 122 may be a wireless interface and/or one or more wireline interfaces that allow for both short-range communication and long-range communication to one or more networks or to one or more remote devices. Such wireless interfaces may provide for communication under one or more wireless communication protocols, such as Bluetooth, WiFi (e.g., an institute of electrical and electronic engineers (IEEE) 802.11 protocol), Long-Term Evolution (LTE), cellular communications, near-field communication (NFC), and/or other wireless communication protocols. Such wireline interfaces may include Ethernet interface, a Universal Serial Bus (USB) interface, or similar interface to communicate via a wire, a twisted pair of wires, a coaxial cable, an optical link, a fiber-optic link, or other physical connection to a wireline network. Thus, the communication interface 122 may be configured to receive input data from one or more devices, and may also be configured to send output data to other devices.
The communication interface 122 may also include a user-input device, such as a keyboard, mouse, or touchscreen, for example.
The data storage 124 may include or take the form of one or more computer-readable storage media that can be read or accessed by the processor(s) 120. The computer-readable storage media can include volatile and/or non-volatile storage components, such as optical, magnetic, organic or other memory or disc storage, which can be integrated in whole or in part with the processor(s) 120. The data storage 124 is considered non-transitory computer readable media. In some examples, the data storage 124 can be implemented using a single physical device (e.g., one optical, magnetic, organic or other memory or disc storage unit), while in other examples, the data storage 124 can be implemented using two or more physical devices.
The data storage 124 thus is a non-transitory computer readable storage medium, and executable instructions 136 are stored thereon. The instructions 136 include computer executable code. When the instructions 136 are executed by the processor(s) 120, the processor(s) 120 are caused to perform functions. Such functions include e.g., obtaining, using the camera 130, a two-dimensional (2D) image of an object, receiving, from the server 104, an identification of the object based on the 2D image of the object, obtaining, using the one or more sensors 132, additional data of the object, obtaining, using the one or more sensors 132, additional data of a surrounding environment of the object, and generating a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object. These functions are described in more detail below.
The processor(s) 120 may be a general-purpose processor or a special purpose processor (e.g., digital signal processors, application specific integrated circuits, etc.). The processor(s) 120 can include one or more CPUs, such as one or more general purpose processors and/or one or more dedicated processors (e.g., application specific integrated circuits (ASICs), digital signal processors (DSPs), network processors, etc.). For example, the processor(s) 170 can include a tensor processing unit (TPU) for training and/or inference of machine learning models. The processor(s) 120 may receive inputs from the communication interface 122, and process the inputs to generate outputs that are stored in the data storage 124 and output to the display 128. The processor(s) 120 can be configured to execute the executable instructions 136 (e.g., computer-readable program instructions) that are stored in the data storage 124 and are executable to provide the functionality of the computing device 108 described herein.
The output interface 126 outputs information to the display 128 or to other components as well. Thus, the output interface 126 may be similar to the communication interface 122 and can be a wireless interface (e.g., transmitter) or a wired interface as well.
The camera 130 may include a high-resolution camera to capture 2D images of objects and environment.
The sensors 132 include a number of sensors such as a depth camera 137, an inertial measurement unit (IMU) 138, one or more motion tracking cameras 140, one or more radars 142, one or more microphone arrays 144, and one or more proximity sensors 146. More or fewer sensors may be included as well.
Depth camera 137 may be configured to recover information regarding depth of objects in an environment, such as three-dimensional (3D) characteristics of the objects. For example, depth camera 137 may be or include an RGB-infrared (RGB-IR) camera that is configured to capture one or more images of a projected infrared pattern, and provide the images to a processor that uses various algorithms to triangulate and extract 3D data and outputs one or more RGBD images. The infrared pattern may be projected by a projector that is integrated with depth camera 137. Alternatively, the infrared pattern may be projected by a projector that is separate from depth camera 137 (not shown).
IMU 138 may be configured to determine a velocity and/or orientation of the robotic device. In one example, IMU may include a 3-axis gyroscope, a 3-axis accelerometer, a 3-axis compass, and one or more processors for processing motion information.
Motion tracking camera 140 may be configured to detect and track movement of objects by capturing and processing images (e.g., RGB-IR images). In some instances, the motion tracking camera 140 may include one or more IR light emitting diodes (LEDs) that enable detection in low-luminance lighting conditions. Motion tracking camera 140 may include a wide field of view (FOV), such as a 180 degree FOV. In one example configuration, the computing device 108 may include a first motion tracking camera configured to capture images on a first side of the computing device 108 and a second motion tracking camera configured to capture images on an opposite side of the computing device 108.
Radar 142 may include an object-detection system that uses electromagnetic waves to determine a range, angle, or velocity of objects in an environment. Radar 142 may operate by firing laser pulses out into an environment, and measuring reflected pulses with one or more sensors. In one example, radar 142 may include a solid-state millimeter wave radar having a wide FOV, such as a 150 degree FOV.
Microphone 144 may include a single microphone or a number of microphones (arranged as a microphone array) operating in tandem to perform one or more functions, such as recording audio data. In one example, the microphone 144 may be configured to locate sources of sounds using acoustic source localization.
Proximity sensor 146 may be configured to detect a presence of objects within a range of the computing device 108. For instance, proximity sensor 146 can include an infrared proximity sensor. In one example, the computing device 108 may include multiple proximity sensors, with each proximity sensor arranged to detect objects on different sides of the computing device 108 (e.g., front, back, left, right, etc.).
The robotic device 200 may include the same or similar components of the computing device 108 (and/or may include a computing device 108) including the processor(s) 120, the communication interface 122, the data storage (memory) 124, the output interface 126, the display 128, the camera 130, and the sensors 132 each connected to the communication bus 134. Description of these components is the same as above for the computing device 108. The robotic device 200 may also include hardware to enable communication within the robotic device 200 and between the robotic device 200 and other devices (not shown). The hardware may include transmitters, receivers, and antennas, for example.
The robotic device 200 may also include additional sensors 132, such as contact sensor(s) 148 and a payload sensor 150.
Contact sensor(s) 148 may be configured to provide a signal when robotic device 200 contacts an object. For instance, contact sensor(s) 148 may be a physical bump sensor on an exterior surface of robotic device 200 that provides a signal when contact sensor(s) 148 comes into contact with an object.
Payload sensor 150 may be configured to measure a weight of a payload carried by robotic device 200. For instance, payload sensor 150 can include a load cell that is configured to provide an electrical signal that is proportional to a force being applied to platform or other surface of robotic device 200.
As further shown in
Accessory system 156 may include one or more mechanical components configured to facilitate performance of an accessory task. As one example, accessory system 156 may include a motor and a fan configured to facilitate vacuuming. For instance the electric motor may cause the fan to rotate in order to create suction and facilitate collecting dirt, dust, or other debris through an intake port. As another example, the accessary system 156 may include one or more actuators configured to vertically raise a platform or other structure of robotic device 200, such that any objects placed on top of the platform or structure are lifted off of the ground. In one example, accessory system 156 may be configured to lift a payload of about 10 kilograms. Other examples are also possible depending on the desired activities for the robotic device 200.
Within examples, the computing device 108 may be used by a user and/or the robotic devices 102a, 102b can be programmed to autonomously collect data and generate or modify a knowledge graph of objects or environments. Initially, known labeled data can be accessed, such as use of a cloud object recognizer to determine an identification of an object within a captured image. In an example scenario, the robotic device 102a may be driving around an environment and may capture 2D RGB images of objects using the camera 130 (e.g., an image of a dining room table), and the table can be identified using the cloud object recognizer with the 2D image as in the input. Now, once the table has been recognized, the robotic device 102a can also obtain more data about the table that is to be labeled and associated with the table in a knowledge graph of the table. As examples, additional images of other viewpoints, additional types of data (e.g., depth images, location in the dining room, etc.) can be gathered and stored with the knowledge graph of the table. In sum, additional observations of the table are collected from different points of view to generate or modify a knowledge graph of the table, that can then be used for training a new object classifier, for example.
When new data is collected by the robotic device 102a of the table, such as new observations from many vantage points and at various/different times of day, a large dataset is generated that describes the table, and also, describes items associated with the table (e.g., chairs and their positions with respect to the table). Thus, an initial object recognition can be performed using a single 2D image, and a knowledge graph can be expanded using data collected with respect to a context of the object.
As another example, a generic knowledge graph may specify an object is associated with a certain location (e.g., a plate is associated with a kitchen counter, which is associated with a kitchen, which is an example of a higher level space within a home). Examples herein can be performed to gather yet more detailed and contextual information to further annotate the knowledge graph and organize the data in a hierarchical semantic manner to illustrate relationships between the objects (e.g., labels from general to detail such as home-kitchen-counter-plate). Other examples can include gathering data to enable label objects personally (e.g., identify shoes, determine specific model, determine that shoes belong to John Smith, and disambiguating between other shoes owned and worn by John Smith).
Method 400 may include one or more operations, functions, or actions as illustrated by one or more of blocks 402-410. It should be understood that for this and other processes and methods disclosed herein, flowcharts show functionality and operation of one possible implementation of present examples. In this regard, each block may represent a module, a segment, or a portion of program code, which includes one or more instructions executable by a processor for implementing specific logical functions or steps in the process. The program code may be stored on any type of computer readable medium or data storage, for example, such as a storage device including a disk or hard drive. Further, the program code can be encoded on a computer-readable storage media in a machine-readable format, or on other non-transitory media or articles of manufacture. The computer readable medium may include non-transitory computer readable medium or memory, for example, such as computer-readable media that stores data for short periods of time like register memory, processor cache and Random Access Memory (RAM). The computer readable medium may also include non-transitory media, such as secondary or persistent long term storage, like read only memory (ROM), optical or magnetic disks, compact-disc read only memory (CD-ROM), for example. The computer readable media may also be any other volatile or non-volatile storage systems. The computer readable medium may be considered a tangible computer readable storage medium, for example.
In addition, each block in
At block 402, the method 400 includes obtaining, using the camera 130 of the computing device 108, a two-dimensional (2D) image of an object. For example, a user may use the computing device 108 to capture an image of an object, or the robotic device 102a may be programmed to capture a 2D image of an object using the camera 130.
At block 404, the method 400 includes receiving, from the server 104, an identification of the object based on the 2D image of the object. For example, the computing device 108 and/or the robotic device 102a may send the 2D image of the object to the server 104, which performs an object recognition using any type of cloud object recognizer, and then returns an identification of the object to computing device 108 and/or the robotic device 102a. The identification may indicate any number or type of information such as a name of the object (e.g., a chair), a category of the object, a model of the object, etc.
At block 406, the method 400 includes obtaining, using one or more sensors 132 of the computing device 108, additional data of the object. In one example, obtaining the additional data of the object includes obtaining images of the object from additional points of view, or of a different scale. In another example, obtaining the additional data of the object includes obtaining different types of data, such as depth images of the object.
In yet another example, obtaining the additional data of the object includes obtaining, using the microphone 144, audio from the surrounding environment of the object. In an example scenario, the 2D image may be of a table located in a kitchen in a house, and audio can be recorded in a vicinity of the table to document sounds that occur in the kitchen and that can be included in the knowledge graph of the table.
In another example scenario in which the method is performed by the robotic device 102a operable to move throughout an environment, obtaining the additional data of the object includes the robotic device 102a moving around the object to collect data of the object using the sensors 132 on-board the robotic device 102a. In this scenario, the robotic device 102a may capture additional images from all different points of view and poses of the object, and also may capture additional images of portions of the object too that can be associated with the object. As the robotic device 102a approaches the table, a field of view of the table to the robotic device 102a is reduced and once within a certain distance, the robotic device 102a may only have legs of the table in the field of view. Thus, images of the legs of the table can be captured and associated with the knowledge graph of the table as well to provide yet further detailed data useful for describing the table.
In yet further examples, obtaining the additional data of the object includes obtaining the additional data at different times of day. For example, lighting of the scene and environment in which the object is present changes throughout the day, and thus, images of the object can be captured over time during the day to gather data about the object as observed with various changes in lighting. The robotic device 102a can be programmed to return to a location of the object at different times of day, or at every hour of the day, to collect data of the object, for example.
At block 408, the method 400 includes obtaining, using the one or more sensors 132 of the computing device 108, additional data of a surrounding environment of the object. Thus, after obtaining additional data of the object, additional data of the surrounding environment can also be obtained so as to gather yet further details to be associated with the object in the knowledge graph to generate a full dataset to describe the object. Additional data of the environment may be collected in the same or similar manners as with respect to collecting additional data of the object. The surrounding environment may include a room in which the object is present, for example. The surrounding environment may computing device 108 and/or the robotic device 102a alternatively be more granular to only include a space around the object defined by boundaries of various distances (e.g., within 5-10 feet of the object). Still further, the surrounding environment may additionally or alternatively be defined to be more expansive and may include an entire house in which the object is present.
At block 410, the method 400 includes generating a knowledge graph including (i) the additional data of the object associated with the identification of the object and (ii) the additional data of the surrounding environment of the object also associated with the identification of the object and organized in a hierarchical semantic manner to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object. The knowledge graph can be generated by the computing device 108 and stored in memory of the computing device 108, or generated by the server 104 and stored in memory of the server 104, for example.
Within the knowledge graph, the additional data of the object is stored with a label indicating the identification of the object.
Within examples described herein, the knowledge graph can be generated by a computing device by generating a new knowledge graph, modifying an existing knowledge graph, generation of a knowledge graph based on guidance/seeding of a graph framework, or any combination of these. As an example, a framework of the knowledge graph can be curated by operators or obtained from other sources, and the computing device can use the framework in addition with machine learning or unsupervised learning to determine how and where to add additional nodes and details on the braches as leaves of the graph. Similarly, the framework can have associated object relationships such as physical adjacency (on top, under, next to, etc.) for certain objects or how objects may be used together. Any pre-defined attributes can be associated with the framework to further construct details of the knowledge graph with the additional data that is obtained using the computing device, for example.
The knowledge graph thus includes the additional data 512 of the object associated with the identification of the object (e.g., food) and additional data of the surrounding environment of the object also associated with the identification of the object. All information in the knowledge graph is organized in a hierarchical semantic manner starting with general/high level descriptions of a Home and continuing to more granular/detailed descriptions of areas and objects in the Home to illustrate relationships between the object and at least one item represented by the additional data of the surrounding environment of the object. All of the additional data 512 is collected by the computing device 108 and/or robotic device 200 using sensors 132 to enable a more complete dataset to be generated that describes the object.
Although not shown in the knowledge graph 500 of
A goal of the knowledge graph 500 is to describe, in as complete manner as possible and with as much data and different data types as possible, areas in an environment and also objects in the environment. By using the suite of sensors 132, all different types of data can be collected by the computing device 108 to enable a full description to be generated. Then, a knowledge graph can be generated, or an existing knowledge graph can be modified to generate further branches that are populated with the additional data that is collected.
In an example scenario, including past collected data can be helpful for instances in which the knowledge graph 500 is used for object recognition. For instance, an image of a cooked egg differs from an image of an uncooked egg in a shell. Thus, having prior images of an uncooked egg associated with images/data of the cooked egg as positioned on the plate enables the computing device 108 to capture an image of the cooked egg and perform object recognition through use of the knowledge graph 500, and to enable improved artificial intelligence functions to be performed.
In each of the images captured and shown in
Example knowledge graphs described herein may be useful for artificial intelligence functions of a computing or robotic device and/or for reference to recognize higher level spaces such as kitchens and living rooms based on observation of objects associated with those rooms. This enables increased precision and recall of object recognition. As an example, if the computing device 108 is not in the kitchen, then nodes of the knowledge graph referring to the kitchen are not referenced. Alternatively, when a kitchen appliance is recognized in an image, e.g., refrigerator, the computing device 108 can make a determination through inferences that the computing device 108 is located in a kitchen.
Different examples of the system(s), device(s), and method(s) disclosed herein include a variety of components, features, and functionalities. It should be understood that the various examples of the system(s), device(s), and method(s) disclosed herein may include any of the components, features, and functionalities of any of the other examples of the system(s), device(s), and method(s) disclosed herein in any combination, and all of such possibilities are intended to be within the scope of the disclosure.
The description of the different advantageous arrangements has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the examples in the form disclosed. After reviewing and understanding the foregoing disclosure, many modifications and variations will be apparent to those of ordinary skill in the art. Further, different examples may provide different advantages as compared to other examples. The example or examples selected are chosen and described in order to best explain the principles, the practical application, and to enable others of ordinary skill in the art to understand the disclosure for various examples with various modifications as are suited to the particular use contemplated.