The present disclosure relates generally to a service signaling.
A broadcast service is capable of being received by users having broadcast receivers. Broadcast services can be roughly divided into two categories, namely, a radio broadcast service carrying only audio and a multimedia broadcast service carrying audio, video and data. Such broadcast services have developed from analog services to digital services. More recently, various types of broadcasting systems (such as a cable broadcasting system, a satellite broadcasting system, an Internet based broadcasting system, and a hybrid broadcasting system using both a cable network, Internet, and/or a satellite) provide high quality audio and video broadcast services along with a high-speed data service. Also, broadcast services include sending and/or receiving audio, video, and/or data directed to an individual computer and/or group of computers and/or one or more mobile communication devices.
In addition to more traditional stationary receiving devices, mobile communication devices are likewise configured to support such services. Such configured mobile devices have facilitated users to use such services while on the move, such as mobile phones.
An increasing need for multimedia services has resulted in various wireless and/or broadcast services for both mobile communications and general wire communications. Further, this convergence has merged the environment for different wire and wireless broadcast services.
Open Mobile Alliance (OMA), is a standard for interworking between individual mobile solutions, serves to define various application standards for mobile software and Internet services. OMA Mobile Broadcast Services Enabler Suite (BCAST) is a specification designed to support mobile broadcast technologies. The OMA BCAST defines technologies that provide IP based mobile content delivery, which includes a variety of functions such as a service guide, downloading and streaming, service and content protection, service subscription, and roaming.
The foregoing and other objectives, features, and advantages of the invention will be more readily understood upon consideration of the following detailed description of the invention, taken in conjunction with the accompanying drawings.
Referring to
(Open Mobile Alliance) Broadcast (BCAST) may include an application layer and a transport layer. The logical architecture of the BCAST system may include a Content Creation (CC) 101, a BCAST Service Application 102, a BCAST Service Distribution Adaptation (BSDA) 103, a BCAST Subscription Management (BSM) 104, a Terminal 105, a Broadcast Distribution System (BDS) Service Distribution 111, a BDS 112, and an Interaction Network 113. It is to be understood that the broadcast system and/or receiver system may be reconfigured, as desired. It is to be understood that the broadcast system and/or receiver system may include additional elements and/or fewer elements, as desired.
In general, the Content Creation (CC) 101 may provide content that is the basis of BCAST services. The content may include files for common broadcast services, e.g., data for a movie including audio and video. The Content Creation 101 provides a BCAST Service Application 102 with attributes for the content, which are used to create a service guide and to determine a transmission bearer over which the services will be delivered.
In general, the BCAST Service Application 102 may receive data for BCAST services provided from the Content Creation 101, and converts the received data into a form suitable for providing media encoding, content protection, interactive services, etc. The BCAST Service Application 102 provides the attributes for the content, which is received from the Content Creation 101, to the BSDA 103 and the BSM 104.
In general, the BSDA 103 may perform operations, such as file and/or streaming delivery, service gathering, service protection, service guide creation and/or delivery and service notification, using the BCAST service data provided from the BCAST Service Application 102. The BSDA 103 adapts the services to the BDS 112.
In general, the BSM 104 may manage, via hardware or software, service provisioning, such as subscription and charging-related functions for BCAST service users, information provisioning used for BCAST services, and mobile terminals that receive the BCAST services.
In general, the Terminal 105 may receive content and/or service guide and program support information, such as content protection, and provides a broadcast service to a user. The BDS Service Distribution 111 delivers mobile broadcast services to a plurality of terminals through mutual communication with the BDS 112 and the Interaction Network 113.
In general, the BDS 112 may deliver mobile broadcast services over a broadcast channel, and may include, for example, a Multimedia Broadcast Multicast Service (MBMS) by 3rd Generation Project Partnership (3GPP), a Broadcast Multicast Service (BCMCS) by 3rd Generation Project Partnership 2 (3GPP2), a DVB-Handheld (DVB-H) by Digital Video Broadcasting (DVB), or an Internet Protocol (IP) based broadcasting communication network. The Interaction Network 113 provides an interaction channel, and may include, for example, a cellular network. 3GPP MBMS is described in technical standard (TS) “3GPP: TS 26.346 V12.4.0 (2014-12)”, “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Multimedia Broadcast Multicast Service (MBMS); Protocols and codecs (Release 12)”, which is incorporated by reference in their entirety.
The reference points, or connection paths between the logical entities of
BCAST-1 121 is a transmission path for content and content attributes, and BCAST-2 122 is a transmission path for a content-protected or content-unprotected BCAST service, attributes of the BCAST service, and content attributes.
BCAST-3 123 is a transmission path for attributes of a BCAST service, attributes of content, user preference and/or subscription information, a user request, and a response to the request. BCAST-4 124 is a transmission path for a notification message, attributes used for a service guide, and a key used for content protection and service protection.
BCAST-5 125 is a transmission path for a protected BCAST service, an unprotected BCAST service, a content-protected BCAST service, a content-unprotected BCAST service, BCAST service attributes, content attributes, a notification, a service guide, security materials such as a Digital Right Management (DRM) Right Object (RO) and key values used for BCAST service protection, and data and signaling transmitted through a broadcast channel.
BCAST-6 126 is a transmission path for a protected BCAST service, an unprotected BCAST service, a content-protected BCAST service, a content-unprotected BCAST service, BCAST service attributes, content attributes, a notification, a service guide, security materials such as a DRM RO and key values used for BCAST service protection, and data and signaling transmitted through an interaction channel.
BCAST-7 127 is a transmission path for service provisioning, subscription information, device management, and user preference information transmitted through an interaction channel for control information related to receipt of security materials, such as a DRM RO and key values used for BCAST service protection.
BCAST-8 128 is a transmission path through which user data for a BCAST service is provided. BDS-1 129 is a transmission path for a protected BCAST service, an unprotected BCAST service, BCAST service attributes, content attributes, a notification, a service guide, and security materials, such as a DRM RO and key values used for BCAST service protection.
BDS-2 130 is a transmission path for service provisioning, subscription information, device management, and security materials, such as a DRM RO and key values used for BCAST service protection.
X-1 131 is a reference point between the BDS Service Distribution 111 and the BDS 112. X-2 132 is a reference point between the BDS Service Distribution 111 and the Interaction Network 113. X-3 133 is a reference point between the BDS 112 and the Terminal 105. X-4 134 is a reference point between the BDS Service Distribution 111 and the Terminal 105 over a broadcast channel. X-5 135 is a reference point between the BDS Service Distribution 111 and the Terminal 105 over an interaction channel. X-6 136 is a reference point between the Interaction Network 113 and the Terminal 105.
Referring to
With respect to
The Administrative Group 200 may include a Service Guide Delivery Descriptor (SGDD) block 201. The Provision Group 210 may include a Purchase Item block 211, a Purchase Data block 212, and a Purchase Channel block 213. The Core Group 220 may include a Service block 221, a Schedule block 222, and a Content block 223. The Access Group 230 may include an Access block 231 and a Session Description block 232.
The service guide may further include Preview Data 241 and Interactivity Data 251 in addition to the four information groups Administrative Group 200, Provision Group 210, Core Group 220, and Access Group 230.
The aforementioned components may be referred to as basic units or fragments constituting aspects of the service guide, for purposes of identification.
The SGDD fragment 201 may provide information about a delivery session where a Service Guide Delivery Unit (SGDU) is located. The SGDU is a container that contains service guide fragments 211, 212, 213, 221, 222, 223, 231, 232, 241, and 251, which constitute the service guide. The SGDD may also provide the information on the entry points for receiving the grouping information and notification messages.
The Service fragment 221, which is an upper aggregate of the content included in the broadcast service, may include information on service content, genre, service location, etc. In general, the ‘Service’ fragment describes at an aggregate level the content items, which comprise a broadcast service. The service may be delivered to the user using multiple means of access, for example, the broadcast channel and the interactive channel. The service may be targeted at a certain user group or geographical area. Depending on the type of the service it may have interactive part(s), broadcast-only part(s), or both. Further, the service may include components not directly related to the content but to the functionality of the service such as purchasing or subscription information. As the part of the Service Guide, the ‘Service’ fragment forms a central hub referenced by the other fragments including ‘Access’, ‘Schedule’, ‘Content’ and ‘PurchaseItem’ fragments. In addition to that, the ‘Service’ fragment may reference ‘PreviewData’ fragment. It may be referenced by none or several of each of these fragments. Together with the associated fragments the terminal may determine the details associated with the service at any point of time. These details may be summarized into a user-friendly display, for example, of what, how and when the associated content may be consumed and at what cost.
The Access fragment 231 may provide access-related information for allowing the user to view the service and delivery method, and session information associated with the corresponding access session. As such, the ‘Access’ fragment describes how the service may be accessed during the lifespan of the service. This fragment contains or references Session Description information and indicates the delivery method. One or more ‘Access’ fragments may reference a ‘Service’ fragment, offering alternative ways for accessing or interacting with the associated service. For the Terminal, the ‘Access’ fragment provides information on what capabilities are required from the terminal to receive and render the service. The ‘Access’ fragment provides Session Description parameters either in the form of inline text, or through a pointer in the form of a Uniform Resource Identifier (URI) to a separate Session Description. Session Description information may be delivered over either the broadcast channel or the interaction channel.
The Session Description fragment 232 may be included in the Access fragment 231, and may provide location information in a URI form so that the terminal may detect information on the Session Description fragment 232. The Session Description fragment 232 may provide address information, codec information, etc., about multimedia content existing in the session. As such, the ‘SessionDescription’ is a Service Guide fragment, which provides the session information for access to a service or content item. Further, the Session Description may provide auxiliary description information, used for associated delivery procedures. The Session Description information is provided using either syntax of Session Description Protocol (SDP) in text format, or through a 3rd Generation Partnership Project (3GPP) Multimedia Broadcast Multicast Service (MBMS) User Service Bundle Description. Auxiliary description information is provided in XML format and contains an Associated Delivery Description as specified in [BCAST10-Distribution]. Note that in case SDP syntax is used, an alternative way to deliver the Session Description is by encapsulating the SDP in text format in ‘Access’ fragment. Note that Session Description may be used both for Service Guide delivery itself as well as for the content sessions.
The Purchase Item fragment 211 may provide a bundle of service, content, time, etc., to help the user subscribe to or purchase the Purchase Item fragment 211. As such, the ‘PurchaseItem’ fragment represents a group of one or more services (i.e. a service bundle) or one or more content items, offered to the end user for free, for subscription and/or purchase. This fragment can be referenced by ‘PurchaseData’ fragment(s) offering more information on different service bundles. The ‘PurchaseItem’ fragment may be also associated with: (1) a ‘Service’ fragment to enable bundled services subscription and/or, (2) a ‘Schedule’ fragment to enable consuming a certain service or content in a certain timeframe (pay-per-view functionality) and/or, (3) a ‘Content’ fragment to enable purchasing a single content file related to a service, (4) other ‘PurchaseItem’ fragments to enable bundling of purchase items.
The Purchase Data fragment 212 may include detailed purchase and subscription information, such as price information and promotion information, for the service or content bundle. The Purchase Channel fragment 213 may provide access information for subscription or purchase. As such, the main function of the ‘PurchaseData’ fragment is to express the available pricing information about the associated purchase item. The ‘PurchaseData’ fragment collects the information about one or several purchase channels and may be associated with PreviewData specific to a certain service or service bundle. It carries information about pricing of a service, a service bundle, or, a content item. Also, information about promotional activities may be included in this fragment. The SGDD may also provide information regarding entry points for receiving the service guide and grouping information about the SGDU as the container.
The Preview Data fragment 241 may be used to provide preview information for a service, schedule, and content. As such, ‘PreviewData’ fragment contains information that is used by the terminal to present the service or content outline to users, so that the users can have a general idea of what the service or content is about. ‘PreviewData’ fragment can include simple texts, static images (for example, logo), short video clips, or even reference to another service which could be a low bit rate version for the main service. ‘Service’, ‘Content’, ‘PurchaseData’, ‘Access’ and ‘Schedule’ fragments may reference ‘PreviewData’ fragment.
The Interactivity Data fragment 251 may be used to provide an interactive service according to the service, schedule, and content during broadcasting. More detailed information about the service guide can be defined by one or more elements and attributes of the system. As such, the InteractivityData contains information that is used by the terminal to offer interactive services to the user, which is associated with the broadcast content. These interactive services enable users to e.g. vote during TV shows or to obtain content related to the broadcast content. ‘InteractivityData’ fragment points to one or many ‘InteractivityMedia’ documents that include xhtml files, static images, email template, Short Message Service (SMS) template, Multimedia Messaging Service (MMS) documents, etc. The ‘InteractivityData’ fragment may reference the ‘Service’, ‘Content’ and ‘Schedule’ fragments, and may be referenced by the ‘Schedule’ fragment.
The ‘Schedule’ fragment defines the timeframes in which associated content items are available for streaming, downloading and/or rendering. This fragment references the ‘Service’ fragment. If it also references one or more ‘Content’ fragments or InterativityData′ fragments, then it defines the valid distribution and/or presentation timeframe of those content items belonging to the service, or the valid distribution timeframe and the automatic activation time of the InteractivityMediaDocuments associated with the service. On the other hand, if the ‘Schedule’ fragment does not reference any ‘Content’ fragment(s) or ‘InteractivityData’ fragment(s), then it defines the timeframe of the service availability which is unbounded.
The ‘Content’ fragment gives a detailed description of a specific content item. In addition to defining a type, description and language of the content, it may provide information about the targeted user group or geographical area, as well as genre and parental rating. The ‘Content’ fragment may be referenced by Schedule, PurchaseItem or ‘InteractivityData’ fragment. It may reference ‘PreviewData’ fragment or ‘Service’ fragment.
The ‘PurchaseChannel’ fragment carries the information about the entity from which purchase of access and/or content rights for a certain service, service bundle or content item may be obtained, as defined in the ‘PurchaseData’ fragment. The purchase channel is associated with one or more Broadcast Subscription Managements (BSMs). The terminal is only permitted to access a particular purchase channel if it is affiliated with a BSM that is also associated with that purchase channel. Multiple purchase channels may be associated to one ‘PurchaseData’ fragment. A certain end-user can have a “preferred” purchase channel (e.g. a mobile operator) to which purchase requests should be directed. The preferred purchase channel may even be the only channel that an end-user is allowed to use.
The ServiceGuideDeliveryDescriptor is transported on the Service Guide Announcement Channel, and informs the terminal the availability, metadata and grouping of the fragments of the Service Guide in the Service Guide discovery process. A SGDD allows quick identification of the Service Guide fragments that are either cached in the terminal or being transmitted. For that reason, the SGDD is preferably repeated if distributed over broadcast channel. The SGDD also provides the grouping of related Service Guide fragments and thus a means to determine completeness of such group. The ServiceGuideDeliveryDescriptor is especially useful if the terminal moves from one service coverage area to another. In this case, the ServiceGuideDeliveryDescriptor can be used to quickly check which of the Service Guide fragments that have been received in the previous service coverage area are still valid in the current service coverage area, and therefore don't have to be re-parsed and re-processed.
Although not expressly depicted, the fragments that constitute the service guide may include element and attribute values for fulfilling their purposes. In addition, one or more of the fragments of the service guide may be omitted, as desired. Also, one or more fragments of the service guide may be combined, as desired. Also, different aspects of one or more fragments of the service guide may be combined together, reorganized, and otherwise modified, or constrained as desired.
Referring to
The SG Announcement Channel 300 may include at least one of SGDD 200 (e.g., SGDD #1, . . . , SGDD #2, SGDD #3), which may be formatted in any suitable format, such as that illustrated in Service Guide for Mobile Broadcast Services, Open Mobile Alliance, Version 1.0.1, Jan. 9, 2013 and/or Service Guide for Mobile Broadcast Services, open Mobile Alliance, Version 1.1, Oct. 29, 3013; both of which are incorporated by reference in their entirety. The descriptions of elements and attributes constituting the Service Guide Delivery Descriptor fragment 201 may be reflected in any suitable format, such as for example, a table format and/or in an eXtensible Markup Language (XML) schema.
The actual data is preferably provided in XML format according to the SGDD fragment 201. The information related to the service guide may be provided in various data formats, such as binary, where the elements and attributes are set to corresponding values, depending on the broadcast system.
The terminal 105 may acquire transport information about a Service Guide Delivery Unit (SGDU) 312 containing fragment information from a DescriptorEntry of the SGDD fragment received on the SG Announcement Channel 300.
The DescriptorEntry 302, which may provide the grouping information of a Service Guide includes the “GroupingCriteria”, “ServiceGuideDeliveryUnit”, “Transport”, and AlternativeAccessURI”. The transport-related channel information may be provided by the “Transport” or “AlternativeAccessURI”, and the actual value of the corresponding channel is provided by “ServiceGuideDeliveryUnit”. Also, upper layer group information about the SGDU 312, such as “Service” and “Genre”, may be provided by “GroupingCriteria”. The terminal 105 may receive and present the SGDUs 312 to the user according to the corresponding group information.
Once the transport information is acquired, the terminal 105 may access the Delivery Channels acquired from a DescriptorEntry 302 in an SGDD 301 on an Service Guide (SG) Delivery Channel 310 to receive the actual SGDU 312. The SG Delivery Channels can be identified using the “GroupingCriteria”. In the case of time grouping, the SGDU can be transported with a time-based transport channel such as an Hourly SG Channel 311 and a Daily SG Channel. Accordingly, the terminal 105 can selectively access the channels and receive the SGDUs existing on the corresponding channels. Once the entire SGDU is completely received on the SG Delivery Channels 310, the terminal 105 checks fragments contained in the SGDUs received on the SG Delivery Channels 310 and assembles the fragments to display an actual full service guide 320 on the screen which can be subdivided on an hourly basis 321.
In the conventional mobile broadcast system, the service guide is formatted and transmitted such that only configured terminals receive the broadcast signals of the corresponding broadcast system. For example, the service guide information transmitted by a DVB-H system can only be received by terminals configured to receive the DVB-H broadcast.
The service providers provide bundled and integrated services using various transmission systems as well as various broadcast systems in accordance with service convergence, which may be referred to as multiplay services. The broadcast service providers may also provide broadcast services on IP networks. Integrated service guide transmission and/or reception systems may be described using terms of entities defined in the 3GPP standards and OMA BCAST standards (e.g., a scheme). However, the service guide and/or reception systems may be used with any suitable communication and/or broadcast system.
Referring to
The “type” column indicates an index representing an element or an attribute. An element can be one of E1, E2, E3, E4, . . . , E[n]. E1 indicates an upper element of an entire message, E2 indicates an element below the E1, E3 indicates an element below E2, E4 indicates an element below the E3, and so forth. An attribute is indicated by A. For example, an “A” below E1 means an attribute of element E1. In some cases the notation may mean the following E=Element, A=Attribute, E1=sub-element, E2=sub-element's sub-element, E[n]=sub-element of element[n−1]. The “category” column is used to indicate whether the element or attribute is mandatory. If an element is mandatory, the category of the element is flagged with an “M”. If an element is optional, the category of the element is flagged with an “O”. If the element is optional for network to support it the element is flagged with a “NO”. If the element is mandatory for terminal to support it is flagged with a TM. If the element is mandatory for network to support it the element is flagged with “NM”. If the element is optional for terminal to support it the element is flagged with “TO”. If an element or attribute has cardinality greater than zero, it is classified as M or NM to maintain consistency. The “cardinality” column indicates a relationship between elements and is set to a value of 0, 0 . . . 1, 1, 0 . . . n, and 1 . . . n. 0 indicates an option, 1 indicates a necessary relationship, and n indicates multiple values. For example, 0 . . . n means that a corresponding element can have no or n values. The “description” column describes the meaning of the corresponding element or attribute, and the “data type” column indicates the data type of the corresponding element or attribute.
A service may represent a bundle of content items, which forms a logical group to the end-user. An example would be a Television (TV) channel, composed of several TV shows. A ‘Service’ fragment contains the metadata describing the Mobile Broadcast service. It is possible that the same metadata (i.e., attributes and elements) exist in the ‘Content’ fragment(s) associated with that ‘Service’ fragment. In that situation, for the following elements: ‘ParentalRating’, ‘TargetUserProfile’, ‘Genre’ and ‘BroadcastArea’, the values defined in ‘Content’ fragment take precedence over those in ‘Service’ fragment.
The program guide elements of this fragment may be grouped between the Start of program guide and end of program guide cells in a fragment. This localization of the elements of the program guide reduces the computational complexity of the receiving device in arranging a programming guide. The program guide elements are generally used for user interpretation. This enables the content creator to provide user readable information about the service. The terminal should use declared program guide elements in this fragment for presentation to the end-user. The terminal may offer search, sort, etc. functionalities. The Program Guide may consist of the following service elements: (1) Name; (2) Description; (3) AudioLanguage; (4) TextLanguage; (5) ParentalRating; (6) TargetUserProfile; and (7) Genre.
The “Name” element may refer to Name of the Service, possibly in multiple languages. The language may be expressed using built-in XML attribute ‘xml:lang’.
The “Description” element may be in multiple languages and may be expressed using built-in XML attribute ‘xml:lang’.
The “AudioLanguage” element may declare for the end users that this service is available with an audio track corresponding to the language represented by the value of this element. The textual value of this element can be made available for the end users in different languages. In such a case the language used to represent the value of this element may be signaled using the built-in XML attribute ‘xml:lang’, and may include multi-language support. The AudioLanguage may contain an attribute languageSDPTag.
The “languageSDPTag” attribute is an identifier of the audio language described by the parent ‘AudioLanguage’ element as used in the media sections describing the audio track in a Session Description. Each ‘AudioLanguage’ element declaring the same audio stream may have the same value of the languageSDPTag′.
The “TextLanguage” element may declare for the end user that the textual components of this service are available in the language represented by the value of this element. The textual components can be, for instance, a caption or a sub-title track. The textual value of this element can be made available for the end users in different languages. In such a case the language used to represent the value of this element may be signaled using the built-in XML attribute ‘xml:lang’, and may include multi-language support. The same rules and constraints as specified for the element ‘AudioLanguage’ of assigning and interpreting the attributes languageSDPTag′ and ‘xml:lang’ may be applied for this element.
The “languageSDPTag” attribute is an identifier of the text language described by the parent ‘TextLanguage’ element as used in the media sections describing the textual track in a Session Description.
The “ParentalRating” element may declare criteria parents and might be used to determine whether the associated item is suitable for access by children, defined according to the regulatory requirements of the service area. The terminal may support ‘ParentalRating’ being a free string, and the terminal may support the structured way to express the parental rating level by using the ‘ratingSystem’ and ‘ratingValueName’ attributes.
The “ratingSystem” attribute may specify the parental rating system in use, in which context the value of the ‘ParentalRating’ element is semantically defined. This allows terminals to identify the rating system in use in a non-ambiguous manner and act appropriately. This attribute may be instantiated when a rating system is used. Absence of this attribute means that no rating system is used (i.e. the value of the ‘ParentalRating’ element is to be interpreted as a free string).
The “ratingValueName” attribute may specify the human-readable name of the rating value given by this ParentalRating element.
The “TargetUserProfile” may specify elements of the users whom the service is targeting at. The detailed personal attribute names and the corresponding values are specified by attributes of ‘attributeName’ an ‘attributeValue’. Amongst the possible profile attribute names are age, gender, occupation, etc. (subject to national and/or local rules and/or regulations, if present and as applicable regarding use of personal profiling information and personal data privacy). The extensible list of ‘attributeName’ and ‘attributeValue’ pairs for a particular service enables end user profile filtering and end user preference filtering of broadcast services. The terminal may be able to support ‘TargetUserProfile’ element. The use of ‘TargetUserProfile’ element may be an “opt-in” capability for users. Terminal settings may allow users to configure whether to input their personal profile or preference and whether to allow broadcast service to be automatically filtered based on the users' personal attributes without users' request. This element may contain the following attributes: attributeName and attributeValue.
The “attributeName” attribute may be a profile attribute name.
The “attributeValue” attribute may be a profile attribute value.
The “Genre” element may specify classification of service associated with characteristic form (e.g. comedy, drama). The OMA BCAST Service Guide may allow describing the format of the Genre element in the Service Guide in two ways. The first way is to use a free string. The second way is to use the “href” attributes of the Genre element to convey the information in the form of a controlled vocabulary (classification scheme as defined in [TVA-Metadata] or classification list as defined in [Moving Image Genre-Form Guide (MIGFG)]). The built-in XML attribute xml:lang may be used with this element to express the language. The network may instantiate several different sets of ‘Genre’ element, using it as a free string or with a ‘href’ attribute. The network may ensure the different sets have equivalent and nonconflicting meaning, and the terminal may select one of the sets to interpret for the end-user. The ‘Genre’ element may contain the following attributes: type and href.
The “type” attribute may signal the level of the ‘Genre’ element, such as with the values of “main”, “second”, and “other”.
The “href” attribute may signal the controlled vocabulary used in the ‘Genre’ element. After reviewing the set of programming guide elements and attributes; (1) Name; (2) Description; (3) AudioLanguage; (4) TextLanguage; (5) ParentalRating; (6) TargetUserProfile; and (7) Genre it was determined that the receiving device still may have insufficient information defined within the programming guide to appropriately render the information in a manner suitable for the viewer. In particular, the traditional National Television System Committee (NTSC) television stations typically have numbers such as, 2, 4, 6, 8, 12, and 49. For digital services, program and system information protocol includes a virtual channel table that, for terrestrial broadcasting defines each digital television service with a two-part number consisting of a major channel followed by a minor channel. The major channel number is usually the same as the NTSC channel for the station, and the minor channels have numbers depending on how many digital television services are present in the digital television multiples, typically starting at 1. For example, the analog television channel 9, WUSA-TV in Washington, D.C., may identify its two over-the-air digital services as follows: channel 9-1 WUSA-DT and channel 9-2 9-Radar. This notation for television channels is readily understandable by a viewer, and the programming guide elements may include this capability as an extension to the programming guide so that the information may be computationally efficiently processed by the receiving device and rendered to the viewer.
Referring to
After further reviewing the set of programming guide elements and attributes; (1) Name; (2) Description; (3) AudioLanguage; (4) TextLanguage; (5) ParentalRating; (6) TargetUserProfile; and (7) Genre it was determined that the receiving device still may have insufficient information suitable to appropriately rendering the information in a manner suitable for the viewer. In many cases, the viewer associates a graphical icon with a particular program and/or channel and/or service. In this manner, the graphical icon should be selectable by the system, rather than being non-selectable.
Referring to
After further reviewing the set of programming guide elements and attributes; (1) Name; (2) Description; (3) AudioLanguage; (4) TextLanguage; (5) ParentalRating; (6) TargetUserProfile; and (7) Genre it was determined that the receiving device still may have insufficient information suitable to appropriately rendering the information in a manner suitable for the viewer. In many cases, the viewer may seek to identify the particular extension being identified using the same extension elements. In this manner, a url may be used to specifically identify the particular description of the elements of the extension. In this manner, the elements of the extension may be modified in a suitable manner without having to expressly describe multiple different extensions.
Referring to
Referring to
In other examples, instead of using Data Type “string” for MajorChannelNum and MinorChannelNum elements, other data types may be used. For example, the data type unsignedInt may be used. In another example, a string of limited length may be used, e.g. string of 10 digits. An exemplary XML schema syntax for the above extensions is illustrated below.
In some examples the ServiceMediaExtension may be included inside a OMA “extension” element or may in general use OMA extension mechanism for defining the ServiceMediaExtension.
In some examples the MajorChannelNum and MinorChannelNum may be combined into one common channel number and represented. For example a ChannelNum string may be created by concatenating MajorChannelNum followed by a period (‘.’) followed by MinorChannelNum. Other such combinations are also possible with period replaced by other characters. Similar concept can be applied when using unsignedInt or other data types to represent channel numbers in terms of combining MajorChannelNum and MinorChannelNum into one number representation.
In another example a MajorChannelNum.MinorChannelNum could be represented as “ServiceId” element (Service Id) for the service.
In another example, the ServiceMediaExtension may only be used inside a PrivateExt element within a Service fragment. An exemplary XML schema syntax for such an extension is illustrated below.
This element is a wrapper for extensions to OMA BOAST SG Service fragments. It may only be used inside a PrivateExt element within a Service fragment.
In other examples some of the elements above may be changed from E2 to E1. In other examples the cardinality of some of the elements may be changed. In addition, if desired, the category may be omitted since it is generally duplicative of the information included with the cardinality.
It is desirable to map selected components of the Advanced Television Systems Subcommittee (ATSC) service elements and attributes to the OMA service guide service fragment program guide. For example, the “Description” attribute of the OMA service guide fragment program guide may be mapped to “Description” of the ATSC service elements and attributes, such as for example ATSC-Mobile Digital Television (DTV) Standard, Part 4—Announcement, other similar broadcast or mobile standards for similar elements and attributes. For example, the “Genre” attribute of the OMA service guide fragment program guide may be mapped to “Genre” of the ATSC service elements and attributes, such as for example ATSC-Mobile DTV Standard, Part 4—Announcement, other similar standards for similar elements and attributes. In one example Genre scheme as defined in Section 6.10.2 of ATSC A153 Part 4 may be utilized For example, the “Name” attribute of the OMA service guide fragment program guide may be mapped to “Name” of the ATSC service elements and attributes, such as for example ATSC-Mobile DTV Standard, Part 4—Announcement, other similar standards for similar elements and attributes. Preferably, the cardinality of the name is selected to be 0 . . . N, which permits the omission of the name which reduces the overall bit rate of the system and increase flexibility. For example, the “ParentalRating” attribute of the OMA service guide fragment program guide may be mapped to a new “ContentAdvisory” of the ATSC service element and attributes, such as for example ATSC-Mobile DTV Standard, Part 4—Announcement, or similar standards for similar elements and attributes. For example, the “TargetUserProfile” attribute of the OMA service guide fragment program guide may be mapped to a new “Personalization” of the ATSC service element and attributes, such as for example ATSC-Mobile DTV Standard, Part 4—Announcement, or similar standards for similar elements and attributes.
Referring to
An example XML schema syntax for this is shown below.
In another example the attributes languageSDPTag for the elements AudioLanguage and TextLanguage could be removed. An example XML schema syntax for this is shown below.
Referring to
An example XML schema syntax for this is shown below.
In another example the attributes languageSDPTag for the elements AudioLanguage and TextLanguage could be removed. An example XML schema syntax for this is shown below.
In another example the attribute “language” could be mapped to ATSC service “language” element and could refer to the primary language of the service. In another example the value of element “AudioLanguage” could be mapped to ATSC service “language” element and could refer to the primary language of the audio service in ATSC.
In another example the value of element “TextLanguage” could be mapped to ATSC service “language” element and could refer to the primary language of the text service in ATSC. In some cases the text service may be a service such as closed caption service. In another example the elements AudioLanguage and TextLanguage and their attributes could be removed.
For the service guide, traditionally the consideration has been to reference the linear stream of the audio-visual content, generally referred to as a “linear service”. With the proliferation of applications also referred to as “apps” it is desirable to reference app-based (i.e. application based) services which are other programs that are executed and provide a service to the user, generally referred to as “app-based service”. It is desirable to map notification stream of the “linear service” or the “app-based service” using the Notification ServiceType element 7 of the OMA service guide fragment program guide.
It is also desirable to enable the notification of other services using the ServiceType element of the OMA service guide fragment program guide. The ServiceType may use the range “reserved for proprietary use” to include additional service types. For example, ServiceType element value 224 may be used to identify an “App-Based Service” that includes an application component to be used. For example, ServiceType element value 225 may be used to identify an “App-Based Service” that includes non-real time content to be used. For example, ServiceType element value 226 may be used for to identify an “App-Based Service” that includes an on-demand component to be used. In this manner, these app-based services are mapped to the Notification ServiceType element 7, and thus are readily omitted when the Notification ServiceType element 7 does not indicate their existence, thereby reducing the complexity of the bitstream.
In another example, rather than mapping the notification to the value of 7 for OMA ServiceType, an additional ServiceType value may be defined. A Notification ServiceType element 227 of the OMA service guide fragment program guide may be used to identify an “App-Based Service” that includes an application component to be used including a notification stream component.
It is to be understood that other values may likewise be used for the described services. For example instead of ServiceType element value 224, ServiceType element value 225, ServiceType element value 226, and ServiceType element value 227 above the ServiceType element value 240, ServiceType element value 241, ServiceType element value 242, or ServiceType element value 243 may be used. In another case ServiceType element values 129, ServiceType element value 130, ServiceType element value 131, or ServiceType element value 132 may instead be used.
In another example instead if using ServiceType values from the range (128-255) reserved for proprietary use, the values from the range (11-127) reserved for future use may be used.
In another example when using OMA BCAST Guide 1.1 from instead if using ServiceType values from the range (128-255) reserved for proprietary use, the values from the range (14-127) reserved for future use may be used.
In another example when using OMA BCAST Guide 1.1 from [instead if using ServiceType values from the range (128-255) reserved for proprietary use, the values from the range (128-223) reserved for other OMA enablers may be used.
In another example when using OMA BCAST Guide 1.1 from instead if using ServiceType values from the range (128-255) reserved for proprietary use, the values may be restricted in the range (224-255) reserved for other OMA enablers may be used
In another example, for example, an additional ServiceType element value 228 may be used to identify a “Linear Service”. For example, an additional ServiceType element value 229 may be used to identify an “App-Based Service” that includes a generalized application based enhancement. In this manner, the service labeling is simplified by not expressly including services type for application component, non-real time content, nor on-demand component.
In another example, for example, an additional or alternative ServiceType element value 230 may be used for to identify an “App-Based Service” that includes an application based enhancement. In this manner, the notification is further simplified by not expressly including services type for linear service, application component, non-real time content, nor on-demand component.
In another example, for example, the ServiceType element value 1 also may be used for to identify a “Linear Service”. In this manner, the Linear Element is incorporated within the existing syntax structure. In this case the “Linear service” is mapped to Basic TV service.
In another example, for example, the ServiceType element value 11 may be used for to identify a streaming on demand component, which may be an app-based service with app-based enhancement including an on demand component. For example, ServiceType element value 12 may be used to identify a file download on demand component, which may be an app-based enhancement including a non-real time content item component.
In another example, any one of the above service type values may be indicated by a value within another element. For example, an AvailableContent element or attribute and its values could take one of the values from application component, non-real time content, on-demand component, and/or notification.
In another example, the ServiceType value allocation may be done hierarchically. For example, the main service types may be a linear service and an app-based service, and each of these two types of services could include zero or more app-based enhancements components which can include application component, non-real time content, on demand component, and/or notification, a hierarchical allocation of ServiceType values may be done. In this case for “ServiceType” one of the bits of “unsigned Byte” (date type of ServiceType) could be used to signal a linear service (bit with value set to 1) or an app-based service (bit with value set to 0). Then the rest of the bits can signal the service types.
An example is illustrated as follows:
224 (11100000 binary) Linear Service with App-Based Enhancement including application component
240 (11110000 binary) App-Based Service with App-Based Enhancement including application component
225 (11100001 binary) Linear Service with App-Based Enhancement including non-real time content
241 (111100001 binary) App-Based Service with App-Based Enhancement including non-real time content
226 (11100010 binary) Linear Service with App-Based Enhancement including on demand component
242 (11110010 binary) App-Based Service with App-Based Enhancement including on demand component
227 (11100011 binary) Linear Service with App-Based Enhancement including notification stream component
243 (11110011 binary) App-Based Service with App-Based Enhancement including notification stream component
228 (11100100 binary) Linear Service with generic service type
243 (11110100 binary) App-Based Service with generic service type
The generic service type may refer to the service different than a service, which has application component or non-real-time content, or on demand component. In some case the generic service type may be an “unknown” service type.
In another example, the values may use contiguous ServiceType values. For example the service type values could be assigned as follows:
224 Linear Service with App-Based Enhancement including application component
225 App-Based Service with App-Based Enhancement including application component
226 Linear Service with App-Based Enhancement including non-real time content
227 App-Based Service with App-Based Enhancement including non-real time content
228 Linear Service with App-Based Enhancement including on demand component
229 App-Based Service with App-Based Enhancement including on demand component
230 Linear Service with App-Based Enhancement including notification stream component
231 App-Based Service with App-Based Enhancement including notification stream component
In another example the Linear and/or App-based service: App may be further split into two service types (and thus four total service types as) follows:
Where a Primary App, may be an app which is activated as soon as the underlying service is selected. Also non-primary apps may be started later in the service.
In some examples, the service of the type Linear Service: On-Demand component may be forbidden. In that case, no ServiceType value may be assigned for that type of service.
Additional examples related to service signaling are described as follows. In general service announcement and service signaling may be as follows. Service Announcement may include information about programming and services that is designed to allow the viewer or user to make an informed selection about service or content. Service Signaling may include information that enables the receiver to locate and acquire services and to perform basic navigation of the service.
Referring to
With respect to
As a part of receiving service from transmission service 1100, the receiver 1140 may receive signaling information which may provide information about various media streams and data that may be received via delivery mechanism. In one example the signaling information from transmissions service provider 1100 may include component information description 1110. An example of component information description is provided later with respect to
Referring to
Referring to
As a part of receiving service from transmission service provider 1200, the receiver 1240 may receive signaling information which may provide information about various media streams and data that may be received via delivery mechanism. In one example the signaling information from transmissions service provider 1200 may include channel information description 1210. An example of channel information description is provided later with respect to
The Component Information Descriptor of
The syntax for the Component Information Descriptor may conform to the syntax shown in
Semantic meaning of the syntax elements in the component information descriptor of
descriptor_tag—This is 8-bit unsigned integer for identifying this descriptor. Any suitable value between 0-255 which uniquely identifies this descriptor can be signaled. In one example the format of this field may be uimsbf. In another example some other format may be used which allows identifying the descriptor uniquely compared to other descriptors based on this descriptor_tag value.
descriptor_length—This 8-bit unsigned integer may specify the length (in bytes) immediately following the field num_components up to the end of this descriptor. In some examples instead of 8-bit, this field may be 16-bit.
num_components—This 8-bit unsigned integer field may specify the number of components available for this service. The value of this field may be in the range of 1 to 127 inclusive. Values 128-255 are reserved. In an alternative example this field may be split into two separate fields: a 7-bit unsigned integer field num_components and a 1 bit reserved field.
component_type—This 3-bit unsigned integer may specify the component type of this component available in the service. Value of 0 indicates an audio component. Value of 1 indicates a video component. Value of 2 indicated a closed caption component. Value of 3 indicates an application component. Values 4 to 7 are reserved.
component_role—This 4-bit unsigned integer may specify the role or kind of this component. The defined values include one or more:
For audio component (when component_type field above is equal to 0) values of component_role are as follows:
In another example additionally component_role values for audio may be defined as follows: 7=Emergency, 8=Karaoke. In this case the values 9-14 will be reserved and 15 will be used to signal unknown audio role.
For Video (when component_type field above is equal to 1) values of component_role are as follows:
When component_type field above is between 3 to 7, inclusive, the component_role may be equal to 15.
component_protected_flag—This 1-bit flag indicates if this component is protected (e.g. encrypted). When this flag is set to a value of 1 this component is protected (e.g. encrypted). When this flag is set to a value of 0 this component is not protected (e.g. encrypted).
component_id—This 8-bit unsigned integer nay specify the component identifier of this component available in this service. The component_id may be unique within the service.
component_name_length—This 8-bit unsigned integer may specify the length (in bytes) of the component_name_bytes( ) field which immediately follows this field.
component_name_bytes( )—Short human readable name of the component in “English” language. Each character of which may be encoded per UTF-8.
With respect to
The syntax for the Channel Descriptor may conform to the syntax shown in
Semantic meaning of the syntax elements in the channel descriptor of
descriptor_tag—This is 8-bit unsigned integer for identifying this descriptor. Any suitable value between 0-255 which uniquely identifies this descriptor can be signaled. In one example the format of this field may be uimsbf. In another example some other format may be used which allows identifying the descriptor uniquely compared to other descriptors based on this descriptor_tag value.
descriptor_length—This 8-bit unsigned integer may specify the length (in bytes) immediately following this field up to the end of this descriptor.
major_channel_num—This 16-bit unsigned integer may specify the major channel number of the service. In another example the bit width of 8-bit or 12-bit may be used for this field instead of 16-bit.
minor_channel_num—This 16-bit unsigned integer may specify the minor channel number of the service in the case of channel descriptor shown in
In the case of channel descriptor shown in
service_lang_code—Primary language used in the service. This field may consist of one of the 3 letter code in International Standard Organization (ISO) ISO 639-3 titled “Codes for the representation of names of languages—Part 3: Alpha-3 code for comprehensive coverage of languages available at http://www.iso.org which is incorporated by reference in its entirety here by reference. In other examples a predefined list of languages may be defined and this filed can be an index into the list of those fields. In an alternate example 16 bits may be used for this field since upper bound for the number of languages that can be represented is 26×26×26 i.e. 17576 or 17576−547=17030.
service_lang_genre—Primary genre of the service. The service_lang_genre element may be instantiated to describe the genre category for the service. The <classificationSchemeURI> is http://www.atsc.org/XMLSchemas/mh/2009/1.0/genre-cs/ and the value of service_lang_genre may match a termID value from the classification schema in Annex B of A/153 Part 4 document titled “ATSC-Mobile DTV Standard, Part 4—Announcement” available at http://www.atsc.org which is incorporated in its entirety here by reference.
icon_url_length—This 8-bit unsigned integer may specify the length (in bytes) of the icon_url_bytes( ) field which immediately follows this field.
icon_url_bytes( ) URL for the icon used to represent this service. Each character may be encoded per Unicode Transmission Format (UTF)-8. service_descriptor_length—This 8-bit unsigned integer may specify the length (in bytes) of the service_descr_bytes( ) field which immediately follows this field.
service_descr_bytes( ) Short description of the service. Either in “English” language or in the language identified by the value of service_lang_code field in this descriptor. Each character of which may be encoded per UTF-8.
The values of icon_url_length and service_descriptor_length are constrained as specified by the value of the descriptor_length field which provides information about the length of this entire descriptor.
With respect to
ext_channel_info_present_flag—This 1-bit Boolean flag that may indicate, when set to ‘1’, that extended channel information fields for this service including the fields service_lang_code, service_genre_code, service_descr_length, service_descr_bytes( ) icon_url_length, icon_url_bytes( ) are present in this descriptor. A value of ‘0’, may indicate that extended channel information fields for this service including the fields service_lang_code, service_genre_code, service_descr_length, service_descr_bytes( ) icon_url_length, icon_url_bytes( ) are not present in this descriptor.
Thus when using the channel descriptor shown in
In some examples it may be a requirement of bitstream conformance that when channel information descriptor (e.g.
In another example it may be a requirement of a bitstream conformance that ext_channel_info_present_flag may be equal to 1.
In addition to the binary syntax of
In addition to the binary syntax of
Description about various XML schemas and namespaces is provided below. XML schema for User Service Bundle Description for MMT is also described below. User Service Bundle Description provides signaling information which is used for accessing a service.
With respect to
With respect to
These definitions make it efficient to define MMS USBD at the same time preventing an illegal value to be specified for an element or attribute.
The difference between XML schema shown in
In
xmlns:slt=http://www.atsc.org/XMLSchemas/ATSC3/Delivery/SLT/1.0/.
In
<xs:importschemaLocation=“SLT.xsd”
namespace=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/SLT/1.0/”/>.
In
The namespace description and rules for the schema may be defined as below. A general description of XML Schema and Namespaces is also provided below.
A number of XML elements may be defined and used for service signaling and delivery. These elements may correspond to following situations:
To provide various service signaling elements and attributes defined for low level signaling, service layer signaling and ROUTE protocol.
To use and extend elements and attributes defined by 3GPP MBMS for ATSC 3.0 USBD fragment.
These XML elements may be defined with separate namespaces in each individual schema documents. The namespaces used by various schemas may be described when defining various individual schemas. The sub-string part of namespaces between the right-most two ‘/’ delimiters indicate major and minor version of the schemas. The schemas defined initially may have version ‘1.0’, which indicates major version is 1 and minor version is 0.
In order to provide flexibility for future changes in the schema, decoders of XML documents with the namespaces defined currently should ignore any elements or attributes they do not recognize, instead of treating them as errors.
In the event of any discrepancy between the XML schema definitions implied by the table that appear in this document (e.g.
The XML schema document for the schemas defined in this document may be found at the ATSC website.
Description about formal, valid XML schema for MMT USBD is provided below. This explanation is with respect to the XML schema shown in
The bundleDescription may be represented as an XML document containing a bundleDescription root element that conforms to the XML schema. Examples of such a schema file are shown in
The ATSC extensions to the MBMS USBD fragment may be as specified in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0/
The abbreviation “mmtusd” should be used as the namespace prefix for any of the elements of this MMT USBD schema, if they appear in an XML document. The binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document. xmlns:mmtusd=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0”
In a variant example a single namespace may be defined and used for various signaling related schemas. In this case following description may apply to namespace definition.
A number of XML elements may be defined and used for service signaling and delivery. These elements correspond to following situations:
To provide various service signaling elements and attributes defined for low level signaling, service layer signaling and ROUTE protocol.
To use and extend elements and attributes defined by 3GPP MBMS for ATSC 3.0 USBD fragment.
These XML elements may be defined with a single common namespace. The substring part of namespace between the right-most two ‘/’ delimiters indicate major and minor version of the schemas. The schemas defined initially may have version ‘1.0’, which indicates major version is 1 and minor version is 0.
In order to provide flexibility for future changes in the schema, decoders of XML documents with this namespace defined currently should ignore any elements or attributes they do not recognize, instead of treating them as errors.
In the event of any discrepancy between the XML schema definition implied by the table that appear in this document (e.g.
The XML schema document for the schemas defined in this document may be found at the ATSC website.
In a variant example when using a signaled namespace for various signaling related schemas, following may apply.
Description about formal, valid XML schema for MMT USBD may be as follows. This explanation is with respect to the XML schema shown in
The bundleDescription may be represented as an XML document containing a bundleDescription root element that conforms to the XML schema. Examples of such a schema file are shown in
The ATSC extensions to the MBMS USBD fragment may be as specified in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/Signaling/1.0/
The abbreviation “atscsig” should be used as the namespace prefix for any of the elements of the ATSC signaling schemas, if they appear in an XML document. The binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document. xmlns:atscsig=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/Signaling/1.0” In another variant example the actual Uniform Resource Indicator (URL) values defined above for a namespace may instead be changed.
For example instead of URL:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0/
the URL:
http://www.atsc.org/XMLSchemas/MMTUSD/1.0/ may be used.
In another variant example the actual URL values defined above for a namespace may instead be changed so as to not include the version number.
For example instead of URL:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0/
the URL:
http://www.atsc.org/XMLSchemas/MMTUSD/ may be used.
It should be noted that the URLs above use a slash (′r) delimiter as its last characters. In some examples this slash (′r) delimiter as last character may be omitted from the URLs.
For example instead of URL:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0/
the URL:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0 may be used.
Similarly
For example instead of URL:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/
the URL:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD
may be used. For example instead of URL:
http://www.atsc.org/XMLSchemas/MMTUSD/1.0/
the URL:
http://www.atsc.org/XMLSchemas/MMTUSD/1.0
may be used.
For example instead of URL:
http://www.atsc.org/XMLSchemas/MMTUSD/
the URL:
http://www.atsc.org/XMLSchemas/MMTUSD
may be used.
With respect to
With respect to
With respect to
As described previously one of the options for content delivery for streaming and/or file download through ATSC broadcast physical layer is Real-time Object delivery over Unidirectional Transport over UDP and IP. Additional description is provided regarding ROUTE delivery.
A User Service Bundle Description fragment with various elements, attributes and their semantic description for ROUTE is shown in
The bundleDescription may be represented as an XML document containing a bundleDescription root element that conforms to the definitions in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTEUSD/1.0/
The abbreviation “routeusd” should be used as the namespace prefix for any of the elements of this ROUTE user service description schema, if they appear in an XML document. For the initial release of this Standard the binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document. xmlns:routeusd=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTEUSD/1.0/”
The normative XML schema for ROUTE USBD is shown in
Service Transport Session Instance Description (S-TSID) fragment referred by ROUTE USBD in
Each instance of the S-TSID fragment is referenced in the USBD fragment by the @sTSIDUri attribute of the userServiceDescription element.
The S-TSID may be represented as an XML document containing a S-TSID root element that conforms to the definitions in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/
The abbreviation “routesls” should be used as the namespace prefix for any of the elements of this schema, if they appear in an XML document. For the initial release of this Standard the binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document.
xmlns:routesls=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/”
The normative XML schema for S-TSID is included in
S-TSID fragment in
The SrcFlow element describes a source flow. A source flow sends delivery objects to receiver. A delivery object is self-contained, typically associated with certain properties, metadata and timing-related information that are of relevance for the application. SRCFlow element along with its sub-elements an attributes is shown in
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/
The abbreviation “routesls” should be used as the namespace prefix for any of the elements of this schema, if they appear in an XML document. For the initial release of this Standard the binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document.
xmlns:routesls=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/”
SRCFlow element in
The EFDT may be represented as an XML document containing a EFDT root element that conforms to the definitions in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/The
abbreviation “routesls” should be used as the namespace prefix for any of the elements of this schema, if they appear in an XML document. For the initial release of this Standard the binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document.
xmlns:routesls=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/”
The normative XML schema for EFDT is included in
As mentioned previously S-TSID fragment in
RapairFlow element consists of three attributes and two elements. These are described further. The element FECOTI specifies FEC object transmission information. ProtectedObject element is described below. @maximumDelay attribute specifies the maximum delay between any source packet in the source flow and the repair flow. This attribute is optionally signaled. When not signaled the value of this attribute is inferred to be equal to 0. Not signaling this attribute and instead inferring its value allows bit-savings. In another example some other default value may be used for the value of @maximumDelay attribute when it is not signaled. For example a value of 5000 may be used. Or some other value may be used. @overhead attribute indicates the overhead of repair flow in percentage value. @minBuffSize attribute specifies required buffer size for the repair flow.
The RepairFlow may be represented as an XML document containing a RepairFlow root element that conforms to the definitions in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/
The abbreviation “routesls” should be used as the namespace prefix for any of the elements of this schema, if they appear in an XML document. For the initial release of this Standard the binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document.
xmlns:routesls=http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTESLS/1.0/
The normative XML schema for RepairFlow is included in
The repair flow shown in
The normative XML schema for ProtectedObject is included in
In XML schema various custom data types are defined. Also data types are defined for various elements. Information about some of the elements and data types for XML schema in
ContentInfo in SrcFlow: A “string” data types is defined to be used for this element.
@version attribute of Extended file delivery table (EFDT): An unsignedInt data types id defined to be used for this attribute.
@maxExpiresDelta attribute of (EFDT): unsignedInt data types id defined to be used for this attribute.
FileTemplate, FDTParameters elements of EFDT: A “string” data types is defined to be used for this element.
In another example FDTParameters element maybe a data structure comprising one or more file descriptors as specified in the File Delivery over Unidirectional Transport (FLUTE) File Delivery Table (FDT). FLUTE FDT is defined in IETF: RFC 6726, “FLUTE—File Delivery over Unidirectional Transport,” Internet Engineering Task Force, Reston, Va., November, 2012. http://tools.ietf.org/html/rfc6726 which is incorporated here in its entirety by reference.
In yet another example the FDTParameters element maybe a data structure comprising one or more file descriptors as specified in the 3GPP-defined FDT extensions as defined in MBMS 3GPP: TS 26.346 V12.4.0 (2014-12), “3rd Generation Partnership Project; Technical Specification Group Services and System Aspects; Multimedia Broadcast/Multicast Service (MBMS); Protocols and codecs (Release 12)”, which is incorporated here in its entirety by reference. The FDTParameters element may include one or more of elements:
Cache-Control, Alternate-Content-Location-1, Alternate-Content-Location-2, BaseURL-1 and Base-URL-2, and attribute @Availability-Time. The semantics of these elements and attribute are defined in those documents and described below.
In an example, Alternate-Content-Location-1 and/or Alternate-Content-Location-2 elements provide URIs for file repair. The number of byte-range based file repair service URIs may be determined by the number of “Alternate-Content-Location-1” and “Alternate-Content-Location-2” elements in the FDT. Alternate-Content-Location-1 and/or Alternate-Content-Location-2 elements provide the references to the file repair server's resource via the “xs:anyURI” value.
In an example, Base-URL-1 and/or Base-URL-2 elements provide base URL for file repair. When present, the “Base-URL-1” and/or “Base-URL-2” elements may provide base URLs that may be used to resolve a relative reference included in any AlternateContent-Location-1 and/or Alternate-Content-Location-2 element, respectively.
In an example, Cache-Control element provides information about caching directives for file. In case the element “Cache-Control” is not present in the FDT for a corresponding file, the terminal should assume that no caching directives can be given for that file and may handle the caching of that file on a best effort basis.
@maximumDelay attribute of repair flow: An unsignedInt data types id defined to be used for this attribute.
@overhead attribute of repair flow: unsignedInt based type defined for this attribute.
@minBuffSize attribute of repair flow: An unsignedInt data types id defined to be used for this attribute.
FECOTI of repair flow: A “string” data types is defined to be used for this element.
@sessionDescription attribute of ProtectedObject: A “string” data types is defined to be used for this attribute.
@tsi attribute of ProtectedObject: An unsignedInt data types is defined to be used for this attribute.
@sessionDescription attribute of ProtectedObject: A “string” data types is defined to be used for this attribute.
@fecTransportObjectSize attribute of ProtectedObject: An unsignedInt data types is defined to be used for this attribute.
Custom XML data types are defined and used for certain elements and/or attributes. These allow only valid values to be defined and used for various elements and/or attributes. Following custom data types are defined:
Data type for Port is defined based on XML unsignedShort with value of 0 excluded. This allows only valid UDP port values to be defined.
Pattern based data type for IP address is defined to allow only valid IPv4 addresses. This allows only valid IP address values to be defined as opposed to any general purpose string.
Data type for Physical Layer Pipe identifier is defined to be a valid PLP value.
A typical delivery and streaming system needs to convey time information from transmission side to the receiver side. For example This allows the receiver which does not have any other clock source to know current date and time. It also allows synchronization of various streaming media components by referring to common system time which is signaled by transmission side.
For ATSC system time may be delivered via physical layer and/or via transport layer and/or via IP layer. For example system time may be delivered in the ATSC physical layer as a 32-bit count of the number of seconds since Jan. 1, 1970 00:00:00 International Atomic Time (TAI), which is the Precision Time Protocol (PTP) epoch as defined in IEEE 1588. PTP is defined in “IEEE: IEEE 1588-2008 PTP, “Standard for a Precision Clock Synchronization Protocol for Networked Measurement and Control Systems,”, Institute for Electrical and Electronics Engineers.”
Additional system time related information may be signaled in SystemTime element delivered at transport layer. In one example the SystemTime element may have a structure as shown in
System Time may be represented as an XML document containing a SystemTime root element that conforms to the definitions in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/SYSTIME/1.0/
The abbreviation “systime” should be used as the namespace prefix for any of the elements of this schema, if they appear in an XML document. For the initial release of this Standard the binding of this prefix to the namespace can be declared by including the following attribute in the schema element of the XML document.
xmlns:systime=“http://www.atsc.org/XMLSchemas/ATSC3/Delivery/SYSTIME/1.0/”
The normative XML schema for SystemTime is shown in
In XML schema in
A Custom XML data type—“Hour type” is defined which can have a valid value between 0 to 24, inclusive only to indicate a valid day of the month.
Additional variants are now described for a User Service Bundle Description Fragment for MMT.
The USBD fragment for MMT for ATSC 3.0 includes following:
Child attribute serviceId under the element userServiceDescription
Child element contentAdvisoryRating under the element userServiceDescription;
Child element Channel and its child attributes serviceGenre, serviceIcon, and child element ServiceDescription and its child attributes serviceDescrTex, serviceDescrLang under the element userServiceDescription;
Child element mpuComponent and its child attributes mmtPackageID and nextMMTPackageID nextMmtPackageId under the element userServiceDescription;
Child element routeComponent and its child attributes sTSIDUri, sTSIDDestinationIpAddress, sTSIDDestinationUdpPort, sTSIDSourceIPAddress, sTSIDMajorProtocolVersion, sTSIDMinorProtocolVersion under the element userServiceDescription;
Child element broadbandComponent and its child attributes fullMPDUri under the element userServiceDescription; and
Child element ComponentInfo and its child attributes componentType, componentRole, componentProtectedFlag, componentId, componentName under the element userServiceDescription.
Preferably the same information should not be repeated by emission side in the MMT USBD when it is carried in the service announcement. In this case information in service announcement should take precedence.
The bundleDescription may be represented as an XML document containing a bundleDescription root element that conforms to the definitions in the XML schema that has namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/MMTUSD/1.0/
Semantics of various syntax elements in
bundleDescription—Is root element of the User Service Bundle Description.
userServiceDescription—Element corresponds to single instance of an ATSC 3.0 Service.
@globalServiceID—A globally unique URI that identifies the ATSC 3.0 Service. This parameter is used to link USBD to Electronic Service Guide data. Electronic Service Guide provides description about services and programs along with their schedule and other metadata information.
@ serviceId—This attribute provides a reference to corresponding service entry in a service list table. The value of this attribute is the same value of service identifier assigned to the service entry.
Name—Name of the ATSC 3.0 service in the language specified by @lang attribute.
@lang—Language of the ATSC 3.0 service name. The language may be specified according to Best Current Practice (BCP) 47. BCP 47 describes tags for identifying languages and is available at https://tools.ietf.org/html/bcp47. It is incorporated herein by reference in its entirety.
serviceLanguage—Available languages of the ATSC 3.0 service. The language may be specified according to BCP 47.
contentAdvisoryRating—Specifies the content advisory rating, as defined in the ATSC 3.0 service announcement.
Channel—This element contains information about the service.
@ serviceGenre—This attribute indicates primary genre of the service. This attribute may be instantiated to describe the genre category for the service. The <classificationSchemeURI> is http://www.atsc.org/XMLSchemas/mh/2009/1.0/genre-cs/ and the value of serviceGenre may match a termID value from the classification schema in Annex B of A/153 Part 4. A/153 Part 4 describes ATSC mobile DTV standard—Announcement and is available at http://atsc.org/wp-content/uploads/2015/03/a_153-Part-4-2009.pdf. It is incorporated herein by reference in its entirety.
@ serviceIcon—This attribute indicates the URL for the icon used to represent this service.
ServiceDescription—Contains service description possibly in multiple languages.
@ serviceDescrText—This attribute indicates description of the service.
@ serviceDescrLang—This attribute indicates the language of the serviceDescrText. Semantics of xs:lang may be followed.
mpuComponent—A description about the contents components of ATSC 3.0 service delivered as MPUs.
@mmtPackageId—Reference to a MMT Package for content components of the ATSC 3.0 Service delivered as MPUs.
@nextMmtPackageId—Reference to a MMT Package to be used after the one referenced by @mmtPackageId in time for content components of the ATSC 3.0 Service delivered as MPUs.
routeComponent—Provides a description about the contents components of ATSC 3.0 Service delivered by ROUTE.
@ sTSIDUri—Reference to the S-TSID fragment which provides service access related parameters to the Transport sessions carrying contents of this ATSC 3.0 Service.
@ sTSIDDestinationIpAddress—A string containing the dotted-IPv4 destination address of the packets carrying S-TSID for this service. When not present the value of this attribute is inferred to be current MMTP session's destination IP address.
@ sTSIDDestinationUdpPort—A string containing the UDP port number of the packets carrying S-TSID for this service.
@sTSIDSourceIpAddress—A string containing the dotted-IPv4 source address of the packets carrying S-TSID for this service.
@sTSIDMajorProtocolVersion—Major version number of the protocol used to deliver the S-TSID for this service. When not present the value of this attribute is inferred to be 1.
@sTSIDMinorProtocolVersion—Minor version number of the protocol used to deliver the S-TSID for this service. When not present the value of this attribute is inferred to be 0.
broadbandComponent—This element provides a description about the contents components of ATSC 3.0 Service delivered by broadband.
@fullMPDUri—Provides a reference to an Dynamic Adaptive Streaming over HTTP (DASH) Media Presentation Description (MPD) fragment which contains descriptions for content components of the ATSC 3.0 Service delivered over broadband. DASH is specified in ISO/IEC Final Draft International Standard (FDIS) 23009-1:2014 (which is incorporated by reference herein in its entirety).
DASH MPD is a formalized description for a Media Presentation for the purpose of providing a streaming service.
DASH Media Presentation is a collection of data that establishes a bounded or unbounded presentation of media content.
ComponentInfo—Contains information about components available in the service.
For each component this includes information about component type, component role, component name, component identifier, component protection flag.
@componentType—This attribute indicates the type of this component. Value of 0 indicates an audio component. Value of 1 indicates a video component. Value of 2 indicates a closed caption component. Values 3 to 7 are reserved.
@componentRole—This attribute indicates the role or kind of this component. For audio (when componentType attribute above is equal to 0): values of componentRole attribute are as follows: 0=Complete main, 1=Music and Effects, 2=Dialog, 3=Commentary, 4=Visually Impaired, 5=Hearing Impaired, 6=Voice-Over, 7-254=reserved, 255=unknown. For Video (when componentType attribute above is equal to 1) values of componentRole attribute are as follows: 0=Primary video, 1-254=reserved, 255=unknown.
For Closed Caption component (when componentType attribute above is equal to 2) values of componentRole attribute are as follows: 0=Normal, 1=Easy reader, 2-254=reserved, 255=unknown.
When @componentType attribute above has a value is between 3 to 7, inclusive, the @componentRole value may be equal to 255.
@componentProtectedFlag—This attribute indicates if this component is protected (e.g. encrypted). When this flag is set to a value of 1 this component is protected (e.g. encrypted). When this flag is set to a value of 0 this component is not protected (e.g. encrypted). When not present the value of componentProtectedFlag attribute is inferred to be equal to 0.
@componentId—This attribute indicates the identifier of this component. The value of this attribute may be the same as the asset_id in the MP table corresponding to this component.
@componentName—This attribute indicates the human readable name of this component.
In addition to the above elements and attributes an @apdUri attribute is defined in
@apdUri—This optional attribute may provide a reference to the Associated Procedure Description (APD) fragment which provides file repair related information for the content components of ATSC 3.0 service delivered by ROUTE. @apdUri points to an APD fragment which is described below.
When @apdURI is present at least one Alternate-Content-Location-1 element may be present in the EFDT element of the S-TSID fragment pointed by the routeComponent element's @ sTSIDUri attribute.
An example EFDT is shown in
An apd element with @apdUri attribute is defined in
apd—Container element for APD fragment URI.
@apdUri—This optional attribute may provide a reference to the APD fragment which provides file repair related information for the content components of ATSC 3.0 Service delivered by ROUTE. @ apdUri points to an APD fragment which is described below.
When @apdURI is present at least one Alternate-Content-Location-1 element may be present in the EFDT element of the S-TSID fragment pointed by the routeComponent @ sTSIDUri.
The associated procedure description fragment is described as follows:
The APD is an service layer signaling metadata fragment containing information for use in conjunction with certain parameters in the EFDT element of the S-TSID fragment to govern the optional use by the receiver of the HTTP file repair functionality. The file repair procedure corresponds to an HTTP request/response transaction whereby a receiver, unable to acquire the entire object delivered by ROUTE, can request and obtain the missing data via broadband from a file repair server.
An example APD fragment is shown in
The APD may be represented as an XML document containing an associatedProcedureDescription root element that conforms to the definitions in the XML schema that has the namespace:
http://www.atsc.org/XMLSchemas/ATSC3/Delivery/ROUTEAPD/1.0/
The following text specifies the semantics of the elements and attributes in the APD fragment.
associatedProcedureDescription—Root element of the Associated Procedure Description.
postFileRepair—Container of temporal information that govern the start time of the file repair procedure.
@offsetTime—A time interval in seconds that the receiver may wait, after broadcast file transmission has ended, before it can begin the file repair procedure. If this attribute is absent or set to ‘0’, the receiver should not employ a wait time before computing a random time within the time window given by @randomTimePeriod to initiate the file repair request. When not present offsetTime is inferred to be equal to 0.
@randomTimePeriod—After the fixed delay conveyed by offsetTime has transpired, this attribute, as part of the file repair procedure, defines a time window in seconds within which the receiver may calculate a random value. The value of @randomTimePeriod represents an additional wait time by the receiver before it is permitted to initiate the file repair request.
Although
Different data types may be used for an element compared to those shown above. For example instead of unsignedByte data type unsignedShort data type may be used. In another example instead of unsigned Byte data type a String data type may be used.
Instead of signalling a syntax as an attribute it may be signaled as an element. Instead of signalling a syntax as an element it may be signaled as an attribute.
The bit width of various fields may be changed for example instead of 4 bits for an element in the bitstream syntax 5 bits or 8 bits or 2 bits may be used. The actual values listed here are just examples.
Instead of XML format and XML schema Javascript Object Notation (JSON) format and JSON schema may be used. Alternatively the proposed syntax elements may be signaled using a Comma Separated Values (CSV), Backus-Naur Form (BNF), Augmented Backus-Naur Form (ABNF), or Extended Backus-Naur Form (EBNF).
Cardinality of an element and/or attribute may be changed. For example For example cardinality may be changed from “1” to “1 . . . N” or cardinality may be changed from “1” to “0 . . . N” or cardinality may be changed from “1” to “0 . . . 1” or cardinality may be changed from “0 . . . 1” to “0 . . . N” or cardinality may be changed from “0 . . . N” to “0 . . . 1”.
An element and/or attribute may be made required when it is shown above as optional. An element and/or attribute may be made optional when it is shown above as required.
Some child elements may instead be signaled as parent elements or they may be signaled as child elements of another child elements.
All the above variants are intended to be within the scope of the present invention.
In one or more examples, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium and executed by a hardware-based processing unit. Computer-readable media may include computer-readable storage media, which corresponds to a tangible medium such as data storage media, or communication media including any medium that facilitates transfer of a computer program from one place to another, e.g., according to a communication protocol. In this manner, computer-readable media generally may correspond to (1) tangible computer-readable storage media which is non-transitory or (2) a communication medium such as a signal or carrier wave. Data storage media may be any available media that can be accessed by one or more computers or one or more processors to retrieve instructions, code and/or data structures for implementation of the techniques described in this disclosure. A computer program product may include a computer-readable medium.
By way of example, and not limitation, such computer-readable storage media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage, or other magnetic storage devices, flash memory, or any other medium that can be used to store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if instructions are transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. It should be understood, however, that computer-readable storage media and data storage media do not include connections, carrier waves, signals, or other transitory media, but are instead directed to non-transitory, tangible storage media. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
Instructions may be executed by one or more processors, such as one or more digital signal processors (DSPs), general purpose microprocessors, application specific integrated circuits (ASICs), field programmable logic arrays (FPGAs), or other equivalent integrated or discrete logic circuitry. Accordingly, the term “processor,” as used herein may refer to any of the foregoing structure or any other structure suitable for implementation of the techniques described herein. In addition, in some aspects, the functionality described herein may be provided within dedicated hardware and/or software modules configured for encoding and decoding, or incorporated in a combined codec. Also, the techniques could be fully implemented in one or more circuits or logic elements.
The techniques of this disclosure may be implemented in a wide variety of devices or apparatuses, including a wireless handset, an integrated circuit (IC) or a set of ICs (e.g., a chip set). Various components, modules, or units are described in this disclosure to emphasize functional aspects of devices configured to perform the disclosed techniques, but do not necessarily require realization by different hardware units. Rather, as described above, various units may be combined in a hardware unit or provided by a collection of intraoperative hardware units, including one or more processors as described above, in conjunction with suitable software and/or firmware.
Moreover, each functional block or various features of the base station device and the terminal device (the video decoder and the video encoder) used in each of the aforementioned embodiments may be implemented or executed by a circuitry, which is typically an integrated circuit or a plurality of integrated circuits. The circuitry designed to execute the functions described in the present specification may comprise a general-purpose processor, a digital signal processor (DSP), an application specific or general application integrated circuit (ASIC), a field programmable gate array (FPGA), or other programmable logic devices, discrete gates or transistor logic, or a discrete hardware component, or a combination thereof. The general-purpose processor may be a microprocessor, or alternatively, the processor may be a conventional processor, a controller, a microcontroller or a state machine. The general-purpose processor or each circuit described above may be configured by a digital circuit or may be configured by an analogue circuit. Further, when a technology of making into an integrated circuit superseding integrated circuits at the present time appears due to advancement of a semiconductor technology, the integrated circuit by this technology is also able to be used.
It is to be understood that the claims are not limited to the precise configuration and components illustrated above. Various modifications, changes and variations may be made in the arrangement, operation and details of the systems, methods, and apparatus described herein without departing from the scope of the claims.
This Non-provisional application claims priority under 35 U.S.C. § 119 on U.S. Provisional Patent Application No. 62/245,525, filed on Oct. 23, 2015, U.S. Provisional Patent Application No. 62/255,446, filed on Nov. 14, 2015, and U.S. Provisional Patent Application No. 62/331,376 filed on May 3, 2016, the entire contents of which are hereby incorporated by reference.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2016/004660 | 10/21/2016 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
62245525 | Oct 2015 | US | |
62255446 | Nov 2015 | US | |
62331376 | May 2016 | US |