Unless otherwise indicated herein, the materials described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section.
Augmented Reality (AR) generally provides a view of a physical environment while supplementing the physical environment with computer-generated items such as images, text, sound, or video. For example, a person may view the physical environment in front of them on a mobile device's display, or through AR goggles or glasses such as GOOGLE GLASS®. The device may supplement the viewed environment with a variety of computer-generated items. For example, the device may recognize objects in the device's display and may overlay information about the recognized objects, or the device may overlay game characters which may interact with the viewed environment. While AR has the potential to provide a variety of beneficial and entertaining new technologies, AR is still in a relatively early stage of development, and there are many challenges to address as AR matures.
The present disclosure generally describes technologies including devices, methods, and computer readable media relating to AR information management. Some example methods may enable a computing device which receives multiple AR information display requests (AR requests) to prioritize and limit received AR requests and to display prioritized AR requests which are displayable by the computing device in substantially real-time. Each AR request may comprise, e.g., position information that defines where, within an AR environment, the computing device may display the AR request; time information that defines a time period during which the computing device may display the AR request; and/or AR request payload information that defines information for display by the computing device within the AR environment. The computing device may select a set of AR requests for display within a real-time view frame comprising at least a portion of the AR environment. The selected set of AR requests may comprise, e.g., position information defining positions within the real-time view frame and/or time information comprising unexpired time periods. The computing device may prioritize AR requests in the selected set of AR requests to establish prioritized AR requests comprising higher priority and lower priority AR requests. The computing device may display, within the real-time view frame, AR request payload information for at least a subset of the higher priority AR requests within the prioritized AR requests, wherein the displayed subset of the higher priority AR requests may comprise a real-time limited subset displayable by the computing device in substantially real-time. The computing device may subsequently display AR request payload information for one or more additional AR requests within the prioritized AR requests, and a priority associated with each respective additional AR request may determine timing of subsequently displaying each respective additional AR request.
Computing devices and computer readable media having instructions implementing the various technologies described herein are also disclosed. Example computer readable media may comprise non-transitory computer readable storage media having computer executable instructions executable by a processor, the instructions that, when executed by the processor, cause the processor to carry out any combination of the various methods provided herein. Example computing devices may include an AR device comprising a processor, a memory, and an AR information manager configured to carry out the methods described herein.
The foregoing summary is illustrative only and is not intended to be in any way limiting. In addition to the illustrative aspects, embodiments, and features described above, further aspects, embodiments, and features will become apparent by reference to the drawings and the following detailed description.
The foregoing and other features of the present disclosure will become more fully apparent from the following description and appended claims, taken in conjunction with the accompanying drawings. Understanding that these drawings depict only several embodiments in accordance with the disclosure and are, therefore, not to be considered limiting of its scope, the disclosure will be described with additional specificity and detail through use of the accompanying drawings, in which:
In the following detailed description, reference is made to the accompanying drawings, which form a part hereof. In the drawings, similar symbols typically identify similar components, unless context dictates otherwise. The illustrative embodiments described in the detailed description, drawings, and claims are not meant to be limiting. Other embodiments may be utilized, and other changes may be made, without departing from the spirit or scope of the subject matter presented here. It will be readily understood that the aspects of the present disclosure, as generally described herein, and illustrated in the Figures, may be arranged, substituted, combined, and designed in a wide variety of different configurations, all of which are explicitly contemplated and made part of this disclosure.
The present disclosure is generally drawn, inter alia, to technologies including methods, devices, systems and/or computer readable media deployed therein relating to AR information management. In some examples, a computing device which receives multiple AR requests may prioritize and limit the AR requests to display prioritized AR requests which are displayable by the computing device in substantially real-time. The computing device may select a set of AR requests for display within a real-time view frame, prioritize the AR requests, and display a real-time limited subset of the higher priority AR requests. The computing device may subsequently display additional AR requests according to AR request priority, such that AR request priority determines timing of displaying each respective additional AR request.
In one example scenario, a device user in a physical environment, such as a coffee shop or any other physical environment, may use an example AR device arranged according to this disclosure, such as a laptop, smartphone or tablet type mobile device equipped with an AR application, or AR goggles or glasses such as a GOOGLE GLASS® type device, to view AR information. The AR information may be received by the example AR device in the form of “AR information display requests”, referred to herein as “AR requests”.
The example AR device may receive AR requests from any of a wide variety of AR request sources. Example AR request sources may include: a remote AR server adapted to send AR requests to AR devices, optionally based on AR device location and/or user AR information preferences; a local server, e.g., in the coffee shop, adapted to send AR requests to proximal AR devices, e.g., AR devices in or near the coffee shop; a mobile device, such as a laptop, smartphone or tablet type mobile device, e.g., in possession of a coffee shop customer or employee, wherein the mobile device may be adapted to send AR requests to proximal AR devices; a smart environmental sensor or other smart equipment adapted to send AR requests to proximal AR devices, such as a smart coffee cup equipped to send AR requests including temperature of the coffee cup, or a smart Radio Frequency Identification (RFID) reader equipped to send AR requests including identity of RFID badge holders; a vehicle-based or roadside computing device adapted to send AR requests to proximal AR devices, e.g., AR requests comprising vehicle status and/or road condition information; a local AR request generator, e.g., an application or other process executed by the example AR device and adapted to supply AR requests for use by the example AR device, for example, AR requests based on objects recognized through object recognition processes, or AR requests based on Quick Response (QR) codes or other information recognized within a physical environment; and/or any other sources of AR requests as may be developed.
In some embodiments, AR requests may comprise, e.g., position information that defines where, within an AR environment, the example AR device may display the AR request; time information that defines a time period during which the example AR device may display the AR request; and/or AR request payload information that defines information for display by the example AR device within the AR environment. AR requests may furthermore comprise any information disclosed herein or as may be included by those of skill in the art with the benefit of this disclosure.
The example AR device may be adapted to manage received AR requests as described herein, and to display at least a subset of the received AR requests. Displaying AR requests may comprise displaying the AR requests in an “AR environment”. The term “AR environment” as used herein refers to a physical environment viewable on or through an AR device display with overlaid AR information. For example, an AR environment may comprise the example coffee shop or any other environment, as viewed at the example AR device.
The AR environment may be viewed at the example AR device as one or more real-time view frames comprising at least portions of the AR environment. For example, when the example AR device is oriented toward the coffee shop counter, example real-time view frames may comprise the coffee shop counter along with any people or physical features at or near the counter, such as may be viewed by the example AR device's camera. When the example AR device is oriented toward the tables and chairs, example real-time view frames may comprise the tables and chairs along with any people or physical features at or near the tables and chairs. In other embodiments, an AR environment may be presented in a “map” view, comprising, e.g., a map of the AR environment such as a map of the coffee shop's floor plan. In a map view of an AR environment, example real-time view frames may be different from real-time view frames as may be viewed through the AR device's camera, as will be appreciated.
The example AR device may be adapted to display AR requests within an AR environment according to the respective position information of each AR request. For example, in the coffee shop, the example AR device may be adapted to display AR requests comprising position information at or near the counter, at their positions at or near the counter. The example AR device may be adapted to display AR requests comprising position information at or near the tables or chairs, at their positions at or near the tables or chairs. Other AR requests may comprise position information defining positions elsewhere in the AR environment.
As a result, in some embodiments, different AR requests may come into and out of view as the example AR device pans across the coffee shop or other AR environment. In other words, different AR requests may come into and out of view, based on which AR requests are included in real-time view frames viewed at the example AR device. The example AR device may be adapted to display AR requests having positions within a current real-time view frame of the AR environment.
Managing received AR requests may generally account for factors such as AR request priority, time windows during which AR requests may be relevant, position information associated with AR requests, and AR request processing time which may affect whether AR requests are displayable by the example AR device in substantially real-time. The example AR device may manage received AR requests in a manner allowing the example AR device to display, within each real-time view frame, AR request payload information for at least higher priority AR requests as appropriate for each respective real-time view frame. The displayed higher priority AR requests may comprise a real-time limited subset of higher priority AR requests displayable by the example AR device in substantially real-time.
In some embodiments, managing received AR requests may comprise selecting a set of AR requests for display within a real-time view frame comprising at least a portion of the AR environment. The example AR device may be adapted to store received AR requests, and to select sets of AR requests from among stored AR requests. For example, the example AR device may be adapted to select a new set of AR requests for display within each new real-time view frame, as each new real-time view frame comes into view at the example AR device.
In some embodiments, the example AR device may be adapted to select sets of AR requests using AR request position information. Each AR request in a selected set of AR requests may comprise, e.g., position information defining a position within a real-time view frame viewed at the example AR device. The example AR device may be adapted to apply any other selection criteria for AR request selection, in combination with AR request position information. In some embodiments, the example AR device may be adapted to select sets of AR requests using AR request time information. Each AR request in a selected set of AR requests may comprise, e.g., time information that defines an unexpired time period for the AR request.
In some embodiments, managing received AR requests may comprise applying constraints to exclude AR requests from the selected set of AR requests. Constraints may apply any constraint criteria. For example, the example AR device may be adapted to apply a “previously displayed” constraint, a user preference constraint, and/or a distance constraint.
In an example “previously displayed” constraint, AR requests for which AR request payload information has been “previously displayed” may be excluded from the selected set of AR requests. “Previously displayed” may be defined as desired for particular embodiments. In some embodiments, an AR request may be considered as “previously displayed” after the AR request is displayed 1, 2, 3, . . . times. In some embodiments, an AR request may be considered as “previously displayed” after the AR request is displayed for an aggregate time period such as 1, 2, 3, 4, 5, . . . seconds. In some embodiments, an AR request may be considered as “previously displayed” when the AR request has been dismissed by the user.
In an example user preference constraint, AR requests not matching user preferences may be excluded from the selected set of AR requests. User preferences may be specified for example via a User Interface (UI) comprising user preference selection controls. Any user preferences may be included. User preferences may comprise, e.g., user preferences regarding AR request types and/or user preferences regarding AR request origins. For example, a user preference may include or omit AR requests comprising business information, such as business names and hours of operation. When the user preference includes AR requests comprising business information, AR requests comprising business information may not be excluded from the selected set of AR requests. Conversely, when the user preference omits AR requests comprising business information, AR requests comprising business information may be excluded from the selected set of AR requests.
In another example, a user preference may include or omit AR requests from origins which are not pre-approved, such as AR requests received from strangers' mobile devices. When the user preference includes AR requests from origins which are not pre-approved, AR requests from unknown origins may not be excluded from the prioritized AR requests. Conversely, when the user preference omits AR requests from origins which are not pre-approved, AR requests from origins which are not pre-approved may be excluded from the prioritized AR requests. It will be appreciated with the benefit of this disclosure that embodiments may support a wide variety of user preferences, and this disclosure is not limited to the example user preferences described herein.
In an example distance constraint, AR requests comprising position information defining positions greater than a predetermined distance from the example AR device may be excluded from the selected set of AR requests. For example, AR requests comprising position information further than 20, 50, 100, or other distance from the example AR device may be excluded. In some embodiments, a distance constraint may be adaptively modified based on AR environment type. For example, when the example AR device is outside, the distance constraint may be extended to allow for AR requests comprising position information further away, while when the example AR device is inside, the distance constraint may be shortened to allow for AR requests comprising position information at shorter distances away.
In some embodiments, managing received AR requests may comprise prioritizing AR requests from a given selected set of AR requests to establish prioritized AR requests comprising higher priority and lower priority AR requests. The example AR device may be adapted to prioritize AR requests based on any prioritization criteria. For example, AR requests may be prioritized based on AR request types and/or AR request origins. In some embodiments, user prioritization preferences and/or user AR request interaction history may be used to prioritize AR requests.
In embodiments configured to prioritize AR requests based on AR request types, received AR requests may be classified by type, wherein each type may be associated with a corresponding priority value. AR requests may each be assigned the priority value of the respective type under which each respective AR request is classified. For example, AR requests may be classified by content type such as promotional, social, informational, geographical, safety, entertainment, etc. Safety related AR requests may for example have a higher priority, while promotional AR requests may have a lower priority. Thus AR requests classified as safety type AR requests may be established as higher priority, while AR requests classified as promotional type AR requests may be established as lower priority. In order to support classification of AR requests based on AR request types, AR source devices may be adapted to include type information within generated AR requests, or embodiments may configure the example AR device to make type determinations based on AR request payload information and/or other AR request data.
In embodiments configured to prioritize AR requests based on AR request origin, received AR requests may be classified by origin, e.g., by identifying a source of each AR request. Each origin, or origin type, may be associated with a corresponding priority value. AR requests may then be assigned priority values corresponding to their respective origins.
In embodiments configured to prioritize AR requests based on user prioritization preferences, the example AR device may receive user prioritization preferences, e.g., via an AR request prioritization UI adapted to receive user priority levels for different AR request types or origins. The example AR device may then prioritize received AR requests according to user-assigned priority levels.
In embodiments configured to prioritize AR requests based on user AR request interaction history, the example AR device may for example increase priority of AR request types with which the user interacts, while decreasing priority of AR request types with which the user ignores or dismisses. The example AR device may then prioritize received AR requests according to the adjusted (increased or decreased) priority levels. It will be appreciated with the benefit of this disclosure that embodiments may support a wide variety of prioritization criteria, and this disclosure is not limited to the example prioritization criteria described herein.
In some embodiments, prioritizing AR requests may comprise, e.g., performing multiple comparison operations, each comparison operation comprising: comparing a first priority associated with a first AR request with a second priority associated with a second AR request; when the first priority is higher than the second priority, placing the first AR request at a higher priority position, in the prioritized AR requests, than the second AR request; and when the second priority is higher than the first priority, placing the second AR request at a higher priority position, in the prioritized AR requests, than the first AR request. The example AR device may use such multiple comparison operations to produce a prioritized list of AR requests for each selected set of AR requests. Because the list is prioritized, the list may comprise higher and lower priority AR requests.
In some embodiments, prioritizing AR requests may comprise, e.g., comparing priorities of AR requests in the prioritized AR requests with a threshold priority, and establishing AR requests with priorities above the threshold priority among the higher priority AR requests. Meanwhile, AR requests with priorities below the threshold priority may be established among the lower priority AR requests. The example AR device may use such threshold comparison operations to produce a group of higher priority AR requests for each selected set of AR requests.
In some embodiments, managing received AR requests may comprise resolving conflicts between AR requests comprising overlapping position information. As an example of overlapping position information, two or more AR requests may include identical position information, or may include position information which is within a minimum proximity range on the AR device display, such that displayed AR request payload information could overlap should the two AR requests be simultaneously displayed by the example AR device. The example AR device may be configured to resolve conflicts between AR requests for example by adjusting display positions for conflicting AR requests, to thereby display AR request payload information for at least one conflicting AR request at an adjusted position. In some embodiments, an AR request of relatively higher priority may be displayed at its true, unadjusted position, while a conflicting AR request of relatively lower priority may be displayed at an adjusted position. In some embodiments, an AR request displayed at an adjusted position may be displayed with an arrow, or with a speech balloon type graphic, or other indicator to indicate its true, unadjusted position. In some embodiments, the example AR device may be configured to resolve conflicts between AR requests by excluding a conflicting AR request. For example, the example AR device may exclude a conflicting AR request of relatively lower priority (relative to the other conflicting AR request) from a displayed subset of the higher priority requests.
In some embodiments, managing received AR requests may comprise compiling, by the example AR device, a real-time limited subset of the higher priority requests. The real-time limited subset may include e.g., the higher priority AR requests which are displayable by the example AR device in substantially real-time. The real-time limited subset may be compiled for example by including additional AR requests in the real-time limited subset until an aggregate AR request display time exceeds a time limit for substantially real-time display.
For example, in some embodiments, the time limit for substantially real-time display may comprise any time limit up to about 2 seconds. Using an example time limit of 0.1 second, and when each AR request involves 0.01 second of processing time, 10 AR requests may be displayable by the example AR device in substantially real-time. In some embodiments, different AR requests may involve different amounts of processing time, and the individual processing times of each AR request may be added together to determine which AR requests may be included in the real-time limited subset. In other embodiments, average AR request processing times may be used.
The various AR request management operations described herein, e.g., selecting a set of AR requests, applying constraints and prioritizing AR requests, resolving conflicts, and compiling a real-time limited subset of higher priority requests, may be performed in real-time to calculate AR requests for display in each real-time view frame as viewed at the example AR device. Additionally, AR requests may expire, e.g., by expiration of a time period as may be included in each AR request, or by being displayed and subject to a “previously displayed” constraint. In some embodiments, the example AR device may be configured to expunge expired AR requests from AR request storage.
The expiration of AR requests may allow for subsequently displaying additional AR requests, e.g. AR requests beyond those included in an initial real-time limited subset of higher priority AR requests displayed at the example AR device. The example AR device may be adapted to time and/or sequence the display of additional AR requests according to priority thereof. Thus for example, the example AR device may display AR request payload information for additional AR requests within a set of prioritized AR requests, and a priority associated with each respective additional AR request may determine timing of subsequently displaying each respective additional AR request. Additional AR requests having higher priority may be displayed first, that is, first in line subsequent to expiration of one or more AR requests in the real-time limited subset of higher priority AR requests, while further additional AR requests may be displayed next, in an order according to AR request priority.
In
AR device 100 may select AR requests for display on each of real-time view frames 201, 202, 203, and 204 according to the techniques described herein. In
In an example operation of AR device 100, received AR requests 122 may comprise, e.g., AR requests AR1-AR6, as well as any number of additional AR requests. Each of received AR requests 122 may comprise, e.g., position information that defines where, within an AR environment, AR device 100 may display the respective AR request, time information that defines a time period during which AR device 100 may display the respective AR request, and AR request payload information that defines information for display by AR device 100 within the AR environment. Each of received AR requests 122 may optionally comprise any additional information as may be desired for particular embodiments, for example, in some embodiments received AR requests 122 may comprise type information declaring type of AR request.
AR request payload information may comprise a wide variety of information, including text, image, video, and/or other information. For example, AR1 may comprise, e.g., text information comprising a temperature of a coffee cup at the counter, as may be sent by an AR request source such as a coffee maker machine or smart thermometer. AR2 may comprise, e.g., text information comprising an exit door status such as “locked” or “open” as may be sent by an AR request source such as an electronic lock. AR3 may comprise, e.g., text information comprising a message from a device user seated at the location of AR3, as may be sent by an AR request source such as a personal mobile device. AR4 and AR6 may comprise, e.g., a social networking profile pictures of device users at the locations of AR4 and AR6, respectively, as may be sent by AR request sources such as personal mobile devices. AR5 may comprise, e.g., room temperature information as may be sent by an AR request source such as a thermostat. Furthermore, received AR requests 122 may comprise any number of additional AR requests, other than AR1-AR6, and such additional AR requests may include different position information, time information, and/or AR request payload information than that of AR1-AR6.
In some embodiments, position information for AR requests 122 may comprise positions of corresponding AR request sources. For example, position information for AR1 may comprise a position of the coffee maker machine or smart thermometer. Position information for AR2 may comprise a position of the electronic lock. Position information for AR3, AR4, and AR6 may comprise positions of the personal mobile devices generating the respective AR requests. Position information for AR5 may comprise a position of the thermostat. In some embodiments, position information for AR requests 122 may comprise position information appropriate to an AR request, which may be different than AR request source position. For example, a local AR server in the coffee shop (or other AR environment), or a remote AR server, may include different position information, as appropriate, for each of a variety of different AR requests. Position information may comprise, e.g., GPS information or any other position information as appropriate.
Time information for each of AR requests 122 may comprise any time period. For example, time information for AR1 may comprise a relatively short time period, such as 1-30 seconds from a time when AR1 is generated, as may be appropriate in view of, e.g., hot coffee likely changing position and/or cooling. Time information for AR2 may comprise a relatively longer time period, such as 1-60 minutes from a time when AR2 is generated, as may be appropriate in view of likely longer intervals between changes of lock state. Time information for AR3, AR4, and AR6 may comprise intermediate time periods, such as, by way of example, 5-100 seconds from times when AR3, AR4, and AR6 are generated, or other time periods as appropriate. In some embodiments, time information may define time periods beginning after the time when an AR request is generated. For example, an AR request may define a time period beginning one minute (or any other time period) after AR request generation and ending one minute (or any other time period) thereafter.
Selection module 111 may be adapted to select selected set of AR requests 123 for display within a real-time view frame 121 comprising at least a portion of the AR environment. For example, selection module 111 may produce selected set of AR requests 123 for real-time view frame 121 comprising any of real-time view frames 201, 202, 203, or 204. Selection module 111 may be adapted to operate at least in part by taking as input a current set of AR requests 122 and a next real-time view frame 121, and producing as output a set of valid AR requests, namely, selected set of AR requests 123.
In some embodiments, selection module 111 may be arranged to employ software module(s) generally implementing pseudo-code such as:
for every AR request R in the current set of AR requests do
In a first example, real-time view frame 201 may provide a first example real-time view frame of the AR environment, displayed at a time T1, and real-time view frame 202 may comprise a second real-time view frame of the AR environment, displayed at a time T2. Selection module 111 may first select a first selected set of AR requests 123 for display within real-time view frame 201, and selection module 111 may subsequently select a subsequent selected set of AR requests 123 for display within real-time view frame 202.
AR requests in each selected set of AR requests 123 may comprise position information defining positions within the respective real-time view frame 201 or 202, and time information comprising unexpired time periods at a time of each respective real-time view frame 201 or 202. For example, each of AR requests AR1-AR6 may comprise position information defining positions within the AR environment as illustrated in
In another example, real-time view frame 203 may comprise a first real-time view frame of the AR environment, displayed at time T1 and having a view direction V1, wherein a camera direction of AR device 100 is pointed toward the counter. Real-time view frame 204 may comprise a second real-time view frame of the AR environment, displayed at time T2 and having a view direction V2, wherein a camera direction of AR device 100 is pointed toward the table proximal to AR3. Selection module 111 may first select selected set of AR requests 123 for display within real-time view frame 203, and selection module 111 may subsequently select selected set of AR requests 123 for display within real-time view frame 204.
AR requests in each selected set of AR requests 123 may comprise position information defining positions within the respective real-time view frame 203 or 204, and time information comprising unexpired time periods at a time of each respective real-time view frame 201 or 202. For example, each of AR requests AR1-AR2 may comprise position information defining positions within the portion of AR environment illustrated in real-time view frame 203, and each of AR requests AR2, AR3, and AR6 may comprise position information defining positions within the portion of AR environment illustrated in real-time view frame 204. Additionally, AR requests AR1-AR2 may comprise time information comprising unexpired time periods at time T1, while AR requests AR2, AR3, and AR6 may comprise time information comprising unexpired time periods at time T2. As noted herein, when received AR requests 122 comprise additional AR requests meeting the position and time period criteria of a particular real-time view frame, e.g., real-time view frame 203 or 204, selection module 111 may include such additional AR requests within selected set of AR requests 123.
Prioritization module 112 may be adapted to prioritize AR requests to thereby establish higher priority and lower priority AR requests. For example, prioritization module 112 may be adapted to take, as input: selected set of AR requests 123; constraints 124; and priorities 125. Prioritization module 112 may be adapted to produce, as output: prioritized AR requests 126, comprising, e.g., an ordered set of AR requests, in order of AR request priority.
In some embodiments, constraints 124 and priorities 125 may comprise default constraints and priorities, respectively, which may be predetermined for use by ARIMS 110 and may optionally be updated from time to time. In some embodiments, constraints 124 and priorities 125 may comprise constraints and priorities assigned by a user of AR device 100. For example, ARIMS 110 may provide a UI adapted to receive user constraints, such as “never display promotional AR requests”, “never display AR requests of unknown origin” or any other user constraints. ARIMS 110 may provide a UI adapted to receive user priorities, such as by including user priority adjustment controls to adjust priority levels for AR requests of different types, e.g., safety-related AR requests, personal communication AR requests, etc. In some embodiments, ARIMS 110 may be adapted to dynamically update constraints 124 and priorities 125 based on user history. For example, AR requests with which a user interacts, such as by selecting an AR request, responding to a message in an AR request, or zooming in on an AR request, may be weighted as higher priority than AR requests which a user ignores or dismisses.
In some embodiments, prioritization module 112 may comprise two subparts. A first subpart may be arranged to implement a set of constraints 124 to eliminate one or more AR requests, and a second subpart may be arranged to prioritize remaining AR requests according to priorities 125.
The first subpart may employ software module(s) generally implementing pseudo-code such as the following, wherein initially all of selected set of AR requests 123 may be included in prioritized AR requests 126, and subsequently certain AR requests may be excluded from prioritized AR requests 126:
for every AR request R in prioritized AR requests do
enddo
In some embodiments, prioritization module 112 may be adapted to apply one or more constraints 124 to exclude one or more AR requests from selected set of AR requests 123, in connection with generating prioritized AR requests 124. Constraints 124 may comprise, e.g., “previously displayed” constraints, user preference constraints, and/or distance constraints as described herein.
The second subpart of prioritization module 112 may employ software module(s) generally implementing pseudo-code such as the following, to produce, e.g., an ordered list of prioritized AR requests within prioritized AR requests 124:
repeat
until no more changes can be made in list of prioritized AR requests
In some embodiments, prioritization module 112 may be adapted to prioritize AR requests by performing multiple comparison operations, each comparison operation comprising: comparing a first priority associated with a first AR request with a second priority associated with a second AR request; when the first priority is higher than the second priority, placing the first AR request at a higher priority position, in prioritized AR requests 126, than the second AR request; and when the second priority is higher than the first priority, placing the second AR request at a higher priority position, in prioritized AR requests 126, than the first AR request.
It will be appreciated with the benefit of this disclosure that prioritization module 112 may prioritize AR requests according to a wide range of different techniques. This disclosure is not limited to any particular prioritization technique. In some embodiments, prioritization module 112 may be adapted to simultaneously accommodate multiple priorities which may (or may not) overlap. Priorities may be weighted, and prioritization module 112 may be adapted to assign cumulative weighted priority values to each AR request in prioritized AR requests 126. In some embodiments, prioritization module 112 may be adapted to compare priorities of AR requests in prioritized AR requests 126 with a threshold priority, and establish AR requests with priorities above the threshold priority among higher priority AR requests. Prioritization module 112 may for example exclude AR requests with priorities below the threshold priority from prioritized AR requests 126, or may establish AR requests with priorities below the threshold priority as lower priority AR requests. The use of a threshold priority may optionally eliminate nuanced determinations of relative AR request priority and may thereby increase processing speed in some embodiments.
In some embodiments, prioritization module 112 may be adapted to assign priorities to AR requests based on AR request types. For example, prioritization module 112 may classify AR requests according to types, such as: urgent safety, non-urgent safety, personal communication from contact, personal communication from stranger, informational, promotional, or any number of other types. Prioritization module 112 may apply, to each respective AR request, a priority associated with an AR request type under which the respective AR request may be classified.
In an example based on
In an example based on
Conflict resolution module 113 may be adapted to resolve conflicts between AR requests comprising overlapping position information. In some embodiments, conflict resolution module 113 may take prioritized AR requests 126 as input, and conflict resolution module 113 may produce prioritized, conflict-free AR requests 127 as output. Conflict resolution module 113 may for example adjust display positions of conflicting AR requests within prioritized AR requests 126, to thereby include position-adjusted AR requests in prioritized, conflict-free AR requests 127. AR device 100 may display AR request payload information for position-adjusted AR requests at their corresponding adjusted positions, while optionally including an arrow or other visual indication of original AR request position. Alternatively, conflict resolution module 113 may exclude conflicting AR requests from prioritized AR requests 126, so that prioritized, conflict-free AR requests 127 includes a reduced set of AR requests.
In some embodiments, conflict resolution module 113 may be arranged to employ software module(s) generally implementing pseudo-code such as the following, wherein initially all of prioritized AR requests 126 may be included in prioritized, conflict-free AR requests 127, and subsequently certain AR requests may be excluded from prioritized, conflict-free AR requests 127:
repeat
until no more conflicts are identified in prioritized, conflict-free AR requests
In an example based on
In an example based on
Real-time display module 114 may be adapted to prepare real-time view frame overlay 128 for the next real-time view frame to be displayed at display 130. Real-time display module 114 may for example take prioritized, conflict-free AR requests 127 as input, and may output real-time view frame overlay 128, comprising a real-time limited subset of higher priority AR requests ready for display 130.
In some embodiments, real-time display module 114 may be arranged to employ software module(s) generally implementing pseudo-code such as the following:
set L=total time limit to display real-time view frame overlay over the next frame in order to maintain substantially real-time display
set t=0; done=false; real-time view frame overlay={ }
In some embodiments, the real-time display module 114 may omit the above “else” line. Real-time display module 114 may thereby be adapted to include lower priority AR requests in real-time view frame overlay 128, so long as such lower priority AR requests, combined, take less time to display than the remaining time under time limit L.
In some embodiments, real-time display module 114 may compile real-time view frame overlay 128 comprising a real-time limited subset of higher priority AR requests. Real-time display module 114 may include additional AR requests, e.g., from prioritized, conflict-free AR requests 127, in the real-time limited subset until an aggregate AR request display time exceeds a time limit for substantially real-time display. The time limit for substantially real-time display may comprise any selected time limit, e.g. any time limit up to about 2 seconds as disclosed herein.
In some embodiments, ARIMS 110 may be adapted to apply time limits to run each of modules 111, 112, 113, and 114, in order to complete the entire preparation real-time view frame overlay 128 in real time. As such, optimization or truncation techniques can be used to ensure the best performance (even if suboptimal) of ARIMS 110 within available time and computational resources. As more devices communicate AR requests, the number of AR requests available for overlay on real-time view frames may exceed the capabilities of AR device displays. As such, real-time display module 114 may be adapted to ensure real-time view frame overlays can be displayed in substantially real-time, that is, in sufficiently short time that real-time view frame overlays appear to the user to be displayed in real-time over the next real-time view frame.
In examples based on
When real-time view frame overlay 128 is finalized, AR device 100 may be adapted to display real-time view frame overlay 128 over real-time view frame 121 for which real-time view frame overlay 128 was calculated. Real-time view frame overlay 128 may comprise AR request payload information for each of the AR requests included in real-time view frame overlay 128, that is, a real-time limited subset of AR requests displayable by AR device 100 in substantially real-time.
In an example based on
In some embodiments, AR device 100 may be adapted to subsequently display AR request payload information for additional AR requests, e.g., AR requests other than those which may be initially displayed within an AR environment. In an example based on
Depending on the desired configuration, processor 310 may be of any type including but not limited to a microprocessor (μP), a microcontroller (μC), a digital signal processor (DSP), or any combination thereof. Processor 310 may include one or more levels of caching, such as a level one cache 311 and a level two cache 312, a processor core 313, and registers 314. The processor core 313 may include an arithmetic logic unit (ALU), a floating point unit (FPU), a digital signal processing core (DSP Core), or any combination thereof. A memory controller 315 may also be used with the processor 310, or in some implementations the memory controller 315 may be an internal part of the processor 310.
Depending on the desired configuration, the system memory 320 may be of any type including but not limited to volatile memory (such as RAM), non-volatile memory (such as ROM, flash memory, etc.), or any combination thereof. System memory 320 typically includes an operating system 321, one or more applications 322, and program data 325. In some embodiments, operating system 321 may comprise a virtual machine that is managed by a Virtual Machine Manager (VMM). Applications 322 may include, for example, ARIMS module(s) 110. Program data 325 may include received AR requests 122, constraints 124, and priorities 125, along with any other data that may be used by applications 322.
Computing device 300 may have additional features or functionality, and additional interfaces to facilitate communications between the basic configuration 301 and any required devices and interfaces. For example, a bus/interface controller 340 may be used to facilitate communications between the basic configuration 301 and one or more data storage devices 350 via a storage interface bus 341. The data storage devices 350 may be removable storage devices 351, non-removable storage devices 352, or a combination thereof. Examples of removable storage and non-removable storage devices include magnetic disk devices such as flexible disk drives and hard-disk drives (HDD), optical disc drives such as compact disc (CD) drives or digital versatile disc (DVD) drives, solid state drives (SSD), and tape drives, to name a few. Example 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, program modules, or other data.
Level 1 cache 311, level 2 cache 312, system memory 320, removable storage 351, and non-removable storage devices 352 are all examples of computer storage media. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile discs (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that may be used to store the desired information and that may be accessed by computing device 300. Any such computer storage media may be part of device 300.
Computing device 300 may also include an interface bus 342 for facilitating communication from various interface devices (e.g., output interfaces, peripheral interfaces, and communication interfaces) to the basic configuration 301 via the bus/interface controller 340. Example output devices 360 include a graphics processing unit 361 and an audio processing unit 362, which may be configured to communicate to various external devices such as a display or speakers via one or more AN ports 363. Example peripheral interfaces 370 may include a serial interface controller 371 or a parallel interface controller 372, which may be configured to communicate through either wired or wireless connections with external devices such as input devices (e.g., keyboard, mouse, pen, voice input device, touch input device, etc.) or other peripheral devices (e.g., printer, scanner, etc.) via one or more I/O ports 373. Other conventional I/O devices may be connected as well such as a mouse, keyboard, and so forth. An example communications device 380 includes a network controller 381, which may be arranged to facilitate communications with one or more other computing devices 390 over a network communication via one or more communication ports 382.
The computer storage media may be one example of a communication media. Communication media may typically 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 include any information delivery media. A “modulated data signal” may be a signal that has one or more of its 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 (IR), and other wireless media.
Computing device 300 may be implemented as a mobile device. Computing device 300 may also be implemented as head-mounted AR device such as glasses or goggles adapted to overlay AR information on views of the physical world. Computing device 300 may also be implemented as a personal or business use computer including both laptop computer and non-laptop computer configurations.
In
At an “Activate AR” block 402, AR device 100 may activate operation of ARIMS 110, e.g., in response to user selection of an AR application or function at AR device 100. AR device 100 may initiate ARIMS 110 to begin receiving and overlaying AR requests on real-time view frames visible at AR device 100. Block 402 may be followed by operation of ARIMS 110, including blocks 411, 412, and 413.
At a “Receive AR Requests” block 411, AR device 100 may receive AR requests from AR request sources, such as AR request sources 151-153, illustrated in
At a “Manage AR Requests” block 412, AR device 100 may manage AR requests received at block 411, to determine which received AR requests to overlay on real-time view frames viewed at AR device 100. AR device 100 may for example employ modules 111-114 of ARIMS 110, as described with reference to
At a “Display Real-Time View Frame Overlay” block 413, AR device 100 may display real-time view frame overlays, comprising AR requests selected at block 412, for each new real-time view frame viewed at AR device 100. AR requests in a real-time view frame overlay may be displayed according to the techniques described herein, at or near their respective positions in an AR environment, e.g., as illustrated in
In
At an “AR Device Discovery” block 501, AR request source device 500 may discover AR devices available to receive AR requests, optionally along with additional information for each discovered AR device, such as AR device identity, AR device user identity, AR device position, and/or AR request preferences. For example, AR request source device 500 may broadcast a localized wireless discovery signal and AR request source device 500 may listen for responses from any proximal AR devices. AR request source device 500 may exchange further handshake information with any responding AR devices. When AR request source device 500 comprises a remote AR server, AR request source device 500 may receive incoming communications from AR devices, and AR request source device 500 may exchange further handshake information with any AR devices that initiate communication with AR request source device 500. In some embodiments, block 501 may be omitted, and AR request source device 500 may generate and broadcast AR requests, e.g., using blocks 502 and 503, for receipt by any AR devices equipped to receive such broadcasted AR requests. Block 501 may be followed by block 502.
At an “AR Request Generator” block 502, AR request source device 500 may generate AR requests. Generated AR requests may generally comprise any AR request properties described herein, e.g., position information, time information, AR request payload information, type information, and/or any other information as may be employed to support additional functions or features in the spirit of this disclosure.
When AR request source device 500 comprises a mobile device, and position information comprises a current position of the mobile device, AR request source device 500 may determine its real-time position at block 502, e.g., by retrieving GPS position or other position coordinates, and AR request source device 500 may include its real-time position in generated AR requests. When an AR request is associated with an object other than AR request source device 500, AR request source device 500 may determine the position of such object for inclusion in generated AR requests.
To generate time information for AR requests, AR request source device 500 may, e.g., add a predetermined time period for an AR request to a current clock time at which the AR request is generated. The predetermined time period may vary based on the type of AR request, e.g., some AR requests may be relevant for short periods of time such as several seconds, while other AR requests may be relevant for longer periods of time such as several hours. In some embodiments, time information may comprise future starting and ending times, e.g., a relevancy period beginning in one minute from current time, and ending in two minutes from current time.
To generate AR request payload information for AR requests, AR request source device 500 may, e.g., combine any static AR request payload information, which may be identical for all AR requests of a particular type, with any dynamic AR request payload information, which may be gathered by AR request source device 500 in real-time. For example, AR requests comprising vehicle information may combine static vehicle description information with dynamic information such as vehicle speed. AR requests comprising lock state information may comprise static text or image information describing a door with dynamic information describing whether the door is locked or unlocked. AR requests comprising social media status updates or profile information may comprise static user identity information with dynamic status update or profile information.
In some embodiments, block 502 may comprise a “User Interface (UI)” block 503. AR request source device 500 may employ UI 503 to interact with a user at AR request source device 500. The user may optionally supply any AR request properties for inclusion in generated AR requests. For example, the user may supply AR request payload information such as pictures and/or text communications, e.g., via a field or file selection control included in UI 503. The user may also optionally supply time and/or position information for AR requests in some embodiments. In some embodiments, the user may optionally initiate sending AR requests from UI 503. In some embodiments, block 502 may interact with UI provided by other applications at AR request source device 500. For example, a social media application may provide UI 503, wherein UI 503 may be adapted to post a social media status update or picture, and UI 503 may furthermore be adapted to simultaneously include such social media status update or picture in an AR request. Block 502 may be followed by block 503.
At a “Send AR Request(s)” block 503, AR request source device 500 may send AR request(s) generated at block 502. AR requests may be sent using any available wired or wireless communication techniques, as will be appreciated by those of skill in the art. In some embodiments, generated AR requests may be sent to all AR devices discovered at block 501. In some devices, AR request source device 500 may send generated AR requests to a limited set of one or more AR devices, e.g., by sending generated AR requests to Internet Protocol (IP) addresses corresponding to the limited set of AR devices. In some embodiments, the limited set of AR devices may comprise, e.g., AR devices which supplied preference information, at block 501, indicating a preference for AR requests of a type matching a generated AR request. In some embodiments, the limited set of AR devices may comprise AR devices identified by a user of AR request source device 500, e.g., via UI 503. In some embodiments, the limited set of AR devices may comprise AR devices on a list of personal contacts at AR request source device 500. Any other approach may be used to supply AR requests to limited sets of AR devices as will be appreciated.
There is little distinction left between hardware and software implementations of aspects of systems; the use of hardware or software is generally (but not always, in that in certain contexts the choice between hardware and software may become significant) a design choice representing cost vs. efficiency tradeoffs. There are various vehicles by which processes and/or systems and/or other technologies described herein may be effected (e.g., hardware, software, and/or firmware), and that the preferred vehicle will vary with the context in which the processes and/or systems and/or other technologies are deployed. For example, if an implementer determines that speed and accuracy are paramount, the implementer may opt for a mainly hardware and/or firmware vehicle; if flexibility is paramount, the implementer may opt for a mainly software implementation; or, yet again alternatively, the implementer may opt for some combination of hardware, software, and/or firmware.
The foregoing detailed description has set forth various embodiments of the devices and/or processes via the use of block diagrams, flowcharts, and/or examples. Insofar as such block diagrams, flowcharts, and/or examples contain one or more functions and/or operations, it will be understood by those within the art that each function and/or operation within such block diagrams, flowcharts, or examples may be implemented, individually and/or collectively, by a wide range of hardware, software, firmware, or virtually any combination thereof. In one embodiment, several portions of the subject matter described herein may be implemented via Application Specific Integrated Circuits (ASICs), Field Programmable Gate Arrays (FPGAs), digital signal processors (DSPs), or other integrated formats. However, those skilled in the art will recognize that some aspects of the embodiments disclosed herein, in whole or in part, may be equivalently implemented in integrated circuits, as one or more computer programs running on one or more computers (e.g., as one or more programs running on one or more computer systems), as one or more programs running on one or more processors (e.g., as one or more programs running on one or more microprocessors), as firmware, or as virtually any combination thereof, and that designing the circuitry and/or writing the code for the software and or firmware would be well within the skill of one of skill in the art in light of this disclosure. In addition, those skilled in the art will appreciate that the mechanisms of the subject matter described herein are capable of being distributed as a program product in a variety of forms, and that an illustrative embodiment of the subject matter described herein applies regardless of the particular type of signal bearing medium used to actually carry out the distribution. Examples of a signal bearing medium include, but are not limited to, the following: a recordable type medium such as a floppy disk, a hard disk drive, a Compact Disc (CD), a Digital Video Disc (DVD), a digital tape, a computer memory, etc.; and a transmission type medium such as a digital and/or an analog communication medium (e.g., a fiber optic cable, a waveguide, a wired communications link, a wireless communication link, etc.).
Those skilled in the art will recognize that it is common within the art to describe devices and/or processes in the fashion set forth herein, and thereafter use engineering practices to integrate such described devices and/or processes into data processing systems. That is, at least a portion of the devices and/or processes described herein may be integrated into a data processing system via a reasonable amount of experimentation. Those having skill in the art will recognize that a typical data processing system generally includes one or more of a system unit housing, a video display device, a memory such as volatile and non-volatile memory, processors such as microprocessors and digital signal processors, computational entities such as operating systems, drivers, graphical user interfaces, and applications programs, one or more interaction devices, such as a touch pad or screen, and/or control systems including feedback loops and control motors (e.g., feedback for sensing position and/or velocity; control motors for moving and/or adjusting components and/or quantities). A typical data processing system may be implemented utilizing any suitable commercially available components, such as those typically found in data computing/communication and/or network computing/communication systems. The herein described subject matter sometimes illustrates different components contained within, or connected with, different other components. It is to be understood that such depicted architectures are merely examples and that in fact many other architectures may be implemented which achieve the same functionality. In a conceptual sense, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components herein combined to achieve a particular functionality may be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermediate components. Likewise, any two components so associated may also be viewed as being “operably connected”, or “operably coupled”, to each other to achieve the desired functionality, and any two components capable of being so associated may also be viewed as being “operably couplable”, to each other to achieve the desired functionality. Specific examples of operably couplable include but are not limited to physically connectable and/or physically interacting components and/or wirelessly inter-actable and/or wirelessly interacting components and/or logically interacting and/or logically inter-actable components.
With respect to the use of substantially any plural and/or singular terms herein, those having skill in the art may translate from the plural to the singular and/or from the singular to the plural as is appropriate to the context and/or application. The various singular/plural permutations may be expressly set forth herein for sake of clarity.
It will be understood by those within the art that, in general, terms used herein, and especially in the appended claims (e.g., bodies of the appended claims) are generally intended as “open” terms (e.g., the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” etc.). It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases “at least one” and “one or more” to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim recitation to inventions containing only one such recitation, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an” (e.g., “a” and/or “an” should typically be interpreted to mean “at least one” or “one or more”); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should typically be interpreted to mean at least the recited number (e.g., the bare recitation of “two recitations,” without other modifiers, typically means at least two recitations, or two or more recitations). Furthermore, in those instances where a convention analogous to “at least one of A, B, and C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, and C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). In those instances where a convention analogous to “at least one of A, B, or C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, or C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). It will be further understood by those within the art that virtually any disjunctive word and/or phrase presenting two or more alternative terms, whether in the description, claims, or drawings, should be understood to contemplate the possibilities of including one of the terms, either of the terms, or both terms. For example, the phrase “A or B” will be understood to include the possibilities of “A” or “B” or “A and B.”
While certain example techniques have been described and shown herein using various methods, devices and systems, it should be understood by those skilled in the art that various other modifications may be made, and equivalents may be substituted, without departing from claimed subject matter. Additionally, many modifications may be made to adapt a particular situation to the teachings of claimed subject matter without departing from the central concept described herein. Therefore, it is intended that claimed subject matter not be limited to the particular examples disclosed, but that such claimed subject matter also may include all implementations falling within the scope of the appended claims, and equivalents thereof.