[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

CN113785555A - Providing communication services using a set of I/O user devices - Google Patents

Providing communication services using a set of I/O user devices Download PDF

Info

Publication number
CN113785555A
CN113785555A CN201980096046.9A CN201980096046A CN113785555A CN 113785555 A CN113785555 A CN 113785555A CN 201980096046 A CN201980096046 A CN 201980096046A CN 113785555 A CN113785555 A CN 113785555A
Authority
CN
China
Prior art keywords
user
terminal emulation
capabilities
rule
user terminal
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201980096046.9A
Other languages
Chinese (zh)
Other versions
CN113785555B (en
Inventor
汉斯·汉努
科杰尔·拉森
斯蒂凡·万斯特德
托米·阿格伦
彼得·奥克韦斯特
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Telefonaktiebolaget LM Ericsson AB
Original Assignee
Telefonaktiebolaget LM Ericsson AB
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Telefonaktiebolaget LM Ericsson AB filed Critical Telefonaktiebolaget LM Ericsson AB
Publication of CN113785555A publication Critical patent/CN113785555A/en
Application granted granted Critical
Publication of CN113785555B publication Critical patent/CN113785555B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1073Registration or de-registration
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • G06F9/452Remote windowing, e.g. X-Window System, desktop virtualisation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/10Architectures or entities
    • H04L65/1059End-user terminal functionalities specially adapted for real-time communication
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/10Architectures or entities
    • H04L65/1063Application servers providing network services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L65/00Network arrangements, protocols or services for supporting real-time applications in data packet communication
    • H04L65/1066Session management
    • H04L65/1069Session establishment or de-establishment
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/08Protocols specially adapted for terminal emulation, e.g. Telnet
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/52Network services specially adapted for the location of the user terminal
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/56Provisioning of proxy services
    • H04L67/59Providing operational support to end devices by off-loading in the network or by emulation, e.g. when they are unavailable
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/42229Personal communication services, i.e. services related to one subscriber independent of his terminal and/or location
    • H04M3/42263Personal communication services, i.e. services related to one subscriber independent of his terminal and/or location where the same subscriber uses different terminals, i.e. nomadism
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/21Server components or server architectures
    • H04N21/222Secondary servers, e.g. proxy server, cable television Head-end
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/233Processing of audio elementary streams
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/23Processing of content or additional data; Elementary server operations; Server middleware
    • H04N21/234Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs
    • H04N21/2343Processing of video elementary streams, e.g. splicing of video streams or manipulating encoded video stream scene graphs involving reformatting operations of video signals for distribution or compliance with end-user requests or end-user device requirements
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/20Servers specifically adapted for the distribution of content, e.g. VOD servers; Operations thereof
    • H04N21/25Management operations performed by the server for facilitating the content distribution or administrating data related to end-users or client devices, e.g. end-user or client device authentication, learning user preferences for recommending movies
    • H04N21/258Client or end-user data management, e.g. managing client capabilities, user preferences or demographics, processing of multiple end-users preferences to derive collaborative data
    • H04N21/25808Management of client data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/16Communication-related supplementary services, e.g. call-transfer or call-hold
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/24Negotiation of communication capabilities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2203/00Aspects of automatic or semi-automatic exchanges
    • H04M2203/20Aspects of automatic or semi-automatic exchanges related to features of supplementary services
    • H04M2203/2094Proximity
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M2203/00Aspects of automatic or semi-automatic exchanges
    • H04M2203/25Aspects of automatic or semi-automatic exchanges related to user interface aspects of the telephonic communication service
    • H04M2203/255Aspects of automatic or semi-automatic exchanges related to user interface aspects of the telephonic communication service comprising a personalized user interface
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/02Services making use of location information
    • H04W4/023Services making use of location information using mutual or relative location information between multiple location based services [LBS] targets or of distance thresholds
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/80Services using short range communication, e.g. near-field communication [NFC], radio-frequency identification [RFID] or low energy communication

Landscapes

  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Multimedia (AREA)
  • Software Systems (AREA)
  • Business, Economics & Management (AREA)
  • General Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Graphics (AREA)
  • Telephonic Communication Services (AREA)
  • Communication Control (AREA)
  • Computer And Data Communications (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

A user terminal emulation server maintains a database identifying network addresses, UI capabilities, and communication protocols of I/O user devices. A communication session is established between a user terminal emulation application, a network entity, and an I/O user device located in proximity to a user and providing a combined I/O user interface. A delay profile is determined between an application and an I/O user device. A downlink stream from a network entity is split into a plurality of downlink stream components allocated to I/O user equipment. For each downlink stream component, the server formats the component for transmission to the assigned I/O user device, initiates transmission of the formatted downlink stream component to the assigned I/O user device, and controls timing of when the formatted downlink stream component is transmitted to the assigned I/O user device based on a delay profile associated with the assigned I/O user device.

Description

Providing communication services using a set of I/O user devices
Technical Field
The present disclosure relates to a user terminal emulation server for providing communication services using a set of input and/or output (I/O) user devices, a method for providing communication services using a set of I/O user devices by a user terminal emulation server, and a computer program product for providing communication services using a set of I/O user devices.
Background
The search for providing users with increasingly advanced communication and other operational features within the constraints of portable handheld form factors has driven the user terminal market. As designers seek to integrate a greater variety of user interfaces and advanced operating features into portable handheld form factors, the development requirements for user terminals have become more complex. The increase in operating characteristics requires higher integration and faster processing circuits with greater circuit density, which becomes more difficult under cost and power consumption constraints.
This ubiquitous, feature-rich approach to user terminal development does not meet the myriad of different needs that consumers have in seeking solutions for the rapidly expanding variety of communication services. Furthermore, the desire of today's society to maintain connectivity at all times forces users to be vigilantly kept within reach of their user terminals or otherwise risk not being able to receive or initiate communication services in a timely manner.
Disclosure of Invention
Various embodiments disclosed herein relate to providing a centralized server-based method for emulating a user terminal using a set of networked input and/or output (I/O) user devices determined to be located near a future location of the user and having User Interface (UI) capabilities combinable to enable the user to receive and/or initiate communication services with a network entity. While the user is in progress, a user terminal emulation server (also referred to as a "server" for brevity) is operable to identify a set of remote I/O user devices that satisfy future proximity rules by being located near a future location of the user and also satisfy combined capability rules that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide communication services. The user terminal emulation server can then provide communication services between the user and the network entity when the user arrives at a future location.
In one embodiment, a user terminal emulation server for providing communication services using a set of I/O user devices performs operations including maintaining a database identifying network addresses of the I/O user devices, UI capabilities of the I/O user devices, and locations of the I/O user devices based on content of received messages. The user terminal emulation server registers a network address of a user terminal emulation application and an identity of a user to a network entity providing a communication service, wherein the user terminal emulation application is executed by the server. The user terminal emulation server receives a communication request from a network entity for establishing a communication service with a user. In response to the communication request, the user terminal emulation server determines whether a set of local I/O user devices of the I/O user devices identified by the database satisfies the current proximity rule by being located near a current location of the user and satisfies a combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities of the set of local I/O user devices identified by the database and based on the content of the communication request. When it is determined that no set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, the user terminal emulation server also determines whether a set of remote I/O user devices of the I/O user devices identified by the database satisfies the future proximity rule by being located near a future location of the user and satisfies the combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities of the set of remote I/O user devices identified by the database and based on the content of the communication request.
In some further embodiments, the user terminal emulation server responsively provides communication sessions between the user terminal emulation application and the set of remote I/O user devices and between the user terminal emulation application and the network entity when the set of remote I/O user devices satisfies the future proximity rule and satisfies the combined capabilities rule. The user terminal emulation server then routes communication traffic received from the at least one I/O user device in the remote set to the network entity for communication services. For each data type received as communication traffic from the network entity, the user terminal emulation server selects one of the I/O user devices from the set of remote I/O user devices based on a match of characteristics of the data type to UI capabilities of the selected one of the I/O user devices identified by the database, and then routes data of the data type to a network address of the selected one of the I/O user devices.
Some potential advantages of this and related embodiments include that users may receive and initiate communication services without the need for traditional ubiquitous, feature-rich user terminals. The user terminal emulation server can adaptively combine the available UI capabilities of I/O user devices located in the vicinity of the user to enable the provision of user interfacing with communication services. As described below, the myriad types of I/O user devices that can be used with embodiments herein are becoming nearly ubiquitous as the internet of things (IoT) revolution. The user terminal emulation server can dynamically respond to incoming communication requests directed to or outgoing communication requests initiated by the user by operatively communicating with available I/O user devices that may be located near the user or identified at a future planned or suggested location of the user to form a combined user interface through which a user terminal emulation application executed by the server will provide user terminal functionality for the communication service. This server-based approach may provide low-cost, adaptable communication services to users.
Thus, users have reduced or eliminated the need to carry expensive and ubiquitous user terminals (e.g., smart phones) that include all of the necessary UI capabilities (e.g., display devices, keyboards, speakers, etc.). Alternatively, the user may carry a hardware device operable to identify the user through a wireless communication interface to one or more I/O user devices. As the features and capabilities forming the user terminal are not limited to the field of mobile phone manufacturers, the various embodiments disclosed herein may break through the traditional handset-centric mobile communications industry.
Other user terminal emulation servers, methods for a user terminal emulation server, and computer program products for use with a user terminal emulation server according to embodiments of the present subject matter will be or become apparent to one with skill in the art upon review of the following drawings and detailed description. It is intended that all such additional user terminal emulation servers, methods, and computer program products be included within this description, be within the scope of the present subject matter, and be protected by the accompanying claims. Further, it is intended that all embodiments disclosed herein may be implemented separately or combined in any way and/or combination.
Drawings
Aspects of the present disclosure are illustrated by way of example and not limitation in the figures. In the drawings:
FIG. 1 illustrates a system having a user terminal emulation server operably integrated with a set of I/O user devices located in proximity to a user to logically form a virtualized user terminal to provide communication services in accordance with some embodiments of the present disclosure;
FIG. 2 is a block diagram illustrating a user terminal emulation server in communication with various elements of a cellular system to provide communication services in accordance with some embodiments of the present disclosure;
FIG. 3 is a block diagram illustrating a user terminal emulation server communicating with various elements of a cellular system in different ways to provide communication services in accordance with some other embodiments of the present disclosure;
4-6 are combined flow diagrams of operations and related data flows between a user tag (UserTag), an I/O user device, and a user terminal emulation server according to some embodiments of the present disclosure;
FIGS. 7 and 8 are flowcharts of operations that may be performed by a user terminal emulation server to provide communication services over a set of I/O user devices, according to some embodiments of the present disclosure;
FIG. 9 is a flowchart of operations performed by a user tag, an I/O user device, and a user terminal emulation server to establish a communication service initiated by a network entity to connect to a user, and also illustrating the relevant data flow between these elements, in accordance with some embodiments of the present disclosure;
10-12 are flowcharts of operations that may be performed by a user terminal emulation server to provide communication services over a set of I/O user devices in accordance with some embodiments of the present disclosure;
FIG. 13 is a block diagram of hardware circuit components of an I/O user device configured to operate in accordance with some embodiments; and
figure 14 is a block diagram of hardware circuit components of a user terminal emulation server configured to operate in accordance with some embodiments of the present disclosure.
Detailed Description
The inventive concept will now be described more fully hereinafter with reference to the accompanying drawings, in which examples of embodiments of the inventive concept are shown. The inventive concept may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of various inventive concepts to those skilled in the art. It should also be noted that the embodiments are not mutually exclusive. A component from one embodiment may be assumed by default to be present or used in another embodiment.
Various embodiments disclosed herein relate to improvements in the operation of a centralized server-based method for emulating a user terminal using a set of networked input and/or output (I/O) user devices determined to be located near a user and having User Interface (UI) capabilities that can be combined to provide a combined I/O user interface for interfacing the user with a user terminal emulation application of the server to perform communication services.
Some potential advantages of the various embodiments disclosed herein include that users may receive and initiate communication services without the need for traditional ubiquitous, feature-rich user terminals. The user terminal emulation server can adaptively combine the available UI capabilities of I/O user devices located in the vicinity of the user to enable the provision of user interfacing with communication services. The user terminal emulation server can dynamically respond to incoming communication requests directed to or outgoing communication requests initiated by the user by operatively communicating with available I/O user devices that may be located near the user or identified at a future planned or suggested location of the user to form a combined user interface through which a user terminal emulation application executed by the server will provide user terminal functionality for the communication service. This server-based approach may provide low-cost, adaptable communication services to users.
The dynamic allocation of I/O user device capabilities enables efficient and flexible use of any type of I/O user device whenever the I/O user device is located near the user's current location and/or near a future planned or suggested location of the user. The term "I/O user device" may include, but is not limited to, cellular phones, tablet computers, laptop computers, desktop computers, networked cameras (e.g., surveillance cameras), networked microphones, wireless (e.g., bluetooth, WiFi, optical communications, LiFi, and/or cellular) enabled speakers, wired networked speakers, networked televisions, conference phones, computer keyboards, networked monitors, touch screen computer interfaces, smart watches, connected household appliances, connected automobiles, biometric sensors, retinal scanners, accelerometers, tactile feedback generators, and any other type of electronic communication device capable of providing certain UI functions to a user during a communication service. Such I/O user devices are becoming nearly ubiquitous as the internet of things (IoT) revolution. Thus, users have reduced or eliminated the need to carry expensive and ubiquitous user terminals (e.g., smart phones) that include all of the necessary UI capabilities (e.g., display devices, keyboards, speakers, etc.). Alternatively, a user may carry a hardware device operable to identify the user (referred to as a "user tag") through a wireless communication interface (e.g., a Near Field Communication (NFC) interface) to one or more I/O user devices. As the features and capabilities forming the user terminal are not limited to the field of mobile phone manufacturers, the various embodiments disclosed herein may break through the traditional handset-centric mobile communications industry. The user terminal emulation server is operable to provide a user terminal, which may also be referred to as a "soft UE" (SoftUE) or a user terminal emulation application run by the user terminal emulation server.
FIG. 1 illustrates a system having a user terminal emulation server 100 operably integrated with a set of I/O user devices 130 located in proximity to a user to logically emulate a user terminal to provide communication services in accordance with some embodiments of the present disclosure.
Referring to fig. 1, the user terminal emulation server 100 can be a cloud resource remotely networked with the I/O user device 130 or can be more closely located on a network shared with the I/O user device 130. The user terminal emulation server 100 is configured to communicate with the I/O user device 130 to identify which, if any, are located in the vicinity of the user for providing UI capabilities during communication services.
A user may carry a hardware tag (also referred to as a "user tag") that is capable of transmitting a unique user identifier over a communication interface, such as a near field communication interface (e.g., bluetooth, BLE, NFC, RFID, etc., or a combination thereof), for receipt by one or more I/O user devices 130 located in the vicinity of the user. One type of user tag may be a simple standalone electronic device with limited capability to transmit identifiers over a near field communication interface (RF, electromagnetic or optical signaling may be used). Another type of user tag may be a smart phone or smart watch with cellular connectivity that sends a cellular identification (e.g., from a SIM card) or application identification over a cellular interface or near field communication interface.
Alternatively or additionally, the user identifier may be operatively determined by biometric identification operations performed by, for example, one or more I/O user devices 130. Biometric identification operations may include, but are not limited to, one or more of voice recognition, image/face recognition, eye recognition, fingerprint recognition, or combinations thereof. The user identity may be determined based on credentials provided by the user when, for example, logging into an application or account. The cellular telephone may use information from the contracted SIM to provide the user identity, and the proximity of the cellular telephone to the one or more I/O user devices 130 may be determined using Near Field Communication (NFC) capabilities of the telephone.
The user identifier, the user tag identifier and the user terminal application may be logically associated with each other in the database during a user registration process or as part of another setup process. For example, during a user registration process, a user may obtain an account login identifier (used as a user identifier) that is registered in a database as being associated with a user tag identifier that has provided a physical user tag to the user (e.g., purchased by the user) and a user terminal application that emulates a user terminal having defined capabilities (e.g., a cellular telephone that provides voice over cellular and cloud IP communication services).
Operations that may be performed by the system to provide communication services to a user are described further below with reference to fig. 7, which is a flow diagram of the operation of the user terminal emulation server 100 in fig. 7. Referring to fig. 1 and 7, the user terminal emulation server 100 maintains 700 a database 120 that identifies the network address of the I/O user device 130 and also identifies the UI capabilities of the I/O user device 130 based on the content of the received registration message. The UI capabilities of the I/O user device 130 may be logically arranged in the database 120 based on the type of UI capabilities provided (e.g., display device, microphone, speaker, keyboard, and/or camera), and may also be arranged based on the quality of service provided by the UI capabilities and/or the operational characteristics of the UI capabilities. The I/O user device 130 may transmit a registration message including its network address and UI capabilities to the user terminal emulation server 100 in response to an initial setup operation, in response to connecting to a new communication network, and/or in response to another defined event for triggering the generation of the registration message. The registration message may include the geographic location of the I/O user device 130, which may be stored in the database 120. The I/O user device 130 may communicate with the server 100 via a data network (e.g., the internet and/or a private network) using a WiFi transceiver, a bluetooth transceiver, a cellular transceiver, an optical communication transceiver (LiFi), and/or another RF or optical communication transceiver.
The user terminal emulation server 100 registers 702 the network address of the user terminal emulation application 110 and the identity of the user with the network entity 150 providing the communication service. The network entity 150 provides a communication service function 140, which may correspond to, for example, a voice over internet protocol (VoIP) service on the cloud, a Netflix service, a Facebook service, a Skype service, an internet browser service, a cellular communication service, and so forth. The user terminal emulation server 100 executes a user terminal emulation application 110. The user terminal emulation application 110 can run one or more applications typically run by a smartphone, such as a media streaming application (e.g., a movie streaming service such as Netflix), a social media application (e.g., Facebook, Instagram, etc.), a Skype application, an internet browser application, a voice phone call application, a video and voice call application, a camera processing application, a display processing application, a text messaging application, etc.
As shown in FIG. 1, the server 100 may host a different instance of the user terminal emulation application 110 for each user to be provided with communication services (i.e., user terminal emulation applications #1- # N shown corresponding to users 1-N). According to the operations of fig. 7, the user terminal emulation application 110 may perform registration of a user with the network entity 150 and establish a communication service with the user in response to a communication request.
When the communication service function 140 of the network entity 150 is a VoIP service, registering 702 the network address of the user terminal emulation application and the identity of the user with the network entity 150 may include: the network address of the user terminal emulation application 110 and the identity of the user are registered with the VoIP communications service provider's network server.
When the communication service function 140 of the network entity 150 is a cellular communication service, registering 702 with the network entity 150 the network address of the user terminal emulation application and the identity of the user may comprise: the network address of the user terminal emulation application 110 and the identity of the user are registered with a Home Subscriber Server (HSS) or other network node of a core network operated by the cellular communication service provider.
The user terminal emulation server 100 can receive registration messages from the I/O user devices using Session Initiation Protocol (SIP)/Session Description Protocol (SDP), where each registration message identifies a network address and UI capabilities of one of the I/O user devices. The communication request may be received from the network entity 150 using SIP/SDP, and operations to provide communication sessions between the user terminal emulation application 110 and each I/O user device in the set, and between the user terminal emulation application 110 and the requesting user terminal, may be performed using SIP/SDP.
The registration message from the I/O user device may, for example, include an IP address and port number, a MAC address, a Fully Qualified Domain Name (FQDN), and/or another network address, and also include information identifying the UI capabilities of the I/O user device. The I/O user device may respond to becoming powered on by transmitting a registration message to the user terminal emulation server 100.
The user terminal emulation server 100 receives 704 a communication request from the network entity 150 for establishing a communication service between a user and a requesting user terminal (e.g., a cellular phone, a computer with a Skype application, etc.). In response to the communication request, the user terminal emulation server 100 identifies 706 a set of I/O user devices 130 identified by the database 120 that are determined to be located near the user's location and that are also determined to satisfy a combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application 110 based on the UI capabilities of the set of I/O user devices identified by the database 120 and based on the content of the communication request to provide communication services.
Based on determining that the set of I/O user devices satisfies the combined capability rule, the user terminal emulation server 100 provides 708, via the network entity 150, communication sessions between the user terminal emulation application 110 and the I/O user devices in the set, and between the user terminal emulation application 110 and the requesting user terminal. The communication request received 704 by the user terminal emulation application 110 may contain an indication of the minimum UI capability that must be provided to the user during the communication service, such as: only a speaker; a combination of a speaker and a microphone; a display only; a combination of a display device, a speaker, and a microphone; and so on. Thus, the combined capability rules used by the server 100 to determine whether a communication service can be provided and by which set of I/O user devices may be defined based on the minimum UI capabilities indicated by the communication request.
The user terminal emulation server 100 then routes 710 the communication traffic received from the at least one I/O user device in the set to the requesting user terminal via the network entity 150. For each data type received as communication traffic from a requesting user terminal, the user terminal emulation server 100 selects one of the I/O user devices from the set of I/O user devices based on a match of characteristics of the data type to UI capabilities of the selected one of the I/O user devices identified by the database 120, and then routes data of the data type to a network address of the selected one of the I/O user devices.
As will be explained in further detail below, the server 100 may also combine 716 data streams received from the I/O user devices in the set and route the combined data streams to the requesting user terminal, e.g., via the network entity 150.
The user terminal emulation server 100 (e.g., application 110 or an I/O user device processor described below) may be responsible for tracking which I/O user devices are located near the user's current location. Fig. 8 is a flow chart of the corresponding operation. The server 100 may receive 800 from each I/O user device a presence report containing its network address and an identifier of a user determined by the I/O user device to be located nearby. For example, the I/O user device may read a hardware tag (also referred to herein as a "user tag") through the NFC communication interface, may sense biometric information from the user, and/or may perform other operations to detect the presence of the user and identify the user. In response to the presence report, the server 100 updates 802 the database 120 to indicate which user identifiers are located in the vicinity of which I/O user device.
With further reference to the example system of fig. 1, the instantiated user terminal emulation application #1 has determined that the set of I/O user devices 130 is located near the location of the first user carrying the user tag #1 and also has UI capabilities that can be combined to satisfy a combined capabilities rule that provides a combined I/O user interface for use by the first user during the requested communication service. Application #1 responsively uses the set of I/O user devices 130 to provide a combined I/O user interface for use by the first user during communication services between the first user and another user terminal via the network entity 150.
Similarly, the instantiated user terminal emulation application #2 has determined that another set of I/O user devices 130 is located near the location of the second user carrying user tag #2 and also has UI capabilities that can be combined to satisfy the combined capabilities rule that provides a combined I/O user interface for use by the second user during the requested communication service. Application #2 responsively uses the set of I/O user devices 130 to provide a combined I/O user interface for use by the second user during a communication service between the second user and a further user terminal via the network entity 150.
FIG. 1 also shows another set of I/O user devices 130, surrounded by a dashed line, that are not located near user tag #1 or user tag # 2.
As described above, the network entity 150 may use the network address of the user terminal emulation application and the identity of the user previously registered with the network entity 150 to initiate a communication request requesting establishment of a communication service with the identified user. However, additionally or alternatively, the communication request may be generated by one of the I/O user devices 130 in response to a command received from a user located nearby. For example, a user may operate a user interface provided by one of the I/O user devices 130 to initiate a combined audio and video call with another user. The user terminal emulation server 100 (e.g., the IODH or application 110 for the user) receives the communication request along with the identity of the user, which may be sensed via the user tag. The application 110 performs the identifying 706, providing 708, routing 710, selecting 712, and combining 716 operations described above with respect to fig. 7 to establish and operate a communication service between the user and another user via the network entity 150.
Further example systems and related operations will now be described to further illustrate how I/O user devices having different UI capabilities can be operatively combined to provide a combined UI that can be used by a user to satisfy communication requirements of a communication service.
Further illustrative operations are described below with respect to an example embodiment in which the speaker device is one of the I/O user devices 130 in the set that is capable of playing a received audio stream and the microphone device is one of the I/O user devices 130 in the set that is capable of sensing audio to output a microphone stream. The operation of the user terminal emulation application includes updating the database 120 based on the content of the registration messages from the speaker device and the microphone device to identify the network addresses of the speaker device and the microphone device, to identify the UI capabilities of the speaker device as having speaker capabilities and to identify the UI capabilities of the microphone device as having microphone capabilities and optionally also to identify the geographic locations of the speaker device and the microphone device. The speaker UI capabilities may identify the number of speakers provided, sound loudness capabilities, and/or other operational characteristics. The microphone UI capabilities may identify the number of microphones provided, the sensitivity of the microphones, and/or other operational characteristics.
The speaker device and the microphone device are each identified as belonging to a set of I/O user devices that are determined to be located near the location of the user (e.g., user tag #1) and are also determined to satisfy a combined capability rule based on the UI capabilities identified by the database 120 that can be combined to provide a combined I/O UI for the user to interface with the user terminal emulation application 110 to provide the communication service. Based on determining that the speaker device and the microphone device satisfy the combined capability rule, further operations are performed to route the microphone stream received from the microphone device to the requesting user terminal (e.g., via network entity 150). When an audio stream is received as communication traffic from a requesting user terminal, the operations select a speaker device based on matching audio characteristics of the audio stream with speaker capabilities of the speaker device identified by the database, and then route the audio stream to a network address of the speaker device.
When the display device is one of a set of I/O user devices capable of displaying the received video stream, example embodiments may include updating the operation of database 120 based on the content of the registration message to identify a network address of the display device, to identify UI capabilities of the display device as having display capabilities, and optionally also to identify a geographic location of the display device. The display UI capabilities may identify screen display size, aspect ratio, pixel resolution, supported video frame rate, whether the display device supports sharing user support via a split screen configuration, and/or other operational features. The display device is also identified as being among a set of I/O user devices that are determined to be located near the user's location and that are also determined to satisfy a combined capability rule that may be combined to provide a combined I/O UI for the user to interface with the user terminal emulation application 110 to provide communication services based on the UI capabilities identified by the database 120. Based on determining that the speaker device, the display device, and the microphone device satisfy the combined capabilities rule, further operations are responsive to receiving the video stream as communication traffic from the requesting user terminal, selecting the display device based on matching video characteristics of the video stream with display capabilities of the display device identified by the database 120, and then routing the video stream to a network address of the display device.
In an example embodiment, the operations for routing the audio stream and the video stream to the network addresses of the speaker device and the display device, respectively, may include, when audio data and video data within the same stream are received from the requesting user terminal over the first communication session: separating the audio data from the video data; routing the audio data to the network address of the speaker device through the second communication session; and routing the video data to the network address of the display device through the second communication session or the third communication session.
When the camera device is one of the set of I/O user devices capable of outputting a camera stream, example embodiments may include updating operations of database 120 to identify a network address of the camera device, to identify a UI capability of the camera device as having camera capability, and optionally also to identify a geographic location of the camera device based on the content of the registration message. The camera UI capabilities may identify camera pixel count, image quality, light sensitivity, and/or other operational features. The camera device is also identified as being a member of a set of I/O user devices that are determined to be located near the user's location and that are also determined to satisfy combined capability rules that may be combined with other I/O user devices in the set to provide a combined I/OUI for the user to interface with the user terminal emulation application 110 to provide communication services based on the UI capabilities identified by the database 120. Based on determining that the camera device satisfies the combined capability rule, further operations are performed to route the camera stream received from the camera device to the requesting user terminal (e.g., via network entity 150).
The operations for routing the microphone stream received from the microphone device and the camera stream received from the camera device to the requesting user terminal may include: receiving a microphone stream from a microphone device over a first communication session; receiving a camera stream from a camera device over a first communication session or a second communication session; combining the microphone stream and the camera stream into a combined stream; and route the combined stream to the requesting user terminal (e.g., via network entity 150) through the third communication session.
When the keyboard device is one of a set of I/O user devices capable of outputting key selection data in response to a user selecting a key in a key of the keyboard device, example embodiments may include updating operation of database 120 to identify a network address of the keyboard device and to identify a UI capability of the keyboard device as having keyboard capability based on content of the registration message. The keyboard device capabilities may identify a key count, an indication of whether the keyboard is a physical keyboard or a touch-sensitive input device, and/or other keyboard capabilities. The keyboard device is also identified as a member of a set of I/O user devices that are determined to be located near the user's location and that are also determined to satisfy combined capability rules that may be combined with other I/O user devices in the set to provide a combined I/O UI for the user to interface with the user terminal emulation application 110 to provide communication services based on the UI capabilities identified by the database 120. Based on determining that the keyboard device satisfies the combined capabilities rule, further operations are performed to identify a command formed from the key selection data received from the keyboard and to perform an operation that has been predefined to be triggered based on receiving the identified command.
The operations for routing key selection data received from the keyboard device and microphone streams received from the microphone device may include: receiving key selection data from a keyboard device over a first communication session; receiving a microphone stream from a microphone device over a first communication session or a second communication session; combining the key selection data and the microphone stream into a combined stream; and route the combined stream to the requesting user terminal (e.g., via network entity 150) through the third communication session.
While various operations for communication services have been described in the context of successfully establishing a communication service when it is determined that a requested user is located in proximity to a set of I/O user devices that satisfy a combined capability rule, this will not occur when an adequate set of I/O user devices is not determined in this manner. The corresponding operations that the user terminal emulation application 110 can perform when a communication service cannot be established are explained below. In this example, the user terminal emulation application 110 receives another communication request from the network entity 150 for establishing another communication service between another user and another requesting user terminal. In response to the other communication request, the operations determine whether another set of I/O user devices of the I/O user devices identified by database 120 is determined to be located near the location of the other user and available for the other communication service and also provide the other communication service based on the UI capabilities of the other set of I/O user devices identified by database 120 being determined to satisfy a combined capabilities rule that can be combined to provide a combined I/O UI for the other user to interface with the other user terminal emulation application. Based on determining that no other set of I/O user devices is determined to satisfy the combined capabilities rule and is located near the location of the other user, the operations transmit a message to network entity 150 indicating that the other communication service cannot be established. In this manner, network entity 150 is notified that the requested communication service cannot be established with the identified user at this time.
Fig. 2 is a block diagram illustrating the user terminal emulation server 100 as an element of a carrier service node 202 within a cellular system 200. Referring to fig. 2, the communication service functionality 140 (fig. 1) of the network entity may be provided by the operator service node 202 or may be accomplished through an external infrastructure 240 (e.g., the internet). For example, the server 100 may be implemented in the radio access network 220 to provide edge computing with faster responsiveness, or may be implemented within another node of the cellular system 200. The user terminal emulation server 100 can include an I/O user equipment processor (IODH)212, a Control Function (CF)214, an instantiated user terminal emulation application 110, and a serving Gateway (GW) 216. The user terminal emulation application 110 can run one or more applications typically run by a smartphone, such as a Netflix application, a Facebook application, a Skype application, an internet browser application, and the like.
The IODH 212 may perform operations to manage I/O user devices, such as handling maintenance of the database 120 (700 in fig. 7) and/or performing registration of the user terminal emulation application 110 (702 in fig. 7). For example, the IODH 212 is operable to register with the Skype service server the IP address of the Skype application and the Skype name of the user run by or interfaced to the user terminal emulation application 110. The CF 214 may be responsible for assigning an IP address to each user terminal emulation application 110. The IP address to be assigned by the CF 214 may be received from a core network 210 function such as a PDN-GW. The serving GW 216 may interconnect the user terminal emulation server 100 to a PSTN network, a packet data network gateway of a 3GPP (third generation partnership project) system, or the like. The cellular system 200 may include a core network 210 having a Home Subscriber Server (HSS), a Policy and Charging Rules Function (PCRF), a Gateway (GW), and a Mobility Management Entity (MME) that provides control signaling for radio access related to mobile terminal mobility and security. The HSS contains subscriber related information and provides support functions for user authentication and user access systems. The PCRF enables QoS control of each data flow and radio bearer by setting QoS rules for each data flow based on operator set policies and subscriber information. The GWs may include a serving GW (S-GW) and a packet data network GW (PDN-GW), where the S-GW interconnects the core network 210 with the radio access network 220 and routes incoming and outgoing packets for the I/O user devices 232 and/or 130 and the user terminal 230. The PDN-GW interconnects the core network 210 with an external infrastructure 240 (e.g., the internet) and allocates an IP address and performs policy control and charging.
Some cellular communication capable I/O user equipment 232 may communicate with the operator service node 202 via the core network 210, e.g., via an eNB or other radio access node of the radio access network 220. In the system of fig. 2, the user terminal emulation server 100 can handle the establishment of communication services between a selected set of I/O user devices of proximate users and a remote user terminal 230 (e.g., a smartphone) via the cellular system 200.
Fig. 3 is a block diagram illustrating a user terminal emulation server 100 communicating in different ways with various elements of a cellular system 200 operable as a network entity 140 (fig. 1) to provide communication services in accordance with some embodiments of the present disclosure. The system of fig. 3 differs from the system of fig. 2 in that the user terminal emulation server 100 is an internet service within an external infrastructure 240 external to the cellular system 200. In the system of fig. 3, the CF 214 may determine IP addresses to be assigned to different user terminal emulation applications 110 based on signaling from an internet service within the external infrastructure 240.
The above and other operations will now be described in more detail in the context of three different example "use cases": 1) an incoming call scenario; 2) an outgoing call scenario; and 3) shared I/O user device scenarios (sharing of physical resources and/or capabilities).
Example 1: incoming call scenario
This use case involves a user with a user tag or other recognized means being located near an I/O user device 130 with different UI capabilities when the user terminal emulation server receives an incoming call. Although the operations are explained below in the context of identifying a user by a physical user tag carried by the user, the operations are not so limited and may be used with any other means of identifying a user, such as by sensing biometric identification information identifying a user.
The user terminal emulation application 110 can be instantiated or otherwise activated in response to an incoming call (service, session) targeting a user tag. The user terminal emulation application 110 can identify the subscription associated with the user tag (i.e., the physical user) and the preferred communication method (e.g., audio rather than video, audio and video, etc.) that has been specified by the user and determine the UI capabilities of the I/O user device that will be needed to satisfy the UI capabilities that may be specified for the incoming communication session. The user terminal emulation application 110 may require the IODH to identify which I/O user devices 130 are located in the vicinity of the user tag, and may also require the IODH to determine, or may itself determine, whether the identified I/O user devices 130 can combine to meet the UI capabilities specified by the incoming communication session. The user terminal emulation application 110 and/or IODH may receive back an ACK or NACK as to whether the communication service can be provided using a sufficient set of I/O user devices 130. If it is an ACK, the IODH also sets the status of the I/O user devices 130 in the set to "in use" to avoid another user terminal emulation application 110 attempting to use the same I/O user devices 130 as the I/O user devices 130 currently in use. In the case of a NACK, the user terminal emulation application 110 and/or IODH may take different actions to establish a UI capability-simplified communication service with the user according to user settings, for example, in response to only allowing voice-based, rather than a combination of voice and video, communication when no display device is currently available. An example where no display device is available may occur when: the only display device located near the user is currently being used by another user during an ongoing communication service to receive information from another user terminal emulation application, or when no display device is located near the user.
FIG. 4 is a combined flow diagram of operations and related data flows between a user tag, an I/O user device, and a user terminal emulation server according to some embodiments of the present disclosure. Referring to fig. 4, a user tag enters a room and signals 400 its presence to any nearby capable I/O user devices in the room using a discovery beacon signal. Alternatively, one or more I/O user devices determine the presence of a user tag by polling 402, for example by periodically transmitting a discovery beacon signal that triggers response signaling by the user tag. The I/O user device that receives the signaling indicating the presence of the user tag reports 404 to the IODH in the user terminal emulation server along with the network address (e.g., IP address, port number, MAC address, FQDN, etc.) of the I/O user device. The presence update 406 for the detected user corresponds to the user terminal emulation application for the particular user (i.e., user tag). The IODH is operable to receive notifications from I/O user devices located in proximity to the user tag. Additional UI capability discovery (synchronization) communication 410 is performed between the user terminal emulation server and the I/O user device. The I/O user devices are associated with the user in the database, along with an associated indication, subscription, composable UI capabilities provided by a set of I/O user devices located near the user tag. One or more I/O user devices may be selected for default call reception ACK/NACK. Through operation 412, it is now known that a user via a user tag can be reached within the system through an identified set of I/O user devices with identified UI capabilities (e.g., speaker yes/no, display yes/no, microphone yes/no, keyboard yes/no, etc.), thereby creating a logically virtualized user terminal through which communication services can be provided to the user. A user may initiate a communication service through a touch screen, voice commands sensed by a microphone, performing defined gestures observable by a camera, and/or other inputs provided to one of the I/O user devices located in proximity.
In operation 414, an incoming session (e.g., a video call) directed to a user (user tag) from a requesting user terminal arrives at a user terminal emulation server for the user carrying the user tag. In operation 416, the combinable UI capabilities of the available I/O user devices are compared to the UI requirements of the incoming session.
When the combinable UI capability of the set of local I/O user devices does not meet the UI requirements of the incoming session, the user terminal emulation server can: 1) determining whether a set of remote I/O user devices of the I/O user devices identified by the database 120 satisfy a future proximity rule by being located near a future location of the user and satisfy a combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide UI capabilities based on the set of remote I/O user devices identified by the database 120 and communication services determined based on content of the communication request; and 2) when the set of remote I/O user devices satisfies the rule, the server may also responsively use the set of remote I/O user devices to provide the communication service and provide the user with relevant guidance for using the service. Alternatively or additionally, the user terminal emulation server can renegotiate 416 the required UI capabilities (e.g., QoS) for the incoming session when the UI requirements are not met. Example operations that may be performed by elements of the system to determine whether a set of remote I/O user devices satisfies future proximity rules and combined capabilities rules and responsively provide a communication service using the set of remote I/O user devices and provide relevant guidance to a user to use the service are described below with reference to FIGS. 9-12.
Conversely, when the combinable UI capabilities of the I/O user devices meet 418 the UI requirements of the incoming session, the user terminal emulation server prompts the user carrying the user tag via one or more available I/O user devices (e.g., pre-selected answering devices) to provide a session request answer (ACK/NACK). The user responds by either Accepting (ACK) or rejecting (NACK) the incoming session through a pre-selected answering machine 420, providing signaling 422 to the user terminal emulation server. Upon receiving the ACK, operation 424 routes the audio stream from the requesting user terminal to one of the I/O user devices in the set having speaker capability via one or more sessions 426 and routes the video stream from the requesting user terminal to another of the I/O user devices in the set having display capability via one or more sessions 426. Data streams received from one of the I/O user devices in the set over one or more sessions 429 are routed 430 to the requesting user terminal. When two or more data streams are received from an I/O user device over one or more sessions 429, they may be combined into a combined data stream that is routed 430 to the requesting user terminal.
The user terminal emulation server can perform operation 428 of continuously monitoring the presence of I/O user devices to determine when one or more I/O user devices are no longer in the vicinity of the user such that they can no longer be included as part of the combined UI used during an ongoing communication session. In response to the previous member of the set no longer needing to be present, the user terminal emulation server can replace the UI capabilities of another I/O user device to the set for the ongoing communication session by the user. Alternatively, the user terminal emulation server may: 1) determining whether a set of remote I/O user devices of the I/O user devices identified by the database 120 satisfy a future proximity rule by being located near a future location of the user (e.g., along a planned route, a planned location, or a server suggested location) and satisfy a combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities of the set of remote I/O user devices identified by the database 120 and based on the content of the communication request; and 2) when the set of remote I/O user devices satisfies the rule, the server may also responsively use the set of remote I/O user devices to provide the communication service and provide the user with relevant guidance for using the service. 9-12 are described below with reference to example operations that may be performed by elements of the system to determine whether a set of remote I/O user devices satisfies a future proximity rule and a combined capabilities rule and responsively provide a communication service using the set of remote I/O user devices and provide relevant guidance to a user to use the service.
Example 2: outgoing call
This use case involves a user with a user tag being located near an I/O user device 130 with different UI capabilities when the user terminal emulation server receives an outgoing call (communication session). The I/O user devices 130 are associated with the identified users via the user terminal emulation server 100, the user terminal emulation server 100 handles all communication sessions for the users, while the associated I/O user devices 130 are managed by the IODH.
The user terminal emulation application 110 can be instantiated or otherwise activated in response to an outgoing call requested by a user carrying a user tag. A user may initiate an outgoing call through a touch screen, voice commands sensed by a microphone, performing defined gestures observable by a camera, and/or other input provided to one of the I/O user devices located in proximity.
The user terminal emulation application 110 can identify the subscription associated with the user tag (i.e., the physical user) and the preferred communication method (e.g., audio rather than video, audio and video, etc.) that has been specified by the user and determine the UI capabilities of the I/O user device that will be needed to satisfy the UI capabilities that may be specified for the outgoing call. The user terminal emulation application 110 may require the IODH to identify which I/O user devices 130 are located in the vicinity of the user tag, and may also require the IODH to determine, or may itself determine, whether the identified I/O user devices 130 can combine to meet the UI capabilities specified by the outgoing call. The user terminal emulation application 110 and/or IODH may receive back an ACK or NACK as to whether the communication service can be provided using a sufficient set of I/O user devices 130. If it is an ACK, the IODH also sets the status of the I/O user devices 130 in the set to "in use" to avoid another user terminal emulation application 110 attempting to use the same I/O user devices 130 as the I/O user devices 130 currently in use. In the case of a NACK, the user terminal emulation application 110 and/or IODH may take different actions to establish a UI capability-reduced communication service with the user according to user settings, for example, in response to only allowing sound instead of preferred sound and video when no display device is currently available (e.g., when currently used by another user terminal emulation application 110 or when no display device is located near the user tag).
Fig. 5 is a combined flow diagram of outgoing call operations and related data flows between a user tag, an I/O user device, and a user terminal emulation server according to some embodiments of the present disclosure. Referring to fig. 5, a user tag enters a room and signals 500 its presence to any nearby capable I/O user devices in the room using a discovery beacon signal. Alternatively, one or more I/O user devices determine the presence of a user tag by polling 502, for example by periodically transmitting a discovery beacon signal that triggers response signaling by the user tag. The I/O user device that receives the signaling indicating the presence of the user tag is reported 504 to the IODH in the user terminal emulation server along with the network address of the I/O user device (e.g., IP address, port number, MAC address, Fully Qualified Domain Name (FQDN), etc.). The user terminal emulation application corresponding to the particular user (i.e., user tag) is updated 506 for the detected user's presence.
The IODH is operable to receive notifications from I/O user devices located in proximity to the user tag. Additional UI capability discovery (synchronization) communication 510 is performed between the user terminal emulation server and the I/O user device. The I/O user devices are associated with the user in the database, along with an associated indication, subscription, composable UI capabilities provided by a set of I/O user devices located near the user tag. One or more I/O user devices may be selected for default call reception ACK/NACK. Through operation 512, it is now known that a user via a user tag is reachable within the system through an identified set of I/O user devices having identified UI capabilities (e.g., speaker yes/no, display yes/no, microphone yes/no, keyboard yes/no, etc.), thereby creating a logically virtualized user terminal through which communication services can be provided to the user. A user may initiate a communication service through a touch screen, voice commands sensed by a microphone, performing defined gestures observable by a camera, and/or other inputs provided to one of the I/O user devices located in proximity.
In operation 514, the user carrying the user tag uses the UI of one of the I/O user devices to trigger 514 an outgoing call (e.g., a video call) or another communication service, which triggers signaling 516 of the outgoing call to the user terminal emulation server. In operation 518, the IODH queries the user (e.g., displays a message, sounds a sound, etc.) through one of the I/O user devices located in the vicinity of the user to request the user to select a communication method type that is currently available for the outgoing call or other communication service based on the combined UI capabilities of the set of I/O user devices determined to satisfy the current proximity rules and combined capabilities rules of the outgoing call or other communication service (e.g., any one or more of voice input, speaker output, video input, video output, output display device, keyboard input, etc.).
When the combined UI capability of the set of local I/O user devices does not meet the UI requirements of the requested outgoing call or another communication service or does not meet the user's request (e.g., a NACK response to the user query is received), the user terminal emulation server may: 1) determining whether a set of remote I/O user devices of the I/O user devices identified by the database 120 satisfy a future proximity rule by being located near a future location of the user and satisfy a combined capability rule that may be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide an outgoing call or other communication service determined based on the UI capabilities of the set of remote I/O user devices identified by the database 120 and based on the content of the outgoing call request or based on other information received from the user. Example operations that may be performed by elements of the system to determine whether a set of remote I/O user devices satisfies future proximity rules and combined capabilities rules are described below with reference to FIGS. 9-12.
When the combined UI capabilities of the set of local I/O user devices do satisfy the UI requirements of the requested outgoing call or another communication service and/or do satisfy the user's request (e.g., an ACK response to the user query is received), one of the I/O user devices provides response signaling 520 to the IODH indicating the type of communication method selected by the user for the outgoing call. In operation 522, the user terminal emulation server transmits an outgoing session flow request to network entity 150, wherein the request may include an identifier of the calling user, an identifier of the user terminal of the called user, and a quality of service of the communication session. In operation 522, the user terminal emulation server receives a communication session Acceptance (ACK) or rejection (NACK) from the network entity 150. When the communication session is rejected, the user terminal emulation server can attempt to renegotiate 524 the requested communication session, for example, at a lower quality of service.
When the communication session is Accepted (ACK), for each data type received 528 from the requesting user terminal as communication traffic, the user terminal emulation server selects one of the I/O user devices from the set of I/O user devices based on a match of characteristics of the data type to UI capabilities of the one of the I/O user devices identified by the database, and then routes 530 the data of the data type to a network address of the selected one of the I/O user devices. The data originating I/O user device in the I/O user device sends 532 the data streams to the user terminal emulation server over one or more sessions 536, which may combine 538 the data streams into a combined data stream, which is routed 540 to the called user terminal via network entity 150.
The user terminal emulation server can continuously monitor 534 the presence of the I/O user devices to determine when one or more I/O user devices are no longer in the vicinity of the user such that they can no longer be included as part of the combined UI provided during an ongoing communication session. In response to the previous member of the set no longer needing to be present, the user terminal emulation server can replace the UI capabilities of another I/O user device to the set for the ongoing communication session by the user.
Example 3: user shared I/O user equipment (physical resources, UI capabilities)
A third example relates to a scenario where two or more users are located in a physical area with multiple I/O user devices whose combined UI capabilities are insufficient to meet the UI requirements needed to support time-overlapping communication sessions without the two users sharing certain I/O user devices. In this case, the ID entities (i.e., user tags) of both users will be detected in the vicinity of some I/O user devices, which are then associated by the IODH with the user's respective user terminal emulation application 110.
In the illustration of FIG. 6, user terminal emulation application #1 is already in process of an ongoing communication session, with some of the associated I/O user devices assigned to and in use by the first user corresponding to user tag # 1; this means that the example starts after block 430 in fig. 4. At this time, another second user carrying user tag #2 enters the physical area.
In block 610, user tag #2 becomes located near at least one I/O user device that user terminal emulation application #1 is currently using. The at least one I/O user device detects user tag # 2. In response, the IODH instantiates user terminal emulation application #2 on user terminal emulation server 100.
In block 612, a request for a new communication session of the user terminal emulation application #2 is received. In block 614, the IODH considers the priorities between the user terminal emulation applications that have been instantiated. The IODH compares the subscription of the currently hosted (ongoing) user terminal emulation application #1 session with the newly incoming subscription to the request for a communication session towards the user terminal emulation application # 2.
If no prioritization is identified, the user terminal emulation application is treated equally so that the available I/O user devices along with their UI capabilities are allocated in a first-come-first-serve manner. Conversely, if a priority ordering is identified, the IODH operation is to: assigning a priority to a particular I/O user equipment for the user terminal emulation application having the highest priority according to the defined QoS/capability prioritization rules; where a particular UI capability exists at a particular type of I/O user device, some of the UI capability may be operatively shared between the first user and the second user (e.g., a sufficiently large display screen may be divided in half, which are assigned to the first user and the second user, respectively).
In the current scenario, user terminal emulation applications #1 and #2 are treated equally without prioritization, for which all operations within reference box 611 apply.
In block 616, the IODH evaluates the request for the second user and the capability of the user terminal emulation application #2 (taking into account the prioritization established in the previous step, if any). If, regardless of any priority, the user terminal emulation application #2 does not support incoming requests (e.g., determines (via query 617 to the I/O user device) that there are no or insufficient available I/O user devices to satisfy the required UI capabilities), the IODH may be operable to negotiate UI capabilities/QoS with the network entity sending the session request to the second user, or may determine whether a set of remote I/O user devices satisfies future proximity rules and combined capabilities rules, e.g., in accordance with the example operations described below with respect to fig. 9-12. Conversely, if the incoming request is supported by the UI capability provided by the user equipment emulation application #2 for the requested communication session, as determined by the user terminal emulation application #2 query 618 with the I/O user equipment, an ACK is transmitted to the network entity 150.
If the user terminal emulation application #2 can support incoming communication requests when granted a certain priority to use one or more I/O user devices currently being used by the user terminal emulation application #1, operations of block 619 may be performed to preempt or cause sharing of the one or more I/O user devices currently being used by the user terminal emulation application # 1. The IODH and/or user terminal emulation application #1 can then renegotiate 622 the required UI capabilities for the communication session of the first user's user terminal emulation application #1 with the network entity 150. The user terminal emulation application #1 can receive a session ACK/NACK generated 620 by one or more I/O user devices that are preempted or shared with the user terminal emulation application #2 indicating what UI capabilities are available for use by the user terminal emulation application #1, and can responsively terminate the existing communication session if the required UI capabilities provided by the I/O user devices are no longer sufficient for the user terminal emulation application #1 to be used for the communication session.
In block 624, the user terminal emulation application #2 queries whether the communication session requested by the second user is accepted through one of the pre-selected I/O user devices. One of the pre-selected I/O user devices may display 626 a prompt asking the second user for a response, which is provided 628 as an ACK/NACK to the user terminal emulation application # 2. When the second user accepts the communication session (ACK), a communication service is established between the second user and the remote user terminal through the user terminal emulation application #2 and the network entity 150.
The I/O user device presence monitor may operate as a function of the IODH to monitor (continuously, periodically, or in response to the occurrence of defined events) ongoing communication sessions to ensure that all UI capabilities provided by the set of I/O user devices remain located in the vicinity of and available to the user.
Message exchange between different system entities may be performed using the Session Initiation Protocol (SIP) with Session Description Protocol (SDP), where there may be some minor changes with respect to the methods and media formats currently supported in the protocol. Using SIP/SDP may be advantageous because the connection between the I/O user equipment and the user terminal emulation application may be a SIP session that may be established in a similar manner as the connection between two VoIP clients.
More generally, the operations performed by the user terminal emulation server may comprise receiving, from the network entity, another communication request for establishing another communication service between another user and another requesting user terminal. In response to the other communication request, the operations determine whether another set of I/O user devices of the I/O user devices identified by the database are determined to be located near the location of the other user and available for the other communication service and further based on UI capabilities of the other set of I/O user devices identified by the database being determined to satisfy a combined capabilities rule combinable to provide a combined I/O UI for the other user to interface with another user terminal emulation application to provide the other communication service. Based on determining that no other set of I/O user devices is determined to satisfy the combined capabilities rule, to be available for use by the other communication service, and to be located proximate to the location of the other user, the operations responsively configure one of the set of I/O user devices that is located proximate to the other user but is currently in use by the user to operate to provide a shared UI that is used by the user while continuing to provide communication services to the user and is also used by the other user while providing the other communication services to the other user.
In one example, information directed to a user may be routed for display in one half of the screen of the display device, while information directed to another user may be routed for display in the other half of the screen of the display device. In another example, a keyboard may be shared by two users who identify themselves via the keyboard as they enter information (e.g., by typing a user ID, scanning a user tag, biometric scanning, etc.), so that the server may selectively route the keyboard input to the correct one of the two user terminal emulation applications.
Example 4: responding to changes in availability of I/O user equipment
The I/O user devices may move such that the set of I/O user devices located near the user tag changes over time. Moreover, such changes may be caused by one or more I/O user devices becoming inoperable (e.g., powered down) or when the radio air interface between them becomes inoperable or suffers excessive radio interference. The IODH may be configured to dynamically determine which I/O user devices remain available for association with the user tag.
In one embodiment, the mobility aspect is monitored by an I/O user equipment presence monitor (IODPM) located in the IODH, as shown at block 428 in fig. 4 and block 534 in fig. 5. When the IODPM discovers that the current user terminal emulation application (i.e., implicitly, some of the I/O user devices it uses) can no longer obtain sufficient UI capabilities through the set of I/O user devices (e.g., which may result in a breach of the QoS contract for the current communication session), the IODPM may trigger a renegotiation of the UI capability requirements for the communication session through the network entity 150 and possibly with the remote user terminal.
The user terminal emulation server may determine that the user needs to move to another location (referred to as a future location) at which it is determined that a sufficient set of I/O user devices (referred to as a set of remote I/O user devices) are available that may combine to satisfy the combined capability rule. The server may then provide guidance to the user to travel to the other location and provide communication services through the set of remote I/O user devices upon arrival at the future location. For example, the user terminal emulation server may: determining whether a set of remote I/O user devices of the I/O user devices identified by the database 120 satisfy a future proximity rule by being located near a future location of the user and satisfy a combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities of the set of remote I/O user devices identified by the database 120 and based on the content of the communication request; and when the set of remote I/O user devices satisfies the rule, the server may further responsively provide the communication service using the set of remote I/O user devices and provide the user with relevant guidance for using the service. Example operations that may be performed by elements of the system to determine whether a set of remote I/O user devices satisfies future proximity rules and combined capabilities rules and responsively provide a communication service using the set of remote I/O user devices and provide relevant guidance to a user to use the service are described below with reference to FIGS. 9-12.
Establishing communication services using I/O user equipment remotely located from a user
In almost all of the operational scenarios described above, the user terminal emulation server successfully identifies a set of local I/O user devices that provide communication services with the network entity by being located near the user's current location that satisfy the current proximity rules and also satisfy the combined capability rules that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application. Thus, the user terminal emulation server is able to establish communication services between the network entity and the user using the set of local I/O user devices.
However, other scenarios will arise where the user terminal emulation server will not be able to identify a set of local I/O user devices that satisfy the current proximity rules and combined capabilities rules. In one such example scenario, when the user is moving or is about to move, the user terminal emulation server may be configured to find a set of I/O user devices located remotely proximate to the user's future location and satisfying the combined capability rules to provide communication services ("remote I/O user device set"). The future location may correspond to a location toward which the user has traveled based on direction and/or calendar meeting locations, or may be a location at which the user terminal emulation server suggests and provides travel guidance to the user to enable communication services to be obtained through the set of remote I/O user devices. In another such example scenario, when the user terminal emulation server fails to identify a sufficient set of I/O user devices that are located near the current user location and that satisfy the combined capabilities rule, the user terminal emulation server may be configured to find a candidate future location of a proximate user that is located remotely and that satisfies the combined capabilities rule to provide communication services. Again, the user terminal emulation server can help guide the user to a future location and then use the set of remote I/O user devices to establish communication services between the network entity and the user.
Fig. 9 is a flowchart of operations performed by a user tag, an I/O user device, and a user terminal emulation server to establish a communication service initiated by a network entity to connect to a user, and also illustrating the relative data flow between these elements, in accordance with some embodiments of the present disclosure.
The operations of fig. 9 may be particularly useful for scenarios in which the user is traveling such that the I/O user device that initially detected the presence of the user will not be in the vicinity of the user if the communication service is established or for a sufficient duration after establishment. These operations may also be useful for another scenario where the user is currently located in a location where there is not an adequate set of I/O user devices to satisfy the proximity rules and combined capabilities rules. In these scenarios, the user terminal emulation server can identify a set of remote I/O user devices that satisfy the proximity rules and combined capabilities rules for the user's future location. The future location may be, for example, a location that determines a user's direction of travel, a location along a route determined based on a calendar meeting place included in the user's calendar application, and/or another location to which the user terminal emulation server has identified a set of remote I/O user devices that satisfy the rules and to which the user may travel to participate in the communication service.
Referring to fig. 9, the user terminal emulation server and network entity 150 perform operations to register 900 a user identifier and a network address in a database. The user identifier may be a user tag identifier. The user terminal application may be logically associated with the user identifier in the database during a user registration process or as part of another registration process. For example, during a user registration process, a user may obtain an account login identifier (used as a user identifier) that is registered in a database as being associated with a user tag identifier that has provided a physical user tag to the user (e.g., purchased by the user) and a user terminal application that emulates a user terminal having defined capabilities (e.g., a cellular telephone that provides voice over cellular and cloud IP communication services).
A physical user tag carried by a user enters the room and signals 901 its presence to any nearby and capable receiving I/O user devices in the room, for example using a discovery beacon signal. Alternatively, one or more I/O user devices determine the presence of a user tag by polling 902, such as by periodically transmitting a discovery beacon signal that triggers response signaling of the user tag, or otherwise sensing the user tag. The I/O user device that receives the signaling indicating the presence of the user tag reports 904 to the user terminal emulation server along with the network address (e.g., IP address, port number, MAC address, FQDN, etc.) of the I/O user device. The user terminal emulation application corresponding to the particular user (i.e., user tag) is updated 906 for the detected user's presence. The user terminal emulation application is operable to receive notifications from I/O user devices located in proximity to the user tag. Additional UI capability discovery (synchronization) communication is performed between the user terminal emulation server and the I/O user device. The user terminal emulation server may communicate with the I/O user device to discover 908 its geographic location (or may be identified in a previous registration process), UI capabilities (e.g., speaker yes/no, display yes/no, microphone yes/no, keyboard yes/no, etc.), and/or availability for use in communication services. The user terminal emulation server can maintain a database identifying the network address of the I/O user device, the UI capabilities of the I/O user device, and the location of the I/O user device based on the content of the received message.
The user terminal emulation server receives 910 an incoming communication request for a communication service (e.g., a video call) directed to a user (user tag) from the network entity 150. The user terminal emulation server determines 912 whether a set of local I/O user devices of the I/O user devices identified by the database satisfies the current proximity rules by being located near a current location of the user and satisfies the combined capabilities rules that may be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities of the set of local I/O user devices identified by the database and based on the content of the communication request.
When it is determined 912 that the set of local I/O user devices satisfies the current proximity rules and the combined capabilities rule, the user terminal emulation server provides 914 communication sessions between the user terminal emulation application and the set of local I/O user devices and between the user terminal emulation application and the network entity 150. The user terminal emulation server then routes 916 communication traffic received from the at least one I/O user device in the local set to the network entity 150 for communication services. Further, for each data type received as communication traffic from the network entity 150, the user terminal emulation server selects 916 one of the I/O user devices from the set of remote I/O user devices based on a match of characteristics of the data type to UI capabilities of the selected one of the I/O user devices identified by the database, and then routes 916 data of the data type to a network address of the selected one of the I/O user devices. Thus, the user terminal emulation server can use any one or more of the operations and embodiments described above to route communication traffic, including splitting downlink traffic and combining various uplink traffic.
In sharp contrast, when it is determined 912 that none of the set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, the user terminal emulation server also identifies 918 whether a set of remote I/O user devices of the I/O user devices identified by the database satisfies the future proximity rule by being located near a future location of the user and satisfies the combined capabilities rule that are combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities of the set of remote I/O user devices identified by the database and based on the content of the communication request.
Based on determining 918 that the set of remote I/O user devices satisfies the future proximity rule and satisfies the combined capabilities rule, the user terminal emulation server provides 920 communication sessions between the user terminal emulation application and the set of remote I/O user devices and between the user terminal emulation application and the network entity 150. When the user becomes located near the set of remote I/O user devices, the user terminal emulation server routes 922 communication traffic received from at least one I/O user device in the remote set to network entity 150 for communication services. Further, for each data type received as communication traffic from the network entity 150, the user terminal emulation server selects 922 one of the I/O user devices from the set of remote I/O user devices based on a match of characteristics of the data type to UI capabilities of the selected one of the I/O user devices identified by the database, and then routes 922 data of the data type to a network address of the selected one of the I/O user devices. Thus, the user terminal emulation server can use any one or more of the operations and embodiments described above to route communication traffic, including splitting downlink traffic and combining various uplink traffic.
The user terminal emulation server can perform operations of continuously monitoring 924 the presence of I/O user devices in the remote set to determine when one or more I/O user devices are no longer in the vicinity of the user such that they can no longer be included as part of the combined UI used during the ongoing communication session. In response to the previous member of the remote set no longer needing to exist, the user terminal emulation server can replace the UI capabilities of another I/O user device to the remote set used by the user for the ongoing communication session.
These and other related operations that may be performed by a user terminal emulation server configured in accordance with some embodiments are now described more generally with reference to fig. 9. FIG. 9 is a flowchart of operations that may be performed by a user terminal emulation server to identify and use a set of remote I/O user devices such that a current set of local I/O user devices should be used to establish communication services for a user when the user moves or plans to move.
Referring to FIG. 10, a database is maintained 1000 identifying the network address of the I/O user device, the UI capabilities of the I/O user device, and the location of the I/O user device based on the content of the received message. A registration operation 1002 of the network address of the user terminal emulation application and the identity of the user is performed towards the network entity providing the communication service, the user terminal emulation application being executed by the user terminal emulation server. A communication request for establishing a communication service with a user is received 1004 from a network entity.
In response to the communication request, a determination 1006 is performed: determining whether a set of local I/O user devices of the I/O user devices identified by the database satisfy the current proximity rules by being located near a current location of the user and satisfy a combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the determined communication services based on the UI capabilities of the set of local I/O user devices identified by the database and based on the content of the communication request. When it is determined 1006 that no set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, a further determination 1008 is performed: determining whether a set of remote I/O user devices of the I/O user devices identified by the database satisfy a future proximity rule by being located near a future location of the user and satisfy a combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the UI capabilities of the set of remote I/O user devices identified by the database and the communication service determined based on the content of the communication request.
When it is determined 1008 that the set of remote I/O user devices satisfies the future proximity rule and satisfies the combined capabilities rule, performing further operations 1010 comprising: communication sessions between the user terminal emulation application and the set of remote I/O user devices and between the user terminal emulation application and the network entity are provided 1012. The operations also route 1014 communication traffic received from at least one I/O user device in the remote set to a network entity for communication services. For each data type received as communication traffic from the network entity, the operations select 1016 one of the I/O user devices from the set of remote I/O user devices based on a match of characteristics of the data type to UI capabilities of the selected one of the I/O user devices identified by the database, and then route data of the data type to a network address of the selected one of the I/O user devices. Thus, the user terminal emulation server can use any one or more of the operations and embodiments described above to route communication traffic, including splitting downlink traffic and combining various uplink traffic.
In one embodiment, the operation of determining 1008 whether the set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule includes determining whether the user is in progress. In response to the user being traveling, the operations determine a direction of travel, and determine an expected path of travel for the user based on the direction of travel. The user terminal emulation server then preferentially identifies a set of remote I/O user devices of the I/O user devices identified by the database that satisfy the future proximity rule by being located near a future location along the projected path of travel and that satisfy the combined capabilities rule.
The direction of travel of the user may be determined by the user terminal emulation server, e.g., through the IODH, based on positioning information provided by the radio communication network (e.g., system assisted positioning) and/or by the satellite global positioning system (GPS, GLONASS, etc.). The direction of travel of the user may be determined by a user terminal emulation server based on information obtained from one or more user applications executed by the user terminal (e.g., User Equipment (UE), a smartphone, a tablet, a laptop, a desktop computer, etc.) or another system element (e.g., a networked server). The direction of travel of the user may be determined based on the direction in which the plurality of I/O user devices sequentially report sensing the proximity of the user tag. For example, the user terminal emulation server can determine the direction of the user as a direction along a building corridor in response to receiving reports from I/O user devices that are spaced along the corridor and report the ephemeral presence of a user tag when the user walks over the respective I/O user device. The user's speed may be predicted based on knowing: 1) the distance between I/O user devices and the time elapsed between their sequential reporting of the presence of arrival of user tags; and/or 2) the distance between a location where a particular I/O user device may first sense the presence of an arrival of a user tag and a location where the particular I/O user device will detect the departure of the user tag (e.g., loss of a signal from the user tag) and the time elapsed between the arrival and departure. A map application (e.g., google map) may be used to determine the direction and/or speed of travel of the user to determine the direction and/or speed of the user based on the user tags or tracked location of the user terminal (e.g., along roads, railways, bicycle paths, etc.), which may be performed even when the user is not using the map application for route planning.
For example, the operation of determining 1008 by the user terminal emulation server whether the set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule may include: it is determined whether the user is traveling and, while traveling, a predicted route that the user is traveling is obtained from a route planner. The user terminal emulation server may then preferentially identify a set of remote I/O user devices of the I/O user devices identified by the database that satisfy the future proximity rule by being located near a future location along the predicted route and that satisfy the combined capabilities rule.
The operations may include performing machine learning to update a historical route data structure to store information identifying machine-tracked routes traveled by a user over time. The operation of obtaining a predicted route being traveled by the user from the route planner may include accessing a historical route data structure to obtain the predicted route using at least one of: a time of day; day of the week; the location of the user; and a calendar meeting location included in the user calendar application. Machine learning may be performed by a user terminal emulation server, a user application (e.g., hosted on a user terminal), and/or by another element of the system.
Once the user terminal emulation server has identified a set of remote I/O user devices that satisfy the combined capabilities rule, the user may be provided with guidance for traveling from the user's current location to a future location located near the set of remote I/O user devices. The guidance may, for example, include turn-by-turn road navigation instructions, a map showing the current location of the user and the locations of the off-route set of I/O user devices, and arrows pointing to the locations of the off-route set of I/O user devices, etc.
The user terminal emulation server may identify a candidate set of remote I/O user devices and display information that enables the user to select one of the candidate sets that the user will travel to obtain communication services. For example, a map showing the user's current location and relative other locations of the remote I/O user device candidate set may be displayed to the user. Thus, the user may select one of the candidate sets based on the shortest travel time and/or shortest distance. Alternatively, the user terminal emulation server may recommend that the user select a particular one of the candidate sets based on maximum fulfillment of the UI capabilities of the I/O user devices in the candidate set, e.g., based on a shortest travel route, a fastest travel route, and/or a combined capability rule. The user terminal emulation server can indicate which candidate set provides what UI capabilities so that the user can select between them based on what UI capabilities the user desires to use during the communication service (e.g., video and audio, audio only, text input and output, etc.).
The user terminal emulation server may provide feedback through network entity 150 regarding estimating when the user may participate in the requested communication service. Alternatively or additionally, the user terminal emulation server may provide the user with an estimate of when the user will arrive at a future location and be able to participate in the requested communication service.
Example operations are shown in the flowchart of fig. 11. Referring to fig. 11, a user terminal emulation server generates 1100 an estimated time of arrival for a user at a future location and transmits 1102 a message containing information indicative of the estimated time of arrival to a network entity.
Additionally or alternatively, the user terminal emulation server can generate 1100 an estimated time of arrival for the user at a future location and transmit 1104 a message to an I/O user device that is currently located in proximity to the user and that has UI capabilities that can output message content to the user, where the message contains information indicative of the estimated time of arrival.
In response to determining that no set of remote I/O user devices that satisfy the future proximity rules and satisfy the combined capabilities rules by being located near a future location along the predicted route is identified, the user terminal emulation server performs further operations to identify a set of off-route I/O user devices and to assist in navigating the user to the set of off-route for performing the communication service. The respective operations may include determining whether a set of off-route I/O user devices of the I/O user devices identified by the database satisfies an off-route future proximity rule and satisfies a combined capabilities rule by being located near an off-route location within a threshold distance from a predicted route.
When it is determined that the off-route set of I/O user devices satisfies the off-route future proximity rules and the combined capabilities rules, the user terminal emulation server can initiate generation of an alternate route (e.g., by a local routing application and/or by a network route planner such as a google map or apple map application programming interface). The user terminal emulation server may then provide guidance to the user for navigating to the off-route set of I/O user devices along the alternative route (e.g., turn-by-turn road navigation instructions, maps showing the user's current location and the locations of the off-route set of I/O user devices, arrows pointing to the locations of the off-route set of I/O user devices, etc.), and retain the off-route set of I/O user devices for use by the user for communication services. Based on determining that the user has become located proximate to the off-route set of I/O user devices, the user terminal emulation server can responsively provide communication sessions between the user terminal emulation application and the off-route set of I/O user devices and between the user terminal emulation application and the network entity, and route communication traffic received from at least one I/O user device in the off-route set to the network entity for communication services. Thus, the user terminal emulation server can use any one or more of the operations and embodiments described above to route communication traffic, including splitting downlink traffic and combining various uplink traffic.
The user terminal emulation server can be configured to control the movement of I/O user devices to travel to locations where they can be used for communication services. In one embodiment, the operation of determining 1008 whether the set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule may include identifying a remote operation vehicle that transports I/O user devices that may be relocated to a future location of the user to satisfy the future proximity rule and that have UI capabilities that may be combined with UI capabilities of at least one other I/O user device to satisfy the combined capabilities rule, and wherein the at least one other I/O user device is determined to also satisfy the future proximity rule. The user terminal emulation server may then control the remotely operated vehicle to move to a new location that satisfies the future proximity rule and include the remotely operated vehicle and the at least one other I/O user device in a set of remote I/O user devices to provide 1012 communication services to the user.
For example, the user terminal emulation server may determine that a microphone, rather than a camera, is available at a particular location for a video call that requires audio and video capabilities. The user terminal simulation server may then determine that an Unmanned Aerial Vehicle (UAV) having camera UI capabilities may be relocated to the particular location, and responsively control the unmanned aerial vehicle to relocate. The control operation may correspond to sending a command containing the particular location to an UAV management module or to the UAV to initiate movement, or may correspond to providing more real-time guidance while the UAV is flying to the particular location.
When the user terminal emulation server is determining 1008 (FIG. 10) whether the set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule, it may direct one or more resources to the user's current or future location. The resources may correspond to directional microphones, cameras with fields of view, or mobile resources (e.g., the above-described unmanned aerial vehicle or another vehicle that transports I/O user devices with UI capabilities for communication services that may be combined with one or more other I/O user devices to satisfy a combined capabilities rule).
In one embodiment, the operation of determining 1008 whether the set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule may include selecting a camera having a field of view that is orientable to a future location to satisfy the future proximity rule, and wherein the camera has UI capabilities that are combinable with the UI capabilities of at least one other I/O user device to satisfy the combined capabilities rule. The camera is included in a set of I/O user devices for providing communication services. For example, video signals from a camera may be used to capture gestures or user mouth movements that are further machine processed to recognize utterances spoken by the user and/or to recognize commands conveyed by user gestures. The machine-recognized utterance may be converted into a text string that is indicated to network entity 150. Machine-recognized commands (e.g., based on recognized user gestures) may be used by a user to initiate an outgoing request for a communication service and may also be used to recognize the type of service requested (i.e., initiate voice calls, voice and video calls, text messaging services, etc.). The user terminal emulation server can control the camera to directionally steer the field of view to a future location and include the camera in a set of remote I/O user devices that provide communication services to the user.
In additional or alternative embodiments, the operation of determining 1008 whether the set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule may include selecting a microphone having a sensitivity gain that is orientable to a future location to satisfy the future proximity rule, and wherein the microphone has a UI capability that is combinable with the UI capability of the at least one other I/O user device to satisfy the combined capabilities rule. The microphone is included in a set of I/O user devices for providing communication services. For example, microphone signals from a microphone may be processed to machine recognize utterances spoken by a user and/or to recognize spoken commands. The machine-recognized utterance may be converted into a text string that is indicated to network entity 150. The machine-recognized verbal command may be used to initiate an outgoing request for a communication service and may also be used to identify the type of service requested (i.e., initiate a voice call, voice and video call, text messaging service, etc.). The user terminal emulation server can control the microphone to directionally steer the sensitivity gain to a future location and include the microphone in a set of remote I/O user devices that provide communication services to the user.
When a user is traveling along a predefined or observed route, the user terminal emulation server can identify a sequence of sets of I/O user devices that satisfy proximity rules located near various spaced apart locations along the route and that also satisfy combined capability rules. The user terminal emulation server can move one or more I/O user devices to one or more of the spaced apart locations to supplement one or more UI capabilities that would otherwise be lost thereat.
The user terminal emulation server can track the progress of the user along the route and selectively initiate establishment of a communication session between the user terminal emulation server and the next set of I/O user devices to be reached when the user approaches the location of the next set of I/O user devices, and then provide communication services through the next set of I/O user devices when the user arrives. Similarly, the user terminal emulation server can terminate the provision of communication services by a previous set of I/O user devices, including, for example, terminating a communication session between the user terminal emulation server and the previous set of I/O user devices when the user leaves the location of the previous set of I/O user devices along a route to the next set of I/O user devices.
The user terminal emulation server may buffer communication traffic from the network entity 150 when the user is between areas that may be served by a previous set of I/O user devices in a next set of I/O user devices. When starting to provide communication services through the next set of I/O user equipment, the user terminal emulation server can play the buffered communication traffic through the next set of I/O user equipment. The playing of the buffered communication traffic may be performed at a faster data communication rate than it was buffered, so that the user may catch up with real-time while the buffered communication traffic may be received. For example, when the buffered communication traffic includes video, the user terminal emulation server can stream the video at a higher frame rate such that it appears to be fast-forwarding so that the user can catch up with the real-time video stream provided through the network entity 150.
Alternatively or additionally, the buffering of communication traffic may be performed when the user terminal emulation server initially starts providing communication services through the set of local I/O user devices but subsequently needs to transfer ongoing communication services to the set of remote I/O user devices. Such a scenario may be required when: the user is moving or when one of the I/O user devices in the local set is no longer available and the remaining I/O user devices in the local set do not satisfy the combined capability rule for continued use in a communication session where UI capability is degraded.
An example embodiment of these operations is explained with reference to the flowchart of FIG. 12 in conjunction with the flowchart of FIG. 10. Referring to fig. 10 and 12, when it is determined 1006 (fig. 10) that the set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, the user terminal emulation server provides 1200 communication sessions between the user terminal emulation application and the set of local I/O user devices and between the user terminal emulation application and the network entity 150. The user terminal emulation server then routes 1202 communication traffic between the network entity and the I/O user devices in the local set for communication services. In routing communication traffic, if the currently missing I/O user device in the local set is determined to no longer be available for communication service and no other I/O user device has the UI capability of the currently missing I/O user device and satisfies the current proximity rule, the user terminal emulation server then determines 1204 that a service interruption condition has occurred. In response to the service interruption condition, the user terminal emulation server responsively suspends 1206 further routing of at least some communication traffic between the network entity and the I/O user devices on the local set, and transmits 1208 a message to the network entity containing information identifying that the communication service lost the currently lost UI capability of the I/O user device.
As described above, the loss of I/O user devices in the set may be compensated for by negotiating with the network entity 150 and/or the user a simplified UI capability for performing the ongoing communication service. The user terminal emulation server may negotiate with network entity 150 for modifications to the combined capability rules. In response to the negotiation, the user terminal emulation server can determine whether the modified set of local I/O user devices satisfies the current proximity rule and satisfies the modification of the combined capabilities rule. The user terminal emulation server may restart further routing of communication traffic between the network entity and the modified set of local I/O user devices when the modified set of local I/O user devices satisfies the modification of the current proximity rule and the combined capabilities rule. The negotiation may result in a need to provide simplified UI capabilities by the set of I/O user devices to satisfy the combined capability rules for the communication service. For example, the combined capability rule may be modified to require a reduced set of UI capabilities for continuing communication services between the network entity and the user.
When a user moves from a previous set of I/O user devices to a future set of I/O user devices while providing a communication service, a user terminal emulation server suspends routing of communication traffic for the communication service to prevent loss of the traffic when the user fails to receive the traffic. The user terminal emulation server may be configured to buffer in memory communication traffic received from the network entity 150 to be routed to the currently lost I/O user device when further routing is suspended. When the modified set of local I/O user devices is provided with a replacement I/O user device having UI capabilities of the currently lost I/O user device and further routing is restarted, the user terminal emulation server can provide the communication traffic buffered in memory to the replacement I/O user device.
As described above, buffered communication traffic may be streamed or otherwise provided at a higher communication rate than it was received from the network entity, such that the user may catch up with the network entity to avoid further increases in the amount of buffered communication traffic. Higher communication rates may enable users to catch up to real time, which may be considered a necessary goal of video conferencing communication services. Thus, providing the communication traffic buffered in the memory to the alternative I/O user device may comprise streaming the communication traffic from the buffer in the memory to the alternative I/O user device at least at a first data communication rate, and once the buffered communication traffic has been emptied by the streaming to the alternative I/O user device, further streaming the communication traffic currently received from the network entity to the alternative I/O user device at a rate no greater than a second data communication rate, wherein the second data communication rate is lower than the first data communication rate.
While the user is on the go, the user may continue to access a portable one of the I/O user devices that enables the communication service to continue but the UI capabilities are degraded. Once the user touches the next set of (remote) I/O user devices, the portable I/O user device may be included in the next set of I/O user devices for continuing to provide communication services. The user terminal emulation server can provide notification to the network entity 150 and/or the user of what UI capabilities have been maintained for the communication service while the user is underway, and can also provide the network entity and/or the user with an estimate of how long it will take the user to reach the next set of I/O user devices to provide enhanced UI capabilities for the communication service.
As described above, when a set of remote I/O user devices is identified that are available to satisfy the combined capabilities rule, the user terminal emulation server can configure the I/O user devices to be shared by more than one user for more than one communication service. For example, a display device may be configured with a split screen where half of the screen is used by a first user for a first communication service and the other half of the screen is used by a second user for a second communication service.
Example scenarios and use cases
When a user carrying a user tag moves into a certain area, the user terminal emulation server may seek to identify UI capabilities from various types of, for example, human-interpretable input/output devices (e.g., microphones, screens, and speakers) or non-human-readable (sensor-like) devices (e.g., cameras, lidar, accelerometers, and GNSS inputs) that may combine to provide combined UI capabilities that satisfy combined capability rules for current or future communication services.
In one scenario, an ongoing communication session between user a (i.e., user tag a) and user B (i.e., user tag B) may include a need for voice communication capabilities for which the user terminal emulation server seeks to identify microphones, speakers, and/or other I/O user devices that may support such voice communication capabilities that are located near the user's current location and/or near other candidate future locations for one or more of the users. When user a desires to extend the communication session to include video communications, user a may lack a camera and/or screen. The user terminal emulation server may responsively decide to re-plan the ongoing travel path for user a so that user a will later (or within a predefined time) enter an area where a public camera (stationary camera) will become available, or may control a movable camera (e.g., transported by unmanned aerial vehicle, person, car, bus, train, etc.) to be carried in proximity to user a.
For example, in a first user path re-planning scenario, the user terminal emulation server may notify user a that the requested UI capabilities will become available for some distance and/or time along a newly proposed route presented to user a. The user terminal emulation server may also transmit information informing user B of the estimated time that user a will be available for video communication, such as identifying that user a will be available to join a video call after 30 seconds and then providing dynamic updates when user a is near the camera/screen location (e.g., "time remaining 20 seconds, 10 seconds, 5 seconds, 4 seconds, 3 seconds, 2 seconds, 1 second … … in-call").
In a second approach where the camera is transported to the location used by user a, whereas the addition of UI capabilities is not handled by the user himself but by a third party (i.e., UAV), the user terminal emulation server can provide information informing users a and B, respectively, of the estimated time of arrival of the additional UI capabilities for use by user a.
In another scenario, for example, where a public camera will become available for user a to use in an ongoing communication service, the user terminal emulation server or connected route planner may guide user a along a certain path to a future location where user a will be within the field of view of the public camera. For example, a public camera may be associated with an I/O user device (e.g., a camera connected to user C's cell phone) carried by a third person (user C). The user terminal emulation server may ask user C whether or not to allow the cellular phone camera to be used for the communication service provided between user a and user B through the network entity 150. The query may actually be an acceptance or rejection of the permission to use the camera, presented to user C, which may be communicated back to the user terminal emulation server. Alternatively or additionally, the query may be processed by the cell phone of user C and/or by the network entity through rules based on a defined set of user terms and conditions, wherein the response acceptance or rejection to the permission is generated by the cell phone and/or the network entity without directly querying user C. When permission is granted, the user terminal emulation server can include the camera of user C's cell phone within the set of I/O user devices through which communication services are provided, and can terminate use of the camera when it is predicted that user a is no longer within the field of view of the camera and/or when communication services are otherwise terminated. In this way, user B may be provided with a video stream from user C's cell phone camera displaying user a as part of the enhanced UI capabilities of the ongoing communication service.
Although some embodiments have been described in the context of transporting a camera by a vehicle or a person, other ways of transporting an I/O user device in proximity to a user are contemplated. For example, a touch screen user input interface, output speaker, input microphone, fingerprint reader, scanner reader, biometric sensor, and/or other UI capabilities may be shipped to a current user location or one or more future locations of the user along a route that has been planned by the user or suggested to the user by the user terminal emulation server to enable the provision of continuous communication services with the user.
Example I/O user Equipment and user terminal Emulation Server
FIG. 13 is a block diagram of hardware circuit components of an I/O user device 130 configured to operate in accordance with some embodiments. The I/O user device 130 may include wired/wireless network interface circuitry 1302, near field communication circuitry 1320, at least one processor circuit 1300 (processor), and at least one memory circuit 1310 (memory). The processor 1300 is connected in communication with other components. The memory 1310 stores program code (e.g., a user terminal emulation application) 1312 that is executed by the processor 1300 to perform the operations disclosed herein. The processor 1300 may include one or more data processing circuits (e.g., microprocessors and/or digital signal processors), which may be collocated or distributed across one or more data networks. The processor 1300 is configured to execute the program code 1312 in the memory 1310 (described below as a non-transitory computer-readable medium) to perform some or all of the operations and methods disclosed herein for one or more embodiments of a mobile electronic device. The I/O user device 130 may include one or more UI component devices including, but not limited to, a microphone 1340, speakers 1350, camera 1330, and display device 1360, as well as a user input interface 1370 (e.g., keyboard, touch screen interface, physical switches, etc.).
Figure 14 is a block diagram of the hardware circuit components of the user terminal emulation server 100 configured to operate in accordance with some embodiments. The user terminal emulation server 100 can include wired/wireless network interface circuitry 1420, a database 120 (e.g., listing I/O user devices, UI capabilities of I/O user devices, communication protocols for communicating with I/O user devices, known proximity to user identifiers, etc.), a display device 1430, a user input interface 1440 (e.g., a keyboard, touch screen interface, physical switch, etc.), at least one processor circuit 1400 (processor), and at least one memory circuit 1410 (memory). Processor 1400 is connected in communication with other components. Memory 1410 may store a user terminal emulation application 1412 that is executed by processor 1400 to perform the operations disclosed herein. Processor 1400 may include one or more data processing circuits (e.g., microprocessors and/or digital signal processors) that may be collocated or distributed across one or more data networks. The processor 1400 is configured to execute computer program instructions in the memory 1410 (described below as a non-transitory computer readable medium) to perform some or all of the operations and methods disclosed herein for one or more embodiments of a mobile electronic device.
Cloud implementation
Alternatively, some or all of the operations described above as being performed by the user terminal emulation server 100 or the I/O user device 130 can be performed by one other device and/or another node that is part of the cloud computing resources. For example, these operations may be performed as network functions near the edge (e.g., in a cloud server or cloud resources of a telecommunications network operator (e.g., in a cloudlan or core network)) and/or may be performed by cloud servers or cloud resources of a media provider (e.g., an iTunes service provider or a Spotify service provider).
Acronyms
3GPP 3rd Generation Partnership Project' third Generation Partnership Project
ACK Acknowledgement
Application, i.e. program, Application
DPM Data Presence Monitor
EC Edge Cloud
Evolved Node B (a.k.a. RBS, Radio Base Station) Evolved Node B (also known as RBS, Radio Base Station)
GW Gateway (also an acronym for Leif GW persion)
ICMP Internet Control Message Protocol
IOD Input and/or Output Device
IODH IOD Handler IOD processor
International Telecommunication Union (ITU International Telecommunication Union)
NACK Non ACK negative acknowledgement
NFC Near Field Communication
RTP Real Time Protocol
RTCP Real Time Control Protocol
SDP Session Description Protocol
SIM Subscriber Identity Module
Software-defined Smartphone (e.g., UE) Software defined by Software of SoftUE (e.g., UE)
SUE SoftUE Soft UE
SR Sender Response
UE User Equipment (UE) User Equipment (UE) User Equipment (UE) User Equipment (UE) equipment (UE equipment) User equipment (UE equipment (UE) equipment (UE equipment) equipment (UE equipment) equipment (UE
UT User Tag User label
Other definitions and examples
In the above description of various embodiments of the inventive concept, it is to be understood that the terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the inventive concept. Unless otherwise defined, all terms (including technical and scientific terms) used herein have the same meaning as commonly understood by one of ordinary skill in the art to which the inventive concepts belong. It will be further understood that terms, such as those defined in commonly used dictionaries, should be interpreted as having a meaning that is consistent with their meaning in the context of this specification and the relevant art and will not be interpreted in an idealized or overly formal sense expressly so defined herein.
When an element is referred to as being "connected," "coupled," "responsive" to another element or variants thereof, it can be directly connected, coupled, or responsive to the other element or intervening elements may be present. In contrast, when an element is referred to as being "directly connected to," "directly coupled to," "directly responsive to" another element or variants thereof, there are no intervening elements present. Like reference numerals refer to like elements throughout. Further, "coupled," "connected," "responsive," or variations thereof as used herein may include wirelessly coupled, connected, or responsive. As used herein, the singular forms "a", "an" and "the" are intended to include the plural forms as well, unless the context clearly indicates otherwise. Well-known functions or constructions may not be described in detail for brevity and/or clarity. The term "and/or" includes any and all combinations of one or more of the associated listed items.
It will be understood that, although the terms "first," "second," "third," etc. may be used herein to describe various elements/operations, these elements/operations should not be limited by these terms. These terms are only used to distinguish one element/operation from another element/operation. Thus, a first element/operation in some embodiments may be termed a second element/operation in other embodiments without departing from the teachings of the present inventive concept. Throughout the specification, the same reference numerals or the same reference indicators denote the same or similar elements.
As used herein, the terms "comprises," "comprising," "includes," "including," "has," "having" or variants thereof, are open-ended and include one or more stated features, integers, elements, steps, components or functions, but do not preclude the presence or addition of one or more other features, integers, elements, steps, components, functions or groups thereof. Further, as used herein, the general abbreviation "e.g." from the latin phrase "exempli gratia" may be used to introduce or designate one or more general instances of a previously mentioned item, for example, and is not intended to limit that item. The general abbreviation "i.e." from the latin phrase "id est" may be used to specify a particular item from a more general narrative.
Example embodiments are described herein with reference to block diagrams and/or flowchart illustrations of computer-implemented methods, apparatus (systems and/or devices) and/or computer program products. It will be understood that blocks of the block diagrams and/or flowchart illustrations, and combinations of blocks in the block diagrams and/or flowchart illustrations, can be implemented by computer program instructions executed by one or more computer circuits. These computer program instructions may be provided to a processor circuit of a general purpose computer circuit, special purpose computer circuit, and/or other programmable data processing circuit to produce a machine, such that the instructions, which execute via the processor of the computer and/or other programmable data processing apparatus, transform and control transistors, values stored in memory locations, and other hardware components within such circuits to implement the functions/acts specified in the block diagrams and/or flowchart block or blocks, thereby creating a means (function) and/or structure for implementing the functions/acts specified in the block diagrams and/or flowchart block or blocks.
These computer program instructions may also be stored in a tangible computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instructions which implement the function/act specified in the block diagrams and/or flowchart block or blocks. Accordingly, embodiments of the inventive concept may be embodied in hardware and/or in software (including firmware, resident software, micro-code, etc.) that runs on a processor (e.g., a digital signal processor), which may be collectively referred to as "circuitry," "a module," or variants thereof.
It should also be noted that, in some alternative implementations, the functions/acts noted in the blocks may occur out of the order noted in the flowcharts. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality/acts involved. Furthermore, the functionality of a given block of the flowchart and/or block diagrams may be separated into multiple blocks and/or the functionality of two or more blocks of the flowchart and/or block diagrams may be at least partially integrated. Finally, other blocks may be added/inserted between the illustrated blocks and/or blocks/operations may be omitted without departing from the scope of the inventive concept. Further, while some of the figures include arrows on communication paths to illustrate the primary direction of communication, it is to be understood that communication may occur in the opposite direction to the depicted arrows.
Many variations and modifications may be made to the embodiments without substantially departing from the principles of the present inventive concept. All such variations and modifications are intended to be included herein within the scope of the present inventive concept. Accordingly, the above-disclosed subject matter is to be considered illustrative, and not restrictive, and the appended examples are intended to cover all such modifications, enhancements, and other embodiments, which fall within the spirit and scope of the inventive concept. Thus, to the maximum extent allowed by law, the scope of the present inventive concept is to be determined by the broadest permissible interpretation of the present disclosure including the following examples of embodiments and their equivalents, and shall not be restricted or limited by the foregoing detailed description.

Claims (20)

1. A user terminal emulation server (100) for providing communication services using a set of input and/or output, I/O, user devices (130), the user terminal emulation server (100) comprising:
at least one processor; and
at least one memory storing program code executable by the at least one processor to perform operations comprising:
maintaining (1000), based on the content of the received message, a database identifying a network address of an I/O user device, user interface, UI, capabilities of the I/O user device, and a location of the I/O user device;
registering (1002) a network address of a user terminal emulation application and an identity of a user with a network entity providing a communication service, the user terminal emulation application being executed by the user terminal emulation server;
receiving (1004) a communication request from the network entity for establishing a communication service with the user; and
in response to the communication request, determining (1006) whether a set of local I/O user devices of I/O user devices identified by the database satisfies a current proximity rule by being located near a current location of the user and satisfies a combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on UI capabilities identified by the database for the set of local I/O user devices and based on content of the communication request; and
when it is determined that no set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, further determining (1008) whether a set of remote I/O user devices of the I/O user devices identified by the database satisfies a future proximity rule by being located in a vicinity of a future location of the user and the combined capabilities rule that can be combined to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities identified by the database for the set of remote I/O user devices and based on the content of the communication request.
2. The user terminal emulation server of claim 1, based on determining (1008) that the set of remote I/O user devices satisfies the future proximity rule and satisfies the combined capabilities rule, the program code further performing operations comprising:
providing (1012) communication sessions between the user terminal emulation application and the set of remote I/O user devices and between the user terminal emulation application and the network entity;
routing (1014), for the communication service, communication traffic received from at least one I/O user device in the remote set to the network entity; and
for each data type received as communication traffic from the network entity, one of the I/O user devices is selected (1016) from the set of remote I/O user devices based on characteristics of the data type matching UI capabilities identified by the database for the one of the I/O user devices, and data of the data type is then routed to a network address of the selected one of the I/O user devices.
3. The user terminal emulation server of any of claims 1-2, wherein the operations further comprise:
generating an estimated time of arrival of the user at the future location; and
transmitting a message to the network entity, the message containing information indicative of the estimated time of arrival.
4. The user terminal emulation server of any of claims 1-3, wherein the operations further comprise:
generating an estimated time of arrival of the user at the future location; and
transmitting the message to an I/O user device currently located in proximity to the user and having UI capabilities capable of outputting message content to the user, wherein the message contains information indicative of the estimated time of arrival.
5. The user terminal emulation server of any of claims 1-4, where the operation of determining (1008) whether a set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule comprises:
determining whether the user is in progress;
determining a direction of travel in response to the user being in progress;
determining a projected path of travel for the user based on the direction of travel; and
preferentially identifying, among the I/O user devices identified by the database, a set of remote I/O user devices that satisfy the future proximity rule and satisfy the combined capability rule by being located near the future location along the projected path of travel.
6. The user terminal emulation server of any of claims 1-5, where the operation of determining (1008) whether a set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule comprises:
determining whether the user is in progress;
in response to the user being in progress, obtaining a predicted route that the user is traveling from a route planner; and
preferentially identifying, among the I/O user devices identified by the database, a set of remote I/O user devices that satisfy the future proximity rule and satisfy the combined capability rule by being located near the future location along the predicted route.
7. The user terminal emulation server of claim 6, wherein the operations further comprise:
performing machine learning to update a historical route data structure to store information identifying machine-tracked routes traveled by the user over time,
wherein the operation of obtaining a predicted route that the user is traveling from a route planner comprises: accessing the historical route data structure to obtain the predicted route using at least one of: a time of day; day of the week; a location of the user; and a calendar meeting location included in the user calendar application.
8. The user terminal emulation server of any of claims 6-7, wherein the operations further comprise:
in response to not identifying a set of remote I/O user devices that satisfy the future proximity rule and satisfy the combined capabilities rule by being located near the future location along the predicted route, performing the following:
determining whether a set of off-route I/O user devices of the I/O user devices identified by the database satisfies an off-route future proximity rule by being located near an off-route location within a threshold distance from a predicted route and satisfies the combined capabilities rule; and
when it is determined that the off-route set of I/O user devices satisfies the off-route future proximity rule and the combined capabilities rule,
initiating generation of an alternative route, providing guidance to the user for navigating along the alternative route to the set of off-route I/O user devices, and retaining the set of off-route I/O user devices for use by the user for the communication service;
based on determining that the user has become located near the off-route set of I/O user devices, providing communication sessions between the user terminal emulation application and the off-route set of I/O user devices and between the user terminal emulation application and the network entity, and routing communication traffic received from at least one I/O user device in the off-route set to the network entity for the communication service.
9. The user terminal emulation server of any of claims 1-8, where the operation of determining (1008) whether a set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule comprises:
identifying an I/O user device of a mobile terminal type registered by another user, the I/O user device having a location that satisfies the future proximity rule and having UI capabilities that can be combined with UI capabilities of at least one other I/O user device to satisfy the combined capability rule, and wherein the at least one other I/O user device is determined to also satisfy the future proximity rule;
transmitting a request to the mobile terminal operated by the other user to provide the communication service to the user using the mobile terminal; and
in response to receiving an indicated acknowledgement of acceptance of the request for the mobile terminal, including the mobile terminal and the at least one other I/O user device in the set of remote I/O user devices to provide the communication service to the user.
10. The user terminal emulation server of any of claims 1-9, where the operation of determining (1008) whether a set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule comprises:
identifying a remotely operated vehicle transporting an I/O user device that is relocatable to the future location of the user to satisfy the future proximity rule and has UI capabilities that are combinable with UI capabilities of at least one other I/O user device to satisfy the combined capability rule, and wherein the at least one other I/O user device is determined to also satisfy the future proximity rule;
controlling the remotely operated vehicle to move to a new location that satisfies the future proximity rule; and
including the remotely operated vehicle and the at least one other I/O user device in the set of remote I/O user devices to provide the communication service to the user.
11. The user terminal emulation server of any of claims 1-9, where the operation of determining (1008) whether a set of remote I/O user devices satisfies the future proximity rule and the combined capabilities rule comprises:
selecting at least one of: a camera having a field of view orientable to steer to the future location to satisfy the future proximity rule, and wherein the camera has a UI capability combinable with a UI capability of at least one other I/O user device to satisfy the combined capability rule; and a microphone having a sensitivity gain that is orientable to the future position so as to satisfy the future proximity rule, and wherein the microphone has a UI capability that is combinable with a UI capability of at least one other I/O user device to satisfy the combined capability rule;
controlling the selected at least one of: the camera directionally steering the field of view to the future location; and the microphone directionally steering the sensitivity gain to the future position; and
including the selected at least one of the camera and the microphone in the set of remote I/O user devices to provide the communication service to the user.
12. The user terminal emulation server of any of claims 1-11, when it is determined (1006) that the current proximity rule is satisfied by a set of local I/O user devices and the combined capabilities rule is satisfied:
providing (1200) communication sessions between the user terminal emulation application and the set of local I/O user devices and between the user terminal emulation application and the network entity;
routing (1202) communication traffic between the network entity and I/O user equipment in the local set for the communication service;
while routing the communication traffic, determining (1204) that a service disruption condition has occurred when a currently lost I/O user device in the local set is determined to no longer be available for communication service and no other I/O user devices have UI capabilities of the currently lost I/O user device and satisfy the current proximity rule;
suspending (1206) further routing of at least some communication traffic between the network entity and the I/O user equipment on the local set in response to the service disruption condition; and
transmitting (1208) a message to the network entity, the message containing information identifying that the communication service loses UI capability of the currently lost I/O user device.
13. The user terminal emulation server of claim 12, wherein the operations further comprise:
negotiating with the network entity a modification to the combined capability rule;
determining, in response to the negotiating, whether a modified set of local I/O user devices satisfies the current proximity rule and satisfies the modification to the combined capabilities rule;
restarting further routing of communication traffic between the network entity and the modified set of local I/O user devices when the modified set of local I/O user devices satisfies the current proximity rule and the modification to the combined capabilities rule.
14. The user terminal emulation server of claim 13, wherein the combined capabilities rule requires a reduced set of UI capabilities for continuing communication services between the network entity and the user.
15. The user terminal emulation server of claim 13, wherein the operations further comprise:
buffering, in memory, communication traffic received from the network entity to be routed to the currently lost I/O user equipment while the further routing is suspended;
providing communication traffic buffered in memory to the alternate I/O user device when the modified set of local I/O user devices is provided with an alternate I/O user device having UI capabilities of the currently lost I/O user device and the further routing is restarted.
16. The user terminal emulation server of claim 15, wherein the operation of providing the communication traffic buffered in memory to the alternative I/O user device comprises: streaming the communication traffic from the buffer in memory to the alternative I/O user device at least at a first data communication rate, and once the buffered communication traffic has been emptied by streaming to the alternative I/O user device, further streaming communication traffic currently received from the network entity to the alternative I/O user device at a rate no greater than a second data communication rate, the second data communication rate being lower than the first data communication rate.
17. A method for use by a user terminal emulation server (100) for providing communication services using a set of input and/or output I/O user devices (130), the method comprising:
maintaining a database identifying a network address of an I/O user device, User Interface (UI) capabilities of the I/O user device, and a location of the I/O user device based on content of a received message;
registering a network address of a user terminal emulation application and an identity of a user with a network entity providing a communication service, the user terminal emulation application being executed by the user terminal emulation server;
receiving a communication request from the network entity for establishing a communication service with the user; and
in response to the communication request, determining whether a set of local I/O user devices of the I/O user devices identified by the database satisfy a current proximity rule by being located near a current location of the user and satisfy a combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on UI capabilities identified by the database for the set of local I/O user devices and based on content of the communication request; and
when it is determined that no set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, further determining whether a set of remote I/O user devices of the I/O user devices identified by the database satisfies a future proximity rule by being located near a future location of the user and the combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application is satisfied to provide the communication service determined based on the UI capabilities identified by the database for the set of remote I/O user devices and based on the content of the communication request.
18. The method of claim 18, further comprising:
performing the operations of any of claims 2 to 16.
19. A computer program product comprising a non-transitory computer-readable medium storing program code for execution by at least one processor (1500) of a user terminal emulation server (100) to provide communication services using a set of input and/or output I/O user devices (130), the program code when executed by the at least one processor (1500) performing operations comprising:
maintaining a database identifying a network address of an I/O user device, User Interface (UI) capabilities of the I/O user device, and a location of the I/O user device based on content of a received message;
registering a network address of a user terminal emulation application and an identity of a user with a network entity providing a communication service, the user terminal emulation application being executed by the user terminal emulation server;
receiving a communication request from the network entity for establishing a communication service with the user; and
in response to the communication request, determining whether a set of local I/O user devices of the I/O user devices identified by the database satisfy a current proximity rule by being located near a current location of the user and satisfy a combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on UI capabilities identified by the database for the set of local I/O user devices and based on content of the communication request; and
when it is determined that no set of local I/O user devices satisfies the current proximity rule and satisfies the combined capabilities rule, further determining whether a set of remote I/O user devices of the I/O user devices identified by the database satisfies a future proximity rule by being located near a future location of the user and satisfies a combined capabilities rule combinable to provide a combined I/O user interface for the user to interface with the user terminal emulation application to provide the communication service determined based on the UI capabilities identified by the database for the set of remote I/O user devices and based on the content of the communication request.
20. The computer program product according to claim 19, wherein the program code, when executed by the at least one processor (1500), further performs the operations according to any of claims 2 to 16.
CN201980096046.9A 2019-06-11 2019-06-11 Providing communication services using a set of I/O user devices Active CN113785555B (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/EP2019/065178 WO2020249190A1 (en) 2019-06-11 2019-06-11 Providing communication services using sets of i/o user devices

Publications (2)

Publication Number Publication Date
CN113785555A true CN113785555A (en) 2021-12-10
CN113785555B CN113785555B (en) 2024-01-12

Family

ID=66912808

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201980096046.9A Active CN113785555B (en) 2019-06-11 2019-06-11 Providing communication services using a set of I/O user devices

Country Status (5)

Country Link
US (1) US11736537B2 (en)
EP (1) EP3984204B1 (en)
CN (1) CN113785555B (en)
MX (1) MX2021014813A (en)
WO (1) WO2020249190A1 (en)

Families Citing this family (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10523622B2 (en) * 2014-05-21 2019-12-31 Match Group, Llc System and method for user communication in a network
US11212130B2 (en) * 2019-01-15 2021-12-28 Telefonaktiebolaget Lm Ericsson (Publ) Providing communication services using sets of I/O devices
CA3144124A1 (en) * 2019-06-20 2020-12-24 Telefonaktiebolaget Lm Ericsson (Publ) Providing communication services using sets of i/o user devices
US11907613B2 (en) * 2019-06-24 2024-02-20 Intellectual Discovery Co., Ltd. Method, device, and computer program for audio routing in wireless communication system, and recording medium therefor
US12069114B2 (en) * 2020-04-24 2024-08-20 Ringcentral, Inc. Cloud-based communication system for autonomously providing collaborative communication events
US20240275843A1 (en) * 2021-06-08 2024-08-15 Telefonaktiebolaget Lm Ericsson (Publ) Providing communication services through i/o user devices to a user
EP4359924A1 (en) * 2021-06-22 2024-05-01 Telefonaktiebolaget LM Ericsson (publ) Providing a communication service through i/o devices to a user
CN113741442B (en) * 2021-08-25 2022-08-02 中国矿业大学 Monorail crane automatic driving system and method based on digital twin driving
WO2023085543A1 (en) * 2021-11-10 2023-05-19 Samsung Electronics Co., Ltd. Method and electronic device for generating activity reminder in iot environment
US20240005366A1 (en) * 2022-07-01 2024-01-04 Birdeye, Inc. System and method to manage communications of customers associated to a business
US11863396B1 (en) * 2022-11-18 2024-01-02 Packet Forensics, LLC Passive assessment of signal relays amongst bystanders
WO2024186238A1 (en) * 2023-03-06 2024-09-12 Telefonaktiebolaget Lm Ericsson (Publ) Radio cell load balancing for communication services via i/o user devices performing user terminal emulation as a cloud computing service
WO2024199678A1 (en) * 2023-03-31 2024-10-03 Telefonaktiebolaget Lm Ericsson (Publ) Secure allocation of a user terminal emulator for authenticated user who is registered to another user terminal emulator

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060091205A1 (en) * 2004-11-04 2006-05-04 International Business Machines Corporation Routing telecommunications to a user in dependence upon location
US20140297251A1 (en) * 2013-03-28 2014-10-02 Sphere 3D Inc. Systems and methods for accessing remote resources for emulation
CN104488293A (en) * 2012-05-29 2015-04-01 瑞典爱立信有限公司 Mobile terminal relaying of event notifications in an intelligent transportation system
US20160266916A1 (en) * 2015-03-10 2016-09-15 Giovanni Morelli Systems and Methods for Contextually Allocating Emulation Resources
US20170026974A1 (en) * 2015-07-24 2017-01-26 International Business Machines Corporation Facilitating location of and interaction with a convenient communication device

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6795808B1 (en) 2000-10-30 2004-09-21 Koninklijke Philips Electronics N.V. User interface/entertainment device that simulates personal interaction and charges external database with relevant data
US9510257B2 (en) * 2015-02-26 2016-11-29 Qualcomm Incorporated Opportunistic, location-predictive, server-mediated peer-to-peer offloading
WO2018063163A1 (en) * 2016-09-27 2018-04-05 Google Llc Selective simulation of virtualized hardware inputs
US11637907B2 (en) * 2016-11-16 2023-04-25 Verizon Patent And Licensing Inc. Systems and methods for tracking device IDs for virtualized applications
US11212130B2 (en) * 2019-01-15 2021-12-28 Telefonaktiebolaget Lm Ericsson (Publ) Providing communication services using sets of I/O devices
CA3144124A1 (en) * 2019-06-20 2020-12-24 Telefonaktiebolaget Lm Ericsson (Publ) Providing communication services using sets of i/o user devices

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060091205A1 (en) * 2004-11-04 2006-05-04 International Business Machines Corporation Routing telecommunications to a user in dependence upon location
CN104488293A (en) * 2012-05-29 2015-04-01 瑞典爱立信有限公司 Mobile terminal relaying of event notifications in an intelligent transportation system
US20140297251A1 (en) * 2013-03-28 2014-10-02 Sphere 3D Inc. Systems and methods for accessing remote resources for emulation
US20160266916A1 (en) * 2015-03-10 2016-09-15 Giovanni Morelli Systems and Methods for Contextually Allocating Emulation Resources
US20170026974A1 (en) * 2015-07-24 2017-01-26 International Business Machines Corporation Facilitating location of and interaction with a convenient communication device

Also Published As

Publication number Publication date
EP3984204A1 (en) 2022-04-20
MX2021014813A (en) 2022-01-18
CN113785555B (en) 2024-01-12
EP3984204B1 (en) 2022-11-09
US20220217186A1 (en) 2022-07-07
US11736537B2 (en) 2023-08-22
WO2020249190A1 (en) 2020-12-17

Similar Documents

Publication Publication Date Title
CN113785555B (en) Providing communication services using a set of I/O user devices
JP7257526B2 (en) Providing communication services using a set of I/O devices
US20240275843A1 (en) Providing communication services through i/o user devices to a user
US20200021481A1 (en) Generic and extensible client agent for enabling third party communications
US9936364B2 (en) Mobile device wireless identifier assignment for emergency calls
US11503440B2 (en) Methods and systems for providing enterprise services to wearable and mobile devices
US11503426B2 (en) Methods and systems for managing conferencing features using a distributed communication controller
TWI749534B (en) Providing communication services using sets of i/o user devices
US20220417813A1 (en) Methods and apparatus for application service relocation for multimedia edge services
US20130079029A1 (en) Multi-modality communication network auto-activation
KR101545587B1 (en) Video conference system and method thereof
US20240259946A1 (en) Providing a communication service through i/o devices to a user
EP4422150A1 (en) Dns configuration processing method and apparatus, and communication device and storage medium
WO2023213395A1 (en) Echo cancellation for i/o user devices performing user terminal emulation as a cloud computing service
WO2023081672A1 (en) Assisting local service management on edge terminal devices
CN117768834A (en) Position guidance processing method and device, storage medium and electronic device

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant