This application claims the benefit of European Patent Application No. 22315320.6, filed Dec. 8, 2022, entitled “MULTI-PLATFORM VIRTUAL RETAIL STORE ENGINE”; the entire contents of which are incorporated herein by reference.
Internet browsing began with the original hypertext markup language (HTML). HTML has iterated to its fifth version and continues to evolve. Elegant web browsing experiences are now commonplace, even on wireless mobile phones with small screens. With the correct equipment, augmented reality and virtual reality environments (commonly referred to as the metaverse), are on the cusp of providing even richer experiences than offered by traditional browsing. Standard Internet speeds now offer commonplace real time communication amongst large groups of people. At the same time, Internet content is increasing in volume and changing rapidly. Enormous unresolved challenges are present in permitting small and medium sized businesses, especially those in particular sectors, the opportunity to efficiently supplement or transition their business into virtual reality and augmented reality environments.
An aspect of the present specification provides an adaptation engine comprising:
The processor can be further configured to access the criteria for providing the metaverse locations in the metaverse space by:
The processor can be further configured to determine incompatibilities between objects of the model and the criteria by:
The processor can be further configured to implement the one or more substitution algorithms to replace the given object with the corresponding object generated according to the criteria by one or more of:
The criteria can further comprise a fallback criteria for replacing the given object with the corresponding object.
The processor can be further configured to define certain elements in the model as being incapable of substitution when the model is being initially stored.
The processor can be further configured to provide a plurality of substitutions of the model to mimic dynamic content one a platform server having criteria limited to static content.
The processor can be further configured to provide immersive content representing travel services from a plurality of travel service provider content engines.
The processor can be further configured to connect to a second adaptation for providing immersive content to the metaverse human-machine interface.
Another aspect of the specification provides a method to communicate with a platform server configured to provide a metaverse space comprising:
The method can further comprise accessing the criteria for providing the metaverse locations in the metaverse space by:
The method can further comprise
The method can further comprise implementing the one or more substitution algorithms to replace the given object with the corresponding object generated according to the criteria by one or more of:
The method can further comprise a fallback criteria for replacing the given object with the corresponding object.
The method can further comprise defining certain elements in the model as being incapable of substitution when the model is being initially stored.
The method can further comprise providing a plurality of substitutions of the model to mimic dynamic content one a platform server having criteria limited to static content.
The method can further comprise providing immersive content representing travel services from a plurality of travel service provider content engines.
The method can further comprise accessing connecting to a second adaptation for providing immersive content to the metaverse human-machine interface.
Another aspect of the present specification provides an adaptation engine comprising a network interface configured to communicate with a platform server. The platform server is configured to provide a session with a client device. The adaptation engine includes a processor having access to a memory for storing content for rendering over the session. The processor is configured to: receive a request for content to be delivered to the client device from the platform server; determine a platform server computing resource capability; determine a client device computing resource capability; define a session computing resource capability for the session based on the platform server computing resource capability and the client device computing resource capability; access, from the memory, essential content respective to the request; access, from the memory, additional content augmenting the essential content, based on the session computing resource capability; and, generate a response to the request based on the essential content and the additional content.
The platform computing resource capability can include one or more of an augmented reality environment, a virtual reality environment or a metaverse.
The request can be automatically generated by the platform within based on contextual demographic information of an account associated with the client device accessing other content hosted by the platform.
The client device capability can include augmented reality hardware or virtual reality hardware.
The processor can be further configured to select the essential content and any additional content by from aggregated content the combines a plurality of different content. The different content can be stored on different content engines accessible to the adaptation engine via a content aggregation engine.
The platform computing resource capability can be a website and the computing resource capability can be one of a laptop computer, a desktop computer or a mobile phone.
The request can include an electronic request for content relating to travel services directly from the client device. The travel services request can include any aspect of a travel experience, such as a seat selection on a transportation vehicle.
The request can include an electronic request for content relating retail product purchases, medical services, real estate services, and online retail purchases.
Another aspect of the specification provides a device comprising: a communication interface configured to communicate with a metaverse server configured to provide a given metaverse space; and a processor having access to a memory storing metaverse items for rendering in one or more metaverse spaces, the controller configured to:
The processor can be further configured to determine metaverse capability data for the given metaverse space by communicating with the metaverse server.
The processor can be further configured to one or more of filter and adapt at one or more of the metaverse items based on the metaverse capability data and the HMI data by: one or more of filtering and adapting one or more of the metaverse items to account for one or more of a disability, blindness, color blindness, or deafness of the given user as defined by the HMI data.
The processor can be further configured to one or more of filter and adapt at one or more of the metaverse items based on the metaverse capability data and the HMI data by: one or more of filtering and adapting one or more of the metaverse items to account for an age of the given user as defined by the HMI data.
The processor can be further configured to one or more of filter and adapt at one or more of the metaverse items based on the metaverse capability data and the HMI data by: one or more of filtering and adapting one or more of the metaverse items to account for a defined size of a metaverse location at which the metaverse items are to be located within the given metaverse space as defined by the metaverse capability data.
The processor can be further configured to one or more of filter and adapt at one or more of the metaverse items based on the metaverse capability data and the HMI data by: replacing first metaverse item with a second metaverse item.
The processor can be further configured to one or more of filter and adapt at one or more of the metaverse items based on the metaverse capability data and the HMI data by: ignoring a metaverse item such that the metaverse item is not provided in the given metaverse space.
The processor can be further configured to one or more of filter and adapt at one or more of the metaverse items based on the metaverse capability data and the HMI data by: converting a three-dimensional metaverse item to a two-dimensional metaverse item.
Methods, systems and devices and apparatus according to any combination or variant of the foregoing are contemplated. In summary, in particular, apparatus comprising means to implement each of the steps set out in the methods described above or in the accompanying claims are contemplated. Moreover, also contemplated is a computer program, computer program product or computer readable medium comprising instructions which, when executed by a computer, cause the computer to carry out the steps of any of the methods set out above or in any of the accompanying method claims.
In system 100, platforms 104 connect to a network 106. Any network topology is contemplated, such as, by way of non-limiting example, the Internet, one or more intranets, or combinations thereof. Network 106 interconnects platforms 104, with: a) at least one content engine 108; b) at least one content aggregation engine 112 that is coupled with a platform adaptation engine 116; and, c) a plurality of client devices 120. (In a variant, a single content engine 108 would obviate the need for content aggregation engine 112).
As will be explained in greater detail below, each content engine 108 can be based upon its own computing architecture and will periodically send content to aggregation engine 112 for access by one or more client devices 120 via one or more platforms 104. Content engines 108 can be based on any type of known or future Internet content. In a present illustrative, but non-limiting embodiment, content engines 108 are operated by travel actors within the travel industry, including, but not limited to, airlines, railway systems, car rental agencies, cruise line operators, hotels, restaurants, resorts, and spas.
Thusly, content aggregation engine 112 periodically receives data files including content that has been sent by content engines 108 via network 106. In the present example embodiment, content aggregation engine 112 can be operated by, or accessed by, for example, a travel booking engine. To elaborate, a travel booking engine that could operate content aggregation engine 112 could include well-known travel booking engines such as Expedia™, Travelocity™ or Hotels.com™. There are many other travel booking engines. Content engine 112 can thus be operated directly by such a travel booking engine, or can be hosted by a travel data aggregator, often referred to as a Global Distribution System (“GDS”), such as Amadeus™, Sabre™, Travelport™, Apollo™, Galileo™, Travelfusion™, or Duffel™ Aggregation engine 112 thus collects content from content engines 108 for generation on one or more platforms 104, such that content from engines 108 can be accessed by devices 120.
System 100 also includes adaptation engine 116 which normalizes content from engines 108 across platforms 104 and devices 120. Adaptation engine 116 will be discussed in greater detail below.
Client devices 120 can be any type of human machine interface (HMI) for interacting with platforms 104. For example, client devices 120 can include virtual reality gear, augmented reality gear or mixed reality gear, such as headsets, tracking headsets, holographic devices, hand controllers, full body sensors, haptic feedback, temperature feedback, smell feedback, treadmill or other foot tracking and feedback technology, and/or combinations of any of the foregoing. In addition, client devices 120 can include smart televisions, traditional laptop computers, desktop computers, mobile phones, tablet computers and any other device that can be used by consumers to receive content via one or more of the platforms 104 that complement the input and output hardware devices associated with a given client device 120. Such traditional client devices 120 can also have connected lights, lightstrips, speakers to provide a multi-media experience on such traditional client devices.
According to the specific example in
In this example, computing device 200 includes at least one input device 204. Input from device 204 is received at a processor 208 which in turn controls an output device 212. In the context of all the nodes of system 100, input device 204 can be a traditional keyboard and/or mouse may be connected to provide physical input. Likewise output device 212 can be a display or audio speakers. In variants, additional and/or other input devices 204 or output devices 212 are contemplated or may be omitted altogether as the context requires.
In the specific context of client devices 120, input devices may include physical or virtual keyboards, accelerometers, input buttons, pointing devices, treadmills, temperature sensors, cameras, microphones, global positioning systems (GPS), gyroscopes, olfactometers, velocity sensors, accelerometers, medical sensors (such as pulse rate, blood pressure, stress level, skin moisture level) or any other known or future contemplated input device associated with human-machine interfaces. In the context of client devices 120, output devices may include traditional displays, head-set stereoscope virtual reality displays, augmented or mixed reality displays, haptic feedback, heating or cooling apparatuses, smell generators, sound devices, surround sound systems, smart light bulbs, smart light strips, or any other known or future contemplated output devices associated with human-machine interfaces. Client devices 120 are configured to interact with one or more platforms 104 via network 106 according to the hardware capabilities of a given client device and the corresponding interactive communication capabilities of a given platform 104. (Such hardware, software and interactive communication capabilities may be generically referred to herein as computing resource capabilities.)
Processor 208 may be implemented as a plurality of processors or one or more multi-core processors. The processor 208 may be configured to execute different programing instructions responsive to the input received via the one or more input devices 204 and to control one or more output devices 212 to generate output on those devices.
To fulfill its programming functions, the processor 208 is configured to communicate with one or more memory units, including non-volatile memory 216 and volatile memory 220. Non-volatile memory 216 can be based on any persistent memory technology, such as an Erasable Electronic Programmable Read Only Memory (“EEPROM”), flash memory, solid-state hard disk (SSD), other type of hard-disk, or combinations of them. Non-volatile memory 216 may also be described as a non-transitory computer readable media. Also, more than one type of non-volatile memory 216 may be provided.
Volatile memory 220 is based on any random access memory (RAM) technology. For example, volatile memory 220 can be based on a Double Data Rate (DDR) Synchronous Dynamic Random-Access Memory (SDRAM). Other types of volatile memory 220 are contemplated.
Processor 208 also connects to network 106 via a network interface 232 which includes a buffer, a modulator/demodulator or MODEM, over the various links and/or internet that connects the server equipment to other server equipment. Depending on the node in system 100, network interface 232 can also be used to connect a given node to another computing device that has an input and output device, thereby obviating the need for input device 204 and/or output device 212 altogether.
Programming instructions in the form of applications 224 are typically maintained, persistently, in non-volatile memory 216 and used by the processor 208 which reads from and writes to volatile memory 220 during the execution of applications 224. One or more tables or databases 228 can also be maintained in non-volatile memory 216 for use by applications 224.
Block 404 comprises receiving a content request. The content request can originate from a given client device 120 during a session within a session between that client device 120 and a given platform 104. (Alternatively, or in addition, the content request can originate from a given platform 104 based on an inference made by platform 104 of an experience that is to be tailored to a given client device 120.) The establishment of the session is governed by the architecture of the platform 104, according to the credential management and authentication protocols employed by the platform 104, and according to the account associated with a user of the relevant client device 120. As will be discussed in greater detail below, the specific nature of the content request at block 404 thus depends on the context of the session, but in general terms includes sending the request to content aggregation engine 112 from the platform 104.
The nature of the content request is not particularly limited, but with a few illustrative examples a person of skill in the art will come to appreciate the scope of the present embodiment. As noted earlier, system 100 can have broad application to the travel industry, and thus session 504 can include the opportunity, within a virtual reality environment, to browse, interact with, select and, if desired, provide the technology infrastructure to purchase various travel services.
According to
At this point the overall context of system 100 should be re-emphasized. In a travel industry context, content aggregation engine 112 can access content from a number of travel industry actors who each host content engines 108. Thus the information regarding the specific flight number that utilizes aircraft 612 and the associated seat map from that flight can be sent from the content engine 108 that manages the flight schedules for that specific flight and aircraft 612. In this manner the travel agent avatar 608 within the metaverse platform 104-2 has access, via content aggregation, to a plurality of travel assets hosted by different content engines 108 as aggregated by content engine 112. Thus the specific seat selection exercise represented within session 504-1 is merely one of many different types of hospitality or travel selection exercises that can be effected within session 504, such as, by way of non-limiting examples, airline ticket purchases, hotel room selection, car rental selection, taxi bookings, excursion bookings, concerts, indoor or outdoor events and festivals, dining receptions, exhibitions, and/or any other travel experience that can occur from the beginning of travel to its conclusion. The client avatar 606 can thus be presented with a complete simulation of the complete travel experience, with browsing and selection options offered throughout the entire simulation. The seat selection request 508 and the seat selection exercise in session 504-1 is thus but one non-limiting illustrative example of the travel purchase interactions contemplated by the present specification. Where system 100 is applied to other industries beyond travel, even more possible types of interactions are possible.
Continuing now with the example of the seat selection, once request 508 (from block 404) is received at content aggregation engine 112, then method 400 advances to block 408.
Block 408 comprises determining the platform capability. In system 100, block 408 is performed by adaption engine 116 working in concert with aggregation engine 112. Adaption engine 116 is thus configured to maintain dataset 116-228-1 which includes all of the capabilities of the various platforms 104. Alternatively, such capabilities may be sent dynamically along with request 508, or a hybrid approach may be employed where some capabilities are stored locally in dataset 116-228-1 while others are sent along with the request 508. Overall, block 408 can be based on an application programming interface (API) or similar functionality provided by the operator of each platform 104. Thus, before a response to the request 508 is made, adaptation engine 116 is configured to assess what forms a response may take that will complement the functionality of the platform 104 that issued the request 508 at block 404.
Continuing with the present example, at block 408, based on the fact that request 508 came from metaverse platform 104-2, the capability determination will note that platform 104-2 is a metaverse environment with a given set of parameters for generating virtual objects and having interactions with those objects according to the specific technological architecture of metaverse platform 104-2. As can be noted from scene 504-1, the metaverse environment is rich and contemplates a virtual reality environment.
Block 412 comprises determining the client device capability. More specifically, block 412 comprises determining the capability of the client device that generated the request 508 at block 404. In system 100, block 408 is performed by adaption engine 116 working in concert with aggregation engine 112. Adaption engine 116 can thus be configured to maintain a second dataset 116-228-2 which includes all of the capabilities of the various client devices 120. Alternatively, such capabilities may be dynamically sent along with request 508, or a hybrid approach is possible where some capabilities are sent with the request 508 and others are maintained within dataset 116-228-2. Indeed, like block 408, block 412 can also be effected as part of any API associated with the relevant platform 104. Such client device capabilities are determined based on the specific input and output device hardware configurations of the human-machine interface associated with the requesting client device 120. In the example of
Block 416 comprises accessing the requested content. In the specific example being discussed in relation to a seat map for aircraft 612, it is contemplated thus that content aggregation engine 112 will access content with a respective content engine 108, such as a content engine 108 operated by the airline that owns aircraft 612 and is offering the flight of interest to avatar 606.
Block 420 comprises selecting essential content that is responsive to the request from block 404. (Selecting can be effected in different ways, such as through an inclusion process by choosing from a plurality of stored content, or by an exclusion process by filtering out certain content from the plurality of stored content.) Such essential content is the minimum set of content required to fulfill the transaction (or other interaction) occurring in session 504-1; namely, in the present non limiting example, the selection of a seat on aircraft 612. Thus, the minimum information would include what seats remain available on the aircraft in association the pricing of those seats.
Block 424 comprises determining if there is capability for providing enriched content beyond what was filtered at block 420. In the context of the present example, indeed the rich 3D virtual environment of metaverse platform 104-2 combined with the extensive set of virtual reality input and output devices on client machine 120-4 would lead to a “yes” determination at block 424.
Block 428 comprises selecting additional content. (As noted above, selecting can be effected in different ways, such as through an inclusion process by choosing from a plurality of stored content, or by an exclusion process by filtering out certain content from the plurality of stored content.) The additional selected content is responsive to the request from block 404 and matches any enhanced hardware and software capabilities of the platform 104 and the corresponding client device 104 that is carrying the respective session 504. To clarify, such enhanced hardware and software capabilities refer to any capabilities that go beyond the ability to generate the essential content from block 420. Continuing with the present example, block 428 would take the full set of rich content from block 416 to generate a very rich seat map of all available seats on aircraft 612. As will be explained further below, the degree of “richness” corresponds directly to the hardware of client machine 120 and the platform 104 that generated the request.
Block 432 comprises generating a response to the request from block 404 according to the selections applied at block 420 and block 428. Where different platforms 104 can accommodate the same content, but have different capabilities for presenting that content, then the generation of the response can include adaptations to the selected content respective to the specific capabilities of the target platform 104. To help elaborate, and referring again to our specific example, in association with a fully capable metaverse platform 104-2 and client device 120-4, the full seat map could include a nearly complete rendering of the entirety of the interior cabin of aircraft 612, having very rich textures and visual appearance of seat 628, such as the view of seat 628 in
A person of skill in the art can now appreciate just where the virtual reality experience can extend to what additional filters may be applied at block 428, as such that in a fully capable client device 120-4 such as client device 120-4, the user of client device 120-4 could virtually “walk” through the cabin via feedback and input from the treadmill input/output device on client device 120-4, providing visual feedback of the entire walk through the aircraft. Occupied seats would show avatars inside them, while available seats would be empty for the avatar 606 to simulate virtually sitting various empty seats. With the full set of haptic feedback provided to hands, torso and feet, and a mapping of the physical size of the user, the user of client device 120-4 could control virtual reclining and test out the widths and foot room of the various seats with appropriate feedback and control signals being sent to the input and output device hardware associated with that client device 120-4. The inventors fully appreciate that the limits of this example correspond to the physical limits of the virtual reality input and output devices associated with client device 120-4, but also note that the rapid development of such rigs suggests a continuum of greater offerings and such offerings are likely to extend over the coming years.
A person of skill in the art can now appreciate that system 100 also remains compatible with other client devices 120 and platforms 104. Notably, where a platform 104 or a client device 120 does not have full metaverse capability then system 100 and adaption engine 116 remains flexible to accommodate different technologies. For example, where a seat map request was generated by a mere virtual reality headset 120-1, the seat map response at block 432 would be limited to a virtual view of the inside of the aircraft, but the capability to “walk” through the aircraft would be limited to the mouse or keyboard attached to the computer that connects to the headset 120-1. There would also be curtailed or no opportunity to virtually “sit” in the seat and test the reclining and foot room. As a second example, where the seat map request was generated by laptop computer client machine 120-5, and the platform was travel website platform 104-n, then the filters applied at block 428 would be limited to generating a seat map that is consistent with currently known browser-based seat mapping and seat selection technology, in the form of a two dimensional array of boxes roughly laid out in grid, such as the example seat map 800 in
Referring now to
According to system 100a, content engines 117a are hosted by different retail entities that are establishing virtual (or augmented) reality retail stores within platforms 104a. In general, such virtual or augmented reality stores provide a consistent shopping experience across a plurality of platforms 104a through the entire sales process. (Such a sales process is sometimes referred to by the person of skill in the art as a sales funnel or sales touch points, going from, for example, marketing, lead generation, proposals, sales, conversions, payment processing, closed-won, closed-lost, retention etc. The sales process can be defined differently according to the context of what product or services is being sold and whether the process is business-to-business or business-to-consumer.) The shopping experience is thus typically adapted to the overall narrative of the platform 104a.
For example, the sales process can be reproduced in a medieval fantasy metaverse platform, replete with metaverse objects such as unicorns, satyrs, elves and magicians. In such medieval fantasy metaverse, the shopping experience is tailored to the medieval fantasy narrative, and thus while the shopping experience remains the same as a real-world retail store, the appearance of objects that fulfill the shopping experience would be consistent with the medieval fantasy. As another example, the sales process can be reproduced in a space opera replete with metaverse objects such as starships, laser cannons, multiple planets, strange aliens and intergalactic battles. Thus in a space opera metaverse, the shopping experience can be tailored the space operate narrative, and so the appearance of objects that fulfill the shopping experience would be consistent with the space opera.
In other examples, such virtual stores are configured to mimic real-world retail stores that are configured electronically according to flexible architectural designs that allow a metaverse environment to represent a real-world retail environment. Without limiting the generality of the foregoing, certain specific examples of real-world mimicry of retail stores will now be discussed in relation to platforms 104a. The virtual stores can be generated within platforms 104a according to any real or imagined environment where retail-stores may exist, such as a cluster of retail stores or a row of retail stores along a virtual commercial avenue or street, in an virtual outlet mall, or in virtual airport, train station, cruise-ship or shopping mall. One particular example application of such retail entities that will be discussed herein relate to travel agencies that, in the real-world, attract foot traffic and offer the opportunity for travelers and travel agents to interact, review travel itinerary options, and to complete the purchase of travel assets.
Notably, content engines 109a in system 100a are hosted by retail entities. Each content engine 109a maintains a model of a virtual retail store that is to be rendered across one or more platforms 104a. Note that a single content engine 109a is contemplated, but a presently preferred embodiment contemplates a plurality of content engines 109a, with each content engine 109a representing a single travel agency intending to provide substantially the same virtual retail presence across a plurality of platforms 104a. Thus, adaptation engine 117a is configured to receive models from each content engine 109a, determine criteria for rendering on each platform 104a, and to dynamically adjust the models to provide, as much as a possible, a substantially normalized virtual retail environment across all platforms 104a. In other words, as a given client device 120a accesses different platforms 104a, substantially the same virtual retail environment and experience will be perceived, for each content engine 109a, thereby increasing potential for retail transaction exposures to the hosts of content engines 109a.
Again, as a specific example, travel agencies, as a type of retail entity, will be discussed herein for illustrative purposes, but it is to be understood that the teachings herein can be applied to other types of retail entities.
Block 1004 comprises receiving model parameters. In the example of system 100a, the model parameters are received at adaptation engine 117a from one of the content engines 109a. The initial parameters can be initially established via an administrator at the content engine 109a controlling input devices such as a mouse and keyboard and viewing a monitor and accessing other input/output devices in order to create a set of model parameters for delivery to adaptation engine 117a. According to the present example, the model parameters represent a virtual reality travel agency for rendering in a metaverse on one or more of platforms 104a.
Logo model object 1104-2 can be configured to display the trademark or service mark of the entity that operates content engine 109a. The trademark can be the same as any real-world trademark registrations, thereby creating cross brand recognition across the virtual world of platforms 104a and the real-world.
Note some objects of the model parameters received at block 1104 may be flagged (such as through a “tick box”) as “substitutable” across platforms 104a or “not substitutable” across platforms 104a. It is contemplated that, for example, logo model object 1104-2 may be designated as “not substitutable” due to the desire to maintain the appearance of trademark branding consistency across platforms 104a, each of having its own criteria engine consistent the individual capability of each platform 104a. (These are the same sorts of capabilities previously discussed in relation to block 408 of method 400). Accordingly, as will be discussed in greater detail below, logo model object 1104-2 would be constrained to a format or characteristics of input from content engine 109a that complies with the rendering criteria of platforms 104a.
Thus, formatting or other characteristics such as size, color, skin, noises, sounds, sizes, styles, fonts, resolutions, animations, lighting, shading, refresh rates and associated audio clips may all be constrained to a set of parameters that are known to comply with capabilities across all platforms 104a. In the context of styles and resolutions, it can be noted that certain platforms, such as Minecraft, have the criteria that objects a very low resolution and are “blocky” by design, whereas other platforms have very high resolutions and may be curved. Thus the model parameters, when inputted, adapted or substituted, consider these criteria.
Referring again to
Static storefront object 1104-4 can represent a physical sign such as “store hours” or “address” that, in general, mimics the equivalent of such information of a real-world retail store.
Music object 1104-5 includes a source of a feed of music, either looped or streams, or other audio information such as recorded voice messages, that can be played at the exterior of the model template 1100-1 in order to attract avatars of virtual passers-by, such avatars being controlled via devices 120a as previously discussed in relation to system 100.
Door animation object 1104-6 allows the configuration of the whether the doors are sliding doors or swing doors, and whether there is a physical actuator or whether a presence detection is sufficient to open the door. Audible sounds can accompany the opening or closing of the doors. A virtual doorbell may also be provided. Other door animations will now occur to those skilled in the art.
A person of skill in the art will now begin to appreciate how system 100 and system 100a can be combined, as the interaction in
Referring again to
Returning to
Thus, if there are no incompatibilities at block 1012, a “no” determination is made and method 1000 advances to block 1020. However, if there are incompatibilities at block 1012, then a “yes” determination is made and method 1000 advances to block 1016. According to the previous example, a “no” determination may be made for object 1104-6 at block 1012 for platform 104-1 and platform 104a-2, and so for platform 104a-1 and platform 104a-2, method 1000 advances to block 1020 where whatever API criteria for the respective platform 104a are applied. Again, according to the previous example, a “yes” determination may be made for object 1104-6 for platform 104-3 at block 1012 and method 1000 advances to block 1016 where a substitution parameter is applied. For example, assume the platform 104a-3 can only accommodate swinging doors with no accompanying audio, then at block 1016 the swinging door parameter for object 1104-6 is substituted with a swinging door. Method 1000 then advances to block 1020 and swinging door parameter criteria is applied to the model is applied, based on the API of platform 104a-3.
Again this is but one example and a plurality of criteria based on the APIs for each platform 104a will be canvassed based on the capabilities of the respective platforms 104a and dealt with accordingly at block 1012 and, if necessary, at block 1016. Note from our previous discussion, however, that at block 1004 a given model parameter may be indicated as not being capable of substitution, in which case for that parameter a “No” determination will always be made at block 1012, with the tradeoff that the parameters provided at block 1004 may be constrained to ensure compliance with the capabilities and APIs of all platforms 104a.
Block 1024 comprises generating the model platform. In system 100a block 1024 is performed by adaptation engine 117a which renders the model parameters and uses the API of the respective platform 104a.
Block 1028 comprises sending the platform models, as generated at block 1024 to each platform 104a for rendering.
Block 1032 considers whether all target platforms have been addressed. If not, method 1000 returns to block 1008 until all such platforms 104a have been addressed.
The types of substitutions at block 1016 are not particularly limited. Different types of substitution algorithms are contemplated. For example, certain platforms 104a may accommodate dynamic content for dynamic storefront object 1104-3 of
The types of substitutions at block 1016 can, in addition or in lieu of the foregoing, comprise one or more of: changing an object to an image or video of the object in the corresponding object; changing a color of the given object to a respective color allowed by the criteria; changing the color of the given object to the respective color allowed by the criteria, the respective color allowed by the criteria selected to reduce a difference between the color and the respective color; changing three-dimensional content of the given object to two-dimensional content of the corresponding object; changing at least one of shape and configuration of the object; changing dynamic content of the given object to static content of the corresponding object; changing a rounded or curved object for a blocked object (such as in Minecraft which is built in blocks); changing a customized “skin” (such as an uploaded floor or wall pattern provided at block 1004) for a predefined “skin” (such as one of predefined floor or wall patterns that are constrained to a given metaverse platform 104a).
The substitution algorithms at block 1016 may also be developed using machine learning, neural network or artificial intelligence algorithms. Continuing with the example of sliding door object 1104-6, a machine learning algorithm can monitor a human making such substitutions to satisfy the criteria of the API of platform 104a-3. After a sufficient number of substitutions, the machine learning algorithm in adaptation server 117a can make substitutions of the slide door object 1104-6-S for platform 104a-3 while learning to retain the sliding door object 1104-6 for platform 104a-1 and platform 104a-2. As another example, a customized “skin” that is uploaded at block 1004 may be substituted with a predefined “skin” at block 1016, and thus a machine learning algorithm can monitor a number of manual substitutions of customized “skins” at block 1016 that lead the machine learning algorithm to automatically, in the future, choose certain predefined “skins” as substitutes for a given uploaded customized “skin”. A person of skill in the art will now appreciate how this use of machine learning can be massively scaled for developing other substitutions for other objects, as needed, at block 1016. Thus, in addition to, or in lieu of, a table such as matrix 1500, such machine learning algorithms can be implanted. Furthermore, matrix 1500, itself, can be built entirely or in part using machine learning.
A person of skill in the art will now appreciate that the components of model template 1100-1 are illustrative examples only and that variations to the foregoing are contemplated.
A person skilled in the art will now appreciate that the teachings herein can improve the technological efficiency and computational and communication resource utilization across system 100. As the range of available hardware input and output devices for client devices expand, as metaverse and multimedia platform environments create additional contexts for the delivery of travel agency services. The richness of experience combined with the convenience for users creates the opportunity for greater expectation management as to what travel services are being acquired. At the same time the sheer diversity of client devices and platforms creates a pull in the opposite direction, as there is a need to ensure that travel asset inventories (such as which airline seats, hotel rooms, restaurant booking times, have been sold and which remain open) are constantly updated in real time so that accurate inventory choices are being generated at the time a session for selection of such inventory is occurring between any given client machine and any given platform. The filtering of unneeded content for less capable client machines also reduces network resource stress on network 106, by only delivering the content that can be utilized by the given client device 120. Furthermore, individual retailers such as travel agencies can develop a consistent presence across several platforms using a single interface via a single adaptation engine, thereby reducing the multiplicity of efforts required for a single retail travel agency to build and update separate presences across several different platforms. The result is efficient use of computing resources, including processing, memory and communication resources, across system 100 and its variants, while providing as rich an experience as possible according to the resource capabilities of the client devices 120 and the platforms 104.
In summary, the present specification provides a multiplatform virtual retail store engine. The specification can have particular application to client devices with augmented or virtual reality hardware that interact with different platforms with metaverse capabilities. Rich experiences are provided on client hardware while making efficient use of available processing, memory and communication resources. Embodiments discuss the provision of a single retail store model which is dynamically adapted for generation across the plurality of different platforms according to the different metaverse capabilities.
In view of the above it will now be apparent that variants are contemplated. For example, the foregoing has been discussed in relation to the travel industry, it will now be understood that the above-described embodiments can be modified to other industries. For example, an online e-commerce environment such as Amazon™ that becomes enhanced through virtual reality metaverse offerings can be enhanced using the teachings herein. Example additional industries include vehicle purchases from dealerships, medical services from medical clinics, and real estate services from real estate agencies.
It should be recognized that features and aspects of the various examples provided above can be combined into further examples that also fall within the scope of the present disclosure. In addition, the figures are not to scale and may have size and shape exaggerated for illustrative purposes.
Number | Date | Country | Kind |
---|---|---|---|
22315320.6 | Dec 2022 | EP | regional |