This application is for entry into the U.S. national phase under §371 for International Application No. PCT/IB03/05468 having an international filing date of Nov. 27, 2003, and from which priority is claimed under all applicable sections of Title 35 of the United States Code including, but not limited to, Sections 120, 363 and 365(c), and which in turn claims priority to UK application 0315286.7 filed on Jun. 30, 2003 and UK application 0229477.5 filed on Dec. 18, 2002.
The present invention relates to a method of announcing sessions particularly, although not exclusively to a method of announcing multimedia service sessions through a multicast network.
Audio, video and other types of data may be transmitted through a variety of types of network according to many different protocols. For example, data can be transmitted through a collection of networks usually referred to as the “Internet” using protocols of the Internet protocol suite, such as Internet Protocol (IP) and User Datagram Protocol (UDP).
Data is often transmitted through the Internet addressed to a single user. However, it can be addressed to a group of users. This is known as “multicasting”.
One way of multicasting data is to use an IP datacasting network. Through such an IP-based broadcasting network, one or more service providers can supply different types of IP services including on-line newspapers, radio, television and download of music songs, videos, pictures, games and software. These IP services are organised into sessions, each session comprising one or more media streams in the form of audio, video and/or other types of data.
To determine when and where these sessions occur, users refer to an electronic service guide (ESG). One example used in DVB is an electronic program guide (EPG). The electronic service guide is usually divided up into parts and transmitted to users.
This approach, however, has several drawbacks. On the one hand, if any sessions are updated, then the user usually has to wait until a new version of the service guide has been received before they receive notification of updated sessions. On the other hand, few sessions are usually updated. Therefore, much of the data received by the user is superfluous. This is wasteful both in terms of processing power and electrical power, both of which tend to be in short supply in battery-powered mobile terminals.
The present invention seeks to provide an improved method of announcing sessions transmitted through a network.
According to a first aspect of the present invention there is provided a method of announcing sessions transmitted through a network, the method comprising providing a first set of announcements describing a plurality of sessions and providing a second set of announcements describing at least one updated session.
This has the advantage that it is possible to choose whether to be provided with the first set of announcements describing the plurality of sessions or to be provided with the second set of announcements describing any updated sessions. This allows updated sessions to be announced more quickly and efficiently.
An updated session may be a new session which is added to the plurality of sessions, a one of the plurality of sessions in which content is added, changed or deleted or a session which is deleted from the plurality of sessions.
Providing the first set of announcements and providing the second set of announcements may comprise providing the first set of announcements through a first channel and providing the second set of announcements through a second, different channel.
Providing the first set of announcements and providing the second set of announcements may comprise providing the first set of announcements through a first address, preferably a destination address, such as a first multicast IP address, and providing the second set of announcements through a second, different address, preferably a destination address, for example a second, different multicast IP address, respectively.
Providing the first set of announcements and providing the second set of announcements may comprise providing the first set of announcements through a first port number and providing the second set of announcements through a second, different port number respectively.
Providing the first set of announcements and providing the second set of announcements may comprise providing the first set of announcements through a first logical channel and providing the second set of announcements through a second, different logical channel respectively.
Providing the first set of announcements and providing the second set of announcements may comprise including in each announcement of the first set of announcements data for identifying the announcement as an announcement which describes a one of the plurality of sessions and in each announcement of the second set of announcements data for identifying the announcement as an announcement which describes a one of the at least one updated session.
Providing the first set of announcements and providing the second set of announcements may comprise including in each announcement of the first set of announcements respective data for specifying a position of a corresponding session within a first portion of a session directory and including in each announcement of the second set of announcements respective data for specifying a position of a corresponding session within a second portion of the session directory.
Providing the first set of announcements and providing the second set of announcements may comprise providing the first set of announcements through a first physical channel and providing the second set of announcements through a second, different physical channel respectively.
Providing the first set of announcements and providing the second set of announcements may comprise providing the first set of announcements through a first network and providing the second set of announcements through a second, different network respectively.
The method may further comprise providing a third set of announcements describing another plurality of sessions including the at least one updated session.
The method may comprise providing the first set of announcements through a first channel, providing the second set of announcements describing at least one updated session through a second, different channel and providing a third set of announcements describing another plurality of sessions including the at least one updated session through the first channel.
The method may comprise arranging the providing of said second set of announcements after the providing of said first set of announcements.
The method may comprise arranging the providing of said first set of announcements and the providing of said third set of announcements at substantially during an overlapping or same time periods.
Providing the first set of announcements and providing the second set of announcements may comprise transmitting the first set of announcements through the first channel and transmitting the second set of announcements through the second, different channel.
The method may comprise transmitting the first set of announcements according to a session announcement protocol (SAP), unidirectional hypertext transfer protocol (UHTTP), asynchronous layered coding (ALC) protocol or similar unidirectional protocol based on user datagram protocol (UDP). The method may comprise including a description of a corresponding session in each announcement, for example arranged according to session description protocol (SDP).
The method may comprise providing means for determining whether all of the first set of announcements have been provided, for example by providing the first set of announcements as a series of linked messages.
The method may comprise providing the first set of announcements in a first set of time slots and providing the second set of announcements in a second set of time slots, each timeslot of the first set of timeslots being provided at a different time from each timeslot of the second set of timeslots. The method may comprise multiplexing the first and second sets of announcements.
The method may further comprise providing a third set of announcements identifying the at least one updated session. Providing the second set of announcements describing the at least one updated session may comprise providing a set of announcements identifying the at least one updated session. Providing the second set of announcements describing the at least one updated session may further comprise including a description of a corresponding session. Providing the second set of announcements describing the at least one updated session may comprise providing a set of notifications pointing to the at least one updated session.
According to another aspect of the present invention there is provided a method of announcing sessions transmitted through a network, the method comprising providing a first set of announcements describing a plurality of sessions and providing a second set of announcements identifying at least one updated session.
The method may further comprise providing a third set of announcements describing the at least one updated session. The method may comprise transmitting at least one of the sets of announcements according to asynchronous layered coding (ALC) protocol. The method may comprise transmitting at least one of the sets of announcements according to a protocol based on asynchronous layered coding (ALC) protocol. The method may comprise defining an asynchronous layered coding (ALC) protocol session and defining at least one ALC channel. The method may comprise transmitting a set of metadata for describing the plurality of sessions via a first ALC channel. The method may comprise transmitting a set of metadata for describing at least one updated session via a second, different ALC channel. The method may comprise transmitting a set of metadata for identifying the at least one updated session via a third, different ALC channel. The method may comprise transmitting a set of metadata as a transport object. The method may further comprise defining a respective delivery table relating to the transport object and transmitting the delivery table.
According to a second aspect of the present invention there is provided a computer program product having program code stored on a readable medium so that, when executed by data processing apparatus, causes the data processing apparatus to perform a method of announcing sessions transmitted through a network.
According to a third aspect of the present invention there is provided a method of accessing sessions transmitted through a network, the method comprising selectively receiving a first set of announcements describing a plurality of sessions; and selectively receiving a second set of announcements describing at least one updated session.
The method may further comprise determining whether all of said first set of announcements have been received. The method may further comprise selecting not to receive further said first set of announcements and selecting to receive said second set of announcements. The method may further comprise selecting not to receive a third set of announcements describing another plurality of sessions including said at least one updated session. The method may further comprise selecting to receive a fourth set of announcements describing at least one further updated session.
The method may comprise using the second set of announcements to identify said at least one updated session. The method may comprise selecting to receive another set of announcements including a description of said at least one updated session. The method may comprise obtaining a description of said at least one updated session.
According to another aspect of the present invention there is provided a method of accessing sessions transmitted through a network, the method comprising selectively receiving a first set of announcements describing a plurality of sessions and selectively receiving a second set of announcements identifying at least one updated session. The method may further comprise selectively receiving a third set of announcements describing said at least one updated session.
According to a fourth aspect of the present invention there is provided a method of accessing sessions transmitted through a network, the method comprising listening to a first set of announcements describing a plurality of sessions, determining whether said first set of announcements have been received; if said first set of announcements have been received, then stopping listening to said first set of announcements and listening to a second set of announcements describing at least one updated session.
The method may further comprise stopping listening to a third set of announcements describing a further plurality of sessions including said at least one updated session.
According to a fifth aspect of the present invention there is provided apparatus for announcing sessions transmitted through a network, the apparatus comprising means for providing a first set of announcements describing a plurality of sessions and means for providing a second set of announcements describing at least one updated session.
According to a sixth aspect of the present invention there is provided apparatus for performing the method.
According to a seventh aspect of the present invention there is provided apparatus for announcing sessions transmitted through a network, the apparatus comprising a first transmitter for providing a first set of announcements describing a plurality of sessions and a second transmitter for providing a second set of announcements describing at least one updated session.
The apparatus may comprise means for managing an electronic service guide for announcing sessions to be transmitted through the network, means for managing content of sessions to be transmitted through the network, means for storing and electronic service guide for announcing sessions to be transmitted through the network, means for storing content of sessions to be transmitted through the network, means for determining changes to an electronic service guide, the changes corresponding to updated sessions to be transmitted through the network, a server for providing information relating to changes to an electronic service guide, the changes corresponding to updated sessions to be transmitted through the network, a server for providing content and/or means for transmitting data.
According to an eighth aspect of the present invention there is provided apparatus for accessing sessions transmitted through a network, the apparatus comprising means for selectively receiving a first set of announcements describing a plurality of sessions and means for selectively receiving a second set of announcements describing at least one updated session.
The apparatus may comprise means for determining whether said first set of announcements has been received the apparatus being configured such that if the determining means determines that the first set of announcements has been received, then the means for selectively receiving said second set of announcements is configured to receive the second set of announcements.
The apparatus may comprise means for selectively receiving a third set of announcements describing another plurality of session including the at least one updated session, the apparatus being configured such that if said determining means determines that the first set of announcements has been received, then the means for selectively receiving the third set of announcements is configured not to receive or not to forward the third set of announcements.
The apparatus may comprise means for receiving data, means for filtering an electronic service guide for announcing sessions to be transmitted through the network, means for storing an electronic service guide for announcing sessions to be transmitted through the network, means for browsing an electronic service guide for announcing sessions to be transmitted through the network, means for filtering content, means for storing content and/or means for browsing content.
The apparatus may be a handheld mobile communications device.
According to a ninth aspect of the present invention there is provided a system for presenting program schedule data on a display, said system comprising at least two announcements, the schedule data being organized at least partly from a first set of announcements describing at least partly a plurality of sessions and at least partly from a second set of announcements describing at least one at least partly updated session.
According to an tenth aspect of the present invention there is provided a system for presenting program schedule data on a display, said system comprising at least two announcements, the schedule data being organized at least partly from a first set of repeatable announcements describing a plurality of sessions, at least partly from a second set of repeatable announcements describing at least one at least partly updated session and at least session descriptions of at least one of the repeatable announcements for defining whether the at least one of the first and second announcements is received or not.
According to a eleventh aspect of the present invention there is provided a system for delivering program schedule data to end-user terminals, said system comprising two sets of announcements, each set comprising at least one announcement, the schedule data being organized at least partly from a first set of announcements describing at least partly a plurality of sessions and at least partly from a second set of announcements describing at least one at least partly updated session.
According to a twelfth aspect of the present invention there is provided a system for presenting program schedule data to end-user terminals, said system comprising at least two set of announcements, each set comprising at least one announcement, the schedule data being organized at least partly from a first set of repeatable announcements describing a plurality of sessions, at least partly from a second set of repeatable announcements describing at least one at least partly updated session and at least session descriptions of at least one of the repeatable announcements for defining whether the at least one of the first and second announcements is received or not.
The second set of announcements may include a version number of each updated session for allowing a client to detect if they have missed an earlier update. If a client detects it has missed an earlier update and is not currently receiving the first set of announcements, the client may start receiving the first set of announcements until it has received a full and latest version of the program schedule data. If the client detects that it has received a full and latest version of the program schedule data, it may stop receiving the first set of announcements and continues receiving only the second set of announcements. If the client detects it has missed an earlier update, it may fetch a full and latest version of the program schedule data over an interactive network. Each set of repeatable announcements may be divided into segments before transmission and a location of each segment within a whole transfer may be indicated in a framing field of each respective segment; the indicated location may enable clients to determine whether they have received all segments that constitute a given set or whether they need to wait for receiving more segments.
The program schedule data may be viewed either directly by a human end-user or automatically used by a software application. The program schedule data may be presented progressively to a human end-user or made progressively available to an automatic software application as the said data is being received. The program schedule data may be viewed by a human end-user via a graphical user interface. The program schedule data may be used by a personal video recorder.
Embodiments of the present invention will now be described by way of example with reference to the accompanying drawings in which:
Multicasting System 1
Referring to
An administrator 6 provides scheduled content, such as audio, video and/or other types of data, for datacasting to clients 5 and provides metadata for describing the content. The metadata includes information regarding transmission of content.
The datacast service system 2 generates IP streams carrying content items and related metadata for datacasting to clients 5. The datacaster 3 receives IP streams from the datacast service system 2, provides Layer 2 encapsulation and modulation and transmits the IP data to clients 5 over the datacast network 4. The datacast network 4 is a point-to-multipoint network for delivering IP-based data. Typically, the datacast network 4 supports a plurality of simultaneous datacasts to clients 5. In this example, the datacast network 4 does not provide a return data path from the client 5 to the datacaster 3. The datacast network 5 may be for example a Digital Video Broadcasting (DVB) network, a Digital Audio Broadcasting (DAB) network, an Advanced Television Systems Committee (ATSC) network, an Integrated Services Digital Broadcasting (ISDB) network or a Wireless Local Area Network (WLAN). The client 5 comprises a terminal for receiving content and content descriptions over the datacast network 4 and presenting them to an end-user 7. The terminal may be fixed, such as a desk-top personal computer or a television set-top box, or portable, for instance a lap-top or notebook personal computer, personal digital assistant or mobile telephone handset which have receiving means for receiving broadcast transmissions.
The datacast service system 2 includes an electronic service guide (ESG) management module 8, an ESG database 9 for storing metadata for the electronic service guide, a service discovery server 10, a content management module 11, a contents database 12 for storing content for datacasting and a content server 13.
Electronic Service Guide (ESG) is a set of metadata describing available content such as e.g. streaming media and downloadable files with indication of their transmission schedules. The full or partial metadata of a single ESG is delivered to receiving clients in an ESG session that may comprise one or more channels.
The ESG management module 8 allows the administrator 6 to control metadata for describing datacast content. Content items can be grouped into IP services and IP sessions. Content items can be allocated (or de-allocated) time slots for transmission. Thus, the metadata describes the structure of content items as a hierarchy of IP services and IP sessions. The metadata may also include information on the transmission schedule of IP sessions and individual content items within IP sessions.
The content management module 11 allows the administrator 6 to add, replace and delete content items in the content database 12.
The service discovery server 10 generates announcements of IP services and IP sessions based on the metadata found in the ESG database 9. The announcements are sent to the datacaster 3 for transmission over the datacast network 4. The announcements may be transmitted repetitively by repeating them in carousel style or by transmitting them multiple times.
As will be explained in more detail later, two kinds of announcements are generated. A first kind of announcement describes a full IP service directory and a second kind of announcement describes updates to the IP service directory.
In one embodiment of the present invention, the second kind of announcements is used to transmit an updated session directory.
In another embodiment of the present invention, the second kind of announcements comprises identification of those parts of the service directory that have been changed. The second kind of announcements may comprise only such identification. Such second kind of announcements may be regarded as a notification of updates. The second kind of announcement comprising only notification of updates can be sent more frequently than the second kind of announcements comprising updates. The second kind of announcements may comprise both one or more notifications of updates and one or more updates, whereby the updates are selected from the set of updates available at the time of the announcement.
The content server 13 retrieves scheduling information from the ESG database 9 and, based on the scheduling information, retrieves content from the content database 12 and sends it to the datacaster 3 for transmission over the datacast network 4.
The client 5 includes a datacast receiver 14, a service discovery client 15, an ESG database 16 for storing metadata for the electronic service guide, an ESG browser 17, a content filtering application 18, a content database 19 and a content browser 20.
The datacast receiver 14 receives data over the datacast network 4 whereupon it demodulates and decapsulates the data. In this case, the datacast receiver 14 forwards the demodulated and decapsulated data to an IP stack (not shown). The demodulated and decapsulated data comprises IP packets carrying content streams or metadata describing content. The IP packets are forwarded from the stack (not shown) to IP-based applications 15, 18 running on the client 5.
The service discovery client 15 receives the IP packets on one or more given addresses and one or more given ports for carrying IP service announcements; As will be explained in more detail later, the service discovery client 15 can receive announcements of the first type describing the full service directory and, either alternatively or additionally, announcements of the second type describing updates to service directory. The IP packets carry-metadata which can be stored in the ESG database 16 or forwarded directly to the ESG browser 17.
The ESG database 16 has an information structure very similar to the server-side ESG database 9. The ESG database 16 is initially empty, for example when the client 5 is first switched on, but fills up and is updated as IP session announcements are received from the datacast service system 2.
The ESG browser 17 allows the end-user 7 to view schedules and descriptions of IP services, sessions and content items available from the datacaster service system 2. The ESG browser 17 can retrieve metadata from the ESG database 16 or receive metadata directly from the service discovery client 15.
The content filtering application 18 receives the IP packets on one or more given addresses and one or more given ports configured by the content browser 20 or other applications running on the client. The IP packets carry content which can be stored in the content database 19 or forwarded directly to the content browser 20.
The content browser 20 is loaded and run when the end-user 7 has selected a particular datacast content item for consumption. The content item can be received in real time or retrieved from the content database 19. The content browser 20 can be for example a Web browser, an MP3 player or a streaming video client.
The multicasting system 1 may allow automatic content uploading by external content providers (not shown) and forwarding of Internet-based content. The datacaster 3 can also deliver content to a plurality of datacast networks (not shown), each datacast network comprising one or more transponders.
In an embodiment of the present invention, one or more ESG proxies (not shown) may be provided between the datacaster 3 and the client 4. Each ESG proxy is capable of receiving and transmitting ESG metadata or parts of ESG metadata, updates and/or notifications of updates. Each ESG proxy can filter ESG metadata or parts thereof, including updates and notifications of updates from one or more ESG senders and output the filtered ESG metadata to one or more ESG sessions. Logically, an ESG proxy fits in between ESG senders and receivers. A proxy may also cache ESG metadata or parts thereof including updates and notifications of updates and may provide its own bandwidth control or congestion control schemes on the output.
Sessions
Referring to
Session Directory
Referring to
Each category, sub-category or further sub-category may include one or more sessions. For example, the soccer sub-category 251 includes the first, second and third sessions 221, 222, 223, while the hockey sub-category category 252 includes the fourth session 224.
Referring to
The ESG data 26 is transmitted to clients 5 so as to provide an ESG for users. However, there is a problem if the ESG data 26 needs to be updated, as will now be explained:
Referring to
Referring to
Referring to
Referring to
Referring to
Therefore, it is desirable to provide an improved session directory and an improved ESG.
One solution to the problem is to split the session directory and divide transmission of the ESG accordingly. Description of the session directory is transmitted by sending two types of session announcements one for describing the full session directory and another for describing an updated session directory, as will now be described in more detail:
Referring to
The session directory 28, 28′ is split into two parts at a relatively high level, in this example above the category level, and the two parts are referred to as the full session directory 291 and the updated session directory 292 respectively. Later, in a second example, a session directory is described which is split at a relatively low level.
The full session directory 291 includes substantially the same categories described earlier, such as sports 241. Each category includes sub-categories, such as soccer 251 and hockey 252. Similarly, there may be further sub-categories. Each category, sub-category or any further sub-category may include one or more sessions. In this case, the soccer sub-category 251 includes the first, second and third sessions 221, 222, 223 and the hockey sub-category category 252 includes the fourth sessions 224.
The updated session directory 292 also includes categories which correspond to the categories in the full session directory, such as sports 301. Similarly, each corresponding category includes corresponding sub-categories, such as soccer 311 and hockey 312. Similarly, there may be corresponding further sub-categories. Each corresponding category, corresponding sub-category or any corresponding further sub-category may include, if there has been an update, one or more updated sessions.
Before the update, the updated session directory 292 does not list any sessions. After the update, the updated directory 292 lists updated sessions. In this case, the soccer sub-category 311 includes the updated, first session 221′ and the hockey sub-category category 312 includes the fifth session 225.
This configuration is used to send two types of session announcements. One type of announcement is used to describe all sessions. Another type of announcement is used to describe updated sessions.
Thus, the client may listen initially to announcements of the fist type so as to receive a description of all the sessions, i.e. the full session directory. Once the client has received the description of all sessions, the client may listen only to announcements of the second type so as to learn of any updates to the sessions.
Session Announcements Using SAP and SDP
Referring to
The ESG data 32 includes first, second, third and fourth sets of metadata 331, 332, 333, 334 for describing the first, second, third and fourth sessions 221, 222, 223, 224 respectively.
The updated ESG 32′ includes the updated first, second, third, fourth and fifth sets of metadata 331′, 332, 333, 334, 335 for describing the updated first, second, third, fourth and fifth sessions 221 , 222, 223, 224, 225 respectively.
A Session Announcement Protocol (SAP) is used to transmit sets of metadata 331, 331′, 332, 334, 335 to clients 5 and a Session Description Protocol (SDP) is used to describe the sessions 221, 221′, 222, 223, 224, 225. Reference is made to “Session Announcement Protocol” by M. P. Maher, C. Perkins & E. Whelan, RFC 2974, IETF, October 2000 and to “Session Description Protocol” by M. Handley & V. Jacobson, RFC 2327, IETF, April 1998.
The use of the Session Announcement Protocol and the Session Description Protocol advantageously permits information describing the structure of session directories to be transmitted to clients 5. Reference is made to “Describing session directories in SDP” by R. Finlayson, Internet Draft, IETF, January 2001 and “Towards multicast session directory services” by A. Santos, J. Macedo & V. Freitas. Referring to
Referring to
The first type of session announcements 371 is used to send descriptions of all sessions, i.e. the full session directory 291. During an earlier cycle 381, the announcements 341, 342, 343, 344 describe all sessions 221, 222, 223, 244 before the update and, during a later cycle 382, the announcements 341′, 342, 343, 344, 345 describe all sessions 221′, 222, 223, 224, 225 after the update.
The second type of announcements 372 is used only to send descriptions of sessions that have been added, removed or changed since the transmission of announcements 341, 342, 343, 344 during the earlier cycle 381. In this example, no cycle precedes the earlier cycle 381. Thus, during the earlier cycle 381, there are no announcements of the second type 372. During the later cycle 382, the announcements 341′, 345 describe updated sessions 221′, 225 (
Usually, there will be more than two cycles 381, 382 of announcements. Furthermore, more sessions may be updated. Thus, each subsequent cycle (not shown) may or may not include announcements of the second type 372. Optionally, announcements of the second type 372 may be sent repeatedly during a cycle to protect against irrecoverable transmission errors.
The structure of the session directory 28 (
An embodiment of a process of describing the structure of the session directory 28 according to the present invention includes transmitting a first session announcement on a given multicast address. The first session announcement includes a second multicast address and other details relating to a session directory. The process includes transmitting a second session announcement on the second multicast address. The second session announcement includes a third multicast address and other details relating to a session sub-directory. Because sub-directories in turn can be used to announce a succeeding level of a session directory, the session directory hierarchy can be organized as a tree of any depth. In this example, a root or default session announcement (not shown) is transmitted on a widely known address, which specifies a pair of addresses for receiving announcements of the first and second types 371, 372 respectively.
One or more “category” fields may be included in the session announcements for allowing clients 5 to filter and organize session announcements.
As described earlier, announcements of the first type 371 are transmitted on a first IP address, such as 224.2.17.0.
Referring to
v=0
o=jsmith 2890842807 2890844525 IN IP4 10.47.16.5
c=IN IP4 224.2.17.12/127
t=2892054126 2892399688
m=data 9875 UHTTP UDP
a=cat:Full.Sports.Soccer
If the first session announcement 341 is updated, then the updated first session announcement 341′ may include an SDP description 36 of the updated first session 221′ including, for example:
v=0
o=jsmith 2890842807 2890844526 IN IP4 10.47.16.5
c=IN IP4 224.2.17.12/127
t=2892054126 2892399726
m=data 9875 UHTTP UDP
a=eat:Full.Sports.Soccer
Likewise, the second session announcement 342 may include an SDP description 36 of the second session 222 including, for example:
v=0
o=jsmith 2890842807 2890844526 IN IP4 10.47.16.5
c=IN IP4 224.2.17.13/127
t=2892054126 2892399726
m=video 9875 RTP/AVP 31
a=cat:Full.Sports.Soccer
Announcements of the second type 372 are transmitted on a second IP address, such as 224.2.17.1.
Referring still to
v=0
o=Jsmith 2890842807 2890844526 IN IP4 10.47.16.5
c=IN IP4 224.2.17.12/127
t=2892054126 2892399726
m=data 9875 UHTTP UDP
a=cat:Update.Sports.Soccer
The updated session 221′ (
Firstly, the first session announcement 341 and the updated first session announcement 341′ specify different version numbers in the “o=” field, namely may include comparing version numbers of the first and updated first session announcements 341, 341′ and noting different version numbers.
Secondly, the updated first session announcement 341′ is provided through a different channel, in this case a different IP address, which is reserved for announcements relating to updated sessions. Thus, identifying an updated session may include receiving an announcement on a different channel.
Thirdly, the updated first session announcement 341′ includes a category field, which identifies the fact that the session announcement relates to an update. Thus, identifying an updated session may include determining whether an announcement identifies itself as relating to an update and/or determining a position within a session directory.
Method of Operating the Datacast Service System 2
Referring to
The ESG management module 8 identifies whether sessions have been updated in the content database 12 (step S1). If it identifies any updated sessions, then it updates corresponding sets of metadata in the ESG database (step S2). Updating may include adding or deleting metadata. Metadata is passed to the service discovery server 10, which generates updated session announcements for any updated sets of metadata (step S3). The service discovery server 10 forwards a first set of announcements describing a plurality of sessions, in other words full session announcements, and a second set of announcements describing at least one updated session, in other words updated session announcements, to the datacaster 3 through different channels, such as different IP addresses (steps S4 & S5). The datacaster 3 receives the announcements and transmits them over the datacast network 4 to each clients 5.
Method of Operating Client 5
Referring to
The client 5 checks whether it has received all the session announcements of the first type 371 (step T1). If not, the client 5 listens to both types of announcements 371, 372 (step T1& T2). However, if the client 5 has received all the session announcements of the first type 371, then it can stop listening to announcements of the first type 371 and continue listening only to announcements of the second type 372. This has the advantage that it saves processing power and electrical power because fewer session announcements are received and/or processed.
The first and second types of announcements 371, 372 may include multicast addresses of announcements relating to other session directories, which in turn may include multicast addresses of announcements relating to further session directories.
Announcements of the first type 371 may be considered as relating to a session directory including sub-directories to a given depth of directory hierarchy. Announcements of the second type 372 may likewise be considered as relating to a session directory including sub-directories to a given depth of directory hierarchy. If announcements of either type 371, 372 relate to more than one session directory, then they can be used to announce the details of a different sub-tree of the IP session hierarchy. Thus, if descriptions of multiple subdirectories are transmitted using announcements of the first type 371, then the client 5 may stop receiving announcements relating to a particular subdirectory as soon as it has received all the different session descriptions of that subdirectory.
Referring to
The ESG data 32 and the updated ESG data 32′ are modified to reflect the structure of the second embodiment of a session directory 28″ according to the present invention.
Session Announcements Using UHTTP
A drawback of using session announcements employing SAP and SDP is that it is difficult for a client 5 to establish when it has received enough announcements of the first type 371 to describe the full session directory 291. Announcements 341′, 342, 343, 344, 345 may be lost or corrupted and these protocols do not allow such events to be detected.
In an alternative embodiment, this problem is solved by linking together session announcements describing the full session directory 291.
A Unidirectional Hypertext Transfer Protocol (UHTTP) is used to implement a concatenated transfer of multiple session descriptions and references are made to the Society of Motion Picture and Television Engineers standard SMPTE 364M-2001 “Declarative Data Essence—Unidirectional Hypettext Transport Protocol” and to “Appendix C: The Unidirectional Hypertext Transfer Protocol (UHTTP)” in Enhanced Content Specification, Advanced Television Enhancement Forum.
UHTTP supports MIME multipart/related content-type protocol, so allowing a single UHTTP transfer to comprise multiple independent MIME objects and reference is made to “The MIME Multipart/Related Content-type” by E. Levinson, RFC 2387, IETF (1998).
Referring to
Referring to
Descriptions of updated sessions are transmitted in a seventh UDP packet 417.
As described earlier, a default session announcement may be used to provide details of the full and updated session directories 291, 292. An example of a default session announcement may include:
v=0
o=dcaster 4289098098 4289099125 IN IP4 130.230.3.2
s=Experimental session directory service
i=Full and update session directories delivered via UHTTP
u=http://www.datacaster.com
e=dcaster@datacaster.com
c=IN IP4 224.2.17.12/127
t=2873397496 2873404696
=data 42451 udp uhttp
a=X-session-directory-full
m=data 42452 udp uhttp
a=X-session-directory-updates
In this example, the full session announcements and updated session announcements are provided on different port numbers. Also in this example, UHTTP is used full session announcements and updated session announcements. However, UHTTP may be used for full session announcements, while SAP and SDP may still be used for updated session announcements.
Numbering of data segments 401, 402, 403 allows the client 5 to detect when they have received the ESG data 32. Once this occurs, the client 5 listens for updates.
The use of UHTTP has another advantage. It supports forward error correction (FEC) which can be used to increase the probability of successful transmission even if bit and burst errors occur in transmission. If, however, FEC fails to recover any errors at the client-end, the client 5 waits for periodic UHTTP retransmission. Alternatively, if a return path is provided, then automatic repeat request (ARQ) may be used.
Other protocols which provide reliable delivery of content may be used.
Asynchronous Layer Coding (ALC), or a protocol based on ALC, provides reliable delivery of content and can be used to deliver full or partial ESG metadata, updates and notification of updates.
Asynchronous Layer Coding (ALC) is a scalable reliable content delivery protocol for IP multicasting and reference is made to “Asynchronous Layer Coding protocol instantiation” by M. Luby, J. Gemmell, L. Vicisano, L. Rizzo and J. Crowcroft, RFC 3450, IETF, April 2002 and December 2002.
Reference is also made to “Reliable Multicast Transport Building Blocks for One-to-Many Bulk-Data Transfer” by B. Whetten, L. Vicisano, R. Kermode, M. Handley, S. Floyd and M. Luby, RFC 3048, IETF, January 2001.
Reference is also made to “Layered Coding Transport building block” by B. Whetten, L. Vicisano, L. Rizzo, M. Handley, S. Floyd and M. Luby, Internet Draft, IETF, February 2002.
Session Announcements, Updates and Notifications of Updates Using an ALC-Based Protocol
ALC provides a unidirectional transport service for binary objects, such as files. ALC is based on the Layered Coding Transport (LCT) reliable multicast protocol building block and so inherits the LCT concept of sessions comprising one or more layered channels.
An ALC/LCT session comprises of a set of logically grouped channels associated with a single sender carrying packets with ALC/LCT headers for one or more objects. For the delivery of a full or partial ESG, updates and notifications of the updates, a protocol based on the ALC protocol may be used. Thus, an ESG session can be defined which comprises one or more ESG channels. Each ESG channel corresponds to an ALC session.
As explained earlier, an ALC session comprises one or more ALC channels. Each ALC channel may be thought of as “bit pipe” for forwarding packets according to the ALC protocol. In preparation for an ALC session; a sender selects a number of ALC channels and chooses corresponding bitrates for each of them. Each recipient of the ALC session can control the receiving bitrate by selecting to receive either all ALC channels or only some of them.
An ALC channel is uniquely definable and recognizable by a pair of variables (S, G). S is an IP unicast address of the sender and G is a multicast IP address for a multicast receiving group. G may also be a unicast IP address, but RFC 3450 does not define the use of unicast.
An ALC session is uniquely definable and recognizable by a pair of variable (S, TSI). S is the unicast IP address of the sender and TSI is the value of the Transport Session Identifier field in the header of each ALC packet 47 (
Using ALC or an ALC-based protocol, an ESG session may be defined which comprises at least one ESG channel. Preferably, the ESG session comprises three ESG channels: one channel for delivering a full or partial ESG, one channel for delivering updates and one channel to notify of updates.
Each respective ESG channel carries data packets having the same value in the Transport Session Identifier (TSI) field. Data packets in the same channel are sent from the same source port and IP address, and may be addressed to a different destination port and/or IP address.
An ESG session may include a full ESG channel, an ESG update channel and an ESG notify channel.
The full ESG channel repeatedly delivers an ESG metadata set representing the sender's full or partial ESG metadata set. When only a partial ESG is delivered, clients may be provided access to the full ESG via a different protocol, such as a point-to-point ESG transport protocol.
The update ESG channel repeatedly delivers an ESG metadata set comprising parts of the sender's ESG that have changed since the current version of the full ESG was assembled.
The notify ESG channel repeatedly delivers a metadata set consisting of pointers to parts of the sender's ESG that have changed since the most recent version of the full ESG was constructed. The pointers are data fields within the metadata set, which identify parts that have changed.
Each of the ESG channels in turn may comprise one or more ALC channels. All ALC channels which constitute an ESG channel are sent on consecutive IP addresses. Only a base IP address used for each ESG channel needs to be signalled to the receivers. This is because a “Next flag” in a Congestion Control Indication field enables receivers to discover the following IP addresses that may have been used for the current ESG channel.
ESG receivers with interactive network connection are able to join and leave transport channels, depending on the type of ESG metadata they need to receive and on the congestion status of the network. ESG receivers that only have unidirectional network connectivity are more restricted, but still have the option of filtering out unnecessary transport channels. Furthermore, a network element such as the ESG proxy (not shown) can reduce the number of transport channels forwarded to a unidirectional link, for example when congestion is detected at the feed of such a link.
Referring to
Referring to
In this example, an ALC packet 47 is described which comprises a UDP header 48, an LCT header 49, an FEC payload ID field 50 and payload 51 which includes at least metadata sets 33, 45 or data segments 461, 462.
Between them, the headers, preferably the LCT header 49, may comprise a number of fields (not shown) including a version number field and a number of flags (not shown) including a congestion control flag, a transport session identifier flag, a transport object identifier flag, a half-word flag, a sender current time present flag, an expected residual time present flag, a close session flag and a close object flag. Further data fields may be included which are reserved for future use.
The transport session identifier flag identifies the field format used for the transport session identifier. The transport object identifier flag indicates the field format used for transport object identifier. The sender current time present flag indicates the presence or absence of a sender current time field. The expected residual time present flag indicates the presence or absence of an expected residual time field. The close session flag indicates the ending of the session and the close object flag indicates the ending of the transmission of the object.
Between them, the headers, preferably the LCT header 49, comprise a number of fields (not shown) indicating the length of one or more of the headers and/or of the packet, a number of fields (not shown) with information relating to congestion control and one or more fields (not shown) including one or more identifiers for identifying the transport session and the transport object.
Further data fields (not shown) may carry information, for example relating to ALC encoding symbols and to possible header extensions. The further data fields (not shown) may include information on a Forward Error Correction (FEC) scheme used. FEC data is redundant information generated from, and interleaved with, payload data. The use of FEC allows receivers to reconstruct payload data segments lost or damaged due to transmission errors.
Between them, the headers, preferably the FEC payload ID field 50, includes a source block number (not shown) and an encoding symbol ID (not shown).
The source block number indicates from which source block of the object the encoding symbol(s) in the payload 51 is (are) generated. The encoding symbol ID identifies which specific encoding symbol(s) generated from the source block is (are) are carried in the payload 51.
When a protocol based on the ALC is used, an ALC Protocol Instantiation specific header extension (not shown) is included at least once in the delivery of each transport object. An FEC Object Transmission Information in the header extension enables receivers to discover, in-band, the FEC parameters used to deliver the associated transport object.
A header extension (not shown) comprises one or more fields such as a type of the header extension, a length of the header extension, an identification for the FEC encoder being used, a transfer length of the object, a source block length of every source block of the current transport object carried in the packet payloads, a length of every encoding symbol of the current transport object carried in packet payloads. In addition the header extension may comprise one or more fields reserved for future use.
The information in the congestion control field may, comprise an indication flag, a sequence number the value of which is increased by one for each packet sent, wherein it can be used by receivers to detect packet loss and a part reserved for future use.
When the indication flag is set to ‘1’, it indicates that the current ALC session consists of two or more ALC channels including the current IP address and the next consecutive IP address. A value of ‘0’ in this field indicates that the current IP address is the highest IP address in the current ALC session. Receivers may monitor this field to detect dynamic addition or deletion of ALC channels by ESG senders.
Further details relating to ALC packet format can be found in “Asynchronous Layer Coding protocol instantiation”, RFC 3450, ibid.
In an embodiment of the present invention, the announcements can be regarded as binary objects and thus be called transport objects. Each transport object is identified by the value of a transport object identifier field (not shown), which is unique within the scope of one transport session. Each ESG metadata set is preferably sent as a separate transport object.
For each transport object, additional information may be defined in the form of an ESG delivery table (not shown). On the sender side, ESG delivery table can be inserted in every transport session. On the receiver-side, ESG delivery table information parsing can be provided.
For each type of transport channel in a transport session, a different delivery table can be transmitted.
The ESG delivery table (not shown) may be defined as a set of mappings, each comprising a transport object identifier value and the properties of the transport object. The ESG delivery table may comprise two parts: an ESG header and an ESG payload.
The ESG delivery table header comprises fields for header extension type, header extension length, ESG delivery table version and ESG delivery table expiry.
The ESG header extension is a variable length protocol instantiation specific header extension and it is included in all packets carrying ESG delivery table and it is identical for all packets carrying the same version of the ESG delivery table. The ESG delivery table version is the number of the currently transmitted ESG delivery table. This field has the value of ‘0’ for the ESG delivery table of a new ALC transport session, and is increased by one whenever an updated ESG delivery table is constructed for the same ALC transport session. After reaching its predefined maximum value, the version number wraps back to ‘0’. The ESG delivery table expiry is a time value, indicating the time after which the ESG delivery table is not expected to be valid. A new version of the ESG delivery table is preferably sent before the expiry time of the current version. However, receivers should continue using the current version of the ESG delivery table even after its expiry time if they have not received a newer version.
The ESG payload contains the actual mappings between transport object identifiers and the attributes associated with the transport object identified by each transport object identifier. The ESG payload format may be an XML structure represented as ASCII text, comprising one or more fields such as e.g. a unique identifier for the transport object within the current ALC transport session, a URL for uniquely identifying the current transport object, the length in bytes of the transport object, the MIME type of the transport object, an identifier for the encoding used for the transport object, such as ZLIB compression and an MD5 checksum for the transport object. The ESG payload fields may use the syntax and semantics of the corresponding fields defined in the HTTP 1.1 specification.
Referring to
As explained earlier, announcements comprising notification of updates can be sent more frequently than announcements comprising updates.
The datacast client 5 can choose to listen to announcements comprising notifications of updates in preference to announcements comprising updates. If they receive a notification of an update to a session in which the user may be interested, then the datacast client 5 can listen to announcements comprising updates and/or obtain a description of the session in another way, such by unicast.
Time Division Multiplexing
In the embodiments described earlier, IP packets comprising portions of ESG data 32, 32′ can be transmitted by the datacaster 3 to the client 5 as-and-when transmission slots become available. However, to ensure that the client 5 receives the IP packets, it is preferable that the client 5 be configured to receive data at any time. This has the drawback of unnecessarily using processing and electrical power.
A solution to this problem is to employ time division multiplexing (TDM).
Referring to
Announcements of the first type 371 for describing ESG data and announcements of the second type 372 for describing updates to ESG data are transmitted in different time slots 521, 522. For example, the announcements of the first and second types 371, 372 are transmitted in alternate time slots. However, the time slots 521, 522 need not be adjacent. The time slots may be of variable or fixed length.
Thus, if the client 5 wishes to listen for updates to ESG data, then they do not need to listen to time slots 521 during which announcements of the first type 371 are transmitted, but may listen to time slots 522 during which only announcements of the second type 372 are sent. This allows the client 5 to switch off its receiver 14 (
Datacast Client 5
Referring to
The datacast client 5 may be a handheld mobile communication device for use with first and second wireless communication networks in accordance with the present invention. For example, the first wireless communication network may be a DVB-T or DAB network, or any modification of these or similar networks, and the receiver 56 may be configured to receive and demodulate signals from such a network. The second wireless communication network may be a UMTS network or other 3G, 2.5G or 2G telecommunications network and the transceiver 57 may be configured to receive/transmit and demodulate/modulate signals via a UMTS or similar network.
The datacast client 5 may be a set-top box connected to a television set for use with first and second wired and/or wireless communication networks. For example, the first communication network may be a DVB-T network and the receiver 56 may be configured to receive and demodulate signals from a DVB-T network. The second communications network may the Internet and the transceiver 57 may include a modem (not shown) for connection via a public switched telephone network to an Internet Service Provider
Using two networks, sessions and session announcements may be transmitted over different networks. Alternatively, the first and second types of session announcements may be transmitted over different networks.
When two networks are available, the user of the client device may control the delivery of full or partial ESG metadata, updates thereof and notifications of updates by using a request-response model, wherein the requests are transmitted to the datacast service system through the second communications network. In the communication between the client and the datacast service acknowledgements may be used if required. The client may make a request for notifications using the second communications network, wherein selected notifications are transmitted to the client when such notifications are created.
Computer programs (not shown) when loaded into memory 55 and run by the processor 53 cause the processor 53, in conjunction with other elements of the device, to provide the service discovery client 15, the ESG browser 17, the content filtering application 18 and the content browser 20 respectively. Storage 61 is used to hold the ESG and content databases 16, 19. The user interface 59 allows the user to provide instructions to the ESG browser 17 and the content browser 20, such as instruction to select a session. The display 60 allows the user to view session descriptions and session content. The speaker 62 allows the user to hear session content.
ESG Browser
Referring to
It will be appreciated that many modifications may be made to the embodiment hereinbefore described.
Session announcements may be unicast, rather than multicast, to a client.
Sessions and session announcements may be transmitted over different networks. For example, sessions may be transmitted over a DVB network and session announcements may be sent via a DAB network.
The first and second types of session announcements may be transmitted over different networks. For instance, announcements of the first type may be transmitted through a DVB-T network, while announcements of the second type may be sent though a 3G network. The first and second types of session announcements may be transmitted through the same network, but over one or more different physical channels, for example at different carrier frequencies. The first and second types of session announcements may be transmitted through the same network and over the same physical channels, but over one or more different logical channels.
From reading the present disclosure, other variations and modifications will be apparent to persons skilled in the art. Such variations and modifications may involve equivalent and other features which are already made in design, manufacture and use of systems for announcing sessions and component parts thereof and which may be used instead of or in addition to features already described herein.
Although claims have been formulated in this application to particular combinations of features, it should be understood that the scope of disclosure of the present invention also includes any number of features or any other combinations of features disclosed herein either implicitly or explicitly or any generalisation thereof, whether or not it relates to the same invention as presently claimed in any claim or whether or not it mitigates any or all of the scientific problems as does the present invention. The applicants hereby give notice that new claims may be formulated to such features and/or combination of features during the prosecution of the present application or any further application derived therefrom.
Number | Date | Country | Kind |
---|---|---|---|
0229477.5 | Dec 2002 | GB | national |
0315285.7 | Jun 2003 | GB | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB03/05468 | 11/27/2003 | WO | 00 | 6/22/2006 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2004/056096 | 7/1/2004 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5473642 | Osawa et al. | Dec 1995 | A |
5559548 | Davis | Sep 1996 | A |
5652613 | Lazarus | Jul 1997 | A |
5760821 | Ellis | Jun 1998 | A |
5870725 | Bellinger et al. | Feb 1999 | A |
5917481 | Rzeszewski | Jun 1999 | A |
6020880 | Naimpally | Feb 2000 | A |
6182287 | Schneidewend et al. | Jan 2001 | B1 |
6209131 | Kim et al. | Mar 2001 | B1 |
6272127 | Golden et al. | Aug 2001 | B1 |
6314571 | Ogawa | Nov 2001 | B1 |
6405372 | Kim | Jun 2002 | B1 |
6421067 | Kamen | Jul 2002 | B1 |
6518986 | Mugura | Feb 2003 | B1 |
6522342 | Gagnon | Feb 2003 | B1 |
6763035 | Koskelainen | Jul 2004 | B1 |
6771639 | Holden | Aug 2004 | B1 |
6968566 | Entwistle | Nov 2005 | B1 |
7031326 | Shur et al. | Apr 2006 | B1 |
7080078 | Slaughter et al. | Jul 2006 | B1 |
7181526 | Bell et al. | Feb 2007 | B1 |
7188356 | Miura | Mar 2007 | B1 |
7200597 | Grizzard | Apr 2007 | B1 |
7373650 | Rodriguez | May 2008 | B1 |
7472352 | Liversidge et al. | Dec 2008 | B2 |
8104062 | Terakado | Jan 2012 | B2 |
8245257 | Stettner | Aug 2012 | B1 |
20010037500 | Reynolds et al. | Nov 2001 | A1 |
20020007488 | Kikinis | Jan 2002 | A1 |
20020073426 | Bhatt | Jun 2002 | A1 |
20020083468 | Dudkiewicz | Jun 2002 | A1 |
20020135698 | Shinohara | Sep 2002 | A1 |
20020161634 | Kaars | Oct 2002 | A1 |
20020194600 | Ellis | Dec 2002 | A1 |
20020199192 | Donnelly | Dec 2002 | A1 |
20030051246 | Wilder | Mar 2003 | A1 |
20030093485 | Dougall et al. | May 2003 | A1 |
20030100325 | Paila et al. | May 2003 | A1 |
20030147390 | Rizzo et al. | Aug 2003 | A1 |
20030188313 | Ellis | Oct 2003 | A1 |
20030208760 | Sugai | Nov 2003 | A1 |
20040056096 | Gurevich et al. | Mar 2004 | A1 |
20040078817 | Horowitz | Apr 2004 | A1 |
20050002649 | Boyle | Jan 2005 | A1 |
Number | Date | Country |
---|---|---|
1379335 | Nov 2002 | CN |
1379335 | Nov 2002 | CN |
1246057 | Oct 2002 | EP |
2000-287141 | Oct 2000 | JP |
2001-054034 | Feb 2001 | JP |
2001-54034 | Feb 2001 | JP |
Entry |
---|
Cotter, Paul, et al., “PTV: Intelligent Personalised TV Guides”, IAAI-00 Proceedings, AAAI (www.aaia.org), © 2000, pp. 1-8. |
Smyth, Barry, et al., “Personalized Electronic Program Guides for Digital TV”, AI Magazine, vol. 22, No. 2, AAIA, Spring 2001, pp. 89-98. |
“Session Announcement Protocol;” M. Handley et al; RFC 2974; IETF, Oct. 2000. |
“Session Description Protocol;” M. Handley et al; RFC 2327; IETF; Apr. 1998. |
“Describing Session Directories in SDP;” Ross Finlayson; Internet Draft, IETF, Jan. 24, 2001. |
“Towards Multicast Session Directory Services;” A. Santos et al. |
“Declarative Data Essence—Unidirectional Hypertext Transport Protocol;” SMPTE 364M-2001. |
“Enhanced Content Specification;” Advanced Television Enhancement Forum; Appendix C; 1998, 1999. |
“The MIME Multipart/Related Content-type;” E. Levinson; RFC 2387; IETF, Aug. 1998. |
“Asynchronous Layered Coding Protocol Instantiation;” M. Luby et al; Internet-Draft, IETF, Apr. 25, 2002. |
“Reliable Multicast Transport Building Blocks for One-to-Many Bulk-Data Transfer;” B. Whetten et al; RFC 3048; IETF; Jan. 2001. |
“Layered Coding Transport (LCT) Building Block;” M. Luby et al; RFC 3451, IETF; Dec. 2002. |
Japanese Office Action for corresponding JP Application No. 2005-502465, Aug. 7, 2009, Japan. |
Japanese Office action for corresponding JP App. No. 2005-502465 dated Mar. 23, 2010, pp. 1-11. |
http://www.dvb-h.org/PDF/a099.tm3348r2.cbms1199r14.IPDC—ESG.pdfIP Datacast over DVB-H: Electronic Service Guide(ESG), Nov. 2005, pp. 1,6-8,10. Accessed: Apr. 20, 2010. |
Chinese Office action for corresponding CN App. No. 200380108784.X dated Aug. 16, 2010, pp. 1-11. |
European Office action for corresponding EP app. No. 03 772 570.2-2202 dated Sep. 17, 2010, pp. 1-4. |
Chinese Office action for corresponding CN App. No. 200380108784.X dated Apr. 25, 2011, pp. 1-5. |
Chinese Office Action for CN Application No. 200380108784.X dated Nov. 3, 2011, pp. 1-7. |
Chinese Office Action for related Chinese Application No. 200380108784.X dated Mar. 2, 2012, pp. 1-6. |
Chinese Office Action for related Chinese Application No. 200380108784.X, dated Apr. 9, 2014, with English-language summary,14 pages. |
Number | Date | Country | |
---|---|---|---|
20060253544 A1 | Nov 2006 | US |