The present disclosure is directed to controlling interactions between various artificial reality entities with a defined artificial reality environment schema.
Interaction with computing systems are often founded on a set of core concepts that define how users can interact with that computing system. For example, early operating systems provided textual interfaces to interact with a file directory. This was later built upon with the addition of “windowing” systems whereby levels in the file directory and executing applications were displayed in multiple windows, each allocated a portion of a 2D display that was populated with content selected for that window (e.g., all the files from the same level in the directory, a graphical user interface generated by an application, menus or controls for the operating system, etc.) As computing form factors decreased in size and added integrated hardware capabilities (e.g., cameras, GPS, wireless antennas, etc.) the core concepts again evolved, moving to an “app” focus where each app encapsulated a capability of the computing system.
When computing systems provide a platform for implementing software developed by others, they often include an application programming interface or schema, allowing these other systems to perform a standard set of actions within the platform. Such s schema can provide interfaces and standard objects for interacting within the platform. The schema allows software producers to define data elements and access functions in a standard way that will be acceptable to the platform. The schema further allows entities that instantiate software products built with the schema to expect a set of schema-defined standard functionality from the software products. Finally, the schema allows users on the platform to exchange standard sets of information for interoperability.
The techniques introduced here may be better understood by referring to the following Detailed Description in conjunction with the accompanying drawings, in which like reference numerals indicate identical or functionally similar elements.
Aspects of the present disclosure are directed to defining an artificial reality environment (XRE) and controlling interactions between various artificial reality actors with a defined XRE schema. The XRE schema includes a set of definitions for an artificial reality environment that are device-agnostic, i.e., are independent of whether that artificial reality environment is generated for virtual reality (VR), mixed reality (MR), augmented reality (AR), or another artificial reality (XR) system. The definitions in the XRE schema can include standards for both interfaces and data objects. The XRE schema can define XR elements in terms of entities and components of a spatial “room,” defined as a hierarchy. Because these elements are not depending on a particular type of artificial reality, elements defined in the XRE schema can be shared and used across types of artificial reality platforms.
Each entity can represent a real or virtual object or space, within an artificial reality environment, defined by a name and a collection of one or more components. As used herein, an n-gram surrounded by brackets [ ] define an entity. For example, “[Room]” defines a room entity.
Each component (as part of an entity) can define aspects and expose information about the entity—through meta-data components (e.g., by being a GUID component, an anchor point component, etc.), through fundamental components (e.g., by being a point component, line component, mesh component, etc.), and/or with a collection of other entities contained in the component (e.g., a PhysicalBoundries component can include zero or more wall entities, zero or more floor entities, and zero or more ceiling entities). Each component can provide access to a set of zero or more entities included in the component and/or a set of zero or more functions or actions that can be performed in relation to that component. For example, a component may include a “getComponentName( )” function, a “getComponentDescription( )” function, a “getComponentEntities( )” function, etc. Some components can have internal data or links to virtual objects that exist in the artificial reality environment, for example, a “line” component may have a function “getPoints( ),” which returns a list of points forming the line, and “getDirection( )” which returns a vector for the line. As used herein, an n-gram surrounded by braces { } define a component. For example, “{Plane}” defines a plane (i.e., flat surface) component.
Various elements (entities and components) may be defined types in the XRE schema. Defined entity types can have guarantees specifying a number of components of a particular type that entity must have; and defined component types can have guarantees specifying a number of entities of a particular type that component must have. For example, a “wall” entity type may be defined to always have exactly one anchor point, one container, and one plane. As used herein, a number surrounded by parentheses ( ), followed by an element, defines a guaranteed number of that element. For example, “(1){Volume}” defined as part of a list of components in a room entity, specifies that the room entity has exactly one volume component. Guarantee notation when specified as a single number defines an exact amount of that element (as in the previous example). A+ notation can specify a guarantee, of the preceding given number or more, of the following element type. For example, “(2+)[Wall]” defined as part of a list of entities in a PhysicalBoundaries component, specifies that the PhysicalBoundaries component has two or more wall entities. A | notation can specify a guarantee, of the before or after given number, of the following element type. For example, “(0|1)[Stairs]” defined as part of a list of entities in a PhysicalBoundaries component, specifies that the PhysicalBoundaries component has either zero or one, but no other amounts, of stairs entities. As used herein parent elements that “have,” “link to,” “include,” “contain,” or otherwise specify other child elements can do so by having a reference to those other child elements (e.g., a pointer, a GUID, hierarchy location, etc.) or the data structure for the parent element can contain the data structures for the child elements.
Each artificial reality environment specified in the XRE schema can be defined by a hierarchy, which can be a directed acyclic graph (DAG). The nodes in the hierarchy can be the elements defined for the artificial reality environment with parent/child relationships defining which elements (children) are “contained within” (e.g., are spatially within or provide information for) the parent element. Such relationships are referred to as “links” herein. In various implementations, each element can have exactly one parent element or can have multiple parent elements. As an example of a node having multiple parent elements, a room entity can include A) a container component having all the other entities within the room and B) a PhysicalBoundaries component defining Wall, Floor, and Ceiling entities for the room; a Wall entity may be a child element of both the room's container component and the room's PhysicalBoundaries component. In some implementations, the hierarchy can specify an entity root node, which in some cases is a “room” entity. Additional details on the XRE schema definitions are discussed below in relation to
In practice the XRE schema can define data structures and functions for interactions between actors in an artificial reality environment. In some cases, the actors can comprise producers, instantiators, and consumers. The XRE schema can define interfaces through components that that allow actors to perform defined actions in relation to artificial reality environment elements. In various cases, the multiple actors may not be simultaneously acting with or in an artificial reality environment, but may define elements according to the XRE schema for access by other actors. For example, a producer may initially define an entity type, and that entity definition can be included in an application that is downloaded to an XR device where the application is run to instantiate an instance of the entity type.
A producer is an actor that defines, through the XRE schema, element types. A producer may define an element type, with a constructor for that element type ensuring that the guarantees for an element type are met when an element of that type is instantiated. Examples of producers include system and application developers who construct elements that can be instantiated into an artificial reality environment, e.g., upon certain calls or identified artificial reality environment contexts. For example, an XR device operating system can define a flow for creating a bespoke surface, accessible to running applications, upon detecting a real world surface that matches given dimensions. Additional details on a producer defining an element in the XRE schema are provided below in relation to
An instantiator is an actor that causes elements, defined by the producers, to be created in an artificial reality environment. Instantiators can be parts of an application, operating system, or other control system that watch for triggers or contextual conditions that invoke a constructor from a producer. Thus, instantiators identify the artificial reality environment variables for a constructor, call the constructor, and receive back an element that is part of the artificial reality environment hierarchy. Instantiators can receive trigger and context information from sources such as end-user interactions (e.g., a gesture or command to create an object), sensors or other machine perception interfaces (e.g., cameras paired with object recognizers that identify surrounding real-world objects, which may be mapped to the construction of various artificial reality environment elements), or local or network data sources (e.g., device or cloud sources that provide data elements, which may be mapped to the construction of various artificial reality environment elements). Additional details on an instantiator creating an element, in the XRE schema, using an element definition defined by a producer are provided below in relation to
A consumer is an actor that accesses or updates information defined in elements instantiated in an artificial reality environment according to the XRE schema. An example of a consumer is an operating system or shell feature that queries and sets parameters for existing artificial reality environment elements. Another example of a consumer is an installed application which can query for and perform actions on artificial reality environment elements instantiated into the artificial reality environment. Additional details on consumers querying and interacting with elements, in the XRE schema, are provided below in relation to
Embodiments of the disclosed technology may include or be implemented in conjunction with an artificial reality system. Artificial reality or extra reality (XR) is a form of reality that has been adjusted in some manner before presentation to a user, which may include, e.g., virtual reality (VR), augmented reality (AR), mixed reality (MR), hybrid reality, or some combination and/or derivatives thereof. Artificial reality content may include completely generated content or generated content combined with captured content (e.g., real-world photographs). The artificial reality content may include video, audio, haptic feedback, or some combination thereof, any of which may be presented in a single channel or in multiple channels (such as stereo video that produces a three-dimensional effect to the viewer). Additionally, in some embodiments, artificial reality may be associated with applications, products, accessories, services, or some combination thereof, that are, e.g., used to create content in an artificial reality and/or used in (e.g., perform activities in) an artificial reality. The artificial reality system that provides the artificial reality content may be implemented on various platforms, including a head-mounted display (HMD) connected to a host computer system, a standalone HMD, a mobile device or computing system, a “cave” environment or other projection system, or any other hardware platform capable of providing artificial reality content to one or more viewers.
“Virtual reality” or “VR,” as used herein, refers to an immersive experience where a user's visual input is controlled by a computing system. “Augmented reality” or “AR” refers to systems where a user views images of the real world after they have passed through a computing system. For example, a tablet with a camera on the back can capture images of the real world and then display the images on the screen on the opposite side of the tablet from the camera. The tablet can process and adjust or “augment” the images as they pass through the system, such as by adding virtual objects. “Mixed reality” or “MR” refers to systems where light entering a user's eye is partially generated by a computing system and partially composes light reflected off objects in the real world. For example, a MR headset could be shaped as a pair of glasses with a pass-through display, which allows light from the real world to pass through a waveguide that simultaneously emits light from a projector in the MR headset, allowing the MR headset to present virtual objects intermixed with the real objects the user can see. “Artificial reality,” “extra reality,” or “XR,” as used herein, refers to any of VR, AR, MR, or any combination or hybrid thereof.
Existing AR, VR, and MR systems each define their own data objects and environment variables. This prevents elements defined for one type of XR system from being accessible in another type of XR system. Even simple stand-alone virtual objects may have different function types and variables, preventing that object when defined in one system from being transferable to another system. Further, many XR systems don't specify interfaces and guarantees for XR elements, causing errors even within the same XR system when an element is defined by a producer, instantiated by a separate instantiator, and used by yet another consumer, each of which may have different assumptions about features of an element.
The XRE schema, systems, and processes described herein are expected to overcome these issues in the prior art by defining elements of an artificial reality environment in a manner that can be consistent across XR systems and system types. These element definitions, together with defined relationships among the elements (both through a hierarchy of elements and guarantees in element construction), and interaction methods for actors related to the artificial reality environment (e.g., producers, instantiates, and consumers), ensure consistent artificial reality environment definitions and interactions, eliminating incompatibilities and errors between systems and actors.
Several implementations are discussed below in more detail in reference to the figures.
Computing system 100 can include one or more processor(s) 110 (e.g., central processing units (CPUs), graphical processing units (GPUs), holographic processing units (HPUs), etc.) Processors 110 can be a single processing unit or multiple processing units in a device or distributed across multiple devices (e.g., distributed across two or more of computing devices 101-103).
Computing system 100 can include one or more input devices 120 that provide input to the processors 110, notifying them of actions. The actions can be mediated by a hardware controller that interprets the signals received from the input device and communicates the information to the processors 110 using a communication protocol. Each input device 120 can include, for example, a mouse, a keyboard, a touchscreen, a touchpad, a wearable input device (e.g., a haptics glove, a bracelet, a ring, an earring, a necklace, a watch, etc.), a camera (or other light-based input device, e.g., an infrared sensor), a microphone, or other user input devices.
Processors 110 can be coupled to other hardware devices, for example, with the use of an internal or external bus, such as a PCI bus, SCSI bus, or wireless connection. The processors 110 can communicate with a hardware controller for devices, such as for a display 130. Display 130 can be used to display text and graphics. In some implementations, display 130 includes the input device as part of the display, such as when the input device is a touchscreen or is equipped with an eye direction monitoring system. In some implementations, the display is separate from the input device. Examples of display devices are: an LCD display screen, an LED display screen, a projected, holographic, or augmented reality display (such as a heads-up display device or a head-mounted device), and so on. Other I/O devices 140 can also be coupled to the processor, such as a network chip or card, video chip or card, audio chip or card, USB, firewire or other external device, camera, printer, speakers, CD-ROM drive, DVD drive, disk drive, etc.
In some implementations, input from the I/O devices 140, such as cameras, depth sensors, IMU sensor, GPS units, LiDAR or other time-of-flights sensors, etc. can be used by the computing system 100 to identify and map the physical environment of the user while tracking the user's location within that environment. This simultaneous localization and mapping (SLAM) system can generate maps (e.g., topologies, girds, etc.) for an area (which may be a room, building, outdoor space, etc.) and/or obtain maps previously generated by computing system 100 or another computing system that had mapped the area. The SLAM system can track the user within the area based on factors such as GPS data, matching identified objects and structures to mapped objects and structures, monitoring acceleration and other position changes, etc.
Computing system 100 can include a communication device capable of communicating wirelessly or wire-based with other local computing devices or a network node. The communication device can communicate with another device or a server through a network using, for example, TCP/IP protocols. Computing system 100 can utilize the communication device to distribute operations across multiple network devices.
The processors 110 can have access to a memory 150, which can be contained on one of the computing devices of computing system 100 or can be distributed across of the multiple computing devices of computing system 100 or other external devices. A memory includes one or more hardware devices for volatile or non-volatile storage, and can include both read-only and writable memory. For example, a memory can include one or more of random access memory (RAM), various caches, CPU registers, read-only memory (ROM), and writable non-volatile memory, such as flash memory, hard drives, floppy disks, CDs, DVDs, magnetic storage devices, tape drives, and so forth. A memory is not a propagating signal divorced from underlying hardware; a memory is thus non-transitory. Memory 150 can include program memory 160 that stores programs and software, such as an operating system 162, XRE schema system 164, and other application programs 166. Memory 150 can also include data memory 170 that can include constructed artificial reality environment elements, element definitions (with constructors, access interface functions, guarantees, etc.), element hierarchies, configuration data, settings, user options or preferences, etc., which can be provided to the program memory 160 or any element of the computing system 100.
Some implementations can be operational with numerous other computing system environments or configurations. Examples of computing systems, environments, and/or configurations that may be suitable for use with the technology include, but are not limited to, XR headsets, personal computers, server computers, handheld or laptop devices, cellular telephones, wearable electronics, gaming consoles, tablet devices, multiprocessor systems, microprocessor-based systems, set-top boxes, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, or the like.
The electronic display 245 can be integrated with the front rigid body 205 and can provide image light to a user as dictated by the compute units 230. In various embodiments, the electronic display 245 can be a single electronic display or multiple electronic displays (e.g., a display for each user eye). Examples of the electronic display 245 include: a liquid crystal display (LCD), an organic light-emitting diode (OLED) display, an active-matrix organic light-emitting diode display (AMOLED), a display including one or more quantum dot light-emitting diode (QOLED) sub-pixels, a projector unit (e.g., microLED, LASER, etc.), some other display, or some combination thereof.
In some implementations, the HMD 200 can be coupled to a core processing component such as a personal computer (PC) (not shown) and/or one or more external sensors (not shown). The external sensors can monitor the HMD 200 (e.g., via light emitted from the HMD 200) which the PC can use, in combination with output from the IMU 215 and position sensors 220, to determine the location and movement of the HMD 200.
The projectors can be coupled to the pass-through display 258, e.g., via optical elements, to display media to a user. The optical elements can include one or more waveguide assemblies, reflectors, lenses, mirrors, collimators, gratings, etc., for directing light from the projectors to a user's eye. Image data can be transmitted from the core processing component 254 via link 256 to HMD 252. Controllers in the HMD 252 can convert the image data into light pulses from the projectors, which can be transmitted via the optical elements as output light to the user's eye. The output light can mix with light that passes through the display 258, allowing the output light to present virtual objects that appear as if they exist in the real world.
Similarly to the HMD 200, the HMD system 250 can also include motion and position tracking units, cameras, light sources, etc., which allow the HMD system 250 to, e.g., track itself in 3 DoF or 6 DoF, track portions of the user (e.g., hands, feet, head, or other body parts), map virtual objects to appear as stationary as the HMD 252 moves, and have virtual objects react to gestures and other real-world objects.
In various implementations, the HMD 200 or 250 can also include additional subsystems, such as an eye tracking unit, an audio system, various network components, etc. To monitor indications of user interactions and intentions. For example, in some implementations, instead of or in addition to controllers, one or more cameras included in the HMD 200 or 250, or from external cameras, can monitor the positions and poses of the user's hands to determine gestures and other hand and body motions.
In some implementations, server 310 can be an edge server which receives client requests and coordinates fulfillment of those requests through other servers, such as servers 320A-C. Server computing devices 310 and 320 can comprise computing systems, such as computing system 100. Though each server computing device 310 and 320 is displayed logically as a single server, server computing devices can each be a distributed computing environment encompassing multiple computing devices located at the same or at geographically disparate physical locations.
Client computing devices 305 and server computing devices 310 and 320 can each act as a server or client to other server/client device(s). Server 310 can connect to a database 315. Servers 320A-C can each connect to a corresponding database 325A-C. As discussed above, each server 310 or 320 can correspond to a group of servers, and each of these servers can share a database or can have their own database. Though databases 315 and 325 are displayed logically as single units, databases 315 and 325 can each be a distributed computing environment encompassing multiple computing devices, can be located within their corresponding server, or can be located at the same or at geographically disparate physical locations.
Network 330 can be a local area network (LAN), a wide area network (WAN), a mesh network, a hybrid network, or other wired or wireless networks. Network 330 may be the Internet or some other public or private network. Client computing devices 305 can be connected to network 330 through a network interface, such as by wired or wireless communication. While the connections between server 310 and servers 320 are shown as separate connections, these connections can be any kind of local, wide area, wired, or wireless network, including network 330 or a separate public or private network.
Mediator 420 can include components which mediate resources between hardware 410 and specialized components 430. For example, mediator 420 can include an operating system, services, drivers, a basic input output system (BIOS), controller circuits, or other hardware or software systems.
Specialized components 430 can include software or hardware configured to perform operations for defining an artificial reality environment and controlling interactions between various artificial reality actors. Specialized components 430 can include XRE schema 434, element production module 436, element instantiation module 438, element consumption module 440, persistence and sharing module 442, hierarchy module 444, and components and APIs which can be used for providing user interfaces, transferring data, and controlling the specialized components, such as interfaces 432. In some implementations, components 400 can be in a computing system that is distributed across multiple computing devices or can be an interface to a server-based application executing one or more of specialized components 430. Although depicted as separate components, specialized components 430 may be logical or other nonphysical differentiations of functions and/or may be submodules or code-blocks of one or more applications.
XRE schema 434 can define a set of elements, each as either an entity or a component, where each entity has a defined name and component list, and each component has a defined name any may include an entity list and/or query list. Some of the elements can be generic entities or components and some of the elements can be producer-defined entities or components. Additional details on generic and producer-defined elements are discussed below in relation to
Element production module 436 can be used by producers to define new elements according to the XRE schema. A producer can define an entity with a name, description, and component list (with guarantees for amounts of component types), further specifying the components on the component list either by including existing components or defining new ones. New components can be defined by supplying a component name, component description, entity list (with guarantees for amounts of entity types), and query list. Additional details on defining new elements are provided below in relation to
Element instantiation module 438 can be used by an instantiator to generate instances of elements defined in the XRE schema. Element instantiation module 438 can accomplish this by obtaining parameters for the element to be instantiated (e.g., surrounding objects and surfaces, environment conditions, user status, etc.), call an element constructor defined for the element, and receive back a constructed instance of the element. In some cases, element instantiation module 438 can be used to instantiate elements for multiple features, in an artificial reality environment, each as an element defined by the XRE schema as either an entity or a component. Additional details on instantiating instances of elements are provided below in relation to
Element consumption module 440 can be used by a consumer to access elements defined under the XRE schema. Element consumption module 440 can accomplish this by obtaining an element handle for an element (e.g., through a name or ID search, by traversing a hierarchy, etc.) and, via the handle, either accessing query functions defined for the element or performing get or set operations in relation to parts of the element. Additional details on accessing instantiated elements are provided below in relation to
Persistence and sharing module 442 can store instantiated instances of elements on an XR device and/or share those instances with another XR device (directly or via a cloud repository). Because elements defined according to the XRE schema are device agnostic, such sharing can be between devices of different XR types. Additional details on persistence and sharing are provided below in relation to blocks 514 and 516 of
Hierarchy module 444 can control a hierarchy for all the elements defined for an artificial reality environment. In some implementations, the hierarchy can be a directed acyclic graph (DAG). Nodes in the hierarchy can be elements or can be other references that correspond to elements. A hierarchy can have a root node of a defined type (such as a room node). Edges in the hierarchy can specify which nodes link to other nodes though parent/child relationships. For example, an entity that specifies a component can be the parent of that component. In some cases, hierarchy module 444 can add to the hierarchy a node for each of multiple features (e.g., for elements instantiated by element instantiation module 438) of an artificial reality environment. Additional details on a hierarchy for a space are provided below in relation to
The XRE schema specifies the language used by the artificial reality environment actors to describe, access, and share spatial information. Through APIs for defined elements, actors can use these interfaces to access features of an XR space; create, access, and update virtual objects; and store, retrieve, and share virtual objects. Actors that can perform these actions can include producers who define elements in the XRE schema, instantiators who instantiate instances of the elements defined by the producers with artificial reality environment specifics, and consumers who use instantiated instances of elements in an XR device. In various cases, the producer, instantiator, consumer roles can be performed by the same or different actors. As a first example, an application can define a “desk” entity containing a number of surface components; when that application is downloaded and executed on an MR device, the application instantiates an instance of the desk, setting size and location parameters; as a user interacts with the artificial reality environment containing the desk instance, the application adds items to the top surface of the desk in response to user commands. In this first example, the application is each of the producer, instantiator, and consumer for the desk virtual object. In a second example, an artificial reality environment control application (e.g., an operating system of an VR device) can define a “wall” entity containing a vertical surface component; when a first application creates a virtual room, it can call an API constructor for the wall entity, setting size and location parameters and adding it as an entity in a physicalBoundaries component of a room entity; when a second application executes and receives a command to hang a picture on the wall entity, it can make a call to a placeObject(object) function of the vertical surface of the wall entity, passing the picture object, which the function adds to the vertical surface. In this second example, the control application is the producer of the wall entity, the first application is the instantiator of an instance of the wall entity, and the second application is a consumer of that instance of the wall entity.
In example 500, system features 506 and developers' apps 508 can be producers with defined elements in the XRE schema 502. For example, these applications can define triggers for creating elements in the artificial reality environment, with corresponding constructors that can be called by instantiators to add elements to the artificial reality environment hierarchy. System user interface 510 and machine perception 512 can identify events that define the variable to pass to these constructors. For example, machine perception 512 may use visual data captured by a XR device and a set of machine learning models to identify aspects of a physical space (e.g., physical surfaces and anchor points, objects in the area, identify other user, etc.) and other information (e.g., movements of the XR device and user, data gathered from third parties, etc.). These can be passed to constructors for elements of a room (e.g., defined in system features 506 or developers' apps 508) to define the space as an artificial reality environment—correctly mapping conceptual features to their real-world counterparts (e.g., having a defined “wall” entity with a coordinates component that matches the position of a real-world wall). As another example, system UX 510 may receive user inputs (e.g., gestures, spoken commands, body positions, etc.) which can be passed as parameters to corresponding constructors (e.g., defined in system features 506 or developers' apps 508) to further generate artificial reality environment elements. In some cases, the variables defined by system UX 510 and machine perception 512 can be used together in the same constructor.
In example 500, system features 506 and developers' apps 508 can also be consumers that access artificial reality environment elements via the APIs and other functions defined for the elements in the XRE schema 502. For example, a system feature 506 can act as a producer with a defined “table” entity, and act as an instantiator, getting an anchor point from machine perception system 512 which it passes to the table's constructor to instantiate an instance of the table entity in the artificial reality environment hierarchy; a developer app 508 can then access the table entity, as a consumer, via the artificial reality environment hierarchy and update its location by calling a setLocation(anchor) function of a location component of the table entity.
Example 500 also includes storage 514 illustrating the persistence of the elements by having them stored on the XR device and cloud 516 illustrating the ability of the elements to be shared between XR devices, including different types (e.g., VR, AR, MR, etc.) For example, each element can have a function to serialize/de-serialize it (e.g., as an XML element, JSON blob, simple string, etc.) for storage and sharing.
Entities can have an entity structure 602, with fields such as a name 604, a description 606, and a list of components 608 that the entity contains. Each component in the list of components can have a name 612 and a guarantee 610 with a counter specifying an amount of that component included in the entity.
Components can have a component structure 614, with fields such as a name 616, a description 618, a list of entities 620 that the component contains, and a list of queries 622 that can be executed against the component. Each entity in the list of entities can have a name 626 and a guarantee 624 with a counter specifying an amount of that component included in the entity. Each function in the list of queries can specify a name 630 for calling the function (which may include a list of parameters the function takes), a description 632, and a return type 628 specifying a type of data element (if any) the function returns.
A guarantee for an entity specifies a number of components of a particular type that entity must have and a guarantee for a component specifies a number of entities of a particular type that component must have. For example, a “wall” entity type may be defined to always have exactly one anchor point, one container, and one plane. As used herein, a number surrounded by parentheses ( ), followed by an element, defines a guaranteed number of that element. For example, “(1){Volume}” defined as part of a list of components in a room entity, specifies that the room entity has exactly one volume component. Guarantee notation when specified as a single number defines an exact amount of that element (as in the previous example). A + notation can specify a guarantee, of the preceding given number or more, of the following element type. For example, “(2+)[Wall]” defined as part of a list of entities in a PhysicalBoundaries component, specifies that the PhysicalBoundaries component has two or more wall entities. A | notation can specify a guarantee, of the before or after given number, of the following element type. For example, “(0|1)[Stairs]” defined as part of a list of entities in a PhysicalBoundaries component, specifies that the PhysicalBoundaries component has either zero or one, but no other amounts, of stairs entities.
In some implementations, elements may also specify privacy or security settings. These settings can set particular consumers that are allowed to see or access features of the element or access levels that a consumer must have to see or access features of the element. In some implementations, different features (e.g., properties, functions) of an element may have different privacy or security settings.
While there are infinite possible combinations of entities and components that can be used for additional elements, some examples of additional entities include a desk, cabinet, shelf, wardrobe, window, door, poster, painting, table, plant, lamp, screen, pen, phone, wallet, keys, etc.
Those skilled in the art will appreciate that the components illustrated in
At block 802, process 800 can define an entity element. An entity can represent a real or virtual object or space, within an artificial reality environment, defined by a name and a collection of one or more components. This can include the three steps (which may be performed in various orders) of receiving a name for the entity at block 804, receiving a description for the entity at 806, and receiving a list of components for the entity at 808. One or more of the components on the list of components can include a guarantee, specifying an amount of each component type that must be included in the entity. A constructor for the entity can be defined that takes the specified guaranteed amount of each component type and returns the constructed entity. In various implementations, the listed components in a constructed instance of an entity can be directly read or set by an application that has access to the entity or by calling a Get( ) or Set( ) function for that component of the entity.
At block 810, process 800 can define a component, in the list of components specified at block 808. In some cases, a listed component may already have been defined, (e.g., the component is one of the standard components described in
As discussed above, any block can be removed or rearranged in various implementations. However, block 816 is shown in dashed lines to indicate there are specific instances where block 816 is skipped—e.g., where the list of entities for a component is empty. As indicated by dashed line 818, where block 816 is performed, an instance of process 800 can be performed for each specified entity, allowing that instance of process 800 establish the variables and components of each entity. In some cases, an listed entity may already have been defined, (e.g., the entity is one of the standard entities described in
While a producer can define any number of queries for the list of queries for the component at 820, in some implementations, some default queries can also be included, such as queries to get or set values for the list of entities of the component. In other implementations, these values can be directly read and written to from the component, and thus a Get( ) and Set( ) function is not needed.
At block 822, if all of the components in the list of components from block 808 have not been defined, process 800 can return to block 810 to define the next component. If all of the components in the list of components from block 808 have been defined, process 800 can end.
Once complete, the entity and/or component definitions created through process 800 can be stored and made available to various entities in an XR system. For example, the element definition can be included in an application, can be part of an XR system control application (e.g., Operating System), or can be provided via a remote call to a cloud-system. As a first example, process 800 can be performed as part of developing an application using the XRE schema, that application can be downloaded to an XR device, and the element definitions from the application (made with process 800) can be used by the application, or in some cases by other applications on the XR device, to instantiate an instance of the defined element.
As a second example, an XR device administrator may define one or more elements (pre-installed or delivered to the XR device via an update or element pack) that the XR device control application is configured to instantiate when it recognizes matching features in an artificial reality environment. As a more specific version of this second example, the defined element can be a desk entity and the control application is configured to automatically instantiate an instance of the desk (by calling the desk's constructor) when computer vision systems recognize a horizontal surface of a particular size with a proximate chair. In this second example, the recognized surface can be passed as a parameter to the desk constructor.
As a third example, a user can define a set of nature elements for an application to recognize when in a particular area, the user can share that nature element set with a friend who the user knows is interested in hiking—allowing applications on the friend's XR system to recognize and instantiate instances of the nature elements when their components are recognized in the friend's artificial reality environment.
At block 902, process 900 can obtain the element parameters needed for a constructor of an element to be instantiated. The parameters needed can be defined in a definition for the constructor—e.g., via a defined API. While the parameters of an element can be any data available on an XR device, some examples of element parameters include: a defined anchor point; a defined parent element; identified real-world surfaces; an identified user; a color, texture, or other visual appearance for the element; meta-data features for the element; identified objects the element will be related to; identified user input or commands; etc.
At block 904, process 900 can call a constructor for the element to be instantiated. As discussed above, this constructor can be available by virtue of the constructor being part of the instantiator application, through local or cloud-based API, or through other system calls the instantiator has permission to access. Calling the constructor can include passing the element parameters obtained at block 902 to the constructor. In some implementations, the call to a constructor can be a call that specifies one or more parent elements of the instance of the element to be instantiated. For example, the call can indicate an element the new element will be liked to in that element's list of entities or list of components. As another example, the call can specify one or more hierarchy nodes that will be the parent element(s) for the new element.
At block 906, process 900 can receive the element constructed by the constructor called at block 904. Where a parent element was defined for the constructor, the returned element can already be linked to that parent element and can be included in the hierarchy. In other cases, process 900 can link the new element as a child of another element and/or add the new element to the hierarchy. These relationships between elements can allow consumers to read data about the elements in a space and update element parameters.
At block 1002, process 1000 can obtain a handle for an element defined in a space (e.g., an element instantiated by process 900). An element handle can be the element itself, a pointer to the element, an ID for the element, or other handle that can be used to access functions and/or parameters of an element. For example, an application can request, through a control application of an XR device, a hierarchy corresponding to the space the XR device is currently in, allowing the application to traverse the hierarchy; the application can request an identifier for an element at a given location; the application can request handles for one or more elements by element name or by element type; an element handle can be passed to an application from another application; etc.
At block 1004, process 1000 can use the handle obtained at block 1002 to query and interact with parts of the element. For example, the handle can be a reference to the element “XYZ,” an application can have a new anchor point “AP,” and the application can perform an operation “XYZ.anchor=AP” to move the element XYZ to the new anchor point AP in the artificial reality environment. As another example, the handle can be reference to an elevator entity “ELV,” and an application can perform an operation “ELV.MultiConnection.GetRooms( )” to execute the “GetRooms( )” function of the multiConnection component of the elevator entity; this can return a list of the GUIDs for the rooms connected to that MultiConnection component. The consumer can perform various other actions to get and set properties of the components in a space, traverse the hierarchy, and/or communicate spatial information to other applications. In some cases, applications with proper permissions can also share handles with other applications and/or send elements to other XR device (whether of the same or different XR type).
Reference in this specification to “implementations” (e.g., “some implementations,” “various implementations,” “one implementation,” “an implementation,” etc.) means that a particular feature, structure, or characteristic described in connection with the implementation is included in at least one implementation of the disclosure. The appearances of these phrases in various places in the specification are not necessarily all referring to the same implementation, nor are separate or alternative implementations mutually exclusive of other implementations. Moreover, various features are described which may be exhibited by some implementations and not by others. Similarly, various requirements are described which may be requirements for some implementations but not for other implementations.
As used herein, being above a threshold means that a value for an item under comparison is above a specified other value, that an item under comparison is among a certain specified number of items with the largest value, or that an item under comparison has a value within a specified top percentage value. As used herein, being below a threshold means that a value for an item under comparison is below a specified other value, that an item under comparison is among a certain specified number of items with the smallest value, or that an item under comparison has a value within a specified bottom percentage value. As used herein, being within a threshold means that a value for an item under comparison is between two specified other values, that an item under comparison is among a middle-specified number of items, or that an item under comparison has a value within a middle-specified percentage range. Relative terms, such as high or unimportant, when not otherwise defined, can be understood as assigning a value and determining how that value compares to an established threshold. For example, the phrase “selecting a fast connection” can be understood to mean selecting a connection that has a value assigned corresponding to its connection speed that is above a threshold.
As used herein, the word “or” refers to any possible permutation of a set of items. For example, the phrase “A, B, or C” refers to at least one of A, B, C, or any combination thereof, such as any of: A; B; C; A and B; A and C; B and C; A, B, and C; or multiple of any item such as A and A; B, B, and C; A, A, B, C, and C; etc.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Specific embodiments and implementations have been described herein for purposes of illustration, but various modifications can be made without deviating from the scope of the embodiments and implementations. The specific features and acts described above are disclosed as example forms of implementing the claims that follow. Accordingly, the embodiments and implementations are not limited except as by the appended claims.
Any patents, patent applications, and other references noted above are incorporated herein by reference. Aspects can be modified, if necessary, to employ the systems, functions, and concepts of the various references described above to provide yet further implementations. If statements or subject matter in a document incorporated by reference conflicts with statements or subject matter of this application, then this application shall control.
Number | Name | Date | Kind |
---|---|---|---|
770149 | Bailey | Sep 1904 | A |
6842175 | Schmalstieg et al. | Jan 2005 | B1 |
7650575 | Cummins et al. | Jan 2010 | B2 |
7701439 | Hillis et al. | Apr 2010 | B2 |
8335991 | Douceur et al. | Dec 2012 | B2 |
8558759 | Gomez et al. | Oct 2013 | B1 |
8947351 | Noble | Feb 2015 | B1 |
9055404 | Setlur et al. | Jun 2015 | B2 |
9081177 | Wong et al. | Jul 2015 | B2 |
9117274 | Liao et al. | Aug 2015 | B2 |
9292089 | Sadek | Mar 2016 | B1 |
9477368 | Filip et al. | Oct 2016 | B1 |
9530252 | Poulos et al. | Dec 2016 | B2 |
9817472 | Lee et al. | Nov 2017 | B2 |
10127290 | Armstrong et al. | Nov 2018 | B1 |
10220303 | Schmidt et al. | Mar 2019 | B1 |
10248284 | Itani et al. | Apr 2019 | B2 |
10473935 | Gribetz et al. | Nov 2019 | B1 |
10521944 | Sareen et al. | Dec 2019 | B2 |
10713831 | Arana et al. | Jul 2020 | B2 |
10867450 | Todeschini | Dec 2020 | B2 |
10909762 | Karalis et al. | Feb 2021 | B2 |
10963144 | Fox et al. | Mar 2021 | B2 |
11023096 | Schneider et al. | Jun 2021 | B2 |
11087029 | Satpathy | Aug 2021 | B1 |
11087529 | Yeung et al. | Aug 2021 | B2 |
11126320 | Thompson et al. | Sep 2021 | B1 |
11132066 | Blachly et al. | Sep 2021 | B1 |
11132827 | Gladkov et al. | Sep 2021 | B2 |
11176755 | Tichenor et al. | Nov 2021 | B1 |
11238664 | Tavakoli et al. | Feb 2022 | B1 |
20080089587 | Kim et al. | Apr 2008 | A1 |
20090313299 | Bonev et al. | Dec 2009 | A1 |
20100251177 | Geppert et al. | Sep 2010 | A1 |
20100306716 | Perez | Dec 2010 | A1 |
20110267265 | Stinson | Nov 2011 | A1 |
20120069168 | Huang et al. | Mar 2012 | A1 |
20120143358 | Adams et al. | Jun 2012 | A1 |
20120188279 | Demaine | Jul 2012 | A1 |
20120206345 | Langridge | Aug 2012 | A1 |
20120275686 | Wilson et al. | Nov 2012 | A1 |
20120293544 | Miyamoto et al. | Nov 2012 | A1 |
20130051615 | Lim et al. | Feb 2013 | A1 |
20130063345 | Maeda | Mar 2013 | A1 |
20130069860 | Davidson | Mar 2013 | A1 |
20130117688 | Yerli | May 2013 | A1 |
20130125066 | Klein et al. | May 2013 | A1 |
20130141419 | Mount et al. | Jun 2013 | A1 |
20130147793 | Jeon et al. | Jun 2013 | A1 |
20130169682 | Novak et al. | Jul 2013 | A1 |
20130265220 | Fleischmann et al. | Oct 2013 | A1 |
20140125598 | Cheng et al. | May 2014 | A1 |
20140149901 | Hunter | May 2014 | A1 |
20140236996 | Masuko et al. | Aug 2014 | A1 |
20140268065 | Ishikawa et al. | Sep 2014 | A1 |
20140357366 | Koganezawa et al. | Dec 2014 | A1 |
20140375683 | Salter et al. | Dec 2014 | A1 |
20140375691 | Kasahara | Dec 2014 | A1 |
20140378022 | Muthyala | Dec 2014 | A1 |
20150015504 | Lee et al. | Jan 2015 | A1 |
20150035746 | Cockburn et al. | Feb 2015 | A1 |
20150054742 | Imoto et al. | Feb 2015 | A1 |
20150062160 | Sakamoto et al. | Mar 2015 | A1 |
20150077592 | Fahey | Mar 2015 | A1 |
20150094142 | Stafford | Apr 2015 | A1 |
20150153833 | Pinault et al. | Jun 2015 | A1 |
20150160736 | Fujiwara | Jun 2015 | A1 |
20150169076 | Cohen et al. | Jun 2015 | A1 |
20150181679 | Liao et al. | Jun 2015 | A1 |
20150206321 | Scavezze et al. | Jul 2015 | A1 |
20150220150 | Plagemann et al. | Aug 2015 | A1 |
20150253862 | Seo et al. | Sep 2015 | A1 |
20150261659 | Bader et al. | Sep 2015 | A1 |
20150356774 | Gal et al. | Dec 2015 | A1 |
20160026253 | Bradski et al. | Jan 2016 | A1 |
20160093108 | Mao et al. | Mar 2016 | A1 |
20160110052 | Kim et al. | Apr 2016 | A1 |
20160147308 | Gelman et al. | May 2016 | A1 |
20160170603 | Bastien et al. | Jun 2016 | A1 |
20160173359 | Brenner et al. | Jun 2016 | A1 |
20160180590 | Kamhi et al. | Jun 2016 | A1 |
20160378291 | Pokrzywka | Dec 2016 | A1 |
20170060230 | Faaborg et al. | Mar 2017 | A1 |
20170075420 | Yu et al. | Mar 2017 | A1 |
20170076500 | Maggiore et al. | Mar 2017 | A1 |
20170109936 | Powderly et al. | Apr 2017 | A1 |
20170139478 | Jeon et al. | May 2017 | A1 |
20170192513 | Karmon et al. | Jul 2017 | A1 |
20170206691 | Harrises et al. | Jul 2017 | A1 |
20170214782 | Brinda | Jul 2017 | A1 |
20170242675 | Deshmukh | Aug 2017 | A1 |
20170243465 | Bourne, Jr. et al. | Aug 2017 | A1 |
20170262063 | Blénessy et al. | Sep 2017 | A1 |
20170278304 | Hildreth et al. | Sep 2017 | A1 |
20170287225 | Powderly et al. | Oct 2017 | A1 |
20170296363 | Yetkin et al. | Oct 2017 | A1 |
20170311129 | Lopez-Uricoechea et al. | Oct 2017 | A1 |
20170323488 | Mott et al. | Nov 2017 | A1 |
20170364198 | Yoganandan et al. | Dec 2017 | A1 |
20170372225 | Foresti | Dec 2017 | A1 |
20180005429 | Osman et al. | Jan 2018 | A1 |
20180059901 | Gullicksen | Mar 2018 | A1 |
20180075659 | Browy et al. | Mar 2018 | A1 |
20180091304 | Brook et al. | Mar 2018 | A1 |
20180095616 | Valdivia et al. | Apr 2018 | A1 |
20180107278 | Goel et al. | Apr 2018 | A1 |
20180113599 | Yin | Apr 2018 | A1 |
20180189647 | Calvo et al. | Jul 2018 | A1 |
20180288391 | Lee et al. | Oct 2018 | A1 |
20180300557 | Rodenas et al. | Oct 2018 | A1 |
20180307303 | Powderly et al. | Oct 2018 | A1 |
20180322701 | Pahud et al. | Nov 2018 | A1 |
20180329718 | Klein et al. | Nov 2018 | A1 |
20180335925 | Hsiao et al. | Nov 2018 | A1 |
20180357780 | Young et al. | Dec 2018 | A1 |
20190005724 | Pahud et al. | Jan 2019 | A1 |
20190094981 | Bradski et al. | Mar 2019 | A1 |
20190107894 | Hebbalaguppe et al. | Apr 2019 | A1 |
20190114061 | Daniels et al. | Apr 2019 | A1 |
20190155481 | Diverdi et al. | May 2019 | A1 |
20190172262 | McHugh et al. | Jun 2019 | A1 |
20190197785 | Tate-Gans et al. | Jun 2019 | A1 |
20190213792 | Jakubzak et al. | Jul 2019 | A1 |
20190258318 | Qin et al. | Aug 2019 | A1 |
20190278376 | Kutliroff et al. | Sep 2019 | A1 |
20190279424 | Clausen et al. | Sep 2019 | A1 |
20190279426 | Musunuri et al. | Sep 2019 | A1 |
20190286231 | Burns et al. | Sep 2019 | A1 |
20190317965 | Remis | Oct 2019 | A1 |
20190340833 | Furtwangler et al. | Nov 2019 | A1 |
20190362562 | Benson | Nov 2019 | A1 |
20190369391 | Cordesses et al. | Dec 2019 | A1 |
20190377406 | Steptoe et al. | Dec 2019 | A1 |
20190377416 | Alexander | Dec 2019 | A1 |
20200066047 | Karalis et al. | Feb 2020 | A1 |
20200082629 | Jones et al. | Mar 2020 | A1 |
20200097077 | Nguyen et al. | Mar 2020 | A1 |
20200097091 | Chou et al. | Mar 2020 | A1 |
20200174584 | Schliemann et al. | Jun 2020 | A1 |
20200210127 | Browy | Jul 2020 | A1 |
20200218423 | Ohashi | Jul 2020 | A1 |
20200219319 | Lashmar et al. | Jul 2020 | A1 |
20200225736 | Schwarz et al. | Jul 2020 | A1 |
20200225758 | Tang et al. | Jul 2020 | A1 |
20200226814 | Tang et al. | Jul 2020 | A1 |
20200285761 | Buck et al. | Sep 2020 | A1 |
20200285977 | Brebner | Sep 2020 | A1 |
20200351273 | Thomas | Nov 2020 | A1 |
20200363924 | Flexman et al. | Nov 2020 | A1 |
20200363930 | Srinivasan et al. | Nov 2020 | A1 |
20210012113 | Petill et al. | Jan 2021 | A1 |
20210014408 | Timonen et al. | Jan 2021 | A1 |
20210097768 | Malia et al. | Apr 2021 | A1 |
20210104100 | Whitney et al. | Apr 2021 | A1 |
20210192856 | Lee | Jun 2021 | A1 |
20210256769 | Bailey et al. | Aug 2021 | A1 |
20210272375 | Lashmar et al. | Sep 2021 | A1 |
20210295602 | Scapel et al. | Sep 2021 | A1 |
20210306238 | Cheng et al. | Sep 2021 | A1 |
20210358201 | Cady | Nov 2021 | A1 |
20210390765 | Laaksonen et al. | Dec 2021 | A1 |
20220084279 | Lindmeier et al. | Mar 2022 | A1 |
20220091722 | Faulkner et al. | Mar 2022 | A1 |
20220101612 | Palangie et al. | Mar 2022 | A1 |
20220121344 | Pastrana Vicente et al. | Apr 2022 | A1 |
20220139052 | Tavakoli et al. | May 2022 | A1 |
20220254120 | Berliner et al. | Aug 2022 | A1 |
20220269888 | Stoeva | Aug 2022 | A1 |
20220326967 | Khan | Oct 2022 | A1 |
20220392093 | Poulad et al. | Dec 2022 | A1 |
Number | Date | Country |
---|---|---|
2887322 | Feb 2020 | EP |
2018235371 | Dec 2018 | WO |
2020226832 | Nov 2020 | WO |
2022055822 | Mar 2022 | WO |
Entry |
---|
Broitman A., “Learn and Do More with Lens in Google Images,” Oct. 25, 2018, Retrieved from the Internet: URL: https://www.blog.google/products/search/learn-and-do-more-lens-google-images/ , 4 pages. |
International Search Report and Written Opinion for International Application No. PCT/US2022/032288, dated Sep. 16, 2022, 11 pages. |
Melnick K., “Google Rolls out New AR Features for Its Lens APP,” May 28, 2019, Retrieved from the Internet: URL: https://vrscout.com/news/new-ar-features-google-lens/ , 3 pages. |
“Unity Gets Toolkit for Common AR/VR Interactions” [accessed Apr. 7, 2020]. Unity XR Interaction Toolkit Preview Dec. 19, 2019. |
Hincapie-Ramos, J.D. et al. “GyroWand: IMU-based raycasting for augmented reality head-mounted displays.” Proceedings of the 3rd ACM Symposium on Spatial User Interaction, Aug. 2015, pp. 89-98. |
International Search Report and Written Opinion, PCT Patent Application PCT/US2020/051763, dated Feb. 3, 2021, 11 pages. |
Mayer, S. et al. “The effect of offset correction and cursor on mid-air pointing in real and virtual environments.” Proceedings of the 2018 CHI Conference on Human Factors in Computing Systems, Apr. 2018, pp. 1-13. |
Olwal, A. et al. “The Flexible Pointer: An Interaction Technique for Selection in Augmented and Virtual Reality,” Proceedings of ACM Symposium on User Interface Software and Technology (UIST), pp. 81-82, publication date Nov. 5, 2003. |
Renner, P. et al. “Ray Casting”. [accessed Apr. 7, 2020], 2 pages. |
Schweigert, R. et al. “EyePointing: A gaze-based selection technique.” Proceedings of Mensch and Computer, Sep. 8, 2019, pp. 719-723. |
Invitation to Pay Additional Fees for International Application No. PCT/US2021/044098, dated Nov. 3, 2021, 15 pages. |
Game Ui Examples: “[VR] Half Life Alyx Menu/Settings/UI,” Feb. 27, 2021, 2 pages, retrieved from the Internet URL: https://www.youtube.com/watch?v=- iNR-J2whJQ&t=7s. |
International Search Report and Written Opinion for International Application No. PCT/US2023/033526, dated Dec. 1, 2023, 13 pages. |
Number | Date | Country | |
---|---|---|---|
20230011774 A1 | Jan 2023 | US |