US9131016B2 - Method and apparatus for virtual auditorium usable for a conference call or remote live presentation with audience response thereto - Google Patents
Method and apparatus for virtual auditorium usable for a conference call or remote live presentation with audience response thereto Download PDFInfo
- Publication number
- US9131016B2 US9131016B2 US11/900,232 US90023207A US9131016B2 US 9131016 B2 US9131016 B2 US 9131016B2 US 90023207 A US90023207 A US 90023207A US 9131016 B2 US9131016 B2 US 9131016B2
- Authority
- US
- United States
- Prior art keywords
- node
- signal
- station
- audience
- hierarchy
- 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.)
- Expired - Fee Related, expires
Links
- 238000000034 method Methods 0.000 title claims abstract description 38
- 230000004044 response Effects 0.000 title claims description 82
- 238000004891 communication Methods 0.000 claims description 16
- 238000004590 computer program Methods 0.000 claims description 3
- 230000005236 sound signal Effects 0.000 claims description 3
- 230000002238 attenuated effect Effects 0.000 claims description 2
- GNFTZDOKVXKIBK-UHFFFAOYSA-N 3-(2-methoxyethoxy)benzohydrazide Chemical compound COCCOC1=CC=CC(C(=O)NN)=C1 GNFTZDOKVXKIBK-UHFFFAOYSA-N 0.000 claims 1
- 230000003190 augmentative effect Effects 0.000 abstract description 2
- 239000000872 buffer Substances 0.000 description 57
- 230000008569 process Effects 0.000 description 16
- 230000008901 benefit Effects 0.000 description 7
- 238000012423 maintenance Methods 0.000 description 7
- 238000005259 measurement Methods 0.000 description 5
- 230000008520 organization Effects 0.000 description 5
- 230000008859 change Effects 0.000 description 4
- 230000000694 effects Effects 0.000 description 4
- 238000005516 engineering process Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 230000007246 mechanism Effects 0.000 description 4
- 238000001514 detection method Methods 0.000 description 3
- 238000010586 diagram Methods 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000003111 delayed effect Effects 0.000 description 2
- 239000000284 extract Substances 0.000 description 2
- 230000033001 locomotion Effects 0.000 description 2
- 230000000116 mitigating effect Effects 0.000 description 2
- 239000000203 mixture Substances 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 238000005457 optimization Methods 0.000 description 2
- 238000011084 recovery Methods 0.000 description 2
- 230000009467 reduction Effects 0.000 description 2
- 238000000926 separation method Methods 0.000 description 2
- 230000001360 synchronised effect Effects 0.000 description 2
- 238000012546 transfer Methods 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000003466 anti-cipated effect Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000003139 buffering effect Effects 0.000 description 1
- 230000015556 catabolic process Effects 0.000 description 1
- 230000006835 compression Effects 0.000 description 1
- 238000007906 compression Methods 0.000 description 1
- 235000014510 cooky Nutrition 0.000 description 1
- 230000001419 dependent effect Effects 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000003631 expected effect Effects 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000001404 mediated effect Effects 0.000 description 1
- 230000005012 migration Effects 0.000 description 1
- 238000013508 migration Methods 0.000 description 1
- 238000003801 milling Methods 0.000 description 1
- 230000008447 perception Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000000644 propagated effect Effects 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 238000004088 simulation Methods 0.000 description 1
- 230000006641 stabilisation Effects 0.000 description 1
- 238000011105 stabilization Methods 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/40—Support for services or applications
- H04L65/401—Support for services or applications wherein the services involve a main real-time session and one or more additional parallel real-time or time sensitive sessions, e.g. white board sharing or spawning of a subconference
- H04L65/4015—Support for services or applications wherein the services involve a main real-time session and one or more additional parallel real-time or time sensitive sessions, e.g. white board sharing or spawning of a subconference where at least one of the additional parallel sessions is real time or time sensitive, e.g. white board sharing, collaboration or spawning of a subconference
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/10—Architectures or entities
- H04L65/1059—End-user terminal functionalities specially adapted for real-time communication
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/40—Support for services or applications
- H04L65/403—Arrangements for multi-party communication, e.g. for conferences
- H04L65/4053—Arrangements for multi-party communication, e.g. for conferences without floor control
Definitions
- the present invention relates generally to a communication system for assembling a distributed live audience. More particular still, the invention relates to a system for permitting an audience of a multimedia presentation to exchange their responses with each other and/or with one or more performers.
- the '926 system operates by capturing acoustic signals generated by the locally performing musician, e.g. from his microphone or electric guitar output.
- the resulting electronic audio stream is sent to each of two places: First, and immediately, to all of the remote musicians via a communication channel.
- the communication channel can be one or more voice telephone lines, but is preferably a packet network connection, for example comprising the Internet.
- the audio Upon arrival at the remote location(s), substantially coincident with the local delay elapsing, the audio is played at each of the stations substantially simultaneously; i.e., a brief moment following the original performance.
- the originating musician listens to his own performance with the local delay, preferably through headphones.
- the '926 system suffers from one significant drawback: The musicians have no audience. Other than those participating in the peer-to-peer interconnection that comprises the jam, there is no audience.
- the interconnection mechanism of the '926 system is optimized for low latency, but at the cost of a complete interconnection among the jam participants, which places an increased bandwidth requirement on each participant for each additional peer added to the jam. In such a scenario, a large number of audience members would produce an untenable bandwidth requirement for individual performance stations under '926.
- Conference call systems exist which allow a presenter to be heard by all call participants. Some systems permit other call participants to be heard by everyone as well. Often, such conference calls are implemented with expensive voice bridges. However, there are network-based telephone applications, such as Skype by eBay, Inc of San Jose, Calif., which are implemented using VoIP technology, and which can provide conference calls in small numbers, in the case of Skype up to about five people without a separate voice bridge server. However, for large numbers of participants able to hear each other, voice bridge servers require significant network infrastructure and large amounts of centralized bandwidth. Products such as Skype that run on personal computers are, to date, significantly limited in the count of participants.
- DHT Distributed Hash Table
- the principles and exemplary uses of DHTs are described by Ali Ghodsi in Distributed k - ary System: Algorithms for Distributed Hash Tables , his PhD dissertation to the Royal Institute of Technology, School of Information and Communication Technology, Department of Electronic, Computer, and Software Systems, Swiss, Sweden, December, 2006.
- Distributed Hash Tables also known as structured overlay networks, (SON), are well suited to building scalable, self-managing distributed systems.
- peer-to-peer overlay networks provide algorithms that permit an ad hoc group of stations, each of which only needs to know how to connect to at least one station already in the organization, to interconnect and manage their organization.
- Such peer-to-peer organizations have not previously been shown to support a virtual auditorium environment.
- the capabilities for self-organization and self-maintenance is exploited in the present invention to achieve an interconnection of nodes streaming multimedia among themselves without excessive investment in server capacity and bandwidth being required from any central server.
- audience members preferably in large numbers
- the performers experience the response (e.g., applause, shout-outs, laughter, etc.) of the audience, in substantially real time.
- Such an audience may extend across neighborhoods, cities, states, continents, and even across the globe.
- the present invention satisfies these and other needs and provides further related advantages.
- the present invention relates to a system and method for providing a remote, live performance to a remote, distributed audience, wherein the performers receive the reaction of the audience members in substantially real time.
- the live performance can itself be distributed geographically, as taught in the prior art, and may be multimedia in nature, for example audio (monophonic, stereo, or multi-channel) can be augmented by images, video, MIDI, text (e.g., commentary, lyrics), etc.
- the distributed audience members can receive each other's reaction, also in substantially real time, whereby a virtual auditorium is created wherein the distributed audience members constitute a virtual assembly.
- the same virtual auditorium can be used as a venue to conduct a conference call.
- the performance may be pre-recorded, as with a movie, but the audience can still share a joint reaction, as if they were in a real theatre. Applied to television programming, this could alleviate the need for live studio audiences and laugh tracks (canned laughter used to indicate to an audience that an actor's line was funny).
- a person uses a broadband network connected computer, which may be mobile, to join a peer-to-peer network of the prior art.
- Peers in the network cooperate to organize a hierarchy of audience nodes.
- This audience hierarchy is interconnected in such a way as to allow a presentation to flow from a root node (herein designated as the engineer/server node) to all directly connected audience nodes, and from those audience nodes to the audience nodes of the next hierarchical layer, and so on.
- this structure can also be used to implement a conference call.
- no performance live or otherwise
- the engineer/server node may be the computer of the call organizer.
- commonplace communications capabilities e.g., a single personal computer having only a residential class Internet connectivity, or a mobile device having a WiFi connection.
- Another object of the present invention is to permit conference calls of substantial numbers of participants to be assembled without the need for dedicated voice bridge servers or hardware, or indeed any significant expense on the part of the participants.
- FIG. 1 is a block diagram showing signals exchanged between an audience node and other nodes during a performance
- FIG. 2 is a block diagram showing the hierarchy of audience nodes relative to an engineer/server node moderating a performance
- FIG. 3 shows an exemplary underlying physical network topology in relation to a logical organization of nodes for performers and engineer members
- FIG. 4 shows the same underlying physical network topology in relation to a hierarchy of audience nodes for audience members, and an intermediate distributed organizational layer;
- FIG. 5 shows the same underlying physical network topology, but with an alternative embodiment having a server anchor the organizational layer and audience hierarchy;
- FIG. 6 shows an exemplary underlying physical network topology in relation to a hierarchy of audience nodes for audience members, wherein backup parent nodes are pre-established for rapid recovery;
- FIG. 7 is a detailed schematic of signals within an audience node.
- FIG. 8 is a flowchart of the operation of an audience node.
- the present invention provides distribution of an audio and/or visual performance to an audience in substantially real-time, and accepts an audio response from members of the audience, also substantially in real-time, and provides such response to the distribution point and the performers.
- an audience node 110 suitable for implementing the present invention is shown.
- a live performance is received from the parent node 120 .
- the performance is designated as Content P and is delivered over connection 122 .
- a significant function of local audience node 110 is that the content signal is shared with the zero or more child nodes 130 , 140 , and 150 , here and throughout illustrated as not more than three, thus imbuing local audience node 110 with a fanout of three.
- Audience node 110 is preferably implemented by a personal computer, where audience hierarchy interconnections 122 , 112 , 114 , 116 , 118 , 132 , 142 , and 152 are all logical IP network connections running a VoIP or other streaming protocol for exchange of audio or other multimedia signals. Preferably, these connections provide low latency, high reliability, and high bandwidth. Typically, these connections are established over a single physical connection to a network service provide, for instance through a wireless, DSL, or cable modem (not shown).
- Audience response A N from local node 110 and its zero or more child nodes 130 , 140 , 150 is sent to parent node 120 over response connection 118 .
- Audience response A N comprises audience response U N from local audience member 160 , which enters local node 110 through input 166 , which typically comprises a microphone or other transducer (e.g., a guitar pickup) as needed to format the response of user 160 for use by the system.
- response A N from local node 110 can be implemented according to Equation 1:
- a N U N +A C L +A C M +A C R
- the three separate A C signal components are audience responses from the three (left, middle, and right) exemplary child nodes 130 , 140 , 150 .
- Each of these child nodes is implemented in the same manner as local node 110 , and so what is an A C signal to local node 110 , is the A N signal from the perspective of the corresponding child node.
- Parent node 120 may have children besides local node 110 , and since parent node 120 may have an audience member analogous to local audience member 160 , parent node 120 may be in receipt of audience response signals besides audience response signal A N sent over connection 118 by local node 110 . Such audience response known to the parent is provided to local node 110 over connection 122 , but this preferably excludes signal A N . Thus, over connection 122 , the audience response signal component provided from parent node 120 is A P-N .
- a similar sum is made for audience response received at local node 110 and passed on to the child nodes 130 , 140 , and 150 over connections 112 , 114 , and 116 respectively, and are as shown in Equations 3, 4, and 5:
- a N-C L U N +A C M +A C R
- a N-C M U N +A C L +A C R
- a N-C R U N +A C L +A C M
- the audience responses generated at local node 110 or received from its child nodes are summed, except for the contribution of the individual child nodes to which the corresponding signal is sent.
- Content N Content P +A P-N
- Such content and audience response signals can comprise a single or multi-channel audio stream, typically stereo. It is preferable that content signals comprise a video stream, for instance to show live images of a band as they perform, or in the case of a motion picture score or music video, a live performance may be made in response to the imagery. Additionally, the content or audience response streams may comprise text (e.g., lyrics), MIDI data (Musical Instrument Digital Interface) events, or control signals (e.g., for remotely setting mixer volumes or noise gate levels). In a case where Content P comprises a video component, then output transducer 164 preferably comprises a video display (not shown).
- the presentation provided to local audience member 160 is preferably a combination of the Content P , the audience reaction A P-N provided through parent node 120 , and the audience reaction A C provided collectively by the child nodes 130 , 140 , 150 per Equation 2.
- the combination of Content P and A P-N from the parent is collectively identified as Content N and the further combination with audience reaction A C produces the program to be provided to local audience member 160 by output 162 , the program being rendered by output transducer 164 (shown in the preferred embodiment as headphones).
- the overall audience response is represented to the local user 160 as a stereo stream on output 162 .
- the audience response signal on connection 132 from the left child node 130 is panned to the left channel
- the audience response signal on connection 152 from the right child node 150 is panned to the right channel
- the audience response signal on connection 142 from the middle child can be center-panned, to appear equally on the left and right channels.
- the audience response portion of the signal on connection 122 from parent node 120 if monophonic, can be center panned, but preferably that portion of the signal on connection 122 comprising A P-N is stereophonic. Either way, a simulated spatial relationship among all audience members is formed. Those skilled in the art will appreciate that further spatialization of the audience response can be achieved with additional sound presentation channels, such as achieved with surround sound techniques.
- the signal on connection 122 may be a combination of Content P and A P-N as in a single, mixed and inseparable signal preferably provided in stereo, but allowably in a monophonic format.
- the audience response portion of the signal on connection 112 remains distinct and is separately managed from the content signal Content P . Such a separation allows local user 160 to use local controls (not shown) to adjust the mix of the performance delivered in Content P and the audience response that is heard. Note that audience response signals from the child nodes received over connections 132 , 142 , and 152 are already separate.
- Local node 110 is responsible for passing to child nodes 130 , 140 , and 150 the content stream Content P and preferably the audience response signals of which local node 110 is in receipt, with the exception of those audience response signals received from the corresponding child node. These signals would correspond to the sum of Equation 6 and one of Equations 3, 4, and 5, which correspond to one of child nodes 130 , 140 , and 150 , respectively.
- the audience response portion of the signal on connection 112 to leftmost child 130 does not repeat back to child node 130 any of left child audience response signal received through connection 132 .
- the passing of audience response can be to only parent node 120 , per Equation 1.
- the signals from nodes other than local node 110 may be attenuated by coefficients (not shown) on each term in Equations 1, 3, 4, and 5. In this way, a spatial relationship among the nodes surrounding local node 110 is simulated. If parent node 120 hosted an audience member (not shown) who provided audience response similar to that of audience member 160 , then audience member 160 would perceive that response unattenuated, however corresponding audience members (not shown) hosted at child nodes 130 , 140 , or 150 would hear that component of the parent audience response more quietly—simulating the audience member at the parent node 120 being farther away than audience member 160 at local node 110 , whose response on input 166 would be unattenuated for child nodes 130 , 140 , and 150 .
- Equations 1-5 may be selected to achieve different effects of audience and content mixing without departing from the spirit of the present invention. Further, the individual audience response signals may remain completely or partially distinct from each other or from content signals, again to achieve different effects or to allow audience member 160 a broader range of controls (not shown) such as the ability to increase or decrease the relative volume of the content to the audience response.
- a dynamic range control may be implemented, where in while the level of aggregate audience response is low, the gain (coefficient) on the local audience member response signal may be higher. As the audience response grows, that gain can be reduced. The effect can be used to ensure that shout outs in a quiet virtual auditorium are propagated well.
- audience responses from all sources are mixed together as described in the literal meaning of Equations 1, 3, 4, and 5.
- these audience response signals are combined with content signals as identified in Equation 6 and FIG. 1 .
- bandwidth requirements among nodes are minimized. Where bandwidth is a less constrained resource, as it might be, for instance, with a DSL connection, such restrictive combination is required less, and more distinct signals can be exchanged.
- All of the inter-nodal streams are preferably compressed with a CODEC to conserve bandwidth.
- CODECs for audio include MP3 and AC3.
- the latencies of content sent to the audience nodes is less critical.
- the addition of latency due to a 20 mS, 50 mS, or longer windowed CODEC is not significant.
- MPEG or video conferencing CODECs can be used.
- a decoder (not shown) corresponding to the encoder (not shown) used would be employed upon receipt of a signal and that a suitable encoder is preferably employed on signals sent to other nodes.
- Performance nodes 210 include engineer/server node 220 .
- Audience hierarchy 230 includes numerous audience nodes such as 240 , 242 , 244 , 260 - 268 , 280 , 270 , and additional nodes (not shown) indicated by ellipsis 290 .
- Each node in audience hierarchy 230 behaves as local node 110 and is, in its turn, interconnected with its neighbors as shown in FIG. 1 .
- audience node 263 the parent node 120 is audience node 242
- leftmost child node 130 is audience node 270 .
- the leftmost child node 130 is audience node 263 and the parent node 120 is engineer/server node 220 .
- Audience nodes such as 240 , 242 , 244 which are connected directly to engineer/server node 220 are considered to be ‘first row’ nodes.
- the children of first row nodes are considered to be ‘second row’ nodes, such as 260 - 268 , and their child nodes, e.g., 270 and 280 are ‘third row’ nodes and so on.
- audience nodes 230 to their respective child nodes is exemplary, and the actual fanout of any individual audience node will be limited by the bandwidth available to that node and the amount of bandwidth required for the signals into and out of that node. Further, it is not a requirement that all audience nodes provide the same fanout that the others do.
- engineer/server node 220 is a bridge between the performance nodes 210 and the audience hierarchy 230 .
- engineer/server node 220 is a member of both groups, but has properties unique among the nodes. While the functions of engineer/server node 220 can be distributed among multiple physical devices which may be collocated or remote from each other (an example of which is given in conjunction with FIG. 5 ), it is useful to discuss the operation of engineer/server node 220 as a single entity.
- Engineer/server node 220 is so-named for functional roles it fills.
- the engineer role is analogous to a studio engineer or concert engineer's job.
- a person performing such a job is responsible for mixing the audio, for setting levels at which the band is heard, so that the audience response does not swamp out the performance.
- a studio engineer is responsible for operating the recording equipment to ensure that a clean record of the performance is captured. This task is more challenging in a live environment, where audience response must be included and managed, as too much or too little may aesthetically harm the live performance and/or the recording thereof.
- An engineer (not shown) at node 220 will preferably have controls (not shown) that are able to adjust the ratio between the audience response and the performance content.
- this ratio can be fixed or can be a function, for example, of how many nodes participate in the audience or how many ‘rows back’ an audience node is in the audience hierarchy 230 .
- node 220 can be a station having reliability and bandwidth beyond that of a typical personal computer implementing a node in audience hierarchy 230 .
- Equation 7 What can be shown with Equation 7 is that for F S >F N , that Max A serves a larger audience with the same number of rows. From FIG. 2 , it is clear that audience nodes 240 , 242 , and 244 in the first row receive their content from the performance nodes 210 through only engineer/server node 220 , with no dependence on other audience nodes. Audience nodes 260 - 268 in the second row and 270 , 280 in the third and nodes 290 in rows beyond, depend on audience nodes in prior rows interconnected in the fashion of parent node 120 , such that a chain of connections is made up to the engineer/server node 220 . The reliability of that chain of connections remaining stable is proportional to the number of intervening audience nodes.
- F S c F N
- engineering/server node 220 is responsible for communicating with each of band nodes 212 , 214 , 214 , it may be that the communications bandwidth available to engineering/server node 220 is limited, and F S may be kept small to stay within those limits. At the least, F S can be one, in which case the implementation relies entirely on the fanout of the audience nodes to communicate to the audience hierarchy.
- the performance nodes 210 preferably comprise a distributed performance such as the remote real time collaborative acoustic performance or online audio jamming group, as described in '926 patent. These band members can perform together using performer nodes 212 , 214 , 216 interconnect using the techniques described in '926 to manage the network latency and remain in sync with each other.
- the engineer/server node 220 is preferably a station of the '926 description, and is thereby in full communication with the other jam members.
- the band or a single performer may perform using a single performance station 212 .
- this single performance station functionality could be integrated into the engineer/server node 220 .
- the connection to audience hierarchy 230 provides the band access to a live, reactive, distributed, online audience.
- FIG. 3 shows the topology of physical network 320 , a portion of a wide-area network (WAN).
- the portion of the WAN which physical network 320 represented is that portion involved in supporting a live performance of the present invention.
- High bandwidth connections such as connection 330 are drawn as bold lines.
- Routers 340 and 350 are shown as hexagons. Router 340 , for instance has connections similar to 330 , which only connect to other routers.
- Router 350 connects end user stations to the network.
- Router 350 may be a telephone company or cable television office supplying DSL or cable modem connections, or it may be a WiFi, WiMax, or other node allowing wireless connections, or any other technology permitting stations 270 ′ and 263 ′ to connect to the WAN.
- Physical network 320 preferably comprises the Internet.
- Each station 240 ′, 242 ′, 260 ′, 261 ′, 262 ′, 263 ′, 264 ′, 265 ′, 270 ′ corresponds to respectively numbered audience nodes shown in FIG. 2 and elsewhere.
- Stations 212 ′ and 214 ′ correspond to respectively numbered performance nodes 210 from which band members are participating.
- the engineering/server node 220 is implemented entirely at station 312 ′.
- connection 219 is established over the physical network topology 320 in manners well known: For instance, connection 219 may be implemented with UDP/IP messages or a TCP/IP connection from physical station 212 ′ to router 350 , to router 340 , across backbone 330 , to another router, and so on, until station 214 ′ is reached.
- connection 219 may be implemented with UDP/IP messages or a TCP/IP connection from physical station 212 ′ to router 350 , to router 340 , across backbone 330 , to another router, and so on, until station 214 ′ is reached.
- Such techniques are well known in the field.
- a network location 322 ′ of a server which may provide login services for band and/or audience members.
- a station such as 214 ′ may need to register through a server 322 ′ before being connected to other band members or the engineer/server node 312 .
- membership in the audience hierarchy 230 is a service for sale (e.g., a ticketed event) or otherwise restricted (e.g., private performance)
- a station such as 262 ′ would need to register through server 322 ′ before joining the audience hierarchy 230 .
- nodes and connections in FIG. 2 are in bold, for instance node 212 and connection 213 .
- the bold nodes and connections highlight which elements shown in FIG. 2 are used in subsequent figures, such as FIG. 3 to emphasize how the shape of the hierarchy and organization in FIG. 2 corresponds and is implemented by the structures in subsequent figures.
- node 244 and its descendents are not bolded in FIG. 2 and are not found subsequently.
- performer node 216 nor any third row audience node with the sole exception of node 270 .
- the effective audience hierarchy 410 is comprised of audience nodes 240 , 242 , 260 - 265 , 270 , and connections 221 , 223 , 251 - 256 , 272 , and with engineer/server node 312 being the implementation of engineer/server node 220 , the bold portion of audience hierarchy 230 of FIG. 2 is reproduced.
- Each node in the effective audience hierarchy 410 corresponds to a station in the physical network 320 shown at the bottom of FIG. 4 , as indicated by corresponding numbers 240 ′, 242 ′, 260 ′- 265 ′, 270 ′, 312 ′.
- a distributed hash table (DHT) ring 430 is shown between the upper grouping of the effective audience hierarchy 410 and the lower grouping of physical network 320 .
- DHT distributed hash table
- Each DHT node corresponds to an audience hierarchy node of corresponding number: 240 , 242 , 260 - 265 , 270 ; or to the engineer/server node 312 .
- DHT ring 430 successor pointers 430 are shown which link each of the DHT nodes 240 ′′, 242 ′′, 260 ′′- 265 ′′, 270 ′′, and 312 ′′ into the ring.
- successor pointers 430 are shown which link each of the DHT nodes 240 ′′, 242 ′′, 260 ′′- 265 ′′, 270 ′′, and 312 ′′ into the ring.
- predecessor pointers used for ring maintenance and successor list pointers used for ring stabilization both as taught by Ghodsi (op cit, p 29-30).
- audience hierarchy 410 is the audience hierarchy 230 applied to the audience stations 240 ′, 242 ′, 260 ′- 265 ′, 270 ′, and engineer/server station 312 ′ of WAN topology 320 .
- each node maintains a successor list (op cit, p 33-35 & 75-81), sometimes called a ‘finger list’ or ‘finger table’.
- the first entry in a DHT node's successor list is the node's own successor pointer (shown in DHT ring 430 as successor pointers 432 ).
- the successor of DHT node 265 ′′ is 264 ′′. Additional entries in this list are required to recover from failures.
- the second entry is preferably a pointer (not shown) to the successor of the successor of node 265 ′′, thus, a pointer to node 263 ′′.
- DHT node 264 ′′ fails unexpectedly, node 265 ′′ can figure out how to reconnect the ring.
- Additional entries in the successor list point to more distance nodes in the succession chain, which permits recovery in many cases of multiple or wide-spread failures.
- the station In order for a station in physical network 320 to join a live performance as an audience member, the station must create a DHT node and join DHT ring 430 . To do this, the station must first have information identifying at least one of the DHT nodes already in DHT ring 430 . Preferably, that information is available from a well-known, stable source, and is preferably provided by server 322 ′, though another server (not shown) may be used.
- This configuration process of contacting the well-known source, if needed, and subsequently establishing the connections to join the DHT ring 430 or other organizing entity and subsequently connecting with audience nodes in the audience hierarchy 410 represents a configuration known by, provided to, or created by the station or a combination thereof.
- An application running on server 322 ′ provides a list of all live performances currently available, each corresponding to a separate DHT ring 430 (only one shown). Once a performance is selected by the user of the station, server 322 ′ may deliver to the station and new DHT node information concerning one or more nodes of the DHT ring 430 corresponding to the selected performance, part of the configuration of the station. Once the new DHT node has joined, the creation of an audience node 110 begins. Initially, newly joining audience node 110 can contact neighboring DHT nodes to find one with an open child position.
- DHT node 270 ′′ may contact its predecessor node 263 ′′ with a request to join the audience hierarchy 410 .
- audience node 263 accepts new audience node 270 and preferably reports that it is in the second row.
- audience nodes 263 and 270 cooperate to establish connection 272 , which represents both an instance of connection 122 delivering content and audience reaction to audience node 270 , and an instance of connection 118 returning audience response to parent audience node 263 .
- connection 272 which represents both an instance of connection 112 for delivering content and audience response to child node 270 , and an instance of connection 132 for receiving audience response from child node 270 .
- a new DHT node can attempt to optimize the position it takes in the audience hierarchy 410 .
- audience node 270 can determine that the audience node 263 corresponding to predecessor DHT node 263 ′′ is in the second row (which would place audience node 270 in the third row).
- audience node 270 may query the audience nodes corresponding to other neighbor nodes on DHT ring 430 .
- a query to audience node 270 corresponding to successor DHT node 240 ′′ finds that audience node 270 is in the first row, but that there are no child positions available (assuming the fanout of audience node 240 is limited to three).
- a query to other neighboring nodes i.e., predecessors of predecessors, successors of successors, etc. around the DHT ring 430 ) find that they are either also in the second row, or that their fanout capacity has been filled.
- an exception is found if new audience node 270 were to query engineer/server node 312 , which only has two children.
- audience node 270 might have joined audience hierarchy 410 as a child of engineer/server node 312 with the result that audience node 270 would be in the first row.
- a variety of optimization techniques can be employed. For very large audiences, it is desirable for stations that are in close proximity on the physical network 320 to be close together in audience hierarchy 410 , so that latencies can be minimized. This can be facilitated in some instances by employing the IP address of the stations on physical network 320 as the key a DHT node uses as its identity. For example, audience stations such as 263 ′ and 270 ′ connect to the same access equipment 350 . To have the DHT nodes corresponding to stations 270 ′ and 263 ′ be adjacent in the DHT ring 430 would take advantage of the likely minimum latency found between those two audience nodes, relative to other audience nodes for which the routing would be more elaborate.
- stations 242 ′, 264 ′, and 265 ′ would be expected to have low mutual latencies, as would 240 ′, and 260 ′- 262 ′. While these groupings could occur by using empirical measurements of latencies among arbitrary numbers of previously joined DHT nodes when a new DHT node is joining, the knowledge that contiguous ranges of IP addresses are assigned to common companies, and that individual pieces of routing equipment are often provided with a subrange of addresses for which they are responsible and can assign dynamically. In particular, stations in the physical network 320 having IP addresses differing only in the last octet will be very likely to have low mutual latencies.
- a simple procedure for restructuring the audience hierarchy as an audience node leaves is to always promote the leftmost child node into the position vacated by its parent.
- a leaving parent's position is taken by the leftmost child vacating (for an instant) its position in the hierarchy, at which point the non-leftmost children of the leaving parent remain in place though now attached to the promoted leftmost child.
- the leftmost child of the leftmost child of the leaving parent is promoted to the position vacated by its parent, and so on.
- This method also has the property that each node that is changing its position in the hierarchy is moving forward one row.
- audience members 160 do not experience a discontinuity in audio signals.
- the child having the shortest sub-hierarchy (in rows) can be selected for promotion.
- One way to do this is to promote a first immediate child node of the leaving parent to the leaving parent's position. The remaining immediate children can be positioned as children (or later descendents) of that first child node.
- the reconnections can be implemented, starting with immediate children taking the positions other than the leaving parent's position, and the first child node at the last replacing the parent.
- Additional finesse can be exercised as an audience node leaves audience hierarchy 410 .
- a leaving audience node has no children, there is the opportunity for a sub-hierarchy headed by an audience node in a higher numbered row to be promoted to the position being vacated by the leaving audience node. This too promotes minimizing the height of the audience hierarchy 410 .
- Those skilled in the art will recognize the opportunity to apply many of the well-known algorithms for managing n-tuple trees, where such variations would fall within the intent of the present invention.
- an authentication step (e.g., a login with username and password, or a cookie) occurs between a station or its audience member and engineer/server node 220 prior to joining DHT ring 430 or audience hierarchy 410 .
- an audience node or DHT node misbehaves once or repeatedly, for example, by unceremoniously departing from DHT ring 430 without observing the appropriate steps for leaving the ring, or other problematic behavior, then the account to which the station or audience member is authenticated can be tagged as a ‘problem member’ and either be denied future participation, or be relegated to a position with lower disruptive potential (e.g., being put in the last row of a hierarchy).
- audience nodes 410 some members of audience hierarchy 410 are leaf nodes, that is, they have no children: see audience nodes 260 - 262 , 264 - 265 , and 270 .
- audience nodes are usually added to the outer portion of the hierarchy and don't initially have child nodes attached.
- this leaf node status might be enforced for stations that are detected to have bandwidth adequate only to support communication with the parent.
- a wireless device such as a network enabled cell phone. In this case, even though a device can't participate as a parent node for other audience nodes, there are always positions available within the audience hierarchy 220 that can accommodate a leaf node.
- the fraction of nodes which can be leaf nodes approaches (1-1/fanout).
- the non-leaf audience nodes have an average fanout of three, up to 2 ⁇ 3 of the nodes can be leaf nodes.
- DHT ring 530 DHT ring 530 , audience hierarchy 410 ′, and performance nodes 310 ′ illustrate an implementation where the functions of engineer/server node 220 are divided among the two physical stations 322 ′, the server, and 312 ′, the engineering station (both shown in physical network 320 , entirely applicable to, but not shown in FIG. 5 ).
- the configuration of successor pointers 532 in DHT ring 530 is similar to DHT ring 430 , except that the anchor member is engineer/server node 322 ′′ rather than engineer/server node 312 ′′.
- engineer/server node 322 in audience hierarchy 410 ′ takes the place of engineer/server node 312 in audience hierarchy 410 , such that connections 221 and 223 to first row audience nodes 240 and 242 attach to engineer/server 322 .
- An addition brought on by the separated roles of server and engineer is that server 322 needs to provide engineer station 312 with a signal representing audience response and preferably content using connection 514 .
- server 322 receives the content of performance nodes 212 and 214 and provides the fanout of that content to the first row of audience nodes (which comprises audience nodes 240 and 242 ).
- An engineer (not shown) working through engineer station 312 sets mixing levels and manages recording through connection 512 .
- connections 213 and 215 can remain with engineer station 312 as shown in performance group 310 , and then the engineer station 312 would provide the content to server 322 .
- the advantage of separating the server role from the engineer role of engineer/server node 220 is to rely on server 322 for a higher fanout than might otherwise be available from a the engineer's workstation 312 .
- physical network 620 includes fewer audience members than in earlier figures. Accordingly, DHT ring 630 joined with successor pointers 632 is smaller.
- the smaller number of audience members used in the illustration is because fanout bandwidth of some audience members in audience hierarchy 610 has been allocated as a backup to other audience members in audience hierarchy 610 , for use if a parent audience member fails, as opposed to allocating that fanout bandwidth exclusively to additional audience nodes.
- Audience nodes in audience hierarchy 610 have an alternative to their respective parent connection 122 (from FIG. 1 ) for delivery of content.
- audience node 270 receives at least content from second row parent node 264 over connection 272 .
- another second row node 264 maintains backup connection 272 ′ to third row audience node 270 .
- connection 254 ′ from first row node 240 serves as a backup for second row node 263 in case primary connection 254 from first row node 242 were to fail; as connection 255 ′ is a backup for connection 255 and connection 256 ′ forms a backup for connection 256 .
- engineer/server node 312 may be considered reliable and not subject to offerings of redundant connections. However, especially when splitting the roles of server/engineer node 220 into separate physical entities (as illustrated in FIG. 5 ), a redundant server node (not shown) may provide backup to first row children of server node 322 .
- a server node may be provided that dynamically provides a replacement stream (not shown) in case a parent node unexpectedly fails.
- the switchover can be smooth and perhaps unnoticed by the audience member 160 corresponding to the audience node 110 whose parent 120 failed. Once the switchover has occurred, the system can find a new position within the audience hierarchy so that server bandwidth remains available as a backup for failures.
- backup links will be used infrequently and that, statistically, it is not necessary for a member node of audience hierarchy 610 reserving bandwidth for use as a backup connection to strictly allocate that bandwidth to precisely one other audience member.
- a given audience node may offer more backup connections than it can physically support and be relatively safe because it is statistically unlikely that all such backup connections will be needed at once.
- the backup connections 254 ′- 256 ′ and 272 ′ to their respective backup parents can change dynamically as nodes join and leave DHT ring 630 .
- audience nodes might dynamically and continuously move to different parent nodes or exchange child nodes. In this way, continuous ‘milling about’ in the virtual auditorium can be simulated.
- an explicit control in the user interface would induce the local node 110 to relocate itself within audience hierarchy 220 and might be used, for example, to effectively change an audience node's position within audience hierarchy to move away from noisy or unruly neighbors in the audience hierarchy. Note that no corresponding change is required within DHT ring 430 .
- Such a technique of moving an audience node among other audience nodes in the audience network can be based upon an avatar's movement within a virtual world.
- proximity in a virtual world of two avatars promotes an affinity between the two audience nodes corresponding to the two avatars, and those audience nodes would be migrated toward each other.
- the audience members corresponding to the two avatars could converse by shouting over the music in a nightclub simulation.
- audience hierarchy 410 ′ minus the connection 514 and engineer node 312 (thus removing the engineer role), and minus the interaction with distributed performance 310 ′, is simply a conference call, moderated by a distributed voice bridge managed by the DHT ring 530 or other peer-to-peer organizing mechanism and anchored by server 322 .
- server 322 can be substituted for by another audience station (not shown) with its own audience member participating or moderating the conference call.
- the server is a centralized voice bridge and may be implemented as a voice bridge of the prior art.
- a voice bridge implements a conference call, which may or may not have unmanaged latencies, to which a distributed performance of the prior art having tightly managed latencies, has been connected.
- FIG. 7 shows an exemplary implementation of an audience node 110 .
- connections 122 , 112 , 114 , and 116 conduct both content and audience response, which may be implemented as separate signals over the corresponding connections, but for the simplicity of illustration and as a preferred embodiment, the bandwidth-conserving implementation where content and audience response is combined into a common signal is shown.
- buffer 720 Content and audience response from parent 120 arrives on connection 122 and is collected in buffer 720 .
- buffers 730 , 740 , and 750 collect audience response from child nodes 130 , 140 , and 150 , respectively; and buffer 760 collects audience response from audience member 160 .
- Each mixer 770 , 772 , 774 , 776 , and 778 combines signals for delivery to the audience member 160 , the child nodes 130 , 140 , 150 , and the parent node 120 , respectively.
- each mixer is shown with five inputs, U, L, M, R, and P, corresponding to signals sourced by the audience member, left, middle, and right child nodes, and the parent node.
- Each mixer preferably has a different one of its inputs set to null 710 , always corresponding to the signal from the entity to which the mixer's output will be provided.
- content and audience response from buffer 720 is distributed to mixers 770 , 772 , 774 , 776 , but not to 778 , as made clear by null input 771 on mixer 778 . This configuration helps to minimize feedback.
- each mixer operates to produce a single signal, which may be in stereo, wherein the input components are combined and cannot subsequently be separated.
- mixers 772 , 774 , 776 , 778 can operate as multiplexers such that one or more of the input components remains distinct and separately manageable from the others.
- demultiplexers (not shown) are used at the remote nodes 120 , 130 , 140 , and 150 , and in conjunction with receive buffers 720 , 730 , 740 , and 750 , as needed.
- Such a multiplexer/demultiplexer can take the form of interlacing the distinct signals over the same connection, or by creating multiple, parallel connections (not shown).
- mixer 722 could provide a similar distinction for connection 112 to child 130 , since it has access to an unadulterated content signal and is able to mix other audience responses available to node 110 with the audience response signal from parent node 120 .
- the signal from buffer 720 can be examined by timing control 762 when advanced to mixer 770 .
- Timing control 762 extracts timing information such as a timestamp, a frame number, sample number, etc. so that the signal collected by buffer 760 from audience member 160 can be correspondingly marked or tracked.
- timing information such as a timestamp, a frame number, sample number, etc.
- all responses from all audience members are associated with a position within the content signal. For example, at the onset of a performance, a band may open with a widely recognized-riff. Audience members may react with audible sighs or applause expressing recognition and anticipated pleasure of the piece just beginning.
- outbound mixers 772 , 774 , and 776 can combine content from buffer 720 with local audience response from buffer 760 so that the synchronization between the performance and the audience response is preserved. Note that it is not necessary for content from buffer 720 to be delivered to mixer 770 at the same time as to mixers 772 , 774 , and 776 .
- a preferred embodiment is to select a modest inter-row latency to be established between two consecutive rows in audience hierarchy 230 , for example, 100 mS.
- connection 122 can be measured as described in the prior art (including the '926 patent) and subtracted from the selected inter-row latency to provide a delay time by which, on average, the inbound signal from connection 122 is delayed in buffer 720 before advancing to mixers 772 , 774 , and 776 .
- the content from buffer 720 might only be delayed by 80 mS before presentation to mixer 770 so that enough audience response is collected in buffer 760 to mix with precise synchrony with content from buffer 720 at mixers 772 , 774 , and 776 .
- the inter-row latency is kept below one second because longer latencies are expected to disrupt the perception of ‘real time’.
- longer latencies are expected to disrupt the perception of ‘real time’.
- With extremely widespread connections e.g., audiences that span the globe
- communications channels that employ satellite links such latencies may be unavoidable.
- an echo detection system examines the contents of buffer 760 and earlier contents of buffer 720 .
- a correlation between the two buffer contents would represent the degree of feedback formed if transducer 164 in-use by audience member 160 comprised audio speakers instead of audio headphones, or if the headphones set so loud as to be detected by the microphone comprising input 166 .
- Such an echo detection system could mute the contents of buffer 760 , or preferably perform echo cancellation upon buffer 760 (not shown).
- Many implementations of echo cancellation algorithms and circuitry are well-known in the art.
- Such an echo cancellation system (not shown) of the prior art can substantially eliminate that component of the signal on input 166 caused by transducers 164 , leaving the signal to be substantially comprised of the response from audience member 160 . Further, those skilled in the art may choose to employ techniques such as noise gating, squelch, automatic muting, or the like in cases of high background noise on input 166 .
- An advantage of establishing a inter-row latency value is that an audience node moving from one parent (who may be leaving the DHT ring) to a new parent will have less difficulty receiving a continuous content stream since any candidate new parent in the same row as the original (leaving) parent will have substantially similar content available in buffer 720 which can be received without disruption for the audience node switching parents, or that audience node's dependents.
- Each buffer should also retain signals for several additional inter-row latency periods. This is valuable when an audience node from more than one row back becomes a child of an audience node. Rather than skipping one inter-row latency period of content for each row a child has moved forward, the child can effectively remain in the same row and hear a substantially contiguous content stream, even though attached as a child of a parent more than one row ahead in audience hierarchy 220 (this configuration is not shown in the Figures). In such a case, for the purposes of balancing the hierarchy, the audience node that is maintaining a latency several rows behind its new parent will retain its old row number.
- An optimization that works to resist the total latency of the system from growing as audience nodes leave and others join the hierarchy, is for an audience node that is more than one row removed from its parent node should be migrated to a different parent node not so many rows ahead, if the opportunity arises.
- the audience member if an audience member connects to a parent with the result of connection 122 having a high latency, higher than the inter-row latency, then the audience member preferably receives a higher row designation such that a target of two or more times the inter-row latency can be met reliably. If the audience member changes parents and the latency of new connection 122 to the new parent is less, the higher row designation preferably stands so that no skip occurs in the content provided to that audience node's audience member 160 or to the child nodes.
- an audience member is not moved backward to a higher numbered row, as this will cause a repeat in the content performance of a duration equal to the inter-row latency, unless there was an excess delay provided by buffer 720 .
- inter-row latency budget is predetermined to be 100 mS.
- a parent node provides content to a particular audience node with an actual transport latency of 90 mS.
- An additional 20 mS of latency may be reserved by the buffer to ensure that the jitter in delivery times over the connection 122 is unlikely to cause the buffer to run empty. This totals 110 mS, which exceeds the inter-row latency.
- local node 110 supports unequal inter-row latencies, then even through the connection from its parent runs 10 mS over the inter-row latency budget, it can still operate with children having an under-budget latency, for example, on connection 112 the budget of 100 mS minus the 10 mS overage on connection to the parent's minus a 20 mS jitter-safe buffering reserve, suggest that a connection to a child having an actual transport latency of 70 mS or less would be fine, thus mitigating the overage.
- inter-row latency is merely a convenience for smoothly changing connections between two parents, not a requirement.
- inter-row latency is quantized (e.g., multiples of 100 mS). But even that is not strictly required.
- buffer 720 gathers at least enough signal to protect from likely jitter in connection 122 so that the buffer is unlikely to run empty and produce a situation where mixer 770 runs out of content signal P to be provided to the audience member 160 via output 162 , then that buffer latency is sufficient.
- the '926 patent teaches methods of covering the loss in cases where the input buffer 720 does run out of data because content was lost or delivered too late.
- Exemplary station 270 ′ on physical network 320 executes audience node process 800 , shown in FIG. 8 .
- station 270 ′ will attempt to become an instance of audience node 110 .
- server 322 ′ authenticating to an account known to server 322 ′ and which may be associated with station 270 ′ or member 160 , and selecting one of the available performances known to server 322 ′ whether automatically in accordance with the authentication, or manually by audience member 160 , or a combination of thereof.
- server 322 ′ directs station 270 ′ to contact to at least one node in audience hierarchy 230 .
- this contact is mediated by a self-organized overlay network, such as DHT ring 430 ; but alternatively may be managed by server 322 ′ or engineer/server node 220 .
- station 270 ′ queries and joins DHT ring 430 as DHT node 270 ′′. Thereafter, using its connections as DHT node 270 ′′, station 270 ′ can contact neighbors 240 ′′ and 263 ′′ on the DHT ring 430 and join audience hierarchy 230 as audience node 270 , which is finally an instance of audience node 110 .
- the account when authenticating to an account, can represent a membership account, which may be subject to a subscription or event fee whereby a potential audience member 160 is seen to have paid for access to the presentation.
- authenticating to an account may reference a financial account, for instance a credit card, which might be charged directly for the service or for the presentation to which access is sought.
- audience node 110 preferably iterates over its parent and child nodes in audience hierarchy 230 to determine latencies of connections 112 , 114 , 116 , 118 , 122 , 132 , 142 , 152 . This occurs in step 806 .
- the latency to an remote node is measured, preferably by measuring a round-trip time (RTT) for example through connection 118 to parent node 120 and back over connection 122 , and dividing by two. The result is the expected latency for both connections in the round-trip, and is expected to be symmetrical absent other information about the connections.
- RTT round-trip time
- connection 272 ′ in FIG. 6 Preferably more than one measurement is taken, to lower the noise in the measurement and characterize jitter (fluctuations in latency), and though not shown in FIG. 8 , the measurement process can continue in parallel throughout process 800 as a background task, so as to keep audience node 110 abreast of changes in network traffic. Similar measurements can be made and maintained with respect to alternative or backup connections (e.g., connection 272 ′ in FIG. 6 ) to allow audience hierarchy to anneal its structure to become more stable and/or more optimized. Once connection latencies are characterized satisfactorily, the process continues to step 810 .
- audience node 110 may try to relocate within audience hierarchy 230 (not shown). Contact with other nodes can be initiated through DHT ring 430 or other organizing entity, e.g. server 322 ′ or engineer/server 220 . However, a high latency may be addressed as previously described, by simply accepting it, and preferably incrementing the row number of audience node 110 until the measured latency is less than the increment times a predetermined inter-row latency.
- a stream from the parent 120 which in this example is audience node 263 , is initiated.
- the progress of initiating the stream is monitored in step 812 and once the stream begins over connection 272 , an ongoing capture process 814 is spawned and proceeds to receive that stream into buffer 720 .
- buffer 720 is monitored in step 816 .
- process 818 is spawned to transfer the data captured in buffer 720 to playout to audience member 160 through mixer 770 and output 162 .
- audience response from audience member 160 through input 166 is captured in buffer 760 , preferably in substantial synchrony with the playout. If necessary, echo detection, and mitigation (e.g., by muting) or cancellation occurs here.
- Step 820 initiates the stream for each attached remote audience node (i.e., parent and child nodes).
- Step 822 is performed with respect to the parent node 120 by monitoring the content of buffer 760 .
- process 824 is spawned to stream the output of mixer 778 over connection 118 .
- Step 826 is skipped with respect to parent node 120 .
- step 830 The loop iterates at step 830 , returning for each attached child node.
- An attached child node will have successfully completed its performance of process 800 through step 810 , as a child (e.g., 130 ) of the present audience node, it has the present audience node connected as its parent.
- the present audience node repeats step 822 now with regard to child node 130 monitoring buffer contents in buffer 760 . Once determined that the contents of buffer 760 are sufficient to accommodate expected combined jitter and latencies of connections 122 and 112 , process 824 is spawned to operate mixer 772 and start the stream over connection 112 .
- step 826 a stream initiated by child node 130 in its performance of step 822 relative to its parent (the present audience node) results in a stream arriving over connection 132 and beginning to fill buffer 730 .
- the present audience node monitors the contents of buffer 730 for sufficiency given known latencies and jitter.
- step 826 has considered child buffer 730 to be sufficient, the contents of buffer 730 are allowed to be used by mixers 770 , 774 , 776 , and 778 , whereas before, the contents of buffer 730 were withheld from those mixers.
- buffers 720 , 730 , 740 , 750 and 760 are mixed either synchronously or with a fixed offset, for example, the predetermined inter-row latency by mixers 770 , 772 , 774 , 776 , and 778 .
- this loop will iterate for each child node added, even if the child nodes are added later, as shown by the ongoing maintenance control flow 833 .
- an affected mixing process 824 will mute the corresponding mixer input until the stream stabilizes or is re-established, which may be through a recurrence of step 822 with respect to the faltering or failed node.
- process 800 checks in step 832 for the end of the performance. If the performance is not ended, process 800 preferably includes a maintenance loop 833 , by which mixes for recently added child nodes can be initiated, or faltering nodes can be re-engaged.
- process 800 can conclude at step 836 , wherein any persisting processes spawned can be terminated and buffer resources released.
- a high quality copy of the buffer contents can be immediately sent or saved and later uploaded to server 322 ′, for example using the file transfer protocol FTP.
- FTP file transfer protocol
- a different, higher quality, higher bit rate CODEC may be used for this high quality copy of the buffer.
- a high quality mix of the aggregate audience response can be created from the uploaded audience responses.
- the buffer contents can be made available to mixers 770 , 772 , 774 , 776 , and 778 as appropriate, and streamed to remote nodes.
- maintenance loop 833 is the maintenance of audience hierarchy 230 as neighboring nodes leave, including migration to lower numbered rows or lateral or more dramatic moves needed to switch parents, discussed earlier. Changes to audience hierarchy are preferably initiated as a result of typical (and well known) DHT ring 430 ‘leave’ and ‘ring maintenance’ algorithms, not shown here, taught by Ghodsi.
- no performance group 210 For use with pre-recorded content, no performance group 210 is needed.
- the pre-recorded content can be supplied by engineer/server node 220 and distributed through audience hierarchy 220 .
- no performance group 210 is used.
- the computer of the call organizer is preferably used as the engineer/server node 220 , or as described above, the roles of engineer and server can be divided, as between nodes 312 and 322 as discussed in conjunction with FIG. 5 .
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Telephonic Communication Services (AREA)
Abstract
Description
A N =U N +A C
Where the three separate AC signal components are audience responses from the three (left, middle, and right)
A C =A C
A N-C
A N-C
A N-C
In the case of each Equation 3, 4, and 5, the audience responses generated at
ContentN=ContentP +A P-N
MaxA =F S ×F N (R-1)
Claims (32)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/900,232 US9131016B2 (en) | 2007-09-11 | 2007-09-11 | Method and apparatus for virtual auditorium usable for a conference call or remote live presentation with audience response thereto |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/900,232 US9131016B2 (en) | 2007-09-11 | 2007-09-11 | Method and apparatus for virtual auditorium usable for a conference call or remote live presentation with audience response thereto |
Publications (2)
Publication Number | Publication Date |
---|---|
US20090067349A1 US20090067349A1 (en) | 2009-03-12 |
US9131016B2 true US9131016B2 (en) | 2015-09-08 |
Family
ID=40431715
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/900,232 Expired - Fee Related US9131016B2 (en) | 2007-09-11 | 2007-09-11 | Method and apparatus for virtual auditorium usable for a conference call or remote live presentation with audience response thereto |
Country Status (1)
Country | Link |
---|---|
US (1) | US9131016B2 (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10937418B1 (en) * | 2019-01-04 | 2021-03-02 | Amazon Technologies, Inc. | Echo cancellation by acoustic playback estimation |
US10944999B2 (en) | 2016-07-22 | 2021-03-09 | Dolby Laboratories Licensing Corporation | Network-based processing and distribution of multimedia content of a live musical performance |
Families Citing this family (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8442424B2 (en) * | 2008-09-26 | 2013-05-14 | Deep Rock Drive Partners Inc. | Interactive live political events |
US20140176665A1 (en) * | 2008-11-24 | 2014-06-26 | Shindig, Inc. | Systems and methods for facilitating multi-user events |
FR2939992B1 (en) * | 2008-12-17 | 2010-12-31 | Canon Kk | METHOD FOR BALANCING LATENCY IN A COMMUNICATION SHAFT, DEVICE, COMPUTER PROGRAM PRODUCT, AND CORRESPONDING STORAGE MEDIUM |
US8515041B2 (en) * | 2010-08-31 | 2013-08-20 | Avaya Inc. | Audio conference feedback system and method |
JP2012129800A (en) * | 2010-12-15 | 2012-07-05 | Sony Corp | Information processing apparatus and method, program, and information processing system |
US8411132B2 (en) | 2011-01-27 | 2013-04-02 | Audio Properties, Inc. | System and method for real-time media data review |
US20130178961A1 (en) * | 2012-01-05 | 2013-07-11 | Microsoft Corporation | Facilitating personal audio productions |
US8806518B2 (en) | 2012-06-27 | 2014-08-12 | Intel Corporation | Performance analysis for combining remote audience responses |
CN104104533B (en) * | 2013-04-09 | 2017-08-01 | 广州华多网络科技有限公司 | Section switching method, server and client side's equipment |
US10090002B2 (en) | 2014-12-11 | 2018-10-02 | International Business Machines Corporation | Performing cognitive operations based on an aggregate user model of personality traits of users |
US10013890B2 (en) | 2014-12-11 | 2018-07-03 | International Business Machines Corporation | Determining relevant feedback based on alignment of feedback with performance objectives |
US10282409B2 (en) | 2014-12-11 | 2019-05-07 | International Business Machines Corporation | Performance modification based on aggregation of audience traits and natural language feedback |
US9495361B2 (en) | 2014-12-11 | 2016-11-15 | International Business Machines Corporation | A priori performance modification based on aggregation of personality traits of a future audience |
JP6697158B2 (en) * | 2016-06-10 | 2020-05-20 | 富士通株式会社 | Information management program, information management method, and information management device |
WO2022026425A1 (en) * | 2020-07-27 | 2022-02-03 | Dreamstage, Inc. | System and method for aggregating audiovisual content |
US11777863B2 (en) * | 2020-12-21 | 2023-10-03 | Landis+ Gyr Innovations | Optimized route for time-critical traffic in mesh network |
EP4358522A4 (en) * | 2021-06-15 | 2024-08-14 | Sony Group Corp | Information processing device, information processing method, and information processing system |
US11606400B2 (en) | 2021-07-30 | 2023-03-14 | Zoom Video Communications, Inc. | Capturing and presenting audience response at scale |
CN113596516B (en) * | 2021-08-06 | 2023-02-28 | 腾讯音乐娱乐科技(深圳)有限公司 | Method, system, equipment and storage medium for chorus of microphone and microphone |
Citations (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040034723A1 (en) * | 2002-04-25 | 2004-02-19 | Giroti Sudhir K. | Converged conferencing appliance and methods for concurrent voice and data conferencing sessions over networks |
US6840496B2 (en) * | 2003-02-28 | 2005-01-11 | Advance Modern Technologies Corp. | Automatic flush actuation apparatus |
US6850496B1 (en) * | 2000-06-09 | 2005-02-01 | Cisco Technology, Inc. | Virtual conference room for voice conferencing |
US20050024484A1 (en) * | 2003-07-31 | 2005-02-03 | Leonard Edwin R. | Virtual conference room |
US20050074107A1 (en) * | 2003-10-01 | 2005-04-07 | Renner W. Karl | Conference calls via an intelligent call waiting interface |
US20050187946A1 (en) * | 2004-02-19 | 2005-08-25 | Microsoft Corporation | Data overlay, self-organized metadata overlay, and associated methods |
US20050237952A1 (en) * | 2004-03-19 | 2005-10-27 | Marconi Communications, Inc. | Method and apparatus for conferencing with bandwidth control |
US6973184B1 (en) * | 2000-07-11 | 2005-12-06 | Cisco Technology, Inc. | System and method for stereo conferencing over low-bandwidth links |
US20050286443A1 (en) * | 2004-06-29 | 2005-12-29 | Octiv, Inc. | Conferencing system |
US20060067500A1 (en) * | 2000-05-15 | 2006-03-30 | Christofferson Frank C | Teleconferencing bridge with edgepoint mixing |
US20060132595A1 (en) * | 2004-10-15 | 2006-06-22 | Kenoyer Michael L | Speakerphone supporting video and audio features |
US20060209728A1 (en) | 2005-03-15 | 2006-09-21 | Lucent Technologies Inc. | Method and apparatus for establishing a distributed conference bridge |
US20060210045A1 (en) * | 2002-12-30 | 2006-09-21 | Motorola, Inc. | A method system and apparatus for telepresence communications utilizing video avatars |
US20060256738A1 (en) * | 2004-10-15 | 2006-11-16 | Lifesize Communications, Inc. | Background call validation |
US20070002869A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Routing cache for distributed hash tables |
US20070002778A1 (en) * | 2005-06-08 | 2007-01-04 | Huawei Technologies Co., Ltd. | Method for query of domain names of telephone numbers |
US20070025538A1 (en) * | 2005-07-11 | 2007-02-01 | Nokia Corporation | Spatialization arrangement for conference call |
US20070041366A1 (en) * | 2005-05-24 | 2007-02-22 | Smart Link Ltd. | Distributed conference bridge |
US20070058631A1 (en) * | 2005-08-12 | 2007-03-15 | Microsoft Corporation | Distributed network management |
US7197126B2 (en) * | 2003-05-26 | 2007-03-27 | Hitachi, Ltd. | Human communication system |
US20070140456A1 (en) * | 2001-12-31 | 2007-06-21 | Polycom, Inc. | Method and apparatus for wideband conferencing |
US20070223675A1 (en) * | 2006-03-22 | 2007-09-27 | Nikolay Surin | Method and system for low latency high quality music conferencing |
US20070230482A1 (en) * | 2006-03-31 | 2007-10-04 | Matsushita Electric Industrial Co., Ltd. | Method for on demand distributed hash table update |
US20070279484A1 (en) * | 2006-05-31 | 2007-12-06 | Mike Derocher | User interface for a video teleconference |
US20070291667A1 (en) * | 2006-06-16 | 2007-12-20 | Ericsson, Inc. | Intelligent audio limit method, system and node |
US20080082628A1 (en) * | 2006-09-29 | 2008-04-03 | Microsoft Corporation | Scalable Query Infrastructure |
US20080129816A1 (en) * | 2006-11-30 | 2008-06-05 | Quickwolf Technology, Inc. | Childcare video conferencing system and method |
US20080144794A1 (en) * | 2006-12-14 | 2008-06-19 | Gardner William G | Spatial Audio Teleconferencing |
US20080159507A1 (en) * | 2006-12-27 | 2008-07-03 | Nokia Corporation | Distributed teleconference multichannel architecture, system, method, and computer program product |
US20080192109A1 (en) * | 2005-03-16 | 2008-08-14 | Schmit Chretien Schihin & Mahler | Device for Carrying Out a Video Conference |
US20080260132A1 (en) * | 2007-04-20 | 2008-10-23 | Browan Communications, Inc. | Low bandwidth but high capacity telephone conference system |
US20090262668A1 (en) * | 2005-08-30 | 2009-10-22 | Elad Hemar | Immediate communication system |
US7839803B1 (en) * | 1998-09-25 | 2010-11-23 | Wireless Systems Technologies, Inc. | Method and system of teleconferencing |
US8208477B1 (en) * | 2005-08-24 | 2012-06-26 | Hewlett-Packard Development Company, L.P. | Data-dependent overlay network |
US8504733B1 (en) * | 2007-07-31 | 2013-08-06 | Hewlett-Packard Development Company, L.P. | Subtree for an aggregation system |
-
2007
- 2007-09-11 US US11/900,232 patent/US9131016B2/en not_active Expired - Fee Related
Patent Citations (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7839803B1 (en) * | 1998-09-25 | 2010-11-23 | Wireless Systems Technologies, Inc. | Method and system of teleconferencing |
US20060067500A1 (en) * | 2000-05-15 | 2006-03-30 | Christofferson Frank C | Teleconferencing bridge with edgepoint mixing |
US6850496B1 (en) * | 2000-06-09 | 2005-02-01 | Cisco Technology, Inc. | Virtual conference room for voice conferencing |
US6973184B1 (en) * | 2000-07-11 | 2005-12-06 | Cisco Technology, Inc. | System and method for stereo conferencing over low-bandwidth links |
US20070140456A1 (en) * | 2001-12-31 | 2007-06-21 | Polycom, Inc. | Method and apparatus for wideband conferencing |
US20040034723A1 (en) * | 2002-04-25 | 2004-02-19 | Giroti Sudhir K. | Converged conferencing appliance and methods for concurrent voice and data conferencing sessions over networks |
US20060210045A1 (en) * | 2002-12-30 | 2006-09-21 | Motorola, Inc. | A method system and apparatus for telepresence communications utilizing video avatars |
US6840496B2 (en) * | 2003-02-28 | 2005-01-11 | Advance Modern Technologies Corp. | Automatic flush actuation apparatus |
US7197126B2 (en) * | 2003-05-26 | 2007-03-27 | Hitachi, Ltd. | Human communication system |
US20050024484A1 (en) * | 2003-07-31 | 2005-02-03 | Leonard Edwin R. | Virtual conference room |
US20050074107A1 (en) * | 2003-10-01 | 2005-04-07 | Renner W. Karl | Conference calls via an intelligent call waiting interface |
US20050187946A1 (en) * | 2004-02-19 | 2005-08-25 | Microsoft Corporation | Data overlay, self-organized metadata overlay, and associated methods |
US20050237952A1 (en) * | 2004-03-19 | 2005-10-27 | Marconi Communications, Inc. | Method and apparatus for conferencing with bandwidth control |
US20050286443A1 (en) * | 2004-06-29 | 2005-12-29 | Octiv, Inc. | Conferencing system |
US20060132595A1 (en) * | 2004-10-15 | 2006-06-22 | Kenoyer Michael L | Speakerphone supporting video and audio features |
US20060256738A1 (en) * | 2004-10-15 | 2006-11-16 | Lifesize Communications, Inc. | Background call validation |
US20060209728A1 (en) | 2005-03-15 | 2006-09-21 | Lucent Technologies Inc. | Method and apparatus for establishing a distributed conference bridge |
US20080192109A1 (en) * | 2005-03-16 | 2008-08-14 | Schmit Chretien Schihin & Mahler | Device for Carrying Out a Video Conference |
US20070041366A1 (en) * | 2005-05-24 | 2007-02-22 | Smart Link Ltd. | Distributed conference bridge |
US20070002778A1 (en) * | 2005-06-08 | 2007-01-04 | Huawei Technologies Co., Ltd. | Method for query of domain names of telephone numbers |
US20070002869A1 (en) * | 2005-07-01 | 2007-01-04 | Microsoft Corporation | Routing cache for distributed hash tables |
US20070025538A1 (en) * | 2005-07-11 | 2007-02-01 | Nokia Corporation | Spatialization arrangement for conference call |
US20070058631A1 (en) * | 2005-08-12 | 2007-03-15 | Microsoft Corporation | Distributed network management |
US8208477B1 (en) * | 2005-08-24 | 2012-06-26 | Hewlett-Packard Development Company, L.P. | Data-dependent overlay network |
US20090262668A1 (en) * | 2005-08-30 | 2009-10-22 | Elad Hemar | Immediate communication system |
US20070223675A1 (en) * | 2006-03-22 | 2007-09-27 | Nikolay Surin | Method and system for low latency high quality music conferencing |
US20070230482A1 (en) * | 2006-03-31 | 2007-10-04 | Matsushita Electric Industrial Co., Ltd. | Method for on demand distributed hash table update |
US20070279484A1 (en) * | 2006-05-31 | 2007-12-06 | Mike Derocher | User interface for a video teleconference |
US20070291667A1 (en) * | 2006-06-16 | 2007-12-20 | Ericsson, Inc. | Intelligent audio limit method, system and node |
US20080082628A1 (en) * | 2006-09-29 | 2008-04-03 | Microsoft Corporation | Scalable Query Infrastructure |
US20080129816A1 (en) * | 2006-11-30 | 2008-06-05 | Quickwolf Technology, Inc. | Childcare video conferencing system and method |
US20080144794A1 (en) * | 2006-12-14 | 2008-06-19 | Gardner William G | Spatial Audio Teleconferencing |
US20080159507A1 (en) * | 2006-12-27 | 2008-07-03 | Nokia Corporation | Distributed teleconference multichannel architecture, system, method, and computer program product |
US20080260132A1 (en) * | 2007-04-20 | 2008-10-23 | Browan Communications, Inc. | Low bandwidth but high capacity telephone conference system |
US8504733B1 (en) * | 2007-07-31 | 2013-08-06 | Hewlett-Packard Development Company, L.P. | Subtree for an aggregation system |
Non-Patent Citations (2)
Title |
---|
Boris Mejías, Donatien Grolaux, Peter Van Roy; Improving the Peer-to-Peer Ring for Building Fault-Tolerant Grids; CoreGRID Workshop on Grid Programming Model; Jun. 2006; FORTH-ICS; Heraklion, Greece, (copy attached, see p. 3). |
Ghodsi, Ali; Distributed k-ary System: Algorithms for Distributed Hash Tables; PhD dissertation; Dec. 2006; Royal Institute of Technology, School of Information and Communication Technology, Department of Electronic, Computer, and Software Systems; Stockholm; Sweden (copy attached, see p. 29-30, 63-72, and esp. 116-122). |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10944999B2 (en) | 2016-07-22 | 2021-03-09 | Dolby Laboratories Licensing Corporation | Network-based processing and distribution of multimedia content of a live musical performance |
US11363314B2 (en) | 2016-07-22 | 2022-06-14 | Dolby Laboratories Licensing Corporation | Network-based processing and distribution of multimedia content of a live musical performance |
US11749243B2 (en) | 2016-07-22 | 2023-09-05 | Dolby Laboratories Licensing Corporation | Network-based processing and distribution of multimedia content of a live musical performance |
US10937418B1 (en) * | 2019-01-04 | 2021-03-02 | Amazon Technologies, Inc. | Echo cancellation by acoustic playback estimation |
Also Published As
Publication number | Publication date |
---|---|
US20090067349A1 (en) | 2009-03-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9131016B2 (en) | Method and apparatus for virtual auditorium usable for a conference call or remote live presentation with audience response thereto | |
US9661043B2 (en) | Packet rate control and related systems for interactive music systems | |
EP1312188B1 (en) | Audio data processing | |
US7577110B2 (en) | Audio chat system based on peer-to-peer architecture | |
US9565396B2 (en) | Methods, systems and program products for initiating a process on data network | |
US8144632B1 (en) | Methods, systems and program products for efficient communications during data sharing event | |
US20040111472A1 (en) | Methods and systems for linking virtual meeting attendees over a network | |
US7613137B2 (en) | Data stream communication | |
Lakiotakis et al. | Improving networked music performance systems using application‐network collaboration | |
JP7377352B2 (en) | Multi-member instant messaging method, system, device, electronic device, and computer program | |
Bouillot et al. | Aes white paper: Best practices in network audio | |
WO2024006484A1 (en) | Systems and methods for synchronizing remote media streams | |
Akoumianakis et al. | The MusiNet project: Towards unraveling the full potential of Networked Music Performance systems | |
US11546393B2 (en) | Synchronized performances for remotely located performers | |
Aguirre et al. | Darkcube: A k-Hypercube based P2P VoIP protocol | |
Zimmermann et al. | Audiopeer: A collaborative distributed audio chat system | |
US20230305798A1 (en) | Digital Signal Processing for Cloud-Based Live Performance | |
AU2011217741B2 (en) | A system, method and software application for the dissemination of data across a plurality of computing systems | |
Elleuch | Speech quality evaluation for Large-Scale D2D (Device to device) VoIP conference | |
Gabrielli et al. | Networked Music Performance | |
AU2001282272B8 (en) | Audio data processing | |
Schipani | Remote Engineering: Chronicles of the Adaptable Audio Engineer during COVID-19. | |
Franklin et al. | Merging Places: A Real-Time Distributed Live Reverberation Chamber | |
Kouvelas | A combined network, system and user based approach to improving the quality of multicast audio | |
Kalantzis et al. | Requirements and Application Scenarios in the Context of Network Based Music Collaboration |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: EJAMMING, INC, FLORIDA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:REDMANN, WILLIAM GIBBBENS;REEL/FRAME:019857/0717 Effective date: 20070908 |
|
AS | Assignment |
Owner name: EJAMMING, INC, FLORIDA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KANTOR, GAIL SUSAN;GLUECKMAN, ALAN JAY;REEL/FRAME:023018/0196 Effective date: 20090615 |
|
ZAAA | Notice of allowance and fees due |
Free format text: ORIGINAL CODE: NOA |
|
ZAAB | Notice of allowance mailed |
Free format text: ORIGINAL CODE: MN/=. |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20190908 |
|
PRDP | Patent reinstated due to the acceptance of a late maintenance fee |
Effective date: 20200412 |
|
FEPP | Fee payment procedure |
Free format text: PETITION RELATED TO MAINTENANCE FEES GRANTED (ORIGINAL EVENT CODE: PMFG); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Free format text: PETITION RELATED TO MAINTENANCE FEES FILED (ORIGINAL EVENT CODE: PMFP); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Free format text: SURCHARGE, PETITION TO ACCEPT PYMT AFTER EXP, UNINTENTIONAL. (ORIGINAL EVENT CODE: M2558); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2551); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY Year of fee payment: 4 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20230908 |