Videoconferencing and other forms of virtual collaboration allow the real-time exchange of video, audio, and/or other data among systems in remote locations. That real-time exchange of data often occurs over a computer network in the form of streaming video and/or audio data. Many systems can establish media streams at the beginning of an event, but cannot transition smoothly to new configurations as various systems enter and/or leave an event.
Additionally, numerous methods have been devised to connect systems with identical or substantially compatible capabilities. However, managing events involving systems with differing capabilities and/or systems connected to different networks is substantially more difficult. For example, few existing methods for event configuration adequately negotiate media connections among heterogeneous systems and/or heterogeneous networks. Those systems that require user input to establish connections detract from the collaborative experience. Other systems may establish connections automatically, but base media support on sometimes erroneous assumptions of the capabilities of participating systems.
One established protocol, Session Initiation Protocol (SIP), allows systems to negotiate media connections among multiple devices. However, SIP does not consider the relationships among media streams in order to maintain virtual relationships among participants. Moreover, SIP does not communicate the availability of advanced capabilities that would support optimal media connections. Current virtual collaboration systems do not adequately support systems with varying levels of functionality and/or allow dynamic reconfiguration of participating systems without interruption of an event in progress. They also lack support for the establishment of consistent virtual relationships among participating systems, such as participating systems that have different capabilities and/or that are connected to different networks. Additionally, they do not allow subdivision of resources within a system participating in a virtual collaboration event. Moreover, current virtual collaboration systems do not allow representation of one or more systems connected to one network, as one or more virtual systems connected to a different network.
The accompanying drawings illustrate various examples of the present systems and methods and are a part of the disclosure. The illustrated examples are merely examples of the present systems and methods and do not limit the scope of the disclosure.
Throughout the drawings, identical reference numbers may designate similar, but not necessarily identical, elements.
The present illustrative methods and systems may be adapted to manage the configuration of virtual collaboration systems, such as virtual collaboration systems that involve nodes that have different capabilities and/or that are connected to different networks. Specifically, the present illustrative systems and methods may, among other things, intrinsically consider the relationships among related media streams, manage and maintain the virtual relationships among nodes to optimize the directives to the nodes to support a new topology, support a variety of proprietary and industry-standard communications mechanisms while managing one or more of the nodes equivalently in the event itself, and/or subdivide resources within one or more of the participating nodes. Further details of the present illustrative virtual collaboration systems and methods will be provided below.
As used in the present disclosure and in the appended claims, the term “media” is defined to include text, video, sound, images, data, and/or any other information that may be transmitted over a computer network.
Additionally, as used in the present disclosure and in the appended claims, the term “node” is defined to include any system with one or more components configured to receive, present, and/or transmit media with a remote system directly and/or through a network. Suitable node systems may include videoconferencing studio(s), computer system(s), notebook computer(s), telephone(s), personal digital assistant(s) (PDAs), or any combination of the previously mentioned or similar devices. A node may be a physical node or a simulated node. Unless specified as the former or the latter, the term “node” refers to either or both.
Physical nodes include one or more components that are independent from the components of a host system or hoster, and are configured to receive, present, and/or transmit media with a remote system directly and/or through a network. In contrast, simulated nodes include one or more components that are associated with and/or part of a host system or hoster. Those components of the hoster are configured to receive, present, and/or transmit media with a remote system directly and/or through a network.
In some embodiments, one or more components of the virtual collaboration system and/or other nodes interact with the simulated nodes as if those simulated nodes were separate from the hoster and/or included their own components independent of the hoster. In other words, from the perspective of the physical nodes and one or more components of the virtual collaboration system, the simulated nodes may receive, generate, and/or transmit signals and/or media streams even though a host system or hoster is physically receiving, generating, and/or transmitting those signals and/or streams. In some embodiments, the virtual collaboration system and/or other nodes interact with the simulated nodes with the recognition that those simulated nodes depend on the components of a hoster.
Similarly, as used in the present disclosure and in the appended claims, the term “event” is defined to include any designated time and/or virtual meeting place providing systems a framework to exchange information. An event allows at least one node to transmit and receive media information and/or media streams. According to some embodiments, the event exists separate and distinct from nodes participating in collaboration. Further, an event may exist while nodes are exchanging information and also may exist while no nodes are participating, such as before any nodes have joined an event. An event also may be referred to as a “session.”
Further, as used in the present disclosure and in the appended claims, the term “topology” is defined to include each system associated with an event and its respective configuration, state, and/or relationship to other systems associated with the event. A topology may include node(s), hoster(s), event focus(es), event manager(s), virtual relationships among nodes, mode of participation of the node(s) and/or the hoster(s), and/or media streams associated with the event.
Moreover, as used in the present illustrative disclosure, the terms “subsystem” and “module” may be used interchangeably to include any number of hardware, software, firmware components, or any combination thereof. As used in the present disclosure, the subsystems and modules may be a part of and/or hosted by one or more computing devices, including server(s), personal computer(s), personal digital assistant(s), and/or any other processor containing apparatus. Various subsystems and modules may perform differing functions and/or roles and together may remain a single unit, program, device, and/or system.
In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present systems and methods. It will be apparent, however, to one skilled in the art that the present systems and methods may be practiced without these specific details. Reference in the disclosure to “one example” or “an example” means that a particular feature, structure, and/or characteristic described in connection with the example is included in at least one example. The appearance of the phrase “in one example” in various places in the disclosure are not necessarily all referring to the same example.
As illustrated in
Second nodes 110 may be communicatively coupled to any suitable network(s) and may include physical node(s) and/or simulated node(s). The second nodes that are physical nodes may be referred to as “second physical nodes,” while the second nodes that are simulated nodes may be referred to as “second simulated nodes.” Although three of first nodes 108 and two of second nodes 110 are shown, any suitable number of first and/or second nodes may be communicatively coupled to the event manager system. In some embodiments, first nodes 108 may be communicatively coupled to a first network, while second nodes 110 may be communicatively coupled to a second network that is different from the first network.
Network 102 may be a single data network or may include any number of communicatively coupled networks. Particularly, according to some embodiments, network(s) 102 may include different types of networks, such as local area network(s) (LANs), wide area network(s) (WANs), metropolitan area network(s), wireless network(s), virtual private network(s) (VPNs), Ethernet network(s), token ring network(s), public switched telephone network(s) (PSTNs), general switched telephone network(s) (GSTNs), switched circuit network(s) (SCNs), integrated services digital network(s) (ISDNs), and/or proprietary network(s).
Additionally, according to some embodiments, network(s) 102 also may employ any suitable networking protocol including transmission control protocol/internet protocol (TCP/IP), hypertext transfer protocol (HTTP), file transfer protocol (FTP), T.120, Q.931, stream control transmission protocol (SCTP), multi-protocol label switching (MPLS), point-to-point protocol (PPP), real-time protocol (RTP), real-time control protocol (RTCP), real-time streaming protocol (RTSP), and/or user datagram protocol (UDP). Any suitable combination of network types and network protocols may be used, particularly when there are two or more networks, such as the first and second networks, connected to the event manager system.
Additionally, according to some embodiments, network(s) 102 also may employ any suitable call signaling protocols or connection management protocols, such as Session Initiation Protocol (SIP) and H.323. The network type, network protocols, and the connection management protocols may collectively be referred to as “network characteristics.” Any suitable combination of network characteristics may be used, particularly when there are two or more networks, such as first and second networks, connected to the event manager system. The second network may be referred as having “different network characteristics” from the first network if those networks differ in network type, network protocol, and/or connection management protocol.
Use of the various network protocols and/or connection management protocols may be harmonized by event focus 24, which may translate data to and/or from a protocol preferred by event manager 26, as further described below. Alternatively, or additionally, hoster 22 may convert network protocol(s) to harmonize the various network protocols used by the networks. For example, hoster 22 may convert network protocols such that simulated nodes generated by the hoster use network protocols that are compatible with other first and/or second nodes.
As discussed, nodes 100 may include physical nodes 111 and simulated nodes 27. One or more of nodes 100 that are participating in an event may be referenced during the event through a unique identifier. That identifier may be intrinsic to the system, connection dependent such as IP address or telephone number, assigned by the event manager based on event properties, and/or decided by another policy asserted by the system.
As shown, physical node 111 may include any suitable number of media devices 122, which may include any suitable structure configured to receive media streams 112, display and/or present the received media streams (such as media output 114), generate or form media streams 112 (such as from media inputs 115), and/or transmit the generated media streams. In some embodiments, media streams 112 may be received from and/or transmitted to other nodes 100 and/or hoster 22. According to some embodiments, physical node 111 may be in the form of a telephone, which may include a speaker and a microphone as media devices 122. Alternatively, or additionally, the media devices may include microphone(s), camera(s), video screen(s), keyboard(s), scanner(s), and/or other input and/or output device(s).
Media device 122 may comprise any hardware and/or software element(s) capable of interfacing with one or more other nodes 100, the hoster, and/or one or more networks 102. One or more of the media devices may be configured to receive media streams 112, and/or to reproduce and/or present the received media streams in a manner discernable to an attendee. Physical node 111 also may include one or more environment devices 126, which may include any suitable structure configured to adjust the environment of that node and/or support one or more functions of one or more other nodes 100 and/or the hoster. The environment devices may include participation capabilities not directly related to media stream connections. For example, environment devices 126 may change zoom setting(s) of one or more cameras, and/or may adjust lighting.
According to some embodiments, media devices 122 may be communicatively coupled to various possible media streams 112. Any number of media streams 112 may be connected to the media devices, according to the event topology and/or node capabilities. The coupled media streams may be heterogeneous and/or may include media of different types. According to some embodiments, the physical node may simultaneously transmit and/or receive media streams 112 comprising audio data only, video and audio, video and audio from a specified camera position, and/or collaboration data from a computer display to different nodes participating in an event.
Media streams 112 connected across two or more networks 102 may exchange data in a variety of formats. The media streams or media information transmitted and/or received may conform to coding and decoding standards including G.711, H.261, H.263, H.264, G.723, common intermediate format (CIF), and/or proprietary standard(s). Additionally, or alternatively, any suitable computer-readable file format may be transmitted to facilitate the exchange of text, sound, video, data, and/or other media types.
As shown in
The various modes of participation may be termed intents, and may include n-way audio and video exchange, audio exchange only, audio and high-resolution video, audio and low-resolution video, dynamically selected video display, audio and graphic display of collaboration data, audio and video receipt without transmission, and/or any other combination of media input and/or output. The intent of a physical node may be further defined to include actual and/or desirable relationships present among media devices 122, media streams 112, and other nodes 100, which may be in addition to the specific combination of features and/or media devices 122 already activated to receive and/or transmit the media streams. Additionally, or alternatively, the intent of a physical node may include aspects that influence environment considerations. For example, the number of seats to show in an event, which may, for example, impact zoom setting(s) of one or more cameras.
As shown in
As physical node 111 modifies its prioritized intents 132, node request 120 may be sent to the event manager system. In some embodiments, node requests 120 may be sent to the event focus and/or the hoster. In one example, the node request may comprise one or more acts of connection, such as dialing a telephone number. In another example, the node request may include the prioritized intents and information about the capabilities of the physical node transmitting the node request. The node type, which may indicate capabilities of the physical node and/or relationships among the media devices, is an example of information about capabilities, and may be summarized by a token. For example, the token may be “B2B6,” which may imply “three displays, three cameras, three microphones, one speaker system.” Additionally, or alternatively, the node type and/or associated token may indicate relationships among media devices 122, such as the positioning of three displays to the left, right, and center relative to an attendee.
A physical node may not automatically send the same information of its capabilities and relationships in every situation. Physical node 111 may repeatedly select and/or alter the description of capabilities and/or relationships to disclose. For example, if physical node 111 includes three displays but the center display may be broken or in use, that node may transmit information representing only two displays, one to the right and one to the left of an attendee. Thus, the information about capabilities and relationships of the physical node that event manager may receive may be indicated through the node type and/or prioritized intents 132. The node request may additionally, or alternatively, comprise a form of identification. Although particular components are shown for physical node 111, one or more of the physical nodes may alternatively, or additionally, include one or more other components.
For example, hoster 22 may be configured to receive first media streams 28 transmitted from at least one first node 108 to at least one of simulated node 27, and/or to transmit the first media streams to at least one second node 110. Hoster 22 may additionally, or alternatively, be configured to receive second media streams 30 from at least one second node, and/or to transmit the second media streams from at least one of simulated node 27 to the at least one first node. In some embodiments, first nodes 108 and/or simulated nodes 27 may be communicatively coupled to a first network, while second nodes 110 may be communicatively coupled to a second network that is different from the first network.
Additionally, or alternatively, hoster 22 may be configured to receive inputs 32 and/or system directives 34, and/or to transmit node requests 36. The physical form of hoster 22 may include hardware and/or software/firmware and may include various components, such as coding/decoding mechanisms, media and/or control connector(s), and/or any other system capable of connecting to and/or transmitting data over one or more networks.
For example, hoster 22 may include a synthetic bridge that may remove all network protocol information from second nodes 110 before transferring data over to first nodes 108, event focus 24, and/or event manager 26. Examples of synthetic bridges are described in PCT Patent Application No. PCT/US2007/074851 entitled “Synthetic Bridging,” and filed Jul. 31, 2007. The complete disclosure of that application is herein incorporated by reference for all purposes.
Additionally, or alternatively, hoster 22 may include one or more coding/decoding mechanisms and one or more management systems supported on one or more compute platforms. Alternatively, or additionally, hoster 22 may include at least some components of telephone(s), personal digital assistant(s), laptop(s), computer system(s), video conferencing studio(s), and/or other system(s) capable of connecting to and transmitting data over at least one network.
Hoster 22 may be referenced during an event through a unique identifier, while one or more simulated nodes generated by the hoster may have their own unique identifiers. Those identifiers may be intrinsic to the system, connection dependent such as IP address or telephone number, assigned by the event manager based on event properties, and/or decided by another policy asserted by the system.
As shown, hoster 22 may include a node generator 37, a first distributor 38, and a second distributor 40. Node generator 37 may include any suitable structure configured to generate one or more simulated nodes 27. Simulated nodes 27 may include one or more components and/or one or more functions of physical nodes 111 described above, as provided by hoster 22. For example, from the perspective of the first physical nodes, the event focus, and the event manager, simulated nodes 27 may include a manager and media devices similar to the first physical nodes. Any suitable number of simulated nodes 27 may be generated by the hoster. In some embodiments, at least one first simulated node is generated by the node generator for each second node communicatively coupled to the hoster.
First distributor 38 may include any suitable structure configured to receive second media streams 30 from at least a second node, and/or to transmit the received second media streams from at least one simulated node 27 to at least one first node 108. Second distributor 40 may include any suitable structure configured to receive first media streams 28 transmitted from at least a first node to at least one simulated node 27, and/or to transmit the received first media streams to at least one second node 110.
In some embodiments, first distributor 38 may include a second compositor 44, which may include any suitable structure configured to form second composite media streams 48 from the received second media streams.
In some embodiments, second distributor 40 may include a first compositor 42, which may include any suitable structure configured to form first composite media streams 46 from the received first media streams. The first and second compositors may include any suitable structure configured to combine and/or arrange outputs from multiple media streams into a single output. For example, the first and/or second compositors may combine and/or arrange video images from multiple media streams into a single image. Examples of presentation of first and second composite media streams are provided in
As shown in
As shown in
Additionally, manager 50 may replicate its event participation logic within the one or more simulated nodes, such as providing one or more of the simulated nodes with its own virtual manager, based, at least in part, on the received signals. That replication may allow other nodes 100, such as first nodes 108, to interact with those simulated nodes without recognizing the dependence of the simulated nodes on the hoster. Alternatively, or additionally, manager 50 may represent the hoster multiple times under different guises, such as the one or more simulated nodes and/or the hoster itself, based, at least in part, on the received signals. The manager may allocate one or more of its resources or components, and/or one or more portions of those resources, for the one or more simulated nodes.
As hoster 22 modifies its prioritized intents 54, node requests 36 may be sent and/or transmitted from one or more of the simulated nodes to event focus 24 and/or event manager 26. In one example, the node request may comprise one or more acts of connection, such as connecting one or more simulated nodes to an event that may include one or more first nodes 108 participating. In another example, the node request may include the list of prioritized intents and information about the capabilities and/or preferred modes of participation of the simulated node.
In some embodiments, hoster 22 may include any suitable number of media devices 56, as shown in
Media devices 56 may comprise any hardware and/or software element(s) capable of interfacing with the first distributor, the second distributor, one or more other nodes 100, and/or one or more networks 102. One or more of the media devices may be configured to receive media streams from the first distributor and/or the second distributor, and/or reproduce and/or present the received media streams in a manner discernable to an attendee. Hoster 22′ may additionally, or alternatively, include one or more environment devices 60, which may include any suitable structure configured to adjust the environment of the hoster and/or support one or more functions of one or more other nodes 100.
According to some embodiments, media devices 56 may be communicatively coupled to various possible media streams. Any number of media streams from the first distributor and/or the second distributor may be connected to the media devices, according to the event topology and capabilities of the hoster. The coupled media streams may be heterogeneous and/or may include media of different types. In some embodiments, such as where the hoster includes one or more media devices 56 and/or one or more environment devices, manager 50 of the hoster may additionally, or alternatively, be adapted to receive and/or process hoster directives 61 and configure the first distributor, the second distributor, the node generator, the media device(s) and/or the environment device(s) based, at least in part, on the received directives. Additionally, or alternatively, manager 50 may send hoster requests 62 to the event focus and/or the event manager based, at least in part, on the prioritized intents. Alternatively, or additionally, the manager may generate notifications 51 to provide information to users and/or attendees of the configuration of media devices, node(s) participating and/or requesting participation in the event, etc.
Although a single hoster is shown, event manager system 20 may include two or more hosters, which may distribute media streams among nodes communicatively coupled to one or more networks. For example, a first hoster may be configured to represent one or more nodes communicatively coupled to a second network as one or more simulated nodes communicatively coupled to a first network, while a second hoster may be configured to represent one or more nodes communicatively coupled to a third network as one or more simulated nodes communicatively coupled to the first network.
Event focus 24 may include a common communication interface 64 and a network protocol translation 66, according to some embodiments. The common communication interface and/or the network protocol translation may allow the event focus to receive node requests 36, node requests 120, and/or hoster requests 62 from one or more nodes 100 and/or hoster 22, translate those requests, forward the requests to event manager 26 and receive selected intents 68 and/or media connection assignments 70 from the event manager. In some embodiments, the event focus may receive requests from the first nodes and/or the hoster.
The selected intents and media connection assignments may then be translated to directives by the event focus for transmission to selected nodes, selected simulated nodes, and/or the hoster. The use of event focus 24 to forward and process requests to the event manager may eliminate a need for individual nodes 100 to guarantee compatibility with potentially unforeseen network topologies and/or protocols.
In some embodiments, the simulated nodes may be made compatible with the network topologies and/or protocols of the first physical nodes by the hoster. Alternatively, or additionally, the nodes may participate in an event through various types of networks, which may each have differing capabilities and/or protocols. The event focus may provide at least some of the nodes with a common point of contact with the event. According to some embodiments, node requests 36, node requests 120, and/or hoster requests 62 transmitted to event focus 24 may be interpreted and converted to a format and/or protocol meaningful to event manager 26.
After the event manager determines the new event topology and media stream connections, the event manager may transmit the data to the event focus for distribution to the nodes and/or the hoster. Event focus 24 may then communicate individualized directives to one or more of nodes 100 and/or the hoster that are affected by the directives, indicating a change in the participation of the various nodes and/or the hoster. In some embodiments, the event focus may send directives to first nodes 108 and/or hoster 22.
According to some embodiments, directives may include the selected intent and/or new media connection assignments among the node and/or the hoster receiving the directive and any number of participating nodes, simulated nodes, and/or the hoster. The event focus may be configured to communicate the various directives to nodes 100 through the preferred or actual network protocol for each participating node and/or the hoster.
Node 100, such as first node 108 and/or second node 110, may include a telephone that may submit a request 120 to join an event in the form of dialing a number. Those requests may implicitly indicate that the attendee's system supports the exchange of audio data and that the attendee desires to participate in the event in audio mode. Other requests may be more explicit. Node 100 also may send a request, which may be interpreted and/or translated to an appropriate form by event focus 24 before the request may be communicated to event manager 26. In some embodiments, requests from second nodes 110 may be received by the manager of the hoster. That manager may then send out node requests 36 from one or more simulated nodes 27 and/or hoster requests 62 to the event focus based, at least in part, on the requests from the second nodes.
When the event manager generates media stream assignments, the event focus may form directives useful to one or more of nodes 100 and/or the hoster, which, in the case of the telephone node, may comprise an established connection to a stream of composite audio data for the conference. The event focus may not determine which connections to assign but may provide the event manager one or more channels through which to communicate node configuration and/or hoster configuration data, even if the data may be destined for networks of differing protocols and/or capabilities.
A single event focus 24 may communicate using multiple networks and/or protocols, and thus acts as a gateway among nodes 100, hoster 22, and/or event manager 26. In addition, multiple nodes 100 using the same protocol may communicate with event manager 26 through a single event focus 24. The event focus also may allow the event manager to communicate with nodes 100 from many manufacturers, which may connect through Session Initiation Protocol (SIP) or other standards.
Communication between a node 100 and event manager 26 may be routed through at least one event focus 24, even if the node and the event manager use the same network and/or protocol. In some embodiments, event management system 20 may include multiple event focuses where each event focus may be associated with one or more network protocols and/or connection management protocols used by particular types of nodes. Alternatively, or additionally, one or more of the multiple event focuses may be capable of multiple network protocols and/or connection management protocols used by particular types of nodes.
According to another illustrative example, one node 100 coupled to the illustrative event manager system may participate in an event through a local area network, another node may participate through the Internet, and a third node may participate through an encrypted virtual private network (VPN). The nodes may be physical nodes and/or simulated nodes that are generated by the hoster. As each node 100 joined the event, left the event, or requested to change intent, the corresponding node request may be translated by the associated event focus into the form preferred by the event manager. The module for network protocol translation 66 may employ encryption, decryption, authentication, and/or other capabilities to facilitate communication among the nodes and the event manager. In some embodiments, hoster 22 may incorporate at least some of the components and/or functions of the event focus. Although a single event focus 24 is shown, the event manager system may include two or more event focuses, each of which may be connected to different sets of nodes communicatively coupled to one or more networks.
Regardless of the communication means between the event focus and the event manager, the event manager may include a data storage module or stored topology data module 74 and a plurality of management policies 76. According to some embodiments, the stored topology data module associated with the event manager may describe the state and/or topology of an event, as perceived by the event manager. That data may, according to some embodiments, include the identity of nodes 100 and/or hoster 22 participating in an event, the virtual relationships among the nodes and/or the hoster, the intent or manner in which the nodes and/or the hoster are participating, and the capabilities of the nodes and/or the hoster.
Event manager 26 also may maintain a record of prioritized intents for one or more of nodes 100 and/or hoster 22. As mentioned previously, an intent may include information about relationships among multiple nodes 100, node media devices 122, and/or the hoster, whether present or desired. Additionally, an intent may specify a narrow subset of capabilities of node 100 and/or hoster 22 that are to be utilized during a given event in a certain manner. For example, a first node may include three displays capable of displaying multiple resolutions. An intent for the first node may include a specified resolution for media received from a certain second node, as well as the relationship that the media streams from the second node should be displayed on the left-most display. Additionally, event manager 26 may optimize an event topology based on the intents and/or combinations of intents received.
According to some embodiments, event manager 26 may be configured to receive node requests 120, simulated node requests 36, and/or hoster requests 62 from at least one event focus. The node requests and/or the hoster requests may be identical to the requests originally generated by the nodes and/or the hoster, or may be modified by the event focus to conform to a certain specification, interface, or protocol associated with the event manager.
According to some embodiments, the event manager may make use of stored topology data 74 to create new media connection assignments 70 when node 100 or hoster 22 requests to join an event, leave an event, or change its intent. Prioritized intent information may allow the event manager to assign media streams most closely matching at least some of the attendee's preferences. Additionally, virtual relationship data may allow the event manager to minimize disruption to the event as the topology changes, and node and/or hoster capability data may prevent the event manager from assigning media streams not supported by an identified node or the hoster.
When a change in topology is requested or required, the event manager may select the highest priority intent acceptable to the system for one or more of nodes 100 from the prioritized intents. The selected intent may represent the mode of participation implemented for that node at that time for the specified event. Changes in the event or in other systems participating in the event may cause the event manager to select a different intent as conditions change. Selected intents may be conditioned on any number of factors including network bandwidth or traffic, the number of other nodes participating in an event, the prioritized intents of other participating nodes and/or other nodes scheduled to participate, a policy defined for the current event, a pre-configured management policy, and/or other system parameters.
According to some embodiments, management policies 76 associated with the event manager may be pre-configured policies, which, according to one example, may specify which nodes and/or attendees are permitted to join an event. The management policies may additionally, or alternatively, apply conditions and/or limitations for an event including a maximum duration, a maximum number of connected nodes, a maximum available bandwidth, a minimum-security authentication, and/or minimum encryption strength. Additionally, or alternatively, management policies may determine optimal event topology based, at least in part, on node intents.
The event manager may be configured to transmit a description of the updated event topology to event focus 24. That description may include selected intents 68 for one or more of nodes 100 and/or the hoster as well as updated media connection assignments 70 for those nodes and/or the hoster. The formation of media connection assignments by the event manager may provide for the optimal formation and maintenance of virtual relationships among the nodes and/or the hoster.
Topology and intent information also may be used to modify the environment of one or more of nodes 100 and/or hoster 22, including the media devices not directly related to the transmission, receipt, input, and/or output of media. Central management by the event manager may apply consistent management policies for requests and topology changes in an event. Additionally, the event manager may further eliminate potentially conflicting configurations of media devices and media streams. Details of the illustrative operation of the event manager system will be described below, with reference to
When the initial request is received by the event focus, the event focus may then forward the request to the event manager, and, in turn, may receive those aspects of the updated event topology from the event manager which are necessary to be transmitted to hoster 134 and first node 136, including new media connection assignments and/or selected intents. The two-way communication between the event manager and the event focus is illustrated by the communication arrow 202.
After receiving the updated event topology from the event manager, including new media connection assignments and/or selected intents, the event focus may translate the new media connection assignments and/or selected intents into directives. Once translated, the directives may be transmitted to node(s) that are experiencing a change in configuration (also may be referred to collectively as “affected nodes”) and/or to the hoster, if it is experiencing a change in configuration, as illustrated by transmission arrows 204.
As the affected node(s) and/or the hoster receive the transmitted directives, manager(s) may interpret and may apply the directives received and may send appropriate configuration data and commands to its media device(s) and/or other component(s) to support the new topology. The mentioned communication among the node manager and the media device(s) are illustrated as communication arrows 206.
When appropriately configured to reflect the understood topology, media streams may be connected among the various nodes and/or the hoster as previously assigned by the event manager. The transmission of the various media streams is illustrated by communication arrow 208. The illustrative configuration illustrated in
While
As illustrated in
According to some embodiments, the virtual relationships established among the various nodes by the event manager system may simulate spatial relationships among attendees and promote meaningful interaction. Particularly, according to some embodiments, the perceived topology and issued directives may correspond to certain virtual relationships being envisioned as seats around an imaginary table, where video and/or audio are perceived to come from the left, right, or directly in front of the attendee. According to some embodiments, the virtual relationships may be maintained throughout an event, giving an event a sense of realism and eliminating distractions.
According to some embodiments, the consideration of relationships among the nodes and their corresponding video streams may allow an attendee to speak with remote attendees as if they were looking through a virtual window. One type of virtual relationship may include, for example, the association of a video input stream from an identified node with a corresponding display, camera, and video output stream to allow natural eye contact among attendees at the two nodes. If video from a first node is displayed on the left-most display of a second node, the left-most camera of the second node may be configured to capture the video stream sent back to the first node. Consequently, when an attendee turns to view the left display, his expressions and comments may be transmitted as if he were speaking directly to the attendee displayed on his screen. The connection of video streams to appropriate displays may maintain natural eye contact and may facilitate natural communication among attendees. Additionally, this illustrative configuration may allow the participants to know when other participants are distracted or are shifting their attention from one participant to another.
In conjunction with the video arrangement described above, audio streams also may be linked among attendees based on a virtual relationship among the nodes. Specifically, according to some embodiments, audio recorded from a specific node may be reproduced at the recipient node with the same orientation as the display showing the attendee transmitting the audio stream. Each attendee's voice received may then correspond spatially with the video image of that attendee, enhancing the perceived relationship among the attendees.
According to some embodiments, the event manager may store the topology data containing a record of virtual relationships present in an event and generates the above-mentioned perceived relationships. As the event manager receives node requests and/or hoster requests, at least some changes in topology may take into consideration the best configuration to maintain those virtual relationships and form new ones as necessary. These considerations allow smooth transitions among topologies with varied numbers of participating nodes.
Additionally, media streams from second nodes 110 may be composited by the hoster before being transmitted from one or more simulated nodes 27 to first nodes 108. Additionally, or alternatively, media streams transmitted from first nodes 108 to the one or more simulated nodes may be composited by the hoster before being transmitted to second nodes 110. Examples of second media streams composited by the hoster are shown in the display for hosted sites C-D in
While
According to some embodiments illustrated in
For example, in the three node topology illustrated in
While the examples depicted in
Continuing with the methodologies of the event manager system,
As illustrated in
Once the request has been processed, the node that initiated the request may receive directives from the event focus instructing which media connections have been assigned and which intent has been selected at 224. Directives also may be transmitted to one or more of the nodes and/or the hoster that exchange media information with the requesting node in order to establish connections in the new topology. Consequently, as illustrated in
After receiving a directive, the node manager associated with one or more of the nodes may initialize the selected intent corresponding to the received directive at 226. Specifically, according to some embodiments, the node manager may be configured to calculate a preferred configuration of one or more of its associated media devices to comply with the directive received. Additionally, the node manager associated with the receiving node also may change settings and/or execute initialization software to initialize functionality. According to some embodiments, any number of factors may be considered in selecting the preferred configuration for one or more of the media devices in response to a received directive. Particularly, allocation of the media devices and previously received directives may influence the preferred configuration calculated by the node manager.
Once the node has been initialized to the selected intent, the node manager may configure the media device(s) to allow them to support the assigned media connections and topology at 228, and may configure the node's environment devices to optimize participation. For example, the node manager may dim nearby lights to improve the visibility of a display and/or may dim lights over seats that may not be visible in the event. With the media devices and/or the environment devices configured, the node may then be ready to support as many connections as have been assigned, and may support the transmission and receipt of media in the forms specified by the selected intent.
Finally, the media streams connecting one or more nodes and/or the hoster may be established for the new topology at 230. With the media streams established, the exchange of data may begin, and may continue until additional directives change the mode of participation of one or more of the nodes and/or the hoster. In some embodiments of the method of operation, requests from the second nodes may be received by the hoster, and the hoster may generate one or more simulated nodes, and then send node requests from those simulated nodes based, at least in part, on the received requests. In some embodiments, the event focus and the event manager may send directives to the first nodes and the hoster.
Similarly, the illustrative virtual collaboration method may be initiated when the hoster attempts to join or leave an event, or when the hoster is participating in the event and wants to change its desired mode of participation. When the hoster attempts to join or leave an event, or when it changes its desired mode of participation, the hoster may transmit a hoster request to the event focus at 222. That request may include the prioritized list of intents as well as identification information of the hoster. The information provided to the event focus may be explicit, but may additionally, or alternatively, be implicitly signaled by the type of request transmitted.
Once the request has been processed, the hoster may receive directives from the event focus instructing which media connections have been assigned and which intent has been selected at 224. Directives also may be transmitted to one or more nodes that exchange media information with the hoster in order to establish connections in the new topology. Consequently, as illustrated in
After receiving a directive, the manager associated with the hoster may initialize the selected intent corresponding to the received directive at 226. Specifically, according to some embodiments, the manager may be configured to calculate a preferred configuration of the hoster media devices to comply with the directive received. Additionally, the manager also may change settings and/or execute initialization software to initialize hoster functionality. According to some embodiments, any number of factors may be considered in selecting the preferred configuration for the one or more of the media devices in response to a received directive. Particularly, allocation of the media devices, and previously received directives may influence the preferred configuration calculated by the manager.
Once the hoster has been initialized to the selected intent, the manager may configure the media device(s) to allow them to support the assigned media connections and topology at 228, and may configure the hoster's environment devices, if any, to optimize participation. With the media devices and/or the environment devices configured, the hoster may then be ready to support as many connections as have been assigned, and may support the transmission and receipt of media in the forms specified by the selected intent.
Finally, the media streams connecting one or more of nodes and/or the hoster may be established for the new topology at 230. With the media streams established, the exchange of data may begin, and may continue until additional directives change the mode of participation of the hoster and/or one or more of the nodes.
Once the node request is received, the event focus may translate the request received into a common format preferred by the event manager at 244. The translation to a standard format may include providing a common interface to communicate among multiple network systems and protocols. According to some embodiments, any number of event manager preferred protocols may be used. Once the request is in the correct form, the event focus may forward the request to the event manager at 246.
After the event manager has received and/or processed the node request, updated topology data may be transmitted from the event manager to the event focus. The event focus may receive the updated topology data from the event manager at 248, and may create directives for the affected nodes and/or the hoster based, at least in part, on the updated topology data at 250. The topology data received from the event manager may designate the intents selected for one or more of the nodes as well as the source, destination, and/or type of one or more of the media streams connecting one or more nodes and/or the hoster.
The topology data may be specific enough, for example, to maintain virtual relationships among the node(s) and the hoster, such as the left camera view from one node being displayed on the right-most display of a second node or on the right-most display of the hoster in embodiments where the hoster includes three display devices. The event focus may not necessarily track the virtual relationships among the various nodes and/or the hoster because those relationships may be considered by the event manager. Consequently, according to some embodiments, the event focus may receive a detailed specification of the event for the nodes and/or the hoster.
With the updated topology data received, the event focus may create directives instructing one or more nodes and/or the hoster to establish the correct media connections and may initialize the selected intent at 250. The event focus may then send the recently created directives to one or more of nodes and/or the hoster that may have been affected by the change in topology for implementation at 252. The event focus may then await reception of further node requests and/or hoster requests at 242.
After being assigned to at least one event, the event manager may then wait for requests that will affect the topology of an event that the event manager is assigned to manage at 264. When the event manager receives requests from at least one event focus (or from another client and/or source, such as an administration tool) at 266, the information received may then be stored for later use. Requests may be received from sources such as scheduling applications and/or other support applications.
Specifically, according to some embodiments, the received information may be stored for use in responding to the received request. Based on at least one pre-configured management policy, the event manager may determine the best way to respond to the request at 268. One policy, for example, may use authentication to restrict participation to certain individuals. Another policy may request permission from an already participating node for a new node and/or the hoster to join an event. Another policy may allow as many nodes and the hoster to participate in an event as network bandwidth allows.
After the relevant management policies are applied, the event manager may formulate a new topology and may store the state of the event at 270. According to some embodiments, the event manager may take into account the current topology and additional stored information, such as the prioritized intents of the nodes currently participating in the event and/or the hoster. The event manager may then form the new topology to create and maintain effective virtual relationships among the participating nodes and the hoster. Furthermore, the event manager may take into account varying capabilities of the node(s) and/or the hoster and will not assign media connections that a node and/or the hoster cannot support.
Once the new topology is created, the event manager may transmit the topology data to at least one event focus associated with the event at 272. The topology data may include information specific to one or more nodes and/or the hoster, including one or more media connection assignments and selected intents for one or more nodes and the hoster that communicate with a given event focus. After the topology data has been updated and transmitted, the event manager may return to step 264 to wait for additional requests. One or more of the above illustrative methods, and/or other methods of operation according to this disclosure, may be in the form of computer-executable instructions stored on computer-readable media.
In conclusion, the present illustrative configuration systems and methods are adapted to manage the configuration of virtual collaboration systems. Specifically, the present illustrative method may, among other things, intrinsically consider the relationships among related media streams, manage the virtual relationships among nodes and/or the hoster to optimize the directives to the nodes and/or the hoster to support a new topology, and support a variety of proprietary and industry-standard communications mechanisms while managing one or more nodes and/or the hoster equivalently in the event itself. Further, the present illustrative systems and methods, according to some embodiments, maintain the virtual relationships among node(s) and/or the hoster throughout an event, giving the event a sense of realism while eliminating distractions.
The preceding description has been presented only to show and describe examples of the present illustrative systems and methods. It is not intended to be exhaustive or to limit the systems and methods to any precise form disclosed. Many modifications and variations are possible in light of the above teachings.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US07/80091 | 10/1/2007 | WO | 00 | 10/20/2009 |