Computing devices may be relied on to perform any of a variety of different tasks. Further, computing devices may receive large quantities of content information, such as from video inputs, audio inputs, data transmissions, applications being executed, etc. Some systems may categorize and store the large quantities of content information that computing devices receive to compare related content objects for further processing. For example, the systems may use keyword searches to iterate through each content object from the large quantities of content information to find which content objects are related to the keyword. However, keyword searches may not consider the abstract meaning behind content objects, and may therefore be relatively inaccurate. Further, storing and retrieving objects from large quantities of content information may be computationally inefficient, such as by requiring a relatively large amount of memory to store the content information that is to be searched upon.
It is with respect to these and other general considerations that embodiments have been described. Also, although relatively specific problems have been discussed, it should be understood that the embodiments should not be limited to solving the specific problems identified in the background.
Aspects of the present disclosure relate to methods, systems, and media for storing entries in and/or retrieving information from an object memory.
In some examples, a plurality of content items (e.g., a document, a skill, data object, etc.) are received that have content data. The content items may together form an interaction history between a user and device over a period of time. The content data associated with the content items may be provided to one or more semantic models that generate semantic objects. From one or more of the semantic models, one or semantic objects may be received. The one or more semantic objects may then be inserted into the object memory. The object memory may be a graph with nodes that correspond to stored semantic objects. The nodes may have metadata associated with source data of content data used to generate the stored semantic objects. Accordingly, the semantic objects may be associated with respective indications corresponding to a reference to source data associated with the semantic objects. After the objects are stored, a plurality of collections of stored objects may be received from the object memory, such as based on a provided input. Further, a result may be determined based on a subset of the collections of stored objects and the provided input. The subset of the collections of stored objects may be retrieved based on a similarity to the input object.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Additional aspects, features, and/or advantages of examples will be set forth in part in the following description and, in part, will be apparent from the description, or may be learned by practice of the disclosure.
Non-limiting and non-exhaustive examples are described with reference to the following Figures.
In the following detailed description, references are made to the accompanying drawings that form a part hereof, and in which are shown by way of illustrations specific embodiments or examples. These aspects may be combined, other aspects may be utilized, and structural changes may be made without departing from the present disclosure. Embodiments may be practiced as methods, systems or devices. Accordingly, embodiments may take the form of a hardware implementation, an entirely software implementation, or an implementation combining software and hardware aspects. The following detailed description is therefore not to be taken in a limiting sense, and the scope of the present disclosure is defined by the appended claims and their equivalents.
As mentioned above, computing devices may be relied on to perform any of a variety of different tasks. Further, computing devices may receive large quantities of content information, such as from video inputs, audio inputs, data transmissions, applications being executed, etc.
Some systems may categorize and store the large quantities of content information that computing devices receive to compare related content objects for further processing. For example, the systems may use keyword searches to iterate through each content object from the large quantities of content information to find which content objects are related to the keyword. However, keyword searches may not consider the abstract meaning behind content objects, and may therefore be relatively inaccurate. Further, storing and retrieving objects from large quantities of content information may be computationally inefficient, such as by requiring a relatively large amount of memory to store the content information that is to be searched upon.
When building an operating system and/or kernel for semantic models (e.g., semantic embedding models) to perform actions in a system, the system may have the ability to learn skills and/or commands, such as by referencing external sources. The system may further have an object memory outside of a semantic model, such that semantic context can be built (e.g., in real-time). Further, the system may generate, launch and execute actions based on the object memory.
Recent advancements in artificial intelligence and machine-learning techniques allow for abstract meaning to be extracted from content objects, such as in the form of embeddings and/or text that can be mathematically compared against the abstract meaning of other content objects in the form of embeddings and/or text. Based on the mathematical comparison, a quantitative similarity between the embeddings and/or text, and by consequence the content objects from which the embeddings and/or text were generated, can be determined. A similarity between content objects can provide semantic context to a computing device when determining if an action should be performed and/or what action should be performed.
In some examples, when a user is shopping for a birthday present for a Person A, they may mention to a Person B, via a computing device, that Person A's birthday is December 1. Later, the user may prompt the computing device with, “when was Person A's birthday again?”
A context size of models, such as generative large language models may be very limited, such that it may be beneficial to employ strategies to index and search such dialogue history so that only relevant snippets and/or summaries are used when composing an answer involving historical dialogue.
As another example, a user might ask the computing device “what gift did I give Person A last year?” In this example, mechanisms provided herein might store dialogue history, as well as what pages the user visited and the content of the pages. In some examples, the dialogue history may be a long dialogue history, such as a dialogue occurring over a relatively long period of time, a dialogue involving a plurality of people, and/or a dialogue that includes a relatively large amount of content. Accordingly, mechanisms described herein may be advantageous for indexing and traversing content from relatively long dialogue history.
As still another example, a user might want to ask a specific question regarding a specific, relatively long document with which they are interacting. Task-specific indexes built using mechanisms provided herein may be utilized. Mechanisms provided herein can be used to generate different hierarchical summarizations of the content. For example, sessions of web searching for gifts might get summarized as “Birthday Shopping for Person A.” This summarization could be stored in a hierarchical index and the prompts to generate the summaries could be learned from log mining or specified in real-time for a specific purpose. For example, if asked to “index all information related to Person A,” systems provided herein may generate a hierarchical index with sub-nodes pertaining to Person A's address, phone number, birthday, gifts that the user got her for various years, dialogue history with Person A, etc. Accordingly, mechanisms described herein may be advantageous for indexing and traversing content from relatively long documents.
To retrieve content, a prompt for mechanisms provided herein can be created which asks to compare which node in a current level of an index would be most useful for replying to a current state of a dialogue with a user. The index may be traversed recursively. For non-text content, multi-modal models may be used to answer questions over visual web page content snapshots (e.g., a picture of the present for Person A may be converted into a textual response). In some examples, embedding methods may be used to index and retrieve content.
Some examples provided herein relate to using a model and associated semantic objects to store entries in an embedding object memory that includes embeddings and/or text that correspond to content objects. A system hosting the model may be informed by semantic context and can look into the object memory (e.g., a vectorized command store, a hierarchical index, a graph, etc.) to find matching content information by semantic address (e.g., using cosine distance, another geometric n-dimensional distance function, text comparison techniques, etc.).
In some examples, the object memory may store embeddings associated with models and their specific versions, which may represent the same content information in different semantic embedding spaces. When a new model is added, a content object can be re-encoded (e.g., by generating a new embedding) in the new model semantic space to add to a collection of models. In this manner, a single content object may have a locatable semantic address across models. Storing and retrieving matching content objects may require specific methodologies to ensure the content objects are available across models. The present disclosure discusses aspects of inserting entries into, retrieving information from, and rebalancing an embedding object memory.
Some aspects of the present disclosure relate to methods, systems, and media for storing entries in an object memory. Generally, one or more content items (e.g., emails, audio data, video data, messages, internet encyclopedia data, skills, commands, source code, programmatic evaluations, etc.) may be received. The one or more content items may include one or more content data (e.g., each email in the emails, each audio file in the audio data, each video file in the video data, each message in the messages, each page of the internet encyclopedia, etc.). One or more of the content data associated with the content item may be provided to one or more semantic models (e.g., a generative large language model, machine-learning model, etc.) to generate one or more semantic objects (e.g., embeddings and/or text). One or more semantic objects may be received from the one or more semantic models. In this respect, the large quantities of information that a computing device receives may be converted to embeddings (e.g., semantic embeddings) and/or text that can be mathematically compared and that can occupy a relatively smaller amount of memory than the large quantities of information themselves.
A collection of semantic objects may be associated with a respective semantic model. For example, a first collection of objects may be associated with a first semantic model of the one or more semantic models. Further, the collection of objects may include a first semantic object generated by the first semantic model for at least one content data from the respective content item.
The one or more semantic objects received from the semantic models may be inserted into the object memory. The one or more semantic objects may be associated with a respective indication corresponding to a location of source data associated with the one or more semantic objects. Further, in some examples, the insertion may trigger a memory storage operation to store the one or more semantic objects. A vector representation of the semantic embeddings may be stored in a multi-dimensional memory store, such as an approximate nearest neighbor (ANN) tree, a k-dimensional (k-d) tree, an octree, an n-dimensional tree, or another multi-dimensional memory store that may be recognized by those of ordinary skill in the art at least in light of teachings described herein.
Additionally, or alternatively, some aspects of the present disclosure relate to methods, system, and media for retrieving information from an object memory. Generally, an input object (e.g., embeddings and/or text) may be received that is generated by a machine-learning model. The input object is discussed in further detail later herein. A plurality of collections of stored objects may be retrieved by mechanisms described herein. The plurality of collections of objects may each correspond to respective content data. A subset of objects from at least one of the plurality of collections of stored objects may be retrieved based on a similarity to the input object. Further, an action may be determined based on the subset of objects and the input object.
Advantages of mechanisms disclosed herein may include improved accuracy for comparing subsets of large quantities of content, such as by quantitatively comparing semantic objects corresponding to received content. Furthermore, mechanisms disclosed herein for storing entries in an object memory can improve computational efficiency by, for example, reducing an amount of memory that is needed to track content (e.g., via feature vectors, embeddings, and/or text, as opposed to audio files, video files, and/or encyclopedia pages themselves). Still further, mechanisms disclosed herein can improve computational efficiency for receiving content from an object memory, such as by searching for semantic objects that may be categorized based on their source (e.g., type of data and/or application that generated the data), as opposed to searching through relatively large quantities of raw source data stored in memory.
The computing device 102 can receive content data 110 from the content data source 106, which may be, for example a microphone, a camera, a global positioning system (GPS), etc. that transmits content data, a computer-executed program that generates content data, and/or memory with data stored therein corresponding to content data. The content data 110 may include visual content data, audio content data (e.g., speech or ambient noise), gaze content data, calendar entries, emails, document data (e.g., a virtual document), weather data, news data, blog data, encyclopedia data and/or other types of private and/or public content data that may be recognized by those of ordinary skill in the art. In some examples, the content data may include text, source code, commands, skills, or programmatic evaluations.
The computing device 102 can further receive input data 111 from the input data source 107, which may be, for example, a camera, a microphone, a computer-executed program that generates input data, and/or memory with data stored therein corresponding to input data. The content data 111 may be, for example, a user-input, such as a voice query, text query, etc., an image, an action performed by a user and/or a device, a computer command, a programmatic evaluation, or some other input data that may be recognized by those of ordinary skill in the art.
Additionally, or alternatively, the network 108 can receive content data 110 from the content data source 106. Additionally, or alternatively, the network 108 can receive input data 111 from the input data source 107.
Computing device 102 may include a communication system 112, an object memory insertion engine or component 114, and/or an object memory retrieval engine or component 116. In some examples, computing device 102 can execute at least a portion of the object memory insertion component 114 to generate collections of objects (e.g., embeddings and/or text) corresponding to one or more subsets of the received content data 110 to be inserted into an object memory. For example, each of the subsets of the content data may be provided to a machine-learning model, such as a natural language processor and/or a visual processor, to generate a collection of objects. In some examples, the subsets of content data may be provided to another type of model, such as a generative large language model (LLM).
Further, in some examples, computing device 102 can execute at least a portion of the object memory retrieval component 116 to retrieve a plurality of collections of stored objects from an object memory, based on an input embedding (e.g., generated based on the input data 111), and determine an action. For example, a subset of embeddings may be retrieved from one or more collections of the plurality of collections of stored objects, based on a similarity to the input object, and the action may be determined based on the input object and the subset of objects (e.g., as contextual information in determining an action based on the input object).
Server 104 may include a communication system 118, an object memory insertion engine or component 120, and/or an object memory retrieval engine or component 122. In some examples, server 104 can execute at least a portion of the object memory insertion component 120 to generate collections of objects corresponding to one or more subsets of the received content data 110 to be inserted into an object memory. For example, each of the subsets of the content data may be provided to a machine-learning model, such as a natural language processor and/or a visual processor, to generate a collection of objects. In some examples, the subsets of content data may be provided to a generative large language model (LLM).
Further, in some examples, server 104 can execute at least a portion of the object memory retrieval component 122 to retrieve a plurality of collections of stored objects from an object memory, based on an input object (e.g., generated based on the input data 111), and determine an action. For example, a subset of objects may be retrieved from one or more collections of the plurality of collections of stored objects, based on a similarity to the input object, and the action may be determined based on the input object and the subset of objects (e.g., as contextual information in determining an action based on the input object).
Additionally, or alternatively, in some examples, computing device 102 can communicate data received from content data source 106 and/or input data source 107 to the server 104 over a communication network 108, which can execute at least a portion of the object memory insertion component 114 and/or the object memory retrieval engine 116. In some examples, the object memory insertion component 114 may execute one or more portions of methods/processes 400 and/or 700 described below in connection with
In some examples, computing device 102 and/or server 104 can be any suitable computing device or combination of devices, such as a desktop computer, a vehicle computer, a mobile computing device (e.g., a laptop computer, a smartphone, a tablet computer, a wearable computer, etc.), a server computer, a virtual machine being executed by a physical computing device, a web server, etc. Further, in some examples, there may be a plurality of computing devices 102 and/or a plurality of servers 104. It should be recognized by those of ordinary skill in the art that content data 110 and/or input data 111 may be received at one or more of the plurality of computing devices 102 and/or one or more of the plurality of servers 104, such that mechanisms described herein can insert entries into an object memory and/or use the object memory, based on an aggregation of content data 110 and/or input data 111 that is received across the computing devices 102 and/or the servers 104.
In some examples, content data source 106 can be any suitable source of content data (e.g., a microphone, a camera, a GPS, a sensor, etc.). In a more particular example, content data source 106 can include memory storing content data (e.g., local memory of computing device 102, local memory of server 104, cloud storage, portable memory connected to computing device 102, portable memory connected to server 104, etc.). In another more particular example, content data source 106 can include an application configured to generate content data. In some examples, content data source 106 can be local to computing device 102. Additionally, or alternatively, content data source 106 can be remote from computing device 102 and can communicate content data 110 to computing device 102 (and/or server 104) via a communication network (e.g., communication network 108).
In some examples, input data source 107 can be any suitable source of input data (e.g., a microphone, a camera, a sensor, etc.). In a more particular example, input data source 107 can include memory storing input data (e.g., local memory of computing device 102, local memory of server 104, cloud storage, portable memory connected to computing device 102, portable memory connected to server 104, privately-accessible memory, publicly-accessible memory, etc.). In another more particular example, input data source 107 can include an application configured to generate input data. In some examples, input data source 107 can be local to computing device 102. Additionally, or alternatively, input data source 107 can be remote from computing device 102 and can communicate input data 111 to computing device 102 (and/or server 104) via a communication network (e.g., communication network 108).
In some examples, communication network 108 can be any suitable communication network or combination of communication networks. For example, communication network 108 can include a Wi-Fi network (which can include one or more wireless routers, one or more switches, etc.), a peer-to-peer network (e.g., a Bluetooth network), a cellular network (e.g., a 3G network, a 4G network, a 5G network, etc., complying with any suitable standard), a wired network, etc. In some examples, communication network 108 can be a local area network (LAN), a wide area network (WAN), a public network (e.g., the Internet), a private or semi-private network (e.g., a corporate or university intranet), any other suitable type of network, or any suitable combination of networks. Communication links (arrows) shown in
Generally, when a user is interacting with a computing device (e.g., computing device 102), they may be interacting with applications that are stored locally on the computing device and/or that can be executed locally on the computing device. Information that a user accesses or executes locally on their device may include the private content 200.
The private content includes audio content 202, visual content 204, gaze content 206, calendar entries 208, emails 210, and documents 212, as examples. Additional and/or alternative types of private content may be recognized by those of ordinary skill in the art.
The audio content 202 may include data corresponding to speech data that is generated. For example, the audio content 202 may be generated by the computing device 102 to correspond to audio that is received from a user (e.g., where the user is speaking into a microphone a computing device that may be separate from the computing device 102). Additionally, or alternatively, the audio content 202 may correspond to types of audio data that may be generated by a computing device, such as synthetic speech, animal sounds, beeps, buzzes, or another type of generated audio data.
The visual content 204 may include data corresponding to graphical content that may be displayed and/or generated by a computing device. For example, the visual content 204 may be content that is generated via an application being run on the computing device 102 (e.g., a web-browser, a presentation application, a teleconferencing application, a business management application, etc.). The visual content 204 may include data that is scraped from a screen display of the computing device 102. For example, any visual indication that is displayed on the computing device 102 may be included in the visual content 204.
The gaze content 206 may include data corresponding to where users are looking. For example, specific actions to be performed by a computing device may be associated with a specific location at which a user is looking and/or a combination of locations at which a user is looking within a predefined duration of time.
The calendar entries 208 may include calendar data specific to one or more users. For example, the calendar data may include meetings, appointments, reservations or other types of calendar entries. Additionally, or alternatively, the calendar data may include times, locations, attendees, and/or notes regarding specific calendar entries. Additional and/or alternative data associated with calendar entries may be recognized by those of ordinary skill in the art.
The emails 210 may include email data for one or more emails. For example, the emails 210 may include email data corresponding to a collection or plurality of emails. The email data may include senders and recipients, subjects, messages, images, timestamps, and/or other types of information that may be associated with emails. Additional and/or alternative data associated with calendar entries may be recognized by those of ordinary skill in the art.
The virtual documents 212 may include a type of document that is found in a virtual environment. For example, the virtual document 212 may be a text-editing document, a presentation, an image, a spreadsheet, an animated series of images, a notification, or any other type of virtual document that may be recognized by those of ordinary skill in the art.
Each of the plurality of types of private content 200 may be subsets of the private content 200 that may be received by mechanisms described herein, as a subset of the content data 110. Further, while specific examples of types of private content have been discussed above, additional and/or alternative types of private content may be recognized by those of ordinary skill in the art.
The public content 250 includes weather 252, news 254, encyclopedias 256, blogs 258 and the like. The weather 252 may include information regarding weather that is around a user and/or at a location determined to be of interest for a user. For example, for a given time, weather information (e.g., precipitation, temperature, humidity, etc.) may be received or otherwise obtained for where a user is located (e.g., based on location content) and/or a location determined to be of interest to the user.
The news 254 may include information regarding recent news stories that are determined to be of interest to a user. For example, for a given time, a relatively recent news story covering a significant event may have been released. Additional or alternative types of news stories may include holidays, birthdays, local events, national events, natural disasters, celebrity updates, scientific discoveries, sports updates, or any other type of news that may be recognized by those of ordinary skill in the art.
The encyclopedia 256 may include publicly available encyclopedia information. For example, the encyclopedia 256 may include information from an online database of encyclopedic information. Additionally, or alternatively, the encyclopedia 256 may include pages from an online encyclopedia website. Additional or alternative types of encyclopedia information may be recognized by those of ordinary skill in the art.
The blogs 256 may include information from blogs. For example, the blogs may include publicly available posts from users of a blog website and/or a social media platform. The blogs may be posted by, for example, famous people, such as chefs, politicians, actors, etc. Alternatively, the blogs may be posted by other users who post content online that may be publicly accessible by mechanisms disclosed herein.
Generally, the different content types discussed with respect to
In some examples, the first set of content data 302 includes a plurality of content items that are received and/or collected over a period of time. The content items may together form an interaction history between a user and a device over the period of time. For example, the interaction history may be a dialogue (e.g., spoken, written, etc.) between the user and the device over the period of time. In some examples, the dialogue may occur via a chat-interface that records conversation history. Additionally, or alternatively, the interaction history may be a ledger of activities or engagements between the user and the device over the period of time (e.g., inputs that a user had made to the device, outputs that the device has provided to the user, etc.). As an example, the interaction history may include with which applications of a device a user has interfaced, how long a user interfaces with certain applications, selections that the user makes on the device, or other interactions that may be recognized by those of ordinary skill in the art. Generally, a ledger or recording of these interactions may be stored over time in the first set of content data 302.
The first set of content data 302 may be input into a first model 304. For example, the first model 304 may include a machine-learning model, such as a machine-learning model that is trained to generate embeddings and/or text, based on received content data. In some examples, the first model 304 includes a generative model, such as a generative large language model (LLM). In some examples, the LLM described herein may be an LLM+, which is an augmented LLM that can make calls to external services and/or can perform subroutines that may recursively chain calls to the LLM+. In some examples, the first model 304 includes a natural language processor. Alternatively, in some examples, the first model 304 includes a visual processor. The first model 304 may be trained on one or more datasets that are compiled by individuals and/or systems. Additionally, or alternatively, the first model 304 may be trained based on a dataset that includes information obtained from the Internet. Further, the first model 304 may include a version. One of skill in the art will appreciate that any type of model may be employed as part of the aspects disclosed herein without departing from the scope of this disclosure.
In some examples, the first model 304 can be conditioned with prompts. The prompts may include instructions to summarize data and/or to extract task-specific and/or task-relevant data for indexing. The first model 304 may also be generically prompted to extract information that might be useful for finding things later, e.g., “build a table of contents.” In some examples, the first model 304 may be provided with other specific instructions, such as on how to index the data and/or how to extract information from a dialogue history that might be useful for answering a known newly issued query (e.g., from a user). The first model 304 may be tuned to follow instructional prompts. The prompts may include filtering instructions, such as to build an index over all of the people mentioned in a document that includes names, roles, phone numbers, etc. The filtering instructions could substantially reduce the size of the index and increase its utility for certain tasks later (e.g., at a time of traversal of the index). Mechanisms described herein may use index metadata to choose which index to use for a task at hand.
In some examples, mechanism described herein may attach contextual metadata to items being indexed (e.g., corresponding to the first set of content data 302) that may be useful for finding things later. This might include having the first model 304 generate questions that can be answered by the attached contextual metadata or generating summaries that include additional context, e.g., “generate a summary of this dialogue given that the user is John Smith and the date was Dec. 23, 2020” or broader contextual data that John Smith was composing a birthday card in another application such as a word processing application.
The first model 304 may output a first collection of objects 306. In some examples, the first collection of objects 306 may include one or more semantic embeddings. In some examples, the first collection of objects 306 may include one or more text summaries corresponding to semantic analysis of respective aspects of the first set of content data 302. The first collection of objects 306 may be unique to the first model 304. Additionally, or alternatively, the first collection of objects 306 may be unique to the specific version of the first model 304. Each object in the first collection of objects 306 may correspond to a respective content object and/or respective content data from the first set of content data 302. Therefore, for each object and/or content data in the first set of content data 302, the first model 304 may generate an object.
Each of the objects in the first collection of objects 306 may be associated with a respective indication (e.g., byte address) corresponding to a location of source data associated with the objects. For example, if the first set of content data 302 corresponds to a set of emails, then the first collection of objects 306 may be hash values and/or text summaries generated for each of the emails based on the content within the emails (e.g., abstract meaning of words or images included in the email). An indication corresponding to the location of an email (e.g., in memory) may then be associated with the object generated based off of the email. In this respect, the actual source data of a content object may be stored separately from the corresponding object, thereby allowing the corresponding object to occupy relatively less memory (e.g., than the source data).
The first collection of objects 306 and indications of corresponding source data associated with the first set of content data 302 (and thereby associated with the first collection of objects 306) may be stored together. Specifically, the objects 306 and indications of corresponding source data may be stored in an object memory 310.
The example flow 300 further includes with a second set of content data 303 being received. The second set of content data 303 may be received from a different content data source than the first set of content data 302. For example, the first set of content data 302 may be audio data and the second set of content data 303 may be video data. As another example, the first set of content data 302 may correspond to a first application (e.g., a word-processing application, a spreadsheet application, etc.) and the second set of content data 303 may correspond to a second application that is different than the first application. Additional and/or alternative combinations and examples of content data will be recognized by those of ordinary skill in the art.
In some examples, the second set of content data 303 includes a plurality of content items that are received and/or collected over a period of time. The content items may together form an interaction history between a user and a device over the period of time. For example, the interaction history may be a dialogue (e.g., spoken, written, etc.) between the user and the device over the period of time. In some examples, the dialogue may occur via a chat-interface that records conversation history. Additionally, or alternatively, the interaction history may be a ledger of activities or engagements between the user and the device over the period of time (e.g., inputs that a user had made to the device, outputs that the device has provided to the user, etc.). As an example, the interaction history may include with which applications of a device a user has interfaced, how long a user interfaces with certain applications, selections that the user makes on the device, or other interactions that may be recognized by those of ordinary skill in the art. Generally, a ledger or recording of these interactions may be stored over time in the second set of content data 303.
The second set of content data 303 may be input into a second model 305. For example, the second model 305 may be a machine-learning model, such as a machine-learning model that is trained to generate one or more objects, based on received content data. In some examples, the second model 305 includes a generative model, such as a generative large language model (LLM). In some examples, the LLM described herein may be an LLM+, which is an augmented LLM that can make calls to external services and/or can perform subroutines that may recursively chain calls to the LLM+. In some examples, the second model 305 includes a natural language processor. Alternatively, in some examples, the second model 305 includes a visual processor. The model may be trained on one or more datasets that are compiled by individuals and/or systems. Additionally, or alternatively, the second model 305 may be trained based on a dataset that includes information obtained from the Internet. Further, the second model 305 may include a version. One of skill in the art will appreciate that any type of model may be employed as part of the aspects disclosed herein without departing from the scope of this disclosure.
In some examples, the second model 305 can be conditioned with prompts. The prompts may include instructions to summarize data and/or to extract task-specific and/or task-relevant data for indexing. The second model 305 may also be generically prompted to extract information that might be useful for finding things later, e.g., “build a table of contents.” In some examples, the first model 304 may be provided with other specific instructions, such as on how to index the data and/or how to extract information from a dialogue history that might be useful for answering a known newly issued query (e.g., from a user). The second model 305 may be tuned to follow instructional prompts. The prompts may include filtering instructions, such as to build an index over all of the people mentioned in a document that includes names, roles, phone numbers, etc. The filtering instructions could substantially reduce the size of the index and increase its utility for certain tasks later (e.g., at a time of traversal of the index). Mechanisms described herein may use index metadata to choose which index to use for a task at hand.
In some examples, mechanism described herein may attach contextual metadata to items being indexed (e.g., corresponding to the second set of content data 303) that may be useful for finding things later. This might include having the second model 305 generate questions that can be answered by the attached contextual metadata or generating summaries that include additional context, e.g., “generate a summary of this dialogue given that the user is John Smith and the date was Dec. 23, 2020” or broader contextual data that John Smith was composing a birthday card in another application such as a word processing application.
The second model 305 may output a second collection of object 307. In some examples, the first collection of objects 306 may include one or more semantic embeddings. In some examples, the first collection of objects 306 may include one or more text summaries corresponding to semantic analysis of respective aspects of the first set of content data 302. The second collection of embeddings 307 may be unique to the second model 305. Additionally, or alternatively, the second collection of objects 307 may be unique to the specific version of the second model 305. For example, if the first model 304 and the second model 305 were both to receive the same set of content data, they may output different objects. Further, if a first version of the second model 305 received the same set of content data as a second version of the second model 305, then the first and second version of the second model 305 may output different collections of objects. Each object in the second collection of objects 307 may correspond to a respective content object and/or respective content data from the second set of content data 303. Therefore, for each content data in the second set of content data 303, the second model 305 may generate a respective object (e.g., semantic object).
Each of the semantic objects in the second collection of objects 307 may be associated with a respective indication (e.g., byte address) corresponding to a location of source data associated with the semantic object. For example, if the second set of content data 303 corresponds to a set of encyclopedia data, then the second collection of objects 307 may include hash values and/or text summaries generated for each of the pages of the encyclopedia based on the content within the pages (e.g., abstract meaning of words or images included in the pages). An indication corresponding to the location of the encyclopedia pages may then be associated with the object generated based off of the encyclopedia data. In this respect, the actual source data of a content object may be stored separately from the corresponding object, thereby allowing the corresponding object to occupy relatively less memory (e.g., than the source data).
The second collection of objects 307 and indications of corresponding source data associated with the second set of content data 303 (and thereby associated with the second collection of objects 307) may be stored together. Specifically, the objects 307 and indications of corresponding source data may be stored in an object memory 310.
Accordingly, the object memory 310 may store a plurality of collections of objects (e.g., the first collection of embeddings 306 and the second collection of embeddings 307) with indications that correspond to locations of source data associated with the one or more objects. The plurality of collections of objects may include a plurality of semantic embeddings and/or a plurality of text summaries. The indications may be byte addresses, uniform resource indicators (e.g., uniform resource links), or another form of data that is capable of identifying a location of source data. The source data may be stored in memory of a computing device or server on which the object memory 310 is located. Additionally, or alternatively, the source data may be stored in memory that is remote from a computing device or server on which the object memory 310 is located.
In some examples, the object memory includes a hierarchical index. Additionally, or alternatively, in some examples, the object memory includes a graph. For example, each semantic object may form a node in the graph. Further, edges may extends between one or more of the nodes that have a weight corresponding to a similarity of the nodes between which the edge extends. Accordingly, when traversing the graph, the weight between semantic objects may be used to determine a cost associated with extracting results based on one or more nodes that are determined to be relatively semantically similar.
In some examples, the graph may be an arbitrary directed or undirected graph over a document and/or corpus. Nodes of the graph may be summary nodes or topic nodes that point to various sub-nodes and/or to the underlying data. Accordingly, some graphs described herein may not be limited to tree structures.
In some examples, mechanisms described herein may attached metadata to the nodes. For example, the metadata may include annotations, references to other data, or other information that may be recognized by those of ordinary skill in the art. The metadata may be attached as the graph is traversed, such as to make future traversals faster, more accurate, etc. For example, frequency counts and/or natural language descriptions may be attached. The natural language descriptions may include information regarding what traversal choices were most successful in the past given specific tasks (or, in some examples, embeddings and/or summaries of those tasks).
In some examples, the object memory includes a burst trie. For example, the burst trie may consist of a single container. When the single container is deemed to be inefficient, it may be burst, that is, replaced by a trie node and a set of child containers which between them partition the original container's strings. Data structures which may be used for the container may be recognized by those of ordinary skill in the art. Further, determining when a container should be burst may be recognized by those of ordinary skill in the art.
In some examples, events, actions, etc. which may occur in a ledger for one or more applications/services of a user's device may be stored (e.g., a representation thereof may be stored) in the object memory 310 (e.g., indexed in the object memory 310). In some examples, a ledger refers to a data structure or system used to maintain a log or a history of transactions, events, actions, summaries, etc. associated with an application/service. The ledger may store information related to the transactions, events, actions, summaries, etc. The transactions, events, actions, summaries, etc. may occur across various time scale, levels of abstraction, and/or data modalities. A plurality of models (e.g., first model 304 and second model 305) that can extract and index such transactions, events, actions, summaries, etc. may work together to define node representations that contain one or more embeddings (e.g., one or more representations of audio, video, image, text, and/or structured data of one or more segments of ledger data and/or hierarchical/graphical summary representations of summary representations.
Method 400 begins at operation 402 wherein a plurality of content items are received. The plurality of content items may be received over a period of time. For example, the plurality of content items may be collected over a period of time during which a user interacts with a device. The content items together form an interaction history between a user and device over the period of time (e.g., as shown with respect to
The content items may have one or more content data. The one or more content data may include at least one public content data and/or at least one private content data. The content data may be similar to the content data 110 discussed with respect to
The content data may include one or more of audio content data, visual content data, gaze content data, calendar entries, emails, virtual documents, data generated by specific software applications, weather content data, news content data, encyclopedia content data, and/or blog content data. Additional and/or alternative types of content data may be recognized by those of ordinary skill in the art.
At operation 404, it is determined if the content data have an associated semantic model. For example, the semantic model may be similar to the first model 304 and/or the second model 305 discussed with respect to
If it is determined that each of the content data do not have an associated semantic model, flow branches “NO” to operation 406, where a default action is performed. For example, the content data and/or content items may have an associated pre-configured action. In other examples, method 400 may comprise determining whether the content data and/or content items have an associated default action, such that, in some instances, no action may be performed as a result of the received content items. Method 400 may terminate at operation 406. Alternatively, method 400 may return to operation 402 to provide an iterative loop of receiving one or more content items and determining if at least one of the content data of the content items have an associated semantic model.
If however, it is determined that the content data have an semantic model, flow instead branches “YES” to operation 408, where, the content data associated with the content items are provided to one or more semantic models. The semantic models generate one or more semantic objects. Further, the one or more semantic models may include a version. Each of the semantic objects generated by the respective semantic embedding model may include metadata corresponding to the version of the semantic model that generated the semantic object.
In some examples, the content data is provided to the one or more semantic models locally. In some examples, the content data is provided to the one or more semantic model via an application programming interface (API). For example, a first device (e.g., computing device 102 and/or server 104) may interface with a second device (e.g., computing device 102 and/or server 104) via an API that is configured to provide semantic objects or indications thereof, in response to receiving content data or indications thereof.
At operation 410, one or more semantic objects are received from one or more of the semantic models. In some examples, the one or more semantic objects correspond to the provided content data. In some examples, the one or more semantic objects are a collection or plurality of objects. For example, a collection of objects (such as the first collection of objects 306) may be associated with a first semantic model (e.g., the first model 304). In some examples, the collection of objects may be uniquely associated with the first semantic model, such that a second semantic model generates a different collection of objects than the first semantic model. Further, in some examples, the collection of objects may be uniquely associated with the version of the first semantic model, such that a different version of the first semantic model generates a different collection of objects.
The collection of objects may include a semantic object generated by the first semantic model for at least one content data of a plurality of content data. For example, the content data may correspond to an email, an audio file, a message, a website page, etc. Additional and/or alternative types of content objects or items that correspond to the content data may be recognized by those of ordinary skill in the art.
At operation 412, the one or more semantic objects are inserted into the object memory. In some examples, the object memory may include an index, such as a hierarchical index, or a database, or a tree (e.g., ANN tree, k-d tree, etc.), or a graph. The object memory includes one or more semantic objects (e.g., semantic embeddings and/or semantic text summaries) from the collection of objects. Further, the one or more objects are associated with a respective indication that corresponds to a location of source data associated with the one or more objects. The source data can include one or more of audio files, text files, image files, video files, and/or website pages. Additional and/or alternative types of source data may be recognized by those of ordinary skill in the art. The objects may occupy relatively little memory. For example, one or more of the objects may be a 64-bit hash. As another example, one or more of the objects may be a semantic text summary. Comparatively, the source data may occupy a relatively large amount of memory. Accordingly, by storing an indication to the location of the source data in the object memory, as opposed to the raw source data, mechanisms described herein may be relatively efficient for memory usage of one or more computing devices, while still allowing for relatively quick access to and searching of relevant content.
The indications that corresponds to a location of source data may be metadata, byte addresses, uniform resource indicators (e.g., uniform resource links), or another form of data that is capable of identifying a location of source data. Further, the object memory may be stored at a location that is different than the location of the source data. Additionally, or alternatively, the source data may be stored in memory of a computing device or server on which the object memory (e.g., embedding object memory 310) is located. Additionally, or alternatively, the source data may be stored in memory that is remote from a computing device or server on which the object memory is located.
In some examples, the semantic objects include semantic embeddings and the insertion at operation 412 triggers a memory storage operation to store the one or more semantic embeddings. A vector representation of the semantic embeddings may be stored in a multi-dimensional memory store, such as an ANN tree, a k-d treen, an n-dimensional tree, an octree, or another multi-dimensional memory store that may be recognized by those of ordinary skill in the art in light of teachings described herein. Additional and/or alternative types of storage mechanisms that are capable of storing vector space representations may be recognized by those of ordinary skill in the art.
At operation 414, the object memory is provided. For example, the object memory may be provided as an output for further processing to occur. In some examples, the object memory may be used to retrieve information (e.g., via multi-modal searching of stored and/or related content information) and/or generate an action, as will be described in some examples in further detail herein.
In some examples, the method 400 further includes providing an updated semantic model to replace at least one of the semantic models. The update semantic model includes an updated version that is different than the version of the at least one of the semantic models. From the updated semantic model, an updated collection of objects may be received that correspond to the collections of objects that are generated by the at least one of the semantic models. Further, the updated collection of objects may be stored in the object memory with metadata that corresponds to the updated version.
Generally, objects may be used as quantitative and/or compressed (e.g., memory-efficient) representations of abstract meaning that is discerned from content data. Accordingly, different semantic models may generate different objects for the same received content data, such as depending on how the semantic models are trained (e.g., based on different data sets and/or training methods) or otherwise configured. In some examples, some semantic models may be trained to provide relatively broader interpretations of received content than other semantic models that are trained to provide relatively narrower interpretations of content data. Accordingly, such semantic models may generate different objects.
In some examples, the method 400 further includes deleting the collection of objects that correspond to the updated collection of objects. The collection of objects may include metadata the corresponds to a version that is different than the updated version. Generally, if a first version of a semantic model is replaced with a second version of a semantic model, then it may be efficient for memory storage to delete objects generated by the first version of the semantic model since new embeddings may be stored that are generated by the second version of the semantic model. For example, the objects generated by the second version of the semantic model (e.g., a newer version) may be more desirable for use in further processing than the objects generated by the first version of the semantic model (e.g., an older version).
One of ordinary skill in the art will recognize that in some examples objects may not be deleted, such as when it is not necessary or desirable to delete objects that correspond to different versions of a semantic model. Further, in some examples, objects that correspond to different versions of a semantic model may be stored in the object memory with options to roll-back and/or roll-forward to different version of objects. For example, if a version of objects is corrupted or unusable, then it may be desirable to conduct further processing using a different version of objects that is accessible and/or useable.
Method 400 may terminate at operation 414. Alternatively, method 400 may return to operation 402 (or any other operation from method 400) to provide an iterative loop, such as of receiving a plurality of content items and inserting one or more semantic objects into an object memory based thereon.
In some examples, the input object 502 may be generated based on something other than user-input. For example, the input object 502 may be generated based on an algorithm that triggers the input object 502 to be generated. Additionally, or alternatively, the input object 502 may be generated based on an audio and/or visual input that is received by a computer (e.g., independent from user-input). In some example, the input object 502 may be generated by a natural language processor, or a visual processor, or a generative large language model. Additional and/or alternative methods for generating the input object 502 may be recognized by those of ordinary skill in the art.
The input object 502 may be input into a semantic retrieval engine or component 504. The semantic retrieval engine or component 504 may include hardware and/or software that retrieves, from an object memory 506 (e.g., which may be similar to the object memory provided by method 400), a plurality of stored objects, such as a first collection of stored objects 508, a second collection of stored objects 510, and a third collection of stored objects 512. The first, second, and third collections of stored objects 508, 510, and 512 may each be retrieved based on the input object 502.
The object memory 506 may be a graph. The graph may include a plurality of nodes. In some examples, each node of the plurality of nodes corresponds to a respective stored semantic object of the object memory 506. Edges extending between one or more of the nodes of the graph may include a weight that corresponds to a similarity of the nodes between which the edges extend. Accordingly, when traversing the object memory 506, the weights between stored objects may be used to determine a cost associated with extracting results based on one or more nodes that are determined to be relatively semantically similar. Further, in some examples, at least one node of the object memory 506 (e.g., graph) includes metadata that corresponds to source data 518 of content data to which the at least one node corresponds (e.g., the first set of content data 302 and/or the second set of content data 303 of
Each of the collections of stored objects 508, 510, 512 may correspond to respective content data, such as content data 110, private content data 200, and/or public content data 250. In some examples, the plurality of stored objects (e.g., the objects of collections 508, 510, 512) may each correspond to a different type of content data. In some examples, the first collection of stored objects 508 may include embeddings (e.g., semantic embeddings) and/or text that correspond to calendar invites, the second collection of stored embeddings 510 may include embeddings (e.g., semantic embeddings) and/or text that correspond to emails, and the third collection of stored embeddings 512 may include embeddings (e.g., semantic embeddings) and/or text that correspond to audio files. Additional and/or alternative content types to which the collections of stored embeddings 508, 510, and 512 correspond may be recognized by those of ordinary skill in the art.
A subset of objects may be retrieved from the plurality of stored objects 508, 510, 512 based on a similarity to the input object 502. For example, objects that correspond to one or more emails, one or more calendar invites, one or more audio files, one or more video files, etc. may be received from respective collections of stored objects, such as the plurality of collections of stored objects 508, 510, 512.
In some examples, a respective similarity between the input object and each embedding of the plurality of stored objects 508, 510, 512 may be determined. The determined similarities may be compared to a predetermined threshold. Further, the subset of objects with similarities to the input objects that are less than the predetermined threshold may be retrieved. Therefore, subsets of objects that are determined to be related to the input objects may be retrieved. Mechanisms for determining a similarity of objects to the input objects, when the objects are embeddings, are discussed in further detail with respect to the vector space 600 of
In some examples, an ordered ranking of the similarities may be determined. For example, the similarities may be ordered (e.g., in an increasing or decreasing fashion) based on values associated with the determined similarities. Therefore, a subset of objects may be retrieved based on the ordered ranking (e.g., a specified number of top and/or bottom rankings may be retrieved). In some examples, a subset of objects may be retrieved with similarities to the input object that are less than the predetermined threshold and/or based on the ordered ranking.
In some examples, the semantic retrieval component 504 may include a model, such as a generative large language model (LLM) that traverses objects in the object memory 506. When traversing the objects, the LLM may be conditioned with prompts and/or prompt templates. An LLM decoding process may try to generate a maximally-likely output given the prompts and any data inserted into the prompt template. There may be probabilities and/or logits on tokens and/or phrases in output by the LLM which can be used to further rank traversal choices. The prompts may be task-specific, may come from a library of prompts, and/or may be generated by the LLM itself as it traverses through the object memory 506. The LLM may generate additional subqueries on how next to search for information given a task and/or subtask and the data and/or metadata traversed thus far.
At action determination engine or component 514, a semantic-based result or result 516 is determined based on the subsets of objects (e.g., from the plurality of stored objects 508, 510, 512) and the input object 502. The result 516 may further be determined based on source data 518. For example, mechanisms described herein may locate raw source data corresponding to the subset of objects and determine the result based on further analysis of the content of the raw source data. As discussed earlier herein, the source data may include one or more of audio files, text files, image files, video files, website pages, blog posts, data generated by specific software applications, etc.
The semantic-based result may be any of a plurality of different result. For example, the result may be a search result based on one or more different types of content data that have been derivatively stored in the object memory 506. In some examples, the result includes a plurality of results. The plurality of results may each have a respective confidence score. At least one result of the plurality of results may be provided as an output of mechanisms provided herein, such as based on the confidence scores.
In one particular example, the input object 502 may be generated based on a user-input indicating “What present did I give Sally last year?” Based on the input object 502, mechanisms described herein may retrieve a plurality of stored objects that correspond to emails, calendar events, and browser history. A subset of the email objects may correspond to email source data content such as “Here is your receipt for a bike.” A subset of calendar events may correspond to calendar event data content such as “Sally's Birthday.” A subset of browser history may correspond to browser history source data such as “best bikes to buy as a birthday gift.” Accordingly, based on the plurality of stored objects and/or a subset thereof (e.g., collected throughout an interaction history between a user and device), the intent object, and/or the source data, the semantic-based result may include an indication that the user bought Sally a bike for her birthday last year. Additionally, or alternatively, the result may include a list of potential presents that the user gave to Sally last year with a corresponding confidence threshold for each potential present.
In some examples, one or more traversals of the object memory 506 may be used to extract, assembly, summarize, convert, and/or prepare data. In some examples, the data may be fed into subsequent models, task pipelines, prompt templates, etc. to accomplish a user's goal or subgoal (e.g., as determined at the result determination engine 514). In some examples, a plurality of raw data and/or summary data may be pulled from the object memory 506 to feed into a task/subtask. Feeding into a task/subtask may be more general than just generating a search engine result page (SERP) in that the ultimate next action (e.g., semantic based result 516) could be a user dialogue response (SERP is one specific response), a system action (perform some complex task across one or more applications/services), or further queries to the object memory 506. Generally, mechanisms provided herein may allow for post-processing (e.g., with a large language model) data extracted from the object memory 506 to complete a task. This post-processed data may be from embeddings in nodes of the object memory 506 (e.g., when the object memory 506 includes a graph), raw ledger data, and/or newly summarized/combined data from one or more parts of the object memory 506. In some examples, data extracted from one traversal of the object memory 506 may be used to improve data extracted from a second traversal of the index (e.g., allowing for additional data gathering to be informed by data extracted on a first traversal).
In some examples, a plurality of models may also be used during index traversal to identify relevant portions of a ledger/ledger representation to a task at hand (e.g., an index node with an image embedding may be queried for the presence of a cat and translated from image to text so that a text model may make a decision on how to proceed in the processing of its task goals; there may be jointly trained models that are multi-modal and/or there may be translational models that can convert embeddings across modalities, and thus convert between inputs/output representations of various models). In some examples, a ledger refers to a data structure or system used to maintain a log or a history of transactions, events, actions, summaries, etc. associated with an application/service. The ledger may store information related to the transactions, events, actions, summaries, etc. The transactions, events, actions, summaries, etc. may occur across various time scale, levels of abstraction, and/or data modalities.
As an example, mechanisms provided herein may be able to learn over time (e.g., through offline training, through user demonstrations, improved LLM+, etc.). how to identify the behavior of composing a birthday card from raw events in a ledger (e.g., by learning to optimize what events to extract/index and how to index/organize nodes, such as in the object memory 506, to maximize a success rate (and time to completion, etc.) of an accumulating set of user tasks that occur in the ledger). For example, the mechanisms may learn by using ledger activity from a plurality of users. In some examples, the ledger may be associated with multiple users (e.g., a video application service ledger data wherein events might involve the actions of multiple users/devices).
While particular examples of results have been provided above, the particular examples are merely examples. Additional and/or alternative examples should be recognized by those of ordinary skill in the art in light, at least in light of teachings provided herein.
The feature vectors 602, 604, 606, 608, 610 each have distances that are measurable between each other. For example, a distance between the feature vectors 602, 604, 606, and 608 and the fifth feature vector 610 corresponding to the input embedding 611 may be measured using cosine similarity. Alternatively, a distance between the feature vectors 602, 604, 606, 608 and the fifth feature vector 610 may be measured using another distance measuring technique (e.g., an n-dimensional distance function) that may be recognized by those of ordinary skill in the art.
A similarity of each of the feature vectors 602, 604, 606, 608 to the feature vector 610 corresponding to the input embedding 611 may be determined, for example based on the measured distances between the feature vectors 602, 604, 606, 608 and the feature vector 610. The similarity between the feature vectors 602, 604, 606, 608 and the feature vector 610 may be used to group or cluster the feature vectors 602, 604, 606, and 608 in one or more collections of feature vectors, such as a collection 612, thereby generating a collection of embeddings.
In some examples, the collection 612 may include a predetermined number of feature vectors, such that groups of feature vectors are given a predetermined size. Additionally, or alternatively, in some examples, The distances between each of the feature vectors 602, 604, 606, 608 and the feature vector 610 corresponding to the input embedding 611 may be compared to a predetermined threshold.
The embeddings 603 and 605 that correspond to feature vectors 602 and 604, respectively, may fall within the same content group. For example, the embedding 603 may be related to a first email, and the embedding 605 may be related to a second email. Additional and/or alternative examples of content groups in which the embeddings may be categorized may be recognized by those of ordinary skill in the art.
The collection 612 may be stored in a data structure, such as an ANN tree, a k-d tree, an octree, another n-dimensional tree, or another data structure that may be recognized by those of ordinary skill in the art that is capable of storing vector space representations. Further, memory corresponding to the data structure in which the collection 612 is stored may be arranged or stored in a manner that groups the embeddings and/or vectors in the collection 612 together, within the data structure. In some examples, feature vectors and their corresponding embeddings generated in accordance with mechanisms described herein may be stored for an indefinite period of time. Additionally, or alternatively, in some examples, as new feature vectors and/or embeddings are generated and stored, the new feature vectors and/or embeddings may overwrite older feature vectors and/or embeddings that are stored in memory (e.g., based on metadata of the embeddings indicating a version), such as to improve memory capacity. Additionally, or alternatively, in some examples, feature vectors and/or embeddings may be deleted from memory at specified intervals of time, and/or based on an amount of memory that is available (e.g., in the embedding object memory 310), to improve memory capacity.
Generally, the ability to store embeddings corresponding to received content data allows a user to associate and locate data in a novel manner that has the benefit of being computationally efficient. For example, instead of storing a video recording of a screen of a computing device, or web pages on the Internet, a user may instead store, using mechanisms described herein, embeddings corresponding to content objects. The embeddings may be hashes, as opposed to, for example, video recordings that may be a few hundreds of thousands of pixels, per frame. Therefore, the mechanisms described herein are efficiency for reducing memory usage, as well as for reducing usage of processing resources to search through stored content. Additional and/or alternative advantages may be recognized by those of ordinary skill in the art.
Method 700 begins at operation 702 wherein an input object is received. The input object may include one or more of an embedding (e.g., semantic embedding) or text (e.g., semantic text summary). The input object may be generated by a model, such as a machine-learning model. For example, user-input may be received and the input object may be generated based on the user-input. The input object 502 may correspond to an intent of a user. For example, a user may intend to generate a result (e.g., in response to a query). In some examples, the result may be used to perform an action with their computing device, such as book a flight, or send an email, or create a presentation, or locate a file, or run a program, or display the result. Additional and/or alternative intents that a user has with respect to a computing device may be recognized by those of ordinary skill in the art.
In some examples, the input object may be generated based on something other than user-input. For example, the input object may be generated based on an algorithm that triggers the input object to be generated. Additionally, or alternatively, the input object may be generated based on an audio and/or visual input that is received by a computer (e.g., independent from user-input). Additional and/or alternative methods for generating the input object, such as based on received and/or generated data, may be recognized by those of ordinary skill in the art.
At operation 704, a plurality of stored objects (e.g., semantic objects) are retrieved. The plurality of stored objects may be retrieved from an object memory (e.g., the object memory provided by method 400 illustrated in
In some examples, at operation 706, a subset of objects (e.g., subset of semantic objects) from the plurality of stored objects are retrieved. For example, the subset of objects may be retrieved based on a similarity to the input object. A respective similarity between the input object and each embedding of the plurality of stored objects may be determined. For example, the similarity may be based on a distance between the objects in a vector space, such as the vector space 600 described with respect to
At operation 708, it is determined if there is a result associated with the plurality of stored semantic objects (and/or subset thereof) and the input object. For example, the result may be determined based on the subset of objects and the input object. In some examples, source data that is associated with the subset of objects may be located (e.g., local to a device on which method 700 is being executed and/or remote from a device on which method 700 is being executed) and the result may be further determined based on the source data. As discussed earlier herein, the source data may include one or more of audio files, text files, image files, video files, website pages, blog posts, news stories, data generated by specific software applications, etc.
If it is determined that there is not a result associated with the stored objects, flow branches “NO” to operation 710, where a default action is performed. For example, the stored objects may have an associated pre-configured action. In other examples, method 700 may comprise determining whether the stored objects have an associated default action, such that, in some instances, no action may be performed as a result of the retrieved stored objects. Method 700 may terminate at operation 710. Alternatively, method 700 may return to operation 702 to provide an iterative loop of receiving an input object, retrieving a plurality of stored objects, retrieving a subset of objects from the plurality of stored objects, and determining if there is a result associated with the subset of objects and the input object.
If however, it is determined that there is a result associated with the stored objects and the input object, flow instead branches “YES” to operation 712, where the result is provided as an output. For example, the result may be provided as an output to a user, a system on which method 700 is being executed, and/or a system remote from that on which method 700 is being executed. Further, in some examples, the method 700 may further include adapting a computing device to perform an action based on the result that is provided.
The semantic-based result may be any of a plurality of different result. For example, the result may be a search result based on one or more different types of content data that have been derivatively stored in the object memory. In some examples, the result includes a plurality of results. The plurality of results may each have a respective confidence score. At least one result of the plurality of results may be provided as an output of mechanisms provided herein, such as based on the confidence scores.
In one particular example, the input object may be generated based on a user-input indicating “What present did I give Sally last year?” Based on the input object 502, mechanisms described herein may retrieve a plurality of stored objects that correspond to emails, calendar events, and browser history. A subset of email objects may correspond to email source data content such as “Here is your receipt for a bike.” A subset of calendar events may correspond to calendar event data content such as “Sally's Birthday.” A subset of browser history may correspond to browser history source data such as “best bikes to buy as a birthday gift.” Accordingly, based on the subset of objects, the input object, and/or the source data, the semantic-based result may include an indication that the user bought Sally a bike for her birthday last year. Additionally, or alternatively, the result may include a list of potential presents that the user gave to Sally last year with a corresponding confidence threshold for each potential present.
While particular examples of results have been provided above, the particular examples are merely examples. Additional and/or alternative examples should be recognized by those of ordinary skill in the art in light, at least in light of teachings provided herein.
In examples, generative model package 804 is pre-trained according to a variety of inputs (e.g., a variety of human languages, a variety of programming languages, and/or a variety of content types) and therefore need not be finetuned or trained for a specific scenario. Rather, generative model package 804 may be more generally pre-trained, such that input 802 includes a prompt that is generated, selected, or otherwise engineered to induce generative model package 804 to produce certain generative model output 806. For example, a prompt includes a context and/or one or more completion prefixes that thus preload generative model package 804 accordingly. As a result, generative model package 804 is induced to generate output based on the prompt that includes a predicted sequence of tokens (e.g., up to a token limit of generative model package 804) relating to the prompt. In examples, the predicted sequence of tokens is further processed (e.g., by output decoding 816) to yield output 806. For instance, each token is processed to identify a corresponding word, word fragment, or other content that forms at least a part of output 806. It will be appreciated that input 802 and generative model output 806 may each include any of a variety of content types, including, but not limited to, text output, image output, audio output, video output, programmatic output, and/or binary output, among other examples. In examples, input 802 and generative model output 806 may have different content types, as may be the case when generative model package 804 includes a generative multimodal machine learning model.
As such, generative model package 804 may be used in any of a variety of scenarios and, further, a different generative model package may be used in place of generative model package 804 without substantially modifying other associated aspects (e.g., similar to those described herein with respect to
Generative model package 804 may be provided or otherwise used according to any of a variety of paradigms. For example, generative model package 804 may be used local to a computing device (e.g., computing device 102 in
With reference now to the illustrated aspects of generative model package 804, generative model package 804 includes input tokenization 808, input embedding 810, model layers 812, output layer 814, and output decoding 816. In examples, input tokenization 808 processes input 802 to generate input embedding 810, which includes a sequence of symbol representations that corresponds to input 802. Accordingly, input embedding 810 is processed by model layers 812, output layer 814, and output decoding 816 to produce model output 806. An example architecture corresponding to generative model package 804 is depicted in
As illustrated, architecture 850 processes input 802 to produce generative model output 806, aspects of which were discussed above with respect to
Further, positional encoding 860 may introduce information about the relative and/or absolute position for tokens of input embedding 858. Similarly, output embedding 874 includes a sequence of symbol representations that correspond to output 872, while positional encoding 876 may similarly introduce information about the relative and/or absolute position for tokens of output embedding 874.
As illustrated, encoder 852 includes example layer 870. It will be appreciated that any number of such layers may be used, and that the depicted architecture is simplified for illustrative purposes. Example layer 870 includes two sub-layers: multi-head attention layer 862 and feed forward layer 866. In examples, a residual connection is included around each layer 862, 866, after which normalization layers 864 and 868, respectively, are included.
Decoder 854 includes example layer 890. Similar to encoder 852, any number of such layers may be used in other examples, and the depicted architecture of decoder 854 is simplified for illustrative purposes. As illustrated, example layer 890 includes three sub-layers: masked multi-head attention layer 878, multi-head attention layer 882, and feed forward layer 886. Aspects of multi-head attention layer 882 and feed forward layer 886 may be similar to those discussed above with respect to multi-head attention layer 862 and feed forward layer 866, respectively. Additionally, masked multi-head attention layer 878 performs multi-head attention over the output of encoder 852 (e.g., output 872). In examples, masked multi-head attention layer 878 prevents positions from attending to subsequent positions. Such masking, combined with offsetting the embeddings (e.g., by one position, as illustrated by multi-head attention layer 882), may ensure that a prediction for a given position depends on known output for one or more positions that are less than the given position. As illustrated, residual connections are also included around layers 878, 882, and 886, after which normalization layers 880, 884, and 888, respectively, are included.
Multi-head attention layers 862, 878, and 882 may each linearly project queries, keys, and values using a set of linear projections to a corresponding dimension. Each linear projection may be processed using an attention function (e.g., dot-product or additive attention), thereby yielding n-dimensional output values for each linear projection. The resulting values may be concatenated and once again projected, such that the values are subsequently processed as illustrated in
Feed forward layers 866 and 886 may each be a fully connected feed-forward network, which applies to each position. In examples, feed forward layers 866 and 886 each include a plurality of linear transformations with a rectified linear unit activation in between. In examples, each linear transformation is the same across different positions, while different parameters may be used as compared to other linear transformations of the feed-forward network.
Additionally, aspects of linear transformation 892 may be similar to the linear transformations discussed above with respect to multi-head attention layers 862, 878, and 882, as well as feed forward layers 866 and 886. Softmax 894 may further convert the output of linear transformation 892 to predicted next-token probabilities, as indicated by output probabilities 896. It will be appreciated that the illustrated architecture is provided in as an example and, in other examples, any of a variety of other model architectures may be used in accordance with the disclosed aspects. In some instances, multiple iterations of processing are performed according to the above-described aspects (e.g., using generative model package 804 in
Accordingly, output probabilities 896 may thus form result output 806 according to aspects described herein, such that the output of the generative ML model (e.g., which may include structured output) is used as input for determining an action according to aspects described herein (e.g., similar to the action determination engine 514 of
The system memory 904 may include an operating system 905 and one or more program modules 906 suitable for running software application 920, such as one or more components supported by the systems described herein. As examples, system memory 904 may store object memory insertion engine or component 924 and/or object memory retrieval engine or component 926. The operating system 905, for example, may be suitable for controlling the operation of the computing device 900.
Furthermore, aspects of the disclosure may be practiced in conjunction with a graphics library, other operating systems, or any other application program and is not limited to any particular application or system. This basic configuration is illustrated in
As stated above, a number of program modules and data files may be stored in the system memory 904. While executing on the processing unit 902, the program modules 906 (e.g., application 920) may perform processes including, but not limited to, the aspects, as described herein. Other program modules that may be used in accordance with aspects of the present disclosure may include electronic mail and contacts applications, word processing applications, spreadsheet applications, database applications, slide presentation applications, drawing or computer-aided application programs, etc.
Furthermore, aspects of the disclosure may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors. For example, aspects of the disclosure may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in
The computing device 900 may also have one or more input device(s) 912 such as a keyboard, a mouse, a pen, a sound or voice input device, a touch or swipe input device, etc. The output device(s) 914 such as a display, speakers, a printer, etc. may also be included. The aforementioned devices are examples and others may be used. The computing device 900 may include one or more communication connections 916 allowing communications with other computing devices 950. Examples of suitable communication connections 916 include, but are not limited to, radio frequency (RF) transmitter, receiver, and/or transceiver circuitry; universal serial bus (USB), parallel, and/or serial ports.
The term computer readable media as used herein may include computer storage media. Computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules. The system memory 904, the removable storage device 909, and the non-removable storage device 910 are all computer storage media examples (e.g., memory storage). Computer storage media may include RAM, ROM, electrically erasable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other article of manufacture which can be used to store information and which can be accessed by the computing device 900. Any such computer storage media may be part of the computing device 900. Computer storage media does not include a carrier wave or other propagated or modulated data signal.
Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term “modulated data signal” may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
One or more application programs 1066 may be loaded into the memory 1062 and run on or in association with the operating system 1064. Examples of the application programs include phone dialer programs, e-mail programs, personal information management (PIM) programs, word processing programs, spreadsheet programs, Internet browser programs, messaging programs, and so forth. The system 1002 also includes a non-volatile storage area 1068 within the memory 1062. The non-volatile storage area 1068 may be used to store persistent information that should not be lost if the system 1002 is powered down. The application programs 1066 may use and store information in the non-volatile storage area 1068, such as e-mail or other messages used by an e-mail application, and the like. A synchronization application (not shown) also resides on the system 1002 and is programmed to interact with a corresponding synchronization application resident on a host computer to keep the information stored in the non-volatile storage area 1068 synchronized with corresponding information stored at the host computer. As should be appreciated, other applications may be loaded into the memory 1062 and run on the mobile computing device 1000 described herein (e.g., an embedding object memory insertion engine, an embedding object memory retrieval engine, etc.).
The system 1002 has a power supply 1070, which may be implemented as one or more batteries. The power supply 1070 might further include an external power source, such as an AC adapter or a powered docking cradle that supplements or recharges the batteries.
The system 1002 may also include a radio interface layer 1072 that performs the function of transmitting and receiving radio frequency communications. The radio interface layer 1072 facilitates wireless connectivity between the system 1002 and the “outside world,” via a communications carrier or service provider. Transmissions to and from the radio interface layer 1072 are conducted under control of the operating system 1064. In other words, communications received by the radio interface layer 1072 may be disseminated to the application programs 1066 via the operating system 1064, and vice versa.
The visual indicator 1020 may be used to provide visual notifications, and/or an audio interface 1074 may be used for producing audible notifications via the audio transducer 1025. In the illustrated example, the visual indicator 1020 is a light emitting diode (LED) and the audio transducer 1025 is a speaker. These devices may be directly coupled to the power supply 1070 so that when activated, they remain on for a duration dictated by the notification mechanism even though the processor 1060 and/or special-purpose processor 1061 and other components might shut down for conserving battery power. The LED may be programmed to remain on indefinitely until the user takes action to indicate the powered-on status of the device. The audio interface 1074 is used to provide audible signals to and receive audible signals from the user. For example, in addition to being coupled to the audio transducer 1025, the audio interface 1074 may also be coupled to a microphone to receive audible input, such as to facilitate a telephone conversation. In accordance with aspects of the present disclosure, the microphone may also serve as an audio sensor to facilitate control of notifications, as will be described below. The system 1002 may further include a video interface 1076 that enables an operation of an on-board camera 1030 to record still images, video stream, and the like.
A computing device implementing the system 1002 may have additional features or functionality. For example, the computing device may also include additional data storage devices (removable and/or non-removable) such as, magnetic disks, optical disks, or tape. Such additional storage is illustrated in
Data/information generated or captured by the computing device and stored via the system 1002 may be stored locally on the computing device, as described above, or the data may be stored on any number of storage media that may be accessed by the device via the radio interface layer 1072 or via a wired connection between the computing device and a separate computing device associated with the computing device, for example, a server computer in a distributed computing network, such as the Internet. As should be appreciated such data/information may be accessed via the computing device via the radio interface layer 1072 or via a distributed computing network. Similarly, such data/information may be readily transferred between computing devices for storage and use according to well-known data/information transfer and storage means, including electronic mail and collaborative data/information sharing systems.
An application 1120 (e.g., similar to the application 920) may be employed by a client that communicates with server device 1102. Additionally, or alternatively, object memory insertion engine 1121 and/or object memory retrieval engine 1122 may be employed by server device 1102. The server device 1102 may provide data to and from a client computing device such as a personal computer 1104, a tablet computing device 1106 and/or a mobile computing device 1108 (e.g., a smart phone) through a network 1115. By way of example, the computer system described above may be embodied in a personal computer 1104, a tablet computing device 1106 and/or a mobile computing device 1108 (e.g., a smart phone). Any of these examples of the computing devices may obtain content from the store 1116, in addition to receiving graphical data useable to be either pre-processed at a graphic-originating system, or post-processed at a receiving computing system.
As will be understood from the foregoing disclosure, one aspect of the technology relates to a method for storing an entry in an object memory, the method comprising: receiving a plurality of content items over a period of time, the content items together forming an interaction history between a user and device over the period of time, and the content items each having one or more content data; providing the content data associated with the plurality of content items to one or more semantic models, wherein the one or more semantic models generate one or more semantic objects, wherein the semantic objects are one or more of: semantic embeddings or semantic text; receiving, from one or more of the semantic models, one or semantic objects, wherein the one or more semantic objects correspond to the provided content data; inserting the one or more semantic objects into the object memory, wherein the one or more semantic objects are associated with a respective indication corresponding to a reference to source data associated with the one or more semantic objects; and providing the object memory. In some examples, the semantic objects include semantic embeddings, the insertion triggers a memory storage operation to store the semantic objects, and a vector representation of the semantic embeddings is stored in a multi-dimensional memory store. In some examples, the semantic models comprise a generative large language model (LLM). In some examples, the interaction history is a dialogue between the user and the device. In some examples, the object memory is stored at a location that is different than the location of the source data. the one or more semantic models comprise a version, each of the semantic objects generated by each of the respective models comprise metadata corresponding to the version, and the method further comprises: providing an updated semantic model to replace at least one of the semantic models, the updated semantic model comprising an updated version that is different than the version of the at least one of the semantic models; receiving, from the updated semantic model, an updated one or more semantic objects corresponding to the one or more semantic objects generated by the at least one of the semantic embedding models; and inserting the updated semantic objects in the embedding object memory with metadata corresponding to the updated version. In some examples, the object memory comprises one or more of a hierarchical index or a graph.
In another aspect, the technology relates to a method for retrieving information from an object memory, the method comprising: receiving an input object comprising one or more of an embedding or text, wherein the input object is generated by a machine-learning model; retrieving a plurality of stored semantic objects, from the object memory, based on the input object, wherein the object memory is graph comprising a plurality of nodes, and wherein each node of the plurality of nodes corresponds to a respective stored semantic object of the plurality of stored semantic objects; determining, based on the plurality of semantic objects and the input object, a result; and providing the result as an output. In some examples, each semantic object of the plurality of semantic objects is associated with source data corresponding to the respective content data, the source data comprises one or more of audio files, text files, or image files, and the determining a result comprises: locating the source data; and determining the result based on the input object and the source data. In some examples, the plurality of stored semantic objects each correspond to a different type of content data. Some examples further comprise: determining a respective similarity between the input object and each stored semantic object of the plurality of stored semantic objects; determining an ordered ranking of the one or more similarities or that one or more of the similarities are less than a predetermined threshold; retrieving a subset of stored semantic objects from the plurality of stored semantic objects with similarities to the input object that are less than the predetermined threshold or based on the ordered ranking, thereby retrieving semantic objects that are determined to be related to the input object; and determining the result based on the subset of stored semantic objects and the input object. In some examples, the result comprises a plurality of results, one or more of the plurality of results have a respective confidence score, and at least one result of the plurality of results is provided as the output, based on the confidence scores. Some examples further comprise, prior to receiving the input object: receiving user-input; and generating the input object based on the user-input. In some examples, at least one node of the plurality of nodes comprises metadata corresponding to source data of content data to which the at least one node corresponds.
In a further aspect, the technology relates to a method for inserting entries into and retrieving information from an object memory, the method comprising: receiving a plurality of content items over a period of time, the content items together forming an interaction history between a user and device over the period of time, and the content having one or more content data; providing the content data associated with the plurality of content items to one or more semantic models, wherein the one or more semantic models generate one or more semantic objects comprising one or more of an embedding or text; receiving, from one or more of the semantic models, one or more semantic objects, wherein the one or more semantic objects correspond to the provided content data; inserting the one or more semantic objects into the object memory, wherein the one or more semantic objects are associated with a respective indication corresponding to a reference to source data associated with the one or more semantic objects; receiving an input object comprising one or more of an embedding or text; retrieving a plurality of stored semantic objects, from the object memory, based on the input object; retrieving a subset of semantic objects from the plurality of stored semantic objects based on a similarity to the input object; and providing the subset of semantic objects as an output. In some examples, the semantic objects include semantic embeddings, the insertion triggers a memory storage operation to store the semantic objects, and a vector representation of the semantic embeddings is stored in a multi-dimensional memory store. Some examples further comprise determining, based on the subset of semantic objects and the input object, a plurality of results, wherein one or more results of the plurality of results have a respective confidence score; and providing at least one result of the plurality of results as an output, based on the confidence scores. In some examples, the retrieving a subset of semantic objects comprises: determining a respective similarity between the input object and each semantic object of the plurality of stored semantic objects; determining an ordered ranking of the one or more similarities or that one or more of the similarities are less than a predetermined threshold; and retrieving the subset of semantic objects with similarities to the input object that are less than the predetermined threshold or based on the ordered ranking, thereby retrieving semantic objects that are determined to be related to the input object. In some examples, the semantic models comprise a generative large language model (LLM). In some examples, the content data are provided to the one or more semantic models locally or via an application programming interface (API).
Aspects of the present disclosure, for example, are described above with reference to block diagrams and/or operational illustrations of methods, systems, and computer program products according to aspects of the disclosure. The functions/acts noted in the blocks may occur out of the order as shown in any flowchart. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the functionality/acts involved.
The description and illustration of one or more aspects provided in this application are not intended to limit or restrict the scope of the disclosure as claimed in any way. The aspects, examples, and details provided in this application are considered sufficient to convey possession and enable others to make and use claimed aspects of the disclosure. The claimed disclosure should not be construed as being limited to any aspect, example, or detail provided in this application. Regardless of whether shown and described in combination or separately, the various features (both structural and methodological) are intended to be selectively included or omitted to produce an embodiment with a particular set of features. Having been provided with the description and illustration of the present application, one skilled in the art may envision variations, modifications, and alternate aspects falling within the spirit of the broader aspects of the general inventive concept embodied in this application that do not depart from the broader scope of the claimed disclosure.
This application claims priority to U.S. Provisional Application No. 63/442,299, titled “STORING ENTRIES IN AND RETRIEVING INFORMATION FROM AN OBJECT MEMORY,” filed on Jan. 31, 2023, the entire disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
63442299 | Jan 2023 | US |