The present application generally relates to data processing and presentation techniques for a content feed. More precisely, the present application describes a specific technique to improve the computational efficiency with which content is processed and presented via a content feed, by aggregating content items that share some common characteristic with respect to a connection graph, such as being associated with a common graph edge.
Content feeds have become one of the hallmark features of many popular Internet or web-based services. By way of example, many different Internet services, such as social networking services, e-commerce and marketplace sites, photo sharing sites, news sites, dating sites, and so on, utilize some form of a content feed to present end-users with relevant content. What is referred to herein as a content feed may also be known as a data feed, news feed, product feed, web feed, or simply, a feed. In many instances, the content items that are presented to an end-user of a content feed are selected for presentation to the end-user based on the end-user having previously taken some explicit and specific action to indicate some association or relationship with some aspect of the content item. By way of example, in a social networking service, content items that are published to a content feed by a first member may be presented to a second member when the second member has previously taken some specific and explicit action to establish a formal relationship (e.g., “connection” or “friend”) with the second member. Accordingly, when two members are connected with one another via a social graph maintained by the online service, when a first member publishes content to a content feed, the published content item may be selected for presentation to the second member, via the content feed. Similarly, in the context of a photo sharing site, a first end-user may choose to subscribe to, or “follow,” a second end-user, such that photographs shared by the second end-user will be presented in a content feed to the first end-user only after the first end-user has subscribed to or followed the second end-user.
These formally recognized associations and/or relationships that exist between content items and end-users are generally memorialized in a database maintained by the online service, for example, such as a graph database. A graph database is a special type of database that stores data in a way that recognizes that the importance of the association or relationship between data is often as important as the data itself. These associations and relationships are often conveyed visually as a graph—for example, a plot of nodes and edges, where an edge connecting two nodes represents some type of association or relationship between the particular entities that are represented by the nodes. While a graph of this type is referred to herein as a connection graph, it may also be referred to as a social graph, a connectivity graph, a content graph, or simply a graph, depending upon the specific service or site and the nature of the entities that are represented by the individual nodes. For instance, an e-commerce site may utilize a connection graph with nodes representing end-users (e.g., customers or potential customers), categories of products, brands, and/or individual products. Similarly, asocial graph is a special type of connection graph that is associated with a social networking service. A social graph may have nodes representing people, companies or other organizations, as well as topics to which content items are assigned. Accordingly, the edges connecting the nodes may represent a particular association or relationship between two people, between a person and an organization, or a person's interest in a topic, and so forth.
Embodiments of the present invention are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which:
Described herein are methods and systems for efficiently processing and presenting content items in a content feed, such that content items that share a common edge within a connection graph are aggregated for presentation together within the content feed. In the following description, for purposes of explanation, numerous specific details and features are set forth in order to provide a thorough understanding of the various aspects of different embodiments of the present invention. It will be evident, however, to one skilled in the art, that the present invention may be practiced and/or implemented with varying combinations of the many details and features presented herein.
For purposes of the present application, a content feed is a computer-implemented application or service having a user interface by which content items are presented to end-users of an online service or system. A content feed is sometimes referred to as a news feed, product feed, or simply, a feed. A content feed may be vertically scrolling, such that additional content items can be accessed when the end-user causes the user interface to scroll in an upward/downward direction in relation to the top and bottom of the display. Similarly, a content feed may be horizontally scrolling, such that additional content items may appear to the right or left, in relation to the top/bottom of the display. The nature of the content items presented via a content feed will vary significantly depending upon the application or service with which the content feed is integrated. With many content feeds, the content of each content item is generally structured with individual data fields. For example, separate data fields may be used to specify the author/source of the content, a title, a topic, a brand of a product, and so forth.
Content feeds may present content items that have specifically been designated as having certain content types. Again, the various content types may vary significantly from one context to another, for example, depending upon the nature of the system or service with which the content feed is integrated. In the example of a social networking service, content items may be generally characterized as system-generated content, or user-generated content. By way of example, in the context of a social networking service, system-generated content may include insights regarding an end-user's profile. For example, a system-generated content item may be presented to an end-user to notify the end-user that one of his connections has had a job anniversary (e.g., a connection has been in the same job position with the same company for one or more years), or, has recently added a new job position to his or her profile. Another type of content item that may be characterized as a system-generated content item is an advertisement, including advertisements that specifically reference available job openings, which are generally referred to as job listings or job postings. User-generated content items include the sharing of articles or blog postings hosted by any of a wide variety of third-party sites. Such content items generally include the content of the referenced article or blog posting, but also any commentary provided by the end-user. Of course, user-generated content may include content that is entirely generated by an end-user, without reference to content hosted by a third-party site.
As illustrated in
Next, after the content retrieval phase 102, content ranking 106 occurs. The criteria used to rank the retrieved content items will vary significantly depending upon the nature of the content and the context in which the content feed is presented. By way of example, in the context of a social networking service, the criteria used to rank the content items may include information indicating the relevance or importance of the content item to the end-user, as well as the date/time at which the content was initially posted, with a general preference being to present more current content items. In any case, the result of the content ranking phase 106 is a ranked set of content items eligible for presentation to the end-user. As illustrated in the example shown in
Next, in the third phase, composition processing 108 occurs. The composition processing involves the application of a set of rules used to enhance the order in which content items appear in the final presentation of the content feed. Again, the specific rules that are used in the composition processing phase may vary considerably depending upon the specific nature of the content items and the context in which the content feed is being presented. Generally, one set of composition processing rules may involve what might be referred to as diversity rules intended to ensure that the content feed provides a diverse set of content items. In this context, diversity may be measured based on content types, content sources, and/or content topics. By way of example, in the context of a social networking service, during the composition processing phase, the ranked list of content items may be iteratively processed to ensure that there is a minimum number of content items that separates two content items that share some common characteristic (e.g. type/source/topic). For example, it may be desirable to separate content items that have been published by the same source (e.g., the same end-user), or published on behalf of the same company or organization. Similarly, it may be desirable to separate content items that relate to the same topic, or, have the same content type (e.g., advertisements, job updates, job postings, and so forth). Separating content items by some minimum number of other content items when presenting the content items in the content feed will provide greater diversity of content, and thus improve the overall end-user experience.
Additionally, during the composition processing 108, ranked content items that have recently been presented to the end-user, whether via the content feed or perhaps in some other context, may be identified for exclusion from the content feed. Such content items may be eliminated from the final set of content items presented to the end-user in order to improve the end-user experience by presenting new (e.g., previously unseen) content items to the end-user. As illustrated in the example of
One of the problems with a conventional content feed is that content items that share some common characteristic are separated within the content feed, either as a result of their respective rankings or by virtue of applying the rules of the composition processing stage. For example, if an end-user has previously expressed interest in a particular topic, for example, by electing to follow any content that has been assigned a particular metadata tag, the content items that relate to this topic of interest will likely be separated by other content items when presented in the content feed. By way of example, in
Additionally, processing the content items during the composition processing 108 phase is a computationally expensive process. As previously mentioned, the ranked list of content items may include tens of thousands of individual content items. Enforcing one or more rules that require content items sharing some common characteristic to be separated by some minimum number of other content items when presented in the final presentation of the content feed is computationally very expensive, as the rule(s) must be iteratively applied, and re-applied. For example, when a content item is re-positioned within the content feed as a result of some rule during the composition processing 108 phase, this may result in the violation of some other rule or constraint. Accordingly, after repositioning a content item, the order of the content items must continually be reassessed until all of the composition processing rules are satisfied.
In addition to being computationally expensive, presenting each content item that shares a common edge in a connection graph separately within the content feed increases the overall amount of data that must be communicated from the server to the client when generating the user interface for the content feed. For instance, content items are generally semi-structured with separate data fields indicating, for example, the source of the content (e.g., the name of the end-user who generated or shared the content), a title or subject line, or, one or more metadata tags (e.g., hashtags), and so forth. As many content items share in common information associated with one or more of these specific data fields, presenting each content item as a separate content item in the content feed requires that the information associated with each data field of each content item be communicated separately from the server to the client device. If a computer network has limited bandwidth, communicating all of the data to generate the user interface of the content feed at the client device may take a sufficiently long time that the end-user perceives a delay. Any such perceived delay in the time between requesting information, and being presented with the information, can be an extreme annoyance and frustration to the end-user.
An improved technique for processing content items for presentation via a content feed is illustrated in
Consistent with some embodiments, the content feed advantageously aggregates content items that share a common edge within the connection graph. This is advantageous for at least three specific reasons. First, from the perspective of the end-user, the experience is simply better, as related content items can be consumed sequentially without interruption or distraction by other content items related to a different topic, while still maintaining a certain amount of content diversity. For instance, referring again to the example in
Second, by aggregating content items together, the composition processing step is vastly more efficient as there is less need to iteratively process and re-process the final ranked list of content items. For example, as explained above, when content diversity rules dictate that content items from the same edge within a connection graph be separated by some minimum number of unrelated content items when presented in a content feed, the processing required to satisfy such rules can be computationally expensive as the processing is iterative in nature. That is, after any one content item is repositioned, the content items within the content feed need to be analyzed a second time to make sure that moving one content item to satisfy one rule does not result in a subsequent violation of the same rule, or the violation of a different rule. By aggregating certain content items based on some shared characteristic (e.g., association with a common edge), the overall amount of processing required to enforce some set of diversity rules is significantly reduced, providing for a more efficient process, from a computational processing perspective.
Finally, because content items are grouped together consistent with embodiments of the present invention, less data is ultimately being communicated from the server that generates the content feed to the client device that displays the content feed. Specifically, because various data fields are repetitive in the content carousel, less data is required to be communicated to the client for display. By way of example, if a content carousel includes several content items that are all tagged with the same metadata tag (e.g., hashtag), this tag need only be communicated to the client one time for all content items in the content carousel. Other advantages will be readily apparent from the description of the several figures that follow.
The types of entities represented by the nodes, as well as the various relationships represented by the edges, may vary considerably from one online service to another. By way of example and with reference to
Other online services may use connection graphs that have nodes representing other types of entities, and thus, edges representing other types of associations and/or relationships. By way of example, an e-commerce or marketplace site may have nodes that represent people, categories of products, brands, and so forth. Accordingly, when a person expresses interest in a product, a category of product or a particular brand, the content feed may present product listings that are consistent with the interest(s) of the end-user. If for example an end-user purchases a product of a particular brand, a content feed may group content items—e.g., product listings—that are related to the brand, so that the content items are presented together in a group within the content feed as part of a content carousel.
Consistent with embodiments of the present invention, when an end-user is presented with his or her personalized content feed, content items that share some common characteristic as memorialized in the connection graph may be aggregated into a group, such that the content items are presented in a group, at a position in the content feed that is determined based on the highest ranking content item within the group. For instance, if five content items are all associated with a common edge in a connection graph, all five content items may be selected for presentation in a content carousel, which is then presented in a position within the content feed that is based on the highest ranking content item of the five content items. By way of example, if five content items have been tagged with the tag, “#art” 312, the end-user, Sue Eng 310, may be presented with content feed that includes a content carousel in which the five content items are presented as a group. A least with some embodiments, those content items that are aggregated for presentation in a group may be presented in a horizontally scrolling content carousel, particularly when the content feed is itself a vertically scrolling content feed. As such, in the context of a social networking service, content items that all involve content relating to the same metadata tag (e.g., hashtag) may be grouped for presentation in a common, horizontally scrolling content carousel. Similarly, in the context of an e-commerce or marketplace site, certain product listings that share some common characteristic in the connection graph—for example, product listings sharing the same edge or edge type—may be aggregated and presented in a group within the content feed.
Once the eligible content items have been identified in operation 404, at method operation 406 the eligible content items are ranked, by assigning to each content item a ranking score. In various embodiments, depending upon a variety of factors—for example, the nature of the online service and the types of entities and edges represented within the connection graph—the criteria used in ranking the content items will vary considerably. For instance, with some embodiments, some measure of the strength of connection between an end-user and a source of content (e.g., the end-user who shared a content item) may be used to rank content items. Similarly, the date and time when a content item was first published or posted may be considered when ranking content items, with preference generally being given to more recently posted content items.
After the content items are ranked, resulting in a ranked list of content items, a composition processing operation occurs to make final adjustments to the ranked list of content items before presenting the content items in a content feed. It is during this phase that some set of content items that share a common characteristic—for instance, they are all associated with or related to the end-user by means of a common edge in a connection graph—may be identified and grouped for presentation via a content carousel. For instance, at method operation 408, as part of the composition processing phase, a first content item is identified. The first step in grouping some set of content items involves identifying a first content item that satisfies some characteristic or characteristics that make it eligible for presentation in a group, via a content carousel. The first content item may be the highest ranking content item that satisfies some single characteristic, or set of characteristics. For example, only certain content items may be eligible for grouping based on a common edge in a connection graph. Accordingly, the first step in grouping a set of content items may involve identifying the top ranking content item that has characteristics satisfying whatever characteristics are used in determining which content items to group. For instance, with some embodiments, it may be the case that only certain content items are eligible for grouping, based on the nature of the edge in the connection graph that connects the node, representing the end-user, to the node associated with the particular content items. By way of example, with some embodiments, the content items eligible for grouping, based on association with a common edge, and presentation in a content carousel may include:
Once an eligible content item has been identified, a determination is made at method operation 410 as to the number of other content items in the ranked list satisfying the same conditions—that is, sharing the same association or relationship to the node presenting the end-user as that defined by the edge connected the node, representing the end-user to the first content item. By way of example, in the context of a social networking service, it may be the case that content items that are published by or posted on behalf of an organization are eligible for presentation as a group. If the ranked list of content items includes more than some predetermined number of content items that have been posted by a company with the name, ACME Corp., and the end-user is following ACME Corp., some number of highest ranked posts published by ACME Corp. may be combined or grouped for presentation in a content carousel within the content feed. The position of the content carousel may be selected based on the highest ranking content item in the group of content items presented as part of the content carousel.
Consistent with some embodiments, content items satisfying some characteristic may be grouped only when certain conditions are satisfied. First, with some embodiments, if the end-user does not have a sufficient number of eligible content items in the ranked list of content items, no grouping of content items may be performed. For instance, if the end-user is a new user, and has not interacted with the service or system to a sufficient level, the new end-user may not have very many content items that are eligible for presentation to the end-user in a content feed. This may be the result of the end-user not having formed many connections, and as such, the end-user may not be connected to very many content items within the connection graph.
When an end-user does have a sufficient overall number of content items in the ranked list of content items, grouping content items that satisfy some edge-related characteristic may occur only when there is a number of such content items that exceeds some minimum number (e.g., five), but less than some maximum number (e.g., ten). Accordingly, as indicated at operation 410, after identifying the first content item, the system determines that there is some sufficient number of other content items sharing in common with the first content item the same association with the end-user as that identified by the edge connecting the end-user with the first content item.
Although not shown in
In any case, at operation 412, after processing any additional composition rules, the content feed is generated for presentation at a client device of the end-user. Specifically, the system or services communicates information over a network from a server to a client device of the end-user, such that the information is sufficient to allow the client device to generate a user interface that includes the content feed. The content feed is presented such that those content items identified in operation 410 are included within a content carousel, as a group, such as is illustrated in
The next content item in the content feed with reference number 504 is a horizontally scrolling content carousel for the presentation of a group of content items that share in common the same relationship with the end-user, Jon Doe, as memorialized in the connection graph. In this instance, the content carousel 504 is presenting a group of content items that all relate to the metadata tag, “#fashion,” which Jon Doe has subscribed to, or followed. Within the content carousel 504, multiple content items are accessible. As shown in
With some embodiments, the number of content items presented within a content carousel will be based on the total number of eligible content items that share the same edge in the connection graph, so long as that number exceeds some minimum, and is not greater than some maximum. However, with other embodiments, the number of content items within a content carousel will be predetermined, and will be independent of the total number of eligible content items, so long as there are some minimum number of eligible content items. With some embodiments, when an end-user scrolls to the very last content card in the set of content items selected for presentation via the content carousel, a final content card having a link to other content items, not included within the content carousel, but having the same characteristics as those of the content items presented via the content carousel. For example, although not shown in
Although the example content feed of
In alternative embodiments, the machine 600 operates as a standalone device or may be coupled (e.g., networked) to other machines. In a networked deployment, the machine 600 may operate in the capacity of a server machine or a client machine in a server-client network environment, or as a peer machine in a peer-to-peer (or distributed) network environment. The machine 600 may comprise, but not be limited to, a switch, a controller, a server computer, a client computer, a personal computer (PC), a tablet computer, a laptop computer, a netbook, a set-top box (STB), a PDA, an entertainment media system, a cellular telephone, a smart phone, a mobile device, a wearable device (e.g., a smart watch), a smart home device (e.g., a smart appliance), other smart devices, a web appliance, a network router, a network switch, a network bridge, or any machine capable of executing the instructions 610, sequentially or otherwise, that specify actions to be taken by the machine 600. Further, while only a single machine 600 is illustrated, the term “machine” shall also be taken to include a collection of machines 600 that individually or jointly execute the instructions 610 to perform any one or more of the methodologies discussed herein.
The machine 600 may include processors 604, memory/storage 606, and I/O components 618, which may be configured to communicate with each other such as via a bus 602. In an example embodiment, the processors 604 (e.g., a Central Processing Unit (CPU), a Reduced Instruction Set Computing (RISC) processor, a Complex Instruction Set Computing (CISC) processor, a Graphics Processing Unit (GPU), a Digital Signal Processor (DSP), an Application Specific Integrated Circuit (ASIC), a Radio-Frequency Integrated Circuit (RFIC), another processor, or any suitable combination thereof) may include, for example, a processor 608 and a processor 612 that may execute the instructions 610. The term “processor” is intended to include multi-core processors that may comprise two or more independent processors (sometimes referred to as “cores”) that may execute instructions contemporaneously. Although
The memory/storage 606 may include a memory 614, such as a main memory, or other memory storage, and a storage unit 616, both accessible to the processors 604 such as via the bus 602. The storage unit 616 and memory 614 store the instructions 610 embodying any one or more of the methodologies or functions described herein. The instructions 610 may also reside, completely or partially, within the memory 614, within the storage unit 616, within at least one of the processors 604 (e.g., within the processor's cache memory), or any suitable combination thereof, during execution thereof by the machine 600. Accordingly, the memory 614, the storage unit 616, and the memory of the processors 604 are examples of machine-readable media.
As used herein, “machine-readable medium” means a device able to store instructions and data temporarily or permanently and may include, but is not limited to, random-access memory (RAM), read-only memory (ROM), buffer memory, flash memory, optical media, magnetic media, cache memory, other types of storage (e.g., Erasable Programmable Read-Only Memory (EEPROM)), and/or any suitable combination thereof. The term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store the instructions 610. The term “machine-readable medium” shall also be taken to include any medium, or combination of multiple media, that is capable of storing instructions (e.g., instructions 610) for execution by a machine (e.g., machine 600), such that the instructions, when executed by one or more processors of the machine (e.g., processors 604), cause the machine to perform any one or more of the methodologies described herein. Accordingly, a “machine-readable medium” refers to a single storage apparatus or device, as well as “cloud-based” storage systems or storage networks that include multiple storage apparatus or devices. The term “machine-readable medium” excludes signals per se.
The I/O components 618 may include a wide variety of components to receive input, provide output, produce output, transmit information, exchange information, capture measurements, and so on. The specific I/O components 618 that are included in a particular machine will depend on the type of machine. For example, portable machines such as mobile phones will likely include a touch input device or other such input mechanisms, while a headless server machine will likely not include such a touch input device. It will be appreciated that the I/O components 618 may include many other components that are not shown in
In further example embodiments, the I/O components 618 may include biometric components 630, motion components 634, environmental components 636, or position components 638 among a wide array of other components. For example, the biometric components 630 may include components to detect expressions (e.g., hand expressions, facial expressions, vocal expressions, body gestures, or eye tracking), measure biosignals (e.g., blood pressure, heart rate, body temperature, perspiration, or brain waves), identify a person (e.g., voice identification, retinal identification, facial identification, fingerprint identification, or electroencephalogram based identification), and the like. The motion components 634 may include acceleration sensor components (e.g., accelerometer), gravitation sensor components, rotation sensor components (e.g., gyroscope), and so forth. The environmental components 636 may include, for example, illumination sensor components (e.g., photometer), temperature sensor components (e.g., one or more thermometers that detect ambient temperature), humidity sensor components, pressure sensor components (e.g., barometer), acoustic sensor components (e.g., one or more microphones that detect background noise), proximity sensor components (e.g., infrared sensors that detect nearby objects), gas sensors (e.g., gas detection sensors to detect concentrations of hazardous gases for safety or to measure pollutants in the atmosphere), or other components that may provide indications, measurements, or signals corresponding to a surrounding physical environment. The position components 638 may include location sensor components (e.g., a GPS receiver component), altitude sensor components (e.g., altimeters or barometers that detect air pressure from which altitude may be derived), orientation sensor components (e.g., magnetometers), and the like.
Communication may be implemented using a wide variety of technologies. The I/O components 618 may include communication components 640 operable to couple the machine 600 to a network 632 or devices 620 via a coupling 624 and a coupling 622, respectively. For example, the communication components 640 may include a network interface component or other suitable device to interface with the network 632. In further examples, the communication components 640 may include wired communication components, wireless communication components, cellular communication components, Near Field Communication (NFC) components, Bluetooth®, components (e.g., Bluetooth) Low Energy), Wi-Fi® components, and other communication components to provide communication via other modalities. The devices 620 may be another machine or any of a wide variety of peripheral devices (e.g., a peripheral device coupled via a USB).
Moreover, the communication components 640 may detect identifiers or include components operable to detect identifiers. For example, the communication components 640 may include Radio Frequency Identification (RFID) tag reader components, NFC smart tag detection components, optical reader components (e.g., an optical sensor to detect one-dimensional bar codes such as Universal Product Code (UPC) bar code, multi-dimensional bar codes such as Quick Response (QR) code, Aztec code, Data Matrix, Dataglyph, MaxiCode, PDF417, Ultra Code, UCC RSS-2D bar code, and other optical codes), or acoustic detection components (e.g., microphones to identify tagged audio signals). In addition, a variety of information may be derived via the communication components 640, such as location via Internet Protocol (IP) geo-location, location via Wi-Fi® signal triangulation, location via detecting an NFC beacon signal that may indicate a particular location, and so forth.
In various example embodiments, one or more portions of the network 632 may be an ad hoc network, an intranet, an extranet, a VPN, a LAN, a WLAN, a WAN, a WWAN, a MAN, the Internet, a portion of the Internet, a portion of the PSTN, a plain old telephone service (POTS) network, a cellular telephone network, a wireless network, a Wi-Fi® network, another type of network, or a combination of two or more such networks. For example, the network 632 or a portion of the network 632 may include a wireless or cellular network and the coupling 624 may be a Code Division Multiple Access (CDMA) connection, a Global System for Mobile communications (GSM) connection, or another type of cellular or wireless coupling. In this example, the coupling 624 may implement any of a variety of types of data transfer technology, such as Single Carrier Radio Transmission Technology (1×RTT), Evolution-Data Optimized (EVDO) technology, General Packet Radio Service (GPRS) technology, Enhanced Data rates for GSM Evolution (EDGE) technology, third Generation Partnership Project (3GPP) including 3G, fourth generation wireless (4G) networks. Universal Mobile Telecommunications System (UNITS), High Speed Packet Access (HSPA), Worldwide Interoperability for Microwave Access (WiMAX), Long Term Evolution (LTE) standard, others defined by various standard-setting organizations, other long range protocols, or other data transfer technology.
The instructions 610 may be transmitted or received over the network 632 using a transmission medium via a network interface device (e.g., a network interface component included in the communication components 640) and utilizing any one of a number of well-known transfer protocols (e.g., HTTP). Similarly, the instructions 610 may be transmitted or received using a transmission medium via the coupling 622 (e.g., a peer-to-peer coupling) to the devices 620. The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding, or carrying the instructions 610 for execution by the machine 600, and includes digital or analog communications signals or other intangible media to facilitate communication of such software.
Throughout this specification, plural instances may implement components, operations, or structures described as a single instance. Although individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and nothing requires that the operations be performed in the order illustrated. Structures and functionality presented as separate components in example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter herein.
The embodiments illustrated herein are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed. Other embodiments may be used and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. The Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.
As used herein, the term “or” may be construed in either an inclusive or exclusive sense. Moreover, plural instances may be provided for resources, operations, or structures described herein as a single instance. Additionally, boundaries between various resources, operations, modules, engines, and data stores are somewhat arbitrary, and particular operations are illustrated in a context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within a scope of various embodiments of the present disclosure. In general, structures and functionality presented as separate resources in the example configurations may be implemented as a combined structure or resource. Similarly, structures and functionality presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within a scope of embodiments of the present disclosure as represented by the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.